2020-09-30 16:53:55 +02:00

1180 lines
44 KiB
C++

#include "precomp.h"
#include "channels.h"
#define NSUBGRPS 10
static DWORD s_dwMode;
static void channels_InitHelper(HWND hDlg, LPCTSTR pcszAltDir, LPCTSTR pcszWorkDir, LPCTSTR pcszCustIns,
WORD idList, DWORD dwPlatformId, BOOL fIgnoreOffline);
static void channels_SaveHelper(HWND hwndList, LPCTSTR pcszChanDir, LPCTSTR pcszCustIns, DWORD dwMode);
static int importChannels(HWND hDlg);
static BOOL CALLBACK addEditChannel(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam);
static PCHANNEL findFreeChannel(HWND hwndList);
void WINAPI Channels_InitA(HWND hDlg, LPCSTR pcszAltDir, LPCSTR pcszWorkDir, LPCSTR pcszCustIns,
WORD idList, DWORD dwPlatformId, BOOL fIgnoreOffline)
{
USES_CONVERSION;
channels_InitHelper(hDlg, A2CT(pcszAltDir), A2CT(pcszWorkDir), A2CT(pcszCustIns), idList,
dwPlatformId, fIgnoreOffline);
}
void WINAPI Channels_InitW(HWND hDlg, LPCWSTR pcwszAltDir, LPCWSTR pcwszWorkDir, LPCWSTR pcwszCustIns,
WORD idList, DWORD dwPlatformId, BOOL fIgnoreOffline)
{
USES_CONVERSION;
channels_InitHelper(hDlg, W2CT(pcwszAltDir), W2CT(pcwszWorkDir), W2CT(pcwszCustIns),
idList, dwPlatformId, fIgnoreOffline);
}
void WINAPI Channels_SaveA(HWND hwndList, LPCSTR pcszChanDir, LPCSTR pcszCustIns, DWORD dwMode /*= IEM_NEUTRAL*/)
{
USES_CONVERSION;
channels_SaveHelper(hwndList, A2CT(pcszChanDir), A2CT(pcszCustIns), dwMode);
}
void WINAPI Channels_SaveW(HWND hwndList, LPCWSTR pcwszChanDir, LPCWSTR pcwszCustIns, DWORD dwMode /*= IEM_NEUTRAL*/)
{
USES_CONVERSION;
channels_SaveHelper(hwndList, W2CT(pcwszChanDir), W2CT(pcwszCustIns), dwMode);
}
int WINAPI Channels_Import(HWND hDlg)
{
int nChannels = 0;
nChannels = importChannels(hDlg);
if (nChannels == 0)
ErrorMessageBox(hDlg, IDS_NOCHANNELSTOIMPORT);
return nChannels;
}
BOOL WINAPI Channels_Remove(HWND hDlg)
{
PCHANNEL pChan;
int i;
i = (INT) SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_GETCURSEL, 0, 0);
pChan = (PCHANNEL)SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_GETITEMDATA, (WPARAM)i, 0);
*pChan->szTitle = TEXT('\0');
SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_DELETESTRING, (WPARAM)i, 0);
// if add buttons have been disabled because we reached the max, then reenable them
if (!IsWindowEnabled(GetDlgItem(hDlg, IDC_ADDCHANNEL)))
{
EnableWindow(GetDlgItem(hDlg, IDC_ADDCHANNEL), TRUE);
EnableWindow(GetDlgItem(hDlg, IDC_ADDCATEGORY), TRUE);
}
if (SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_SETCURSEL, (WPARAM)i, 0) == LB_ERR)
{
if (SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_SETCURSEL, (WPARAM)(i-1), 0) == LB_ERR)
{
EnsureDialogFocus(hDlg, IDC_EDITCHANNEL, IDC_ADDCHANNEL);
EnableWindow(GetDlgItem(hDlg, IDC_EDITCHANNEL), FALSE);
EnsureDialogFocus(hDlg, IDC_REMOVECHANNEL, IDC_ADDCHANNEL);
EnableWindow(GetDlgItem(hDlg, IDC_REMOVECHANNEL), FALSE);
}
else
SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_SETTOPINDEX, (WPARAM)i, 0);
}
else
SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_SETTOPINDEX, (WPARAM)i, 0);
return TRUE;
}
static HRESULT xML_GetElementByIndex(IXMLElementCollection* pIXMLElementCollection, LONG nIndex,
IXMLElement** ppIXMLElement)
{
HRESULT hr;
VARIANT var1, var2;
if (!pIXMLElementCollection || !ppIXMLElement)
return E_FAIL;
VariantInit(&var1);
VariantInit(&var2);
var1.vt = VT_I4;
var1.lVal = nIndex;
IDispatch* pIDispatch;
hr = pIXMLElementCollection->item(var1, var2, &pIDispatch);
if (SUCCEEDED(hr) && pIDispatch)
{
hr = pIDispatch->QueryInterface(IID_IXMLElement, (void**)ppIXMLElement);
pIDispatch->Release();
}
else
{
*ppIXMLElement = NULL;
hr = E_FAIL;
}
return hr;
}
static BOOL xML_ParseElement(IXMLElement * pIXMLElement, LPTSTR pszPath,
LPCWSTR pcwszImageTypeW, LPCTSTR pcszBaseUrl)
{
HRESULT hr;
BSTR bstrTagName;
VARIANT var;
WCHAR szImagePathW[MAX_PATH];
TCHAR szFullUrl[INTERNET_MAX_URL_LENGTH];
TCHAR szImageUrl[INTERNET_MAX_URL_LENGTH];
INTERNET_CACHE_ENTRY_INFO *lpiceiInfo;
DWORD dwSize = 0;
USES_CONVERSION;
hr = pIXMLElement->get_tagName(&bstrTagName);
if (SUCCEEDED(hr) && bstrTagName)
{
if (StrCmpIW(bstrTagName, WSTR_LOGO) == 0)
{
VariantInit(&var);
hr = pIXMLElement->getAttribute(WSTR_STYLE, &var);
if ((SUCCEEDED(hr)) && (var.vt == VT_BSTR) && (var.bstrVal != NULL))
{
if ((StrCmpIW(var.bstrVal, pcwszImageTypeW) == 0) ||
((StrCmpIW(pcwszImageTypeW, WSTR_IMAGEW) == 0) &&
(StrCmpIW(var.bstrVal, L"IMAGEWIDE") == 0)))
{
VariantClear(&var);
hr = pIXMLElement->getAttribute(WSTR_HREF, &var);
if ((SUCCEEDED(hr)) && (var.vt == VT_BSTR) && (var.bstrVal != NULL))
{
W2Tbux(var.bstrVal, szImageUrl);
if (PathIsURL(szImageUrl) || ISNULL(pcszBaseUrl))
StrCpy(szFullUrl, szImageUrl);
else
{
DWORD cbSize = sizeof(szFullUrl);
InternetCombineUrl(pcszBaseUrl, szImageUrl, szFullUrl, &cbSize, ICU_NO_ENCODE);
}
RetrieveUrlCacheEntryFile(szFullUrl, NULL, &dwSize, 0);
lpiceiInfo = (INTERNET_CACHE_ENTRY_INFO *)LocalAlloc(LPTR, dwSize);
if (RetrieveUrlCacheEntryFile(szFullUrl, lpiceiInfo, &dwSize, 0))
{
StrCpy(pszPath, lpiceiInfo->lpszLocalFileName);
LocalFree(lpiceiInfo);
UnlockUrlCacheEntryFile(szFullUrl, 0);
return TRUE;
}
else
{
LocalFree(lpiceiInfo);
hr = URLDownloadToCacheFileW(NULL, T2W(szFullUrl), szImagePathW, ARRAYSIZE(szImagePathW), 0, NULL);
if (SUCCEEDED(hr))
{
W2Tbux(szImagePathW, pszPath);
return TRUE;
}
}
}
}
}
}
}
return FALSE;
}
// Takes a cdf url, downloads to the cache if necessary, and parses to
// find the image path in the cache(downloading again if necessary) for
// either wide logo, logo or image. Returns FALSE if none specified
static BOOL getCdfImage(LPCTSTR szCdfUrl, LPTSTR szPath, LPCWSTR szImageTypeW)
{
TCHAR szCdfUrlPath[INTERNET_MAX_URL_LENGTH];
IXMLDocument* pIXMLDocument = NULL;
IPersistStreamInit* pIPersistStreamInit = NULL;
IStream* pIStream = NULL;
IXMLElement *pRootElem = NULL;
BOOL bLoad = FALSE;
HRESULT hr = S_OK;
INTERNET_CACHE_ENTRY_INFO *lpiceiInfo;
DWORD dwSize = 0;
RetrieveUrlCacheEntryFile(szCdfUrl, NULL, &dwSize, 0);
lpiceiInfo = (INTERNET_CACHE_ENTRY_INFO *)LocalAlloc(LPTR, dwSize);
if (RetrieveUrlCacheEntryFile(szCdfUrl, lpiceiInfo, &dwSize, 0))
{
StrCpy(szCdfUrlPath, lpiceiInfo->lpszLocalFileName);
UnlockUrlCacheEntryFile(szCdfUrl, 0);
}
else
{
hr = URLDownloadToCacheFile(NULL, szCdfUrl, szCdfUrlPath, ARRAYSIZE(szCdfUrlPath), 0, NULL);
}
LocalFree(lpiceiInfo);
if (!SUCCEEDED(hr))
{
return FALSE;
}
hr = CoCreateInstance(CLSID_XMLDocument, NULL, CLSCTX_INPROC_SERVER,
IID_IXMLDocument, (void**)&pIXMLDocument);
// load the document
if (SUCCEEDED(hr) && pIXMLDocument)
{
hr = pIXMLDocument->QueryInterface(IID_IPersistStreamInit,
(void**)&pIPersistStreamInit);
if (SUCCEEDED(hr) && pIPersistStreamInit)
{
hr = SHCreateStreamOnFile(szCdfUrlPath, STGM_READ, &pIStream);
if (SUCCEEDED(hr) && pIStream)
{
hr = pIPersistStreamInit->Load(pIStream);
pIStream->Release();
bLoad = TRUE;
}
pIPersistStreamInit->Release();
}
}
if (!bLoad)
{
if (pIXMLDocument)
pIXMLDocument->Release();
return FALSE;
}
// Now lets get the image
hr = pIXMLDocument->get_root(&pRootElem);
if (SUCCEEDED(hr) && pRootElem)
{
TCHAR szBaseUrl[INTERNET_MAX_URL_LENGTH];
VARIANT var;
IXMLElementCollection* pIXMLElementCollection;
VariantInit(&var);
*szBaseUrl = TEXT('\0');
hr = pRootElem->getAttribute(WSTR_BASE, &var);
if ((SUCCEEDED(hr)) && (var.vt == VT_BSTR) && (var.bstrVal != NULL))
W2Tbux(var.bstrVal, szBaseUrl);
hr = pRootElem->get_children(&pIXMLElementCollection);
if (SUCCEEDED(hr) && pIXMLElementCollection)
{
LONG nCount;
hr = pIXMLElementCollection->get_length(&nCount);
if (SUCCEEDED(hr))
{
for (int i = 0; i < nCount; i++)
{
IXMLElement* pIXMLElement;
hr = xML_GetElementByIndex(pIXMLElementCollection, i, &pIXMLElement);
if (SUCCEEDED(hr) && pIXMLElement)
{
if (xML_ParseElement(pIXMLElement, szPath, szImageTypeW, szBaseUrl))
{
pIXMLElement->Release();
hr = S_OK;
break;
}
pIXMLElement->Release();
hr = E_FAIL;
}
}
}
pIXMLElementCollection->Release();
}
pRootElem->Release();
}
pIXMLDocument->Release();
if (SUCCEEDED(hr))
return TRUE;
else
return FALSE;
}
// This DlgProc handles the processing for all popups on all platforms
// Note that the narrow image, wide image, and icon resource id's are the
// same for channels and categories.
static BOOL CALLBACK addEditChannel(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
TCHAR szWrk[MAX_URL];
TCHAR szTitle[MAX_PATH] = TEXT(""); // buffers used for validation
TCHAR szPreUrlPath[MAX_PATH] = TEXT("");
TCHAR szIcon[MAX_PATH] = TEXT("");
TCHAR szLogo[MAX_PATH] = TEXT("");
TCHAR szWebUrl[INTERNET_MAX_URL_LENGTH] = TEXT("");
PCHANNEL pSelCh;
switch (uMsg)
{
case WM_INITDIALOG:
pSelCh = (PCHANNEL)lParam;
SetWindowLongPtr(hDlg, DWLP_USER, (LONG_PTR)pSelCh);
if (pSelCh->fCategory)
{
EnableDBCSChars(hDlg, IDC_CATEGORYHTML);
EnableDBCSChars(hDlg, IDE_CATEGORYTITLE);
SetDlgItemText(hDlg, IDC_CATEGORYHTML, pSelCh->szWebUrl);
SetDlgItemText(hDlg, IDE_CATEGORYTITLE, pSelCh->szTitle);
}
else
{
EnableDBCSChars(hDlg, IDE_CHANNELSRVURL2);
EnableDBCSChars(hDlg, IDE_CHANNELTITLE2);
SetDlgItemText(hDlg, IDE_CHANNELSRVURL2, pSelCh->szWebUrl);
SetDlgItemText(hDlg, IDE_CHANNELTITLE2, pSelCh->szTitle);
}
EnableDBCSChars(hDlg, IDC_CHANNELBITMAP2);
EnableDBCSChars(hDlg, IDC_CHANNELICON2);
SetDlgItemText(hDlg, IDC_CHANNELBITMAP2, pSelCh->szLogo);
SetDlgItemText(hDlg, IDC_CHANNELICON2, pSelCh->szIcon);
if (!pSelCh->fCategory)
{
EnableDBCSChars(hDlg, IDC_CHANNELURL2);
SetDlgItemText(hDlg, IDC_CHANNELURL2, pSelCh->szPreUrlPath);
if (!HasFlag(s_dwMode, (IEM_CORP | IEM_PROFMGR)))
DisableDlgItem(hDlg, IDC_CHANNELOFFL);
else
if (pSelCh->fOffline)
CheckDlgButton(hDlg, IDC_CHANNELOFFL, BST_CHECKED);
}
else
ASSERT(!HasFlag(s_dwMode, IEM_ADMIN));
break;
case WM_COMMAND:
switch(HIWORD(wParam))
{
case BN_CLICKED:
switch (LOWORD(wParam))
{
case IDC_BROWSECHBMP2:
GetDlgItemText(hDlg, IDC_CHANNELBITMAP2, szWrk, ARRAYSIZE(szWrk));
if (BrowseForFile(hDlg, szWrk, ARRAYSIZE(szWrk), GFN_PICTURE))
SetDlgItemText(hDlg, IDC_CHANNELBITMAP2, szWrk);
break;
case IDC_BROWSECHICO2:
GetDlgItemText(hDlg, IDC_CHANNELICON2, szWrk, ARRAYSIZE(szWrk));
if (BrowseForFile(hDlg, szWrk, ARRAYSIZE(szWrk), GFN_ICO | GFN_PICTURE))
SetDlgItemText(hDlg, IDC_CHANNELICON2, szWrk);
break;
case IDC_BROWSECDF2:
GetDlgItemText(hDlg, IDC_CHANNELURL2, szWrk, ARRAYSIZE(szWrk));
if (BrowseForFile(hDlg, szWrk, ARRAYSIZE(szWrk), GFN_CDF))
SetDlgItemText(hDlg, IDC_CHANNELURL2, szWrk);
break;
case IDC_BROWSECATHTML:
GetDlgItemText(hDlg, IDC_CATEGORYHTML, szWrk, ARRAYSIZE(szWrk));
if (BrowseForFile(hDlg, szWrk, ARRAYSIZE(szWrk), GFN_LOCALHTM))
SetDlgItemText(hDlg, IDC_CATEGORYHTML, szWrk);
break;
case IDCANCEL:
EndDialog( hDlg, IDCANCEL );
break;
case IDOK:
pSelCh = (PCHANNEL)GetWindowLongPtr(hDlg, DWLP_USER);
if (pSelCh->fCategory)
{
GetDlgItemText( hDlg, IDE_CATEGORYTITLE, szTitle, ARRAYSIZE(szTitle) );
GetDlgItemText( hDlg, IDC_CATEGORYHTML, szWebUrl, ARRAYSIZE(szWebUrl) );
}
else
{
GetDlgItemText( hDlg, IDE_CHANNELTITLE2, szTitle, ARRAYSIZE(szTitle) );
GetDlgItemText( hDlg, IDE_CHANNELSRVURL2, szWebUrl, ARRAYSIZE(szWebUrl) );
}
GetDlgItemText( hDlg, IDC_CHANNELBITMAP2, szLogo, ARRAYSIZE(szLogo) );
GetDlgItemText( hDlg, IDC_CHANNELICON2, szIcon, ARRAYSIZE(szIcon) );
if (!pSelCh->fCategory) {
GetDlgItemText(hDlg, IDC_CHANNELURL2, szPreUrlPath, ARRAYSIZE(szPreUrlPath));
pSelCh->fOffline = IsWindowEnabled(GetDlgItem(hDlg, IDC_CHANNELOFFL)) &&
(IsDlgButtonChecked(hDlg, IDC_CHANNELOFFL) == BST_CHECKED);
}
if (pSelCh->fCategory)
{
if (!CheckField(hDlg, IDE_CATEGORYTITLE, FC_NONNULL))
break;
}
else
{
if (!CheckField(hDlg, IDE_CHANNELTITLE2, FC_NONNULL) ||
!CheckField(hDlg, IDE_CHANNELSRVURL2, FC_NONNULL | FC_URL))
break;
}
if (!CheckField(hDlg, IDC_CHANNELBITMAP2, FC_FILE | FC_EXISTS) ||
!CheckField(hDlg, IDC_CHANNELICON2, FC_FILE | FC_EXISTS) ||
(!pSelCh->fCategory && !CheckField(hDlg, IDC_CHANNELURL2, FC_FILE | FC_EXISTS)))
break;
// make sure they're not adding a duplicate channel/category name
if ((StrCmpI(pSelCh->szTitle, szTitle) != 0) &&
(ListBox_GetCount(GetDlgItem(pSelCh->hDlg, IDC_CHANNELLIST))) &&
(ListBox_FindStringExact(GetDlgItem(pSelCh->hDlg, IDC_CHANNELLIST), -1,
szTitle) != LB_ERR))
{
ErrorMessageBox(hDlg, IDS_DUPCHAN);
break;
}
StrCpy(pSelCh->szTitle, szTitle);
StrCpy(pSelCh->szWebUrl, szWebUrl);
StrCpy(pSelCh->szPreUrlPath, szPreUrlPath);
StrCpy(pSelCh->szIcon, szIcon);
StrCpy(pSelCh->szLogo, szLogo);
EndDialog( hDlg, IDOK );
break;
}
break;
}
break;
default:
return FALSE;
}
return TRUE;
}
static PCHANNEL findFreeChannel(HWND hwndList)
{
int i;
PCHANNEL pChan;
for (i=0, pChan=(PCHANNEL)GetWindowLongPtr(hwndList, GWLP_USERDATA);
(i < MAX_CHAN) && (pChan != NULL); i++, pChan++)
{
if (ISNULL(pChan->szTitle))
{
ZeroMemory(pChan, sizeof(CHANNEL));
return pChan;
}
}
return NULL;
}
static void convertUrlToFile(LPTSTR pszUrl)
{
TCHAR szFileName[MAX_PATH];
LPTSTR pFile;
if (ISNULL(pszUrl))
return;
if (StrCmpNI(pszUrl, TEXT("file:"), 5) != 0)
return;
else
{
pFile = pszUrl + 5;
while ((*pFile == TEXT('/')) || (*pFile == TEXT(' ')))
{
pFile++;
}
}
StrCpy(szFileName, pFile);
StrCpy(pszUrl, szFileName);
}
static BOOL importAddChannel(HWND hDlg, LPTSTR pszDir, LPTSTR pszChan, PCHANNEL pChan, BOOL fCategory)
{
TCHAR szDeskIni[MAX_PATH];
DWORD dwSize = sizeof(pChan->szWebUrl);
HKEY hkPreload;
int i;
if (ListBox_FindStringExact(GetDlgItem(hDlg, IDC_CHANNELLIST), -1,
pszChan) != LB_ERR)
return FALSE;
PathCombine(szDeskIni, pszDir, TEXT("Desktop.Ini"));
if (!PathFileExists(szDeskIni))
return FALSE;
pChan->szWebUrl[0] = TEXT('\0');
if (fCategory)
{
GetPrivateProfileString(SHELLCLASSINFO, URL, TEXT(""), pChan->szWebUrl, ARRAYSIZE(pChan->szWebUrl), szDeskIni );
GetPrivateProfileString(SHELLCLASSINFO, LOGO, TEXT(""), pChan->szLogo, ARRAYSIZE(pChan->szLogo), szDeskIni );
GetPrivateProfileString(SHELLCLASSINFO, ICONFILE, TEXT(""), pChan->szIcon, ARRAYSIZE(pChan->szIcon), szDeskIni );
// szWebUrl can be empty (this is valid according to the specs)
if (ISNONNULL(pChan->szWebUrl))
{
// szWebUrl is an 8.3 name; construct the fully qualified path
StrCpy(pChan->szPreUrlPath, pChan->szWebUrl); // szPreUrlPath is used
// as a temp buffer
StrCpy(pChan->szWebUrl, pszDir);
PathAppend(pChan->szWebUrl, pChan->szPreUrlPath);
pChan->szPreUrlPath[0] = TEXT('\0');
}
}
else
{
GetPrivateProfileString(CHANNEL_SECT, CDFURL, TEXT(""), pChan->szWebUrl, ARRAYSIZE(pChan->szWebUrl), szDeskIni );
GetPrivateProfileString(CHANNEL_SECT, LOGO, TEXT(""), pChan->szLogo, ARRAYSIZE(pChan->szLogo), szDeskIni );
GetPrivateProfileString(CHANNEL_SECT, ICON, TEXT(""), pChan->szIcon, ARRAYSIZE(pChan->szIcon), szDeskIni );
if (RegOpenKeyEx(HKEY_CURRENT_USER, PRELOAD_KEY, 0, KEY_DEFAULT_ACCESS, &hkPreload) == ERROR_SUCCESS)
{
if (RegQueryValueEx(hkPreload, pChan->szWebUrl, NULL, NULL, (LPBYTE)pChan->szPreUrlPath, &dwSize) != ERROR_SUCCESS)
pChan->szPreUrlPath[0] = TEXT('\0');
else
convertUrlToFile(pChan->szPreUrlPath); // strip "file://" from szPreUrlPath
RegCloseKey(hkPreload);
}
}
// categories do not need to have an .htm file according to the original channel spec
if (!fCategory && ISNULL(pChan->szWebUrl))
{
ZeroMemory(pChan, sizeof(CHANNEL));
return FALSE;
}
StrCpy(pChan->szTitle, pszChan);
pChan->fCategory = fCategory;
i = (INT) SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_ADDSTRING, 0, (LPARAM)pChan->szTitle);
SendDlgItemMessage(hDlg, IDC_CHANNELLIST, LB_SETITEMDATA, (WPARAM)i, (LPARAM)pChan);
if (ISNULL(pChan->szLogo))
{
if (!getCdfImage(pChan->szWebUrl, pChan->szLogo, WSTR_IMAGE))
pChan->szLogo[0] = TEXT('\0');
}
convertUrlToFile(pChan->szLogo);
if (ISNULL(pChan->szIcon))
{
if (!getCdfImage(pChan->szWebUrl, pChan->szIcon, WSTR_ICON))
pChan->szIcon[0] = TEXT('\0');
}
convertUrlToFile(pChan->szIcon);
return TRUE;
}
static BOOL enumChannels(HWND hDlg, LPTSTR pszDir, LPTSTR pszCat, LPINT pnChannels)
{
WIN32_FIND_DATA fd;
TCHAR szFindPath[MAX_PATH];
HANDLE hFind;
BOOL fCategory = FALSE;
StrCpy(szFindPath, pszDir);
PathAppend(szFindPath, TEXT("*.*"));
hFind = FindFirstFile(szFindPath, &fd);
if (hFind == INVALID_HANDLE_VALUE)
return FALSE;
do
{
TCHAR szSubChan[MAX_PATH];
// NOTE: if pszCat is empty string (""), PathAppend doesn't prefix a
// backslash in szSubChan
StrCpy(szSubChan, pszCat);
PathAppend(szSubChan, fd.cFileName);
if ((StrCmp(fd.cFileName, TEXT(".")) != 0) &&
(StrCmp(fd.cFileName, TEXT("..")) != 0) &&
(fd.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY))
{
TCHAR szSubDir[MAX_PATH];
PathCombine(szSubDir, pszDir, fd.cFileName);
fCategory = TRUE;
if (!enumChannels(hDlg, szSubDir, szSubChan, pnChannels))
return FALSE;
}
} while (FindNextFile(hFind, &fd));
FindClose(hFind);
if (ISNONNULL(pszCat))
{
PCHANNEL pChan = findFreeChannel(GetDlgItem(hDlg, IDC_CHANNELLIST));
if (pChan == NULL) // MAX_CHAN reached
{
EnsureDialogFocus(hDlg, IDC_ADDCHANNEL, IDC_REMOVECHANNEL);
EnableWindow(GetDlgItem(hDlg, IDC_ADDCHANNEL), FALSE);
EnsureDialogFocus(hDlg, IDC_ADDCATEGORY, IDC_REMOVECHANNEL);
EnableWindow(GetDlgItem(hDlg, IDC_ADDCATEGORY), FALSE);
return FALSE;
}
if (importAddChannel(hDlg, pszDir, pszCat, pChan, fCategory))
(*pnChannels)++;
}
return TRUE;
}
static int importChannels(HWND hDlg)
{
DWORD dwLength, dwType;
TCHAR szChanPath[MAX_PATH];
TCHAR szChannelsDir[MAX_PATH];
TCHAR szTemp[MAX_PATH];
HKEY hkFav;
int nChannels = 0;
SetCursor(LoadCursor(NULL, IDC_WAIT) );
// build path to current user favorites
dwLength = MAX_PATH;
if (RegOpenKeyEx( HKEY_CURRENT_USER,
TEXT("Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Shell Folders"),
0, KEY_DEFAULT_ACCESS, &hkFav ) != ERROR_SUCCESS)
{
return 0;
}
if (RegQueryValueEx( hkFav, TEXT("Favorites"), NULL, &dwType, (LPBYTE) szChanPath, &dwLength ) != ERROR_SUCCESS)
{
RegCloseKey(hkFav);
return 0;
}
RegCloseKey(hkFav);
// write info about Regular Channels
LoadString( g_hInst, IDS_CHANNELSDIR, szChannelsDir, ARRAYSIZE(szChannelsDir) );
PathCombine(szTemp, szChanPath, szChannelsDir);
// The following scenario would arise if you don't upgrade IE5 over IE4 and
// add a channel. In this case, IE5 would add the channel under the
// Favorites folder itself (szChanPath contains the path to the Favorites
// folder)
if (!PathFileExists(szTemp))
StrCpy(szTemp, szChanPath);
enumChannels(hDlg, szTemp, TEXT(""), &nChannels);
return nChannels;
}
static void channels_InitHelper(HWND hDlg, LPCTSTR pcszAltDir, LPCTSTR pcszWorkDir, LPCTSTR pcszCustIns,
WORD idList, DWORD dwPlatformId, BOOL fIgnoreOffline)
{
TCHAR szTempBuf[16];
PCHANNEL paChannels;
PCHANNEL paOldChannels;
int i;
ASSERT(((pcszAltDir == NULL) && (pcszWorkDir == NULL)) ||
((pcszAltDir != NULL) && (pcszWorkDir != NULL)));
g_dwPlatformId = dwPlatformId;
SendDlgItemMessage(hDlg, idList, LB_RESETCONTENT, 0, 0);
if ((paChannels = (PCHANNEL)CoTaskMemAlloc(sizeof(CHANNEL) * MAX_CHAN)) == NULL)
return;
ZeroMemory(paChannels, sizeof(CHANNEL) * MAX_CHAN);
paOldChannels = (PCHANNEL)SetWindowLongPtr(GetDlgItem(hDlg, idList), GWLP_USERDATA, (LONG_PTR)paChannels);
// delete previous allocation(mainly for profile manager)
if (paOldChannels != NULL)
CoTaskMemFree(paOldChannels);
if (GetPrivateProfileSection(CHANNEL_ADD, szTempBuf, ARRAYSIZE(szTempBuf), pcszCustIns))
{
PCHANNEL pChan;
TCHAR szChTitleParm[16],
szChUrlParm[16],
szChPreUrlParm[32],
szChIconParm[32],
szChBmpParm[32],
szChOfflineParm[16];
int j;
if (StrCmpI(szTempBuf, TEXT("No Channels")) == 0)
return;
for (i = 0, pChan = paChannels; i < MAX_CHAN; i++, pChan++)
{
wnsprintf(szChUrlParm, ARRAYSIZE(szChUrlParm), TEXT("%s%u"), CDFURL, i);
wnsprintf(szChTitleParm, ARRAYSIZE(szChTitleParm), TEXT("%s%u"), CHTITLE, i);
if (GetPrivateProfileString(CHANNEL_ADD, szChTitleParm, TEXT(""), pChan->szTitle, ARRAYSIZE(pChan->szTitle), pcszCustIns) == 0)
break;
GetPrivateProfileString(CHANNEL_ADD, szChUrlParm, TEXT(""), pChan->szWebUrl, ARRAYSIZE(pChan->szWebUrl), pcszCustIns);
wnsprintf(szChPreUrlParm, ARRAYSIZE(szChPreUrlParm), TEXT("%s%u"), CHPREURLPATH, i);
wnsprintf(szChIconParm, ARRAYSIZE(szChIconParm), TEXT("%s%u"), CHICON, i);
wnsprintf(szChBmpParm, ARRAYSIZE(szChBmpParm), TEXT("%s%u"), CHBMP, i);
GetPrivateProfileString(CHANNEL_ADD, szChPreUrlParm, TEXT(""), pChan->szPreUrlPath, ARRAYSIZE(pChan->szPreUrlPath), pcszCustIns);
GetPrivateProfileString(CHANNEL_ADD, szChIconParm,TEXT(""), pChan->szIcon, ARRAYSIZE(pChan->szIcon), pcszCustIns);
GetPrivateProfileString(CHANNEL_ADD, szChBmpParm, TEXT(""), pChan->szLogo, ARRAYSIZE(pChan->szLogo), pcszCustIns);
pChan->fOffline = FALSE;
if (!fIgnoreOffline) {
wnsprintf(szChOfflineParm, ARRAYSIZE(szChOfflineParm), TEXT("%s%u"), IK_CHL_OFFLINE, i);
pChan->fOffline = (BOOL)GetPrivateProfileInt(IS_CHANNEL_ADD, szChOfflineParm, (int)FALSE, pcszCustIns);
}
// delete the files from an alternative dir (desktop dir in profmgr, ieaklite dir
// in wizard), making sure to copy them to the work dir first
if (pcszAltDir != NULL)
{
MoveFileToWorkDir(PathFindFileName(pChan->szPreUrlPath), pcszAltDir, pcszWorkDir, TRUE);
MoveFileToWorkDir(PathFindFileName(pChan->szIcon), pcszAltDir, pcszWorkDir);
MoveFileToWorkDir(PathFindFileName(pChan->szLogo), pcszAltDir, pcszWorkDir);
}
j = (int)SendDlgItemMessage( hDlg, idList, LB_ADDSTRING, 0, (LPARAM) pChan->szTitle);
SendDlgItemMessage(hDlg, idList, LB_SETITEMDATA, (WPARAM)j, (LPARAM)pChan);
}
for (i = 0; i < MAX_CHAN; i++, pChan++)
{
wnsprintf(szChTitleParm, ARRAYSIZE(szChTitleParm), TEXT("%s%u"), CATTITLE, i);
if (GetPrivateProfileString(CHANNEL_ADD, szChTitleParm, TEXT(""), pChan->szTitle, ARRAYSIZE(pChan->szTitle), pcszCustIns) == 0)
break;
pChan->fCategory = TRUE;
wnsprintf(szChUrlParm, ARRAYSIZE(szChUrlParm), TEXT("%s%u"), CATHTML, i);
wnsprintf(szChIconParm, ARRAYSIZE(szChIconParm), TEXT("%s%u"), CATICON, i);
wnsprintf(szChBmpParm, ARRAYSIZE(szChBmpParm), TEXT("%s%u"), CATBMP, i);
GetPrivateProfileString(CHANNEL_ADD, szChUrlParm, TEXT(""), pChan->szWebUrl, ARRAYSIZE(pChan->szWebUrl), pcszCustIns);
GetPrivateProfileString(CHANNEL_ADD, szChIconParm, TEXT(""), pChan->szIcon, ARRAYSIZE(pChan->szIcon), pcszCustIns);
GetPrivateProfileString(CHANNEL_ADD, szChBmpParm, TEXT(""), pChan->szLogo, ARRAYSIZE(pChan->szLogo), pcszCustIns);
pChan->fOffline = FALSE;
// delete the files from the desktop dir
if (pcszAltDir != NULL)
{
MoveFileToWorkDir(PathFindFileName(pChan->szWebUrl), pcszAltDir, pcszWorkDir, TRUE);
MoveFileToWorkDir(PathFindFileName(pChan->szIcon), pcszAltDir, pcszWorkDir, TRUE);
MoveFileToWorkDir(PathFindFileName(pChan->szLogo), pcszAltDir, pcszWorkDir, TRUE);
}
j = (int)SendDlgItemMessage( hDlg, idList, LB_ADDSTRING, 0, (LPARAM) pChan->szTitle);
SendDlgItemMessage(hDlg, idList, LB_SETITEMDATA, (WPARAM)j, (LPARAM)pChan);
}
}
SendDlgItemMessage(hDlg, idList, LB_SETCURSEL, (WPARAM)-1, 0);
}
static void writeIE4Info(HANDLE hInf, int index, PCHANNEL pChan)
{
static const TCHAR c_szInfTitle[] = TEXT("HKCU,\"%s\",\"Title\",,\"%s\"\r\n");
static const TCHAR c_szInfURL_File[] = TEXT("HKCU,\"%s\",\"URL\",,\"%s%%10%%\\web\\%s\"\r\n");
static const TCHAR c_szInfURL_HTTP[] = TEXT("HKCU,\"%s\",\"URL\",,\"%s\"\r\n");
static const TCHAR c_szInfPreloadUrl[] = TEXT("HKCU,\"%s\",\"PreloadURL\",,\"%s%%10%%\\web\\%s\"\r\n");
static const TCHAR c_szInfLogo_File[] = TEXT("HKCU,\"%s\",\"Logo\",,\"%s%%10%%\\web\\%s\"\r\n");
static const TCHAR c_szInfLogo_HTTP[] = TEXT("HKCU,\"%s\",\"Logo\",,\"%s\"\r\n");
static const TCHAR c_szInfIcon_File[] = TEXT("HKCU,\"%s\",\"Icon\",,\"%s%%10%%\\web\\%s\"\r\n");
static const TCHAR c_szInfIcon_HTTP[] = TEXT("HKCU,\"%s\",\"Icon\",,\"%s\"\r\n");
static const TCHAR c_szInfCategory[] = TEXT("HKCU,\"%s\",\"Category\",65537,1\r\n");
TCHAR szKey[MAX_PATH];
TCHAR szInfLine[MAX_PATH];
TCHAR szFileUrlPrefix[ARRAYSIZE(FILEPREFIX)] = TEXT("");
DWORD dwSize;
wnsprintf(szKey, ARRAYSIZE(szKey), TEXT("%%ChannelKey%%\\ieakChl%u"), index);
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfTitle, szKey, pChan->szTitle);
WriteStringToFile(hInf, szInfLine, dwSize);
if (pChan->fCategory)
{
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfCategory, szKey);
WriteStringToFile(hInf, szInfLine, dwSize);
}
else
StrCpy(szFileUrlPrefix, FILEPREFIX);
// BUGBUG: (pritobla) For a category, szWebUrl can be empty; we should take care of this case
if (PathIsFileOrFileURL(pChan->szWebUrl))
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfURL_File, szKey, szFileUrlPrefix, PathFindFileName(pChan->szWebUrl));
else
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfURL_HTTP, szKey, pChan->szWebUrl);
WriteStringToFile(hInf, szInfLine, dwSize);
if (ISNONNULL(pChan->szPreUrlPath))
{
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfPreloadUrl, szKey, szFileUrlPrefix, PathFindFileName(pChan->szPreUrlPath));
WriteStringToFile(hInf, szInfLine, dwSize);
}
if (ISNONNULL(pChan->szLogo))
{
if (PathIsFileOrFileURL(pChan->szLogo))
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfLogo_File, szKey, szFileUrlPrefix, PathFindFileName(pChan->szLogo));
else
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfLogo_HTTP, szKey, pChan->szLogo);
WriteStringToFile(hInf, szInfLine, dwSize);
}
if (ISNONNULL(pChan->szIcon))
{
if (PathIsFileOrFileURL(pChan->szIcon))
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfIcon_File, szKey, szFileUrlPrefix, PathFindFileName(pChan->szIcon));
else
dwSize = wnsprintf(szInfLine, ARRAYSIZE(szInfLine), c_szInfIcon_HTTP, szKey, pChan->szIcon);
WriteStringToFile(hInf, szInfLine, dwSize);
}
}
// The ie4chnls.inf is not made as a template inf file because in the GPE context the
// template inf's will not be available.
static TCHAR szIE4Buf[] = TEXT("[Version]\r\n\
Signature=\"$CHICAGO$\"\r\n\
AdvancedINF=2.5\r\n\r\n\
[DefaultInstall]\r\n\
RequiredEngine=Setupapi,\"Couldn't find Setupapi.dll\"\r\n\
Delreg=IeakChan.DelReg\r\n\
Addreg=IeakChan.AddReg\r\n\
RegisterOCXs=IeakChan.Register\r\n\
DoShellRefresh=1\r\n\r\n\
[IeakChan.Register]\r\n\
%11%\\webcheck.dll,IN,Policy\r\n\r\n\
[IeakChan.DelReg]\r\n\
HKCU,\"Software\\Policies\\Microsoft\\Internet Explorer\\Infodelivery\\CompletedModifications\",\"ChannelDefault\",,,\r\n\r\n\
[Strings]\r\n\
DiskName=\"Channel Files\"\r\n\
ChannelKey=\"Software\\Policies\\Microsoft\\Internet Explorer\\Infodelivery\\Modifications\\ChannelDefault\\AddChannels\"\r\n\
SubKey=\"Software\\Policies\\Microsoft\\Internet Explorer\\Infodelivery\\Modifications\\ChannelDefault\\AddSubscriptions\"\r\n\
CleanKey=\"Software\\Policies\\Microsoft\\Internet Explorer\\Infodelivery\\Modifications\\ChannelDefault\\RemoveAllChannels\"\r\n\r\n\0");
static void channels_SaveHelper(HWND hwndList, LPCTSTR pcszChanDir, LPCTSTR pcszCustIns, DWORD dwMode)
{
PCHANNEL pChan;
PCHANNEL paChannel;
TCHAR szIE4ChnlsInf[MAX_PATH],
szChTitleParm[32],
szChUrlParm[32],
szChPreUrlParm[32],
szChBmpParm[32],
szChIconParm[32],
szChPreUrlNameParm[32],
szChBmpNameParm[32],
szChOfflineParm[16],
szChIconNameParm[32],
szTempPath[MAX_PATH];
LPTSTR pWrk;
HANDLE hInf = NULL;
DWORD dwSize;
int i, j, k;
BOOL fChan = FALSE;
GUID guid;
TCHAR szChlSizeLine[MAX_PATH],
szOemSizeLine[MAX_PATH];
TCHAR szChlSize[5];
TCHAR szOemSize[5];
BYTE bData;
LPTSTR pszBuf;
HKEY hk;
// create a temp path to copy all files to temporarily
GetTempPath(countof(szTempPath), szTempPath);
if (CoCreateGuid(&guid) == NOERROR)
{
TCHAR szGUID[128];
CoStringFromGUID(guid, szGUID, countof(szGUID));
PathAppend(szTempPath, szGUID);
}
else
PathAppend(szTempPath, TEXT("IEAKCHAN"));
PathCreatePath(szTempPath);
WritePrivateProfileString(CHANNEL_ADD, NULL, NULL, pcszCustIns);
WritePrivateProfileString(NULL, NULL, NULL, pcszCustIns);
PathCombine(szIE4ChnlsInf, szTempPath, TEXT("ie4chnls.inf"));
//----- Prepare Channel Size and OEM Size -----
StrCpy(szChlSize, TEXT("0x0B"));
StrCpy(szOemSize, TEXT("0x00"));
if (RegOpenKeyEx(HKEY_CURRENT_USER, DESKTOPKEY, 0, KEY_DEFAULT_ACCESS, &hk) == ERROR_SUCCESS) {
dwSize = sizeof(bData);
if (RegQueryValueEx(hk, CHANNELSIZE, NULL, NULL, &bData, &dwSize) == ERROR_SUCCESS) {
szChlSize[2] = TEXT('\0');
AppendCommaHex(szChlSize, bData, 0);
}
dwSize = sizeof(bData);
if (RegQueryValueEx(hk, OEMSIZE, NULL, NULL, &bData, &dwSize) == ERROR_SUCCESS) {
szOemSize[2] = TEXT('\0');
AppendCommaHex(szOemSize, bData, 0);
}
RegCloseKey(hk);
}
wnsprintf(szChlSizeLine, ARRAYSIZE(szChlSizeLine), REG_KEY_CHAN_SIZE, szChlSize);
wnsprintf(szOemSizeLine, ARRAYSIZE(szOemSizeLine), REG_KEY_OEM_SIZE, szOemSize);
//----- Write the standard goo ---
pszBuf = (LPTSTR)LocalAlloc(LPTR, INF_BUF_SIZE*sizeof(TCHAR));
if (pszBuf == NULL)
return;
dwSize = wnsprintf(pszBuf, INF_BUF_SIZE, TEXT("\r\n[%s]\r\n%s\r\n%s\r\n\r\n"), IEAKCHANADDREG, szChlSizeLine, szOemSizeLine);
hInf = CreateFile(szIE4ChnlsInf, GENERIC_WRITE, FILE_SHARE_READ, NULL, CREATE_ALWAYS, NULL, NULL);
if (hInf == INVALID_HANDLE_VALUE) {
LocalFree(pszBuf);
return;
}
SetFilePointer(hInf, 0, NULL, FILE_BEGIN);
WriteStringToFile(hInf, szIE4Buf, ARRAYSIZE(szIE4Buf));
SetFilePointer(hInf, 0, NULL, FILE_END);
WriteStringToFile(hInf, pszBuf, dwSize);
LocalFree(pszBuf);
paChannel = (PCHANNEL)GetWindowLongPtr(hwndList, GWLP_USERDATA);
for (i = 0, j = 0, k = 0, pChan = paChannel; (i < MAX_CHAN) && (pChan != NULL); i++, pChan++)
{
if (ISNULL(pChan->szTitle))
continue;
if (!pChan->fCategory)
{
fChan = TRUE;
wnsprintf(szChTitleParm, ARRAYSIZE(szChTitleParm), TEXT("%s%u"), CHTITLE, j);
wnsprintf(szChUrlParm, ARRAYSIZE(szChUrlParm), TEXT("%s%u"), CDFURL, j);
WritePrivateProfileString(CHANNEL_ADD, szChTitleParm, pChan->szTitle, pcszCustIns);
WritePrivateProfileString(CHANNEL_ADD, szChUrlParm, pChan->szWebUrl, pcszCustIns);
writeIE4Info(hInf, i, pChan);
wnsprintf(szChPreUrlParm, ARRAYSIZE(szChPreUrlParm), TEXT("%s%u"), CHPREURLPATH, j);
wnsprintf(szChIconParm, ARRAYSIZE(szChIconParm), TEXT("%s%u"), CHICON, j);
wnsprintf(szChBmpParm, ARRAYSIZE(szChBmpParm), TEXT("%s%u"), CHBMP, j);
wnsprintf(szChPreUrlNameParm, ARRAYSIZE(szChPreUrlNameParm), TEXT("%s%u"), CHPREURLNAME, j);
wnsprintf(szChIconNameParm, ARRAYSIZE(szChIconNameParm), TEXT("%s%u"), CHICONNAME, j);
wnsprintf(szChBmpNameParm, ARRAYSIZE(szChBmpNameParm), TEXT("%s%u"), CHBMPNAME, j);
wnsprintf(szChOfflineParm, ARRAYSIZE(szChOfflineParm), TEXT("%s%u"), IK_CHL_OFFLINE, j);
WritePrivateProfileString(CHANNEL_ADD, szChPreUrlParm, pChan->szPreUrlPath, pcszCustIns);
pWrk = StrRChr(pChan->szPreUrlPath, NULL, TEXT('\\'));
if (pWrk != NULL)
{
pWrk++;
WritePrivateProfileString( CHANNEL_ADD, szChPreUrlNameParm, pWrk, pcszCustIns );
if (PathFileExists(pChan->szPreUrlPath))
{
CopyFileToDir(pChan->szPreUrlPath, szTempPath);
CopyHtmlImgs(pChan->szPreUrlPath, szTempPath, NULL, NULL);
}
else
{
TCHAR szFile[MAX_PATH];
PathCombine(szFile, pcszChanDir, PathFindFileName(pChan->szPreUrlPath));
CopyFileToDir(szFile, szTempPath);
CopyHtmlImgs(szFile, szTempPath, NULL, NULL);
}
}
WritePrivateProfileString(CHANNEL_ADD, szChIconParm, pChan->szIcon, pcszCustIns);
pWrk = StrRChr(pChan->szIcon, NULL, TEXT('\\'));
if (pWrk != NULL)
{
pWrk++;
WritePrivateProfileString( CHANNEL_ADD, szChIconNameParm, pWrk, pcszCustIns );
if (PathFileExists(pChan->szIcon))
CopyFileToDir(pChan->szIcon, szTempPath);
else
{
TCHAR szFile[MAX_PATH];
PathCombine(szFile, pcszChanDir, PathFindFileName(pChan->szIcon));
CopyFileToDir(szFile, szTempPath);
}
}
WritePrivateProfileString(CHANNEL_ADD, szChBmpParm, pChan->szLogo, pcszCustIns);
pWrk = StrRChr(pChan->szLogo, NULL, TEXT('\\'));
if (pWrk)
{
pWrk++;
WritePrivateProfileString( CHANNEL_ADD, szChBmpNameParm, pWrk, pcszCustIns );
if (PathFileExists(pChan->szLogo))
CopyFileToDir(pChan->szLogo, szTempPath);
else
{
TCHAR szFile[MAX_PATH];
PathCombine(szFile, pcszChanDir, PathFindFileName(pChan->szLogo));
CopyFileToDir(szFile, szTempPath);
}
}
if (pChan->fOffline)
// NOTE: (andrewgu) no need to write NULL on FALSE as the whole section was
// wiped out up above.
WritePrivateProfileString(IS_CHANNEL_ADD, szChOfflineParm, TEXT("1"), pcszCustIns);
j++;
}
else
{
fChan = TRUE;
wnsprintf(szChTitleParm, ARRAYSIZE(szChTitleParm), TEXT("%s%u"), CATTITLE, k);
WritePrivateProfileString(CHANNEL_ADD, szChTitleParm, pChan->szTitle, pcszCustIns);
writeIE4Info(hInf, i, pChan);
wnsprintf(szChPreUrlParm, ARRAYSIZE(szChPreUrlParm), TEXT("%s%u"), CATHTML, k);
wnsprintf(szChIconParm, ARRAYSIZE(szChIconParm), TEXT("%s%u"), CATICON, k);
wnsprintf(szChBmpParm, ARRAYSIZE(szChBmpParm), TEXT("%s%u"), CATBMP, k);
wnsprintf(szChPreUrlNameParm, ARRAYSIZE(szChPreUrlNameParm), TEXT("%s%u"), CATHTMLNAME, k);
wnsprintf(szChIconNameParm, ARRAYSIZE(szChIconNameParm), TEXT("%s%u"), CATICONNAME, k);
wnsprintf(szChBmpNameParm, ARRAYSIZE(szChBmpNameParm), TEXT("%s%u"), CATBMPNAME, k);
WritePrivateProfileString(CHANNEL_ADD, szChPreUrlParm, pChan->szWebUrl, pcszCustIns);
pWrk = StrRChr(pChan->szWebUrl, NULL, TEXT('\\'));
if (pWrk != NULL) // make sure we're not copying over the file as hidden/system
{
DWORD dwFileAttrib;
dwFileAttrib = GetFileAttributes(pChan->szWebUrl);
SetFileAttributes(pChan->szWebUrl, FILE_ATTRIBUTE_NORMAL);
pWrk++;
WritePrivateProfileString( CHANNEL_ADD, szChPreUrlNameParm, pWrk, pcszCustIns );
if (PathFileExists(pChan->szWebUrl))
CopyFileToDir(pChan->szWebUrl, szTempPath);
else
{
TCHAR szFile[MAX_PATH];
PathCombine(szFile, pcszChanDir, PathFindFileName(pChan->szWebUrl));
CopyFileToDir(szFile, szTempPath);
}
SetFileAttributes(pChan->szWebUrl, dwFileAttrib);
}
WritePrivateProfileString(CHANNEL_ADD, szChIconParm, pChan->szIcon, pcszCustIns);
pWrk = StrRChr(pChan->szIcon, NULL, TEXT('\\'));
if (pWrk != NULL)
{
pWrk++;
WritePrivateProfileString( CHANNEL_ADD, szChIconNameParm, pWrk, pcszCustIns );
if (PathFileExists(pChan->szIcon))
CopyFileToDir(pChan->szIcon, szTempPath);
else
{
TCHAR szFile[MAX_PATH];
PathCombine(szFile, pcszChanDir, PathFindFileName(pChan->szIcon));
CopyFileToDir(szFile, szTempPath);
}
}
WritePrivateProfileString(CHANNEL_ADD, szChBmpParm, pChan->szLogo, pcszCustIns);
pWrk = StrRChr(pChan->szLogo, NULL, TEXT('\\'));
if (pWrk != NULL)
{
pWrk++;
WritePrivateProfileString( CHANNEL_ADD, szChBmpNameParm, pWrk, pcszCustIns );
if (PathFileExists(pChan->szLogo))
CopyFileToDir(pChan->szLogo, szTempPath);
else
{
TCHAR szFile[MAX_PATH];
PathCombine(szFile, pcszChanDir, PathFindFileName(pChan->szLogo));
CopyFileToDir(szFile, szTempPath);
}
}
k++;
}
}
PathRemovePath(pcszChanDir);
if (!fChan)
WritePrivateProfileSection(CHANNEL_ADD, TEXT("No Channels\0"), pcszCustIns);
else
{
// copy over all the files from the temp dir back to the working dir
PathCreatePath(pcszChanDir);
CopyFileToDir(szTempPath, pcszChanDir);
}
WritePrivateProfileString(NULL, NULL, NULL, pcszCustIns);
CloseHandle(hInf);
if (fChan)
{
TCHAR szBuf[MAX_PATH];
wnsprintf(szBuf, ARRAYSIZE(szBuf), TEXT("*,ie4chnls.inf,%s"), DEFAULT_INSTALL);
WritePrivateProfileString(EXTREGINF, TEXT("channels"), szBuf, pcszCustIns);
}
else
{
WritePrivateProfileString(EXTREGINF, TEXT("channels"), NULL, pcszCustIns);
DeleteFile(szIE4ChnlsInf);
}
PathRemovePath(szTempPath);
// do not free for profile manager since we might still be on the page due to file save
if (!HasFlag(dwMode, IEM_PROFMGR) && (paChannel != NULL))
{
CoTaskMemFree(paChannel);
SetWindowLong(hwndList, GWLP_USERDATA, NULL);
}
}