[SHELL32] Code formatting/style/whitespace fix + fix two memory leaks in failure paths of CNewMenu::LoadItem().

This commit is contained in:
Hermès Bélusca-Maïto 2019-04-24 03:36:27 +02:00
parent 8e60c2efee
commit 0416c598f8
No known key found for this signature in database
GPG key ID: 3B2539C65E7B93D0
2 changed files with 51 additions and 41 deletions

View file

@ -31,8 +31,8 @@ CNewMenu::CNewMenu() :
m_pItems(NULL), m_pItems(NULL),
m_pLinkItem(NULL), m_pLinkItem(NULL),
m_pSite(NULL), m_pSite(NULL),
m_hiconFolder(NULL), m_hIconFolder(NULL),
m_hiconLink(NULL) m_hIconLink(NULL)
{ {
} }
@ -76,7 +76,7 @@ CNewMenu::SHELLNEW_ITEM *CNewMenu::LoadItem(LPCWSTR pwszExt)
{ {
HKEY hKey; HKEY hKey;
WCHAR wszBuf[MAX_PATH]; WCHAR wszBuf[MAX_PATH];
BYTE *pData = NULL; PBYTE pData = NULL;
DWORD cbData; DWORD cbData;
StringCbPrintfW(wszBuf, sizeof(wszBuf), L"%s\\ShellNew", pwszExt); StringCbPrintfW(wszBuf, sizeof(wszBuf), L"%s\\ShellNew", pwszExt);
@ -115,7 +115,7 @@ CNewMenu::SHELLNEW_ITEM *CNewMenu::LoadItem(LPCWSTR pwszExt)
{ {
if (Types[i].bNeedData && cbData > 0) if (Types[i].bNeedData && cbData > 0)
{ {
pData = (BYTE*)malloc(cbData); pData = (PBYTE)malloc(cbData);
RegGetValueW(hKey, NULL, Types[i].pszName, dwFlags, &dwType, pData, &cbData); RegGetValueW(hKey, NULL, Types[i].pszName, dwFlags, &dwType, pData, &cbData);
if (!Types[i].bStr && (dwType == REG_SZ || dwType == REG_EXPAND_SZ)) if (!Types[i].bStr && (dwType == REG_SZ || dwType == REG_EXPAND_SZ))
{ {
@ -132,11 +132,17 @@ CNewMenu::SHELLNEW_ITEM *CNewMenu::LoadItem(LPCWSTR pwszExt)
/* Was any key found? */ /* Was any key found? */
if (!Types[i].pszName) if (!Types[i].pszName)
{
free(pData);
return NULL; return NULL;
}
SHFILEINFOW fi; SHFILEINFOW fi;
if (!SHGetFileInfoW(pwszExt, FILE_ATTRIBUTE_NORMAL, &fi, sizeof(fi), SHGFI_USEFILEATTRIBUTES|SHGFI_TYPENAME|SHGFI_ICON|SHGFI_SMALLICON)) if (!SHGetFileInfoW(pwszExt, FILE_ATTRIBUTE_NORMAL, &fi, sizeof(fi), SHGFI_USEFILEATTRIBUTES | SHGFI_TYPENAME | SHGFI_ICON | SHGFI_SMALLICON))
{
free(pData);
return NULL; return NULL;
}
/* Create new item */ /* Create new item */
SHELLNEW_ITEM *pNewItem = static_cast<SHELLNEW_ITEM *>(HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(SHELLNEW_ITEM))); SHELLNEW_ITEM *pNewItem = static_cast<SHELLNEW_ITEM *>(HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(SHELLNEW_ITEM)));
@ -198,9 +204,9 @@ CNewMenu::CacheItems()
} }
} }
} }
dwSize++; dwSize++;
lpValues = (LPWSTR) HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, dwSize * sizeof(WCHAR)); lpValues = (LPWSTR) HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, dwSize * sizeof(WCHAR));
if (!lpValues) if (!lpValues)
return FALSE; return FALSE;
@ -216,17 +222,17 @@ CNewMenu::CacheItems()
HeapFree(GetProcessHeap(), 0, lpValues); HeapFree(GetProcessHeap(), 0, lpValues);
return FALSE; return FALSE;
} }
if (RegSetValueExW(hKey, L"Classes", NULL, REG_MULTI_SZ, (LPBYTE)lpValues, dwSize * sizeof(WCHAR)) != ERROR_SUCCESS) if (RegSetValueExW(hKey, L"Classes", NULL, REG_MULTI_SZ, (LPBYTE)lpValues, dwSize * sizeof(WCHAR)) != ERROR_SUCCESS)
{ {
HeapFree(GetProcessHeap(), 0, lpValues); HeapFree(GetProcessHeap(), 0, lpValues);
RegCloseKey(hKey); RegCloseKey(hKey);
return FALSE; return FALSE;
} }
HeapFree(GetProcessHeap(), 0, lpValues); HeapFree(GetProcessHeap(), 0, lpValues);
RegCloseKey(hKey); RegCloseKey(hKey);
return TRUE; return TRUE;
} }
@ -239,17 +245,17 @@ CNewMenu::LoadCachedItems()
HKEY hKey; HKEY hKey;
SHELLNEW_ITEM *pNewItem; SHELLNEW_ITEM *pNewItem;
SHELLNEW_ITEM *pCurItem = NULL; SHELLNEW_ITEM *pCurItem = NULL;
if (RegOpenKeyExW(HKEY_CURRENT_USER, ShellNewKey, 0, KEY_READ, &hKey) != ERROR_SUCCESS) if (RegOpenKeyExW(HKEY_CURRENT_USER, ShellNewKey, 0, KEY_READ, &hKey) != ERROR_SUCCESS)
return FALSE; return FALSE;
if (RegQueryValueExW(hKey, L"Classes", NULL, NULL, NULL, &dwSize) != ERROR_SUCCESS) if (RegQueryValueExW(hKey, L"Classes", NULL, NULL, NULL, &dwSize) != ERROR_SUCCESS)
return FALSE; return FALSE;
lpValues = (LPWSTR) HeapAlloc(GetProcessHeap(), 0, dwSize); lpValues = (LPWSTR) HeapAlloc(GetProcessHeap(), 0, dwSize);
if (!lpValues) if (!lpValues)
return FALSE; return FALSE;
if (RegQueryValueExW(hKey, L"Classes", NULL, NULL, (LPBYTE)lpValues, &dwSize) != ERROR_SUCCESS) if (RegQueryValueExW(hKey, L"Classes", NULL, NULL, (LPBYTE)lpValues, &dwSize) != ERROR_SUCCESS)
{ {
HeapFree(GetProcessHeap(), 0, lpValues); HeapFree(GetProcessHeap(), 0, lpValues);
@ -258,7 +264,7 @@ CNewMenu::LoadCachedItems()
wszName = lpValues; wszName = lpValues;
for (; '\0' != *wszName; wszName += wcslen(wszName) + 1) for (; *wszName != '\0'; wszName += wcslen(wszName) + 1)
{ {
pNewItem = LoadItem(wszName); pNewItem = LoadItem(wszName);
if (pNewItem) if (pNewItem)
@ -281,10 +287,10 @@ CNewMenu::LoadCachedItems()
} }
} }
} }
HeapFree(GetProcessHeap(), 0, lpValues); HeapFree(GetProcessHeap(), 0, lpValues);
RegCloseKey(hKey); RegCloseKey(hKey);
return TRUE; return TRUE;
} }
@ -306,8 +312,8 @@ UINT
CNewMenu::InsertShellNewItems(HMENU hMenu, UINT idCmdFirst, UINT Pos) CNewMenu::InsertShellNewItems(HMENU hMenu, UINT idCmdFirst, UINT Pos)
{ {
MENUITEMINFOW mii; MENUITEMINFOW mii;
WCHAR wszBuf[256];
UINT idCmd = idCmdFirst; UINT idCmd = idCmdFirst;
WCHAR wszBuf[256];
if (m_pItems == NULL) if (m_pItems == NULL)
{ {
@ -318,7 +324,7 @@ CNewMenu::InsertShellNewItems(HMENU hMenu, UINT idCmdFirst, UINT Pos)
ZeroMemory(&mii, sizeof(mii)); ZeroMemory(&mii, sizeof(mii));
mii.cbSize = sizeof(mii); mii.cbSize = sizeof(mii);
/* Insert new folder action */ /* Insert the new folder action */
if (!LoadStringW(shell32_hInstance, FCIDM_SHVIEW_NEWFOLDER, wszBuf, _countof(wszBuf))) if (!LoadStringW(shell32_hInstance, FCIDM_SHVIEW_NEWFOLDER, wszBuf, _countof(wszBuf)))
wszBuf[0] = 0; wszBuf[0] = 0;
mii.fMask = MIIM_ID | MIIM_BITMAP | MIIM_STRING; mii.fMask = MIIM_ID | MIIM_BITMAP | MIIM_STRING;
@ -341,18 +347,17 @@ CNewMenu::InsertShellNewItems(HMENU hMenu, UINT idCmdFirst, UINT Pos)
++idCmd; ++idCmd;
} }
/* Insert seperator for custom new action */ /* Insert a seperator for the custom new action */
mii.fMask = MIIM_TYPE | MIIM_ID; mii.fMask = MIIM_TYPE | MIIM_ID;
mii.fType = MFT_SEPARATOR; mii.fType = MFT_SEPARATOR;
mii.wID = -1; mii.wID = -1;
InsertMenuItemW(hMenu, Pos++, TRUE, &mii); InsertMenuItemW(hMenu, Pos++, TRUE, &mii);
/* Insert rest of items */ /* Insert the rest of the items */
mii.fMask = MIIM_ID | MIIM_BITMAP | MIIM_STRING; mii.fMask = MIIM_ID | MIIM_BITMAP | MIIM_STRING;
mii.fType = 0; mii.fType = 0;
SHELLNEW_ITEM *pCurItem = m_pItems; for (SHELLNEW_ITEM *pCurItem = m_pItems; pCurItem; pCurItem = pCurItem->pNext)
while (pCurItem)
{ {
/* Skip shortcut item */ /* Skip shortcut item */
if (pCurItem == m_pLinkItem) if (pCurItem == m_pLinkItem)
@ -364,7 +369,6 @@ CNewMenu::InsertShellNewItems(HMENU hMenu, UINT idCmdFirst, UINT Pos)
mii.wID = idCmd; mii.wID = idCmd;
if (InsertMenuItemW(hMenu, Pos++, TRUE, &mii)) if (InsertMenuItemW(hMenu, Pos++, TRUE, &mii))
++idCmd; ++idCmd;
pCurItem = pCurItem->pNext;
} }
return idCmd - idCmdFirst; return idCmd - idCmdFirst;
@ -436,7 +440,7 @@ HRESULT CNewMenu::CreateNewFolder(LPCMINVOKECOMMANDINFO lpici)
WCHAR wszName[MAX_PATH]; WCHAR wszName[MAX_PATH];
WCHAR wszNewFolder[25]; WCHAR wszNewFolder[25];
HRESULT hr; HRESULT hr;
/* Get folder path */ /* Get folder path */
hr = SHGetPathFromIDListW(m_pidlFolder, wszPath); hr = SHGetPathFromIDListW(m_pidlFolder, wszPath);
if (FAILED_UNEXPECTEDLY(hr)) if (FAILED_UNEXPECTEDLY(hr))
@ -553,7 +557,7 @@ HRESULT CNewMenu::NewItemByNonCommand(SHELLNEW_ITEM *pItem, LPWSTR wszName,
else else
{ {
StringCbPrintfW(wszBuf, sizeof(wszBuf), L"Cannot create file: %s", wszName); StringCbPrintfW(wszBuf, sizeof(wszBuf), L"Cannot create file: %s", wszName);
MessageBoxW(NULL, wszBuf, L"Cannot create file", MB_OK|MB_ICONERROR); // FIXME load localized error msg MessageBoxW(NULL, wszBuf, L"Cannot create file", MB_OK | MB_ICONERROR); // FIXME load localized error msg
} }
return S_OK; return S_OK;
@ -615,9 +619,9 @@ CNewMenu::QueryContextMenu(HMENU hMenu,
UINT idCmdLast, UINT idCmdLast,
UINT uFlags) UINT uFlags)
{ {
WCHAR wszNew[200];
MENUITEMINFOW mii; MENUITEMINFOW mii;
UINT cItems = 0; UINT cItems = 0;
WCHAR wszNew[200];
TRACE("%p %p %u %u %u %u\n", this, TRACE("%p %p %u %u %u %u\n", this,
hMenu, indexMenu, idCmdFirst, idCmdLast, uFlags); hMenu, indexMenu, idCmdFirst, idCmdLast, uFlags);
@ -631,7 +635,7 @@ CNewMenu::QueryContextMenu(HMENU hMenu,
cItems = InsertShellNewItems(m_hSubMenu, idCmdFirst, 0); cItems = InsertShellNewItems(m_hSubMenu, idCmdFirst, 0);
memset(&mii, 0, sizeof(mii)); ZeroMemory(&mii, sizeof(mii));
mii.cbSize = sizeof(mii); mii.cbSize = sizeof(mii);
mii.fMask = MIIM_TYPE | MIIM_ID | MIIM_STATE | MIIM_SUBMENU; mii.fMask = MIIM_TYPE | MIIM_ID | MIIM_STATE | MIIM_SUBMENU;
mii.fType = MFT_STRING; mii.fType = MFT_STRING;
@ -654,7 +658,9 @@ CNewMenu::InvokeCommand(LPCMINVOKECOMMANDINFO lpici)
HRESULT hr = E_FAIL; HRESULT hr = E_FAIL;
if (LOWORD(lpici->lpVerb) == 0) if (LOWORD(lpici->lpVerb) == 0)
{
hr = CreateNewFolder(lpici); hr = CreateNewFolder(lpici);
}
else else
{ {
SHELLNEW_ITEM *pItem = FindItemFromIdOffset(LOWORD(lpici->lpVerb)); SHELLNEW_ITEM *pItem = FindItemFromIdOffset(LOWORD(lpici->lpVerb));
@ -715,11 +721,15 @@ CNewMenu::HandleMenuMsg2(UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *plRes
break; break;
DWORD id = LOWORD(lpdis->itemID); DWORD id = LOWORD(lpdis->itemID);
HICON hIcon = 0; HICON hIcon = NULL;
if (id == 0) if (id == 0)
hIcon = m_hiconFolder; {
hIcon = m_hIconFolder;
}
else if (id == 1) else if (id == 1)
hIcon = m_hiconLink; {
hIcon = m_hIconLink;
}
else else
{ {
SHELLNEW_ITEM *pItem = FindItemFromIdOffset(id); SHELLNEW_ITEM *pItem = FindItemFromIdOffset(id);
@ -730,12 +740,12 @@ CNewMenu::HandleMenuMsg2(UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *plRes
if (!hIcon) if (!hIcon)
break; break;
DrawIconEx(lpdis->hDC, DrawIconEx(lpdis->hDC,
2, 2,
lpdis->rcItem.top + (lpdis->rcItem.bottom - lpdis->rcItem.top - 16) / 2, lpdis->rcItem.top + (lpdis->rcItem.bottom - lpdis->rcItem.top - 16) / 2,
hIcon, hIcon,
16, 16,
16, 16,
0, NULL, DI_NORMAL); 0, NULL, DI_NORMAL);
if(plResult) if(plResult)
@ -753,7 +763,7 @@ CNewMenu::Initialize(LPCITEMIDLIST pidlFolder,
m_pidlFolder = ILClone(pidlFolder); m_pidlFolder = ILClone(pidlFolder);
/* Load folder and shortcut icons */ /* Load folder and shortcut icons */
m_hiconFolder = (HICON)LoadImage(shell32_hInstance, MAKEINTRESOURCE(IDI_SHELL_FOLDER), IMAGE_ICON, 16, 16, LR_SHARED); m_hIconFolder = (HICON)LoadImage(shell32_hInstance, MAKEINTRESOURCE(IDI_SHELL_FOLDER), IMAGE_ICON, 16, 16, LR_SHARED);
m_hiconLink = (HICON)LoadImage(shell32_hInstance, MAKEINTRESOURCE(IDI_SHELL_SHORTCUT), IMAGE_ICON, 16, 16, LR_SHARED); m_hIconLink = (HICON)LoadImage(shell32_hInstance, MAKEINTRESOURCE(IDI_SHELL_SHORTCUT), IMAGE_ICON, 16, 16, LR_SHARED);
return S_OK; return S_OK;
} }

View file

@ -59,7 +59,7 @@ private:
SHELLNEW_ITEM *m_pLinkItem; // Points to the link handler item in the m_pItems list. SHELLNEW_ITEM *m_pLinkItem; // Points to the link handler item in the m_pItems list.
CComPtr<IUnknown> m_pSite; CComPtr<IUnknown> m_pSite;
HMENU m_hSubMenu; HMENU m_hSubMenu;
HICON m_hiconFolder, m_hiconLink; HICON m_hIconFolder, m_hIconLink;
SHELLNEW_ITEM *LoadItem(LPCWSTR pwszExt); SHELLNEW_ITEM *LoadItem(LPCWSTR pwszExt);
void UnloadItem(SHELLNEW_ITEM *pItem); void UnloadItem(SHELLNEW_ITEM *pItem);