mirror of
https://github.com/reactos/reactos.git
synced 2025-01-04 05:20:54 +00:00
[SHELL32] Code formatting/style/whitespace fix + fix two memory leaks in failure paths of CNewMenu::LoadItem().
This commit is contained in:
parent
8e60c2efee
commit
0416c598f8
2 changed files with 51 additions and 41 deletions
|
@ -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)));
|
||||||
|
@ -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)
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue