mirror of
https://github.com/microsoft/PowerToys.git
synced 2025-12-16 19:57:57 +01:00
Bug Fixes for PowerRename (#614)
* Bug Fixes Fixes include: * Pass parent HWND to UI so dialog is no longer appearing in top corner all the time * Fix duplicate entries for PowerRename in context menu for shortcuts * Fix crashing bug due to telemetry not getting unregistered on unload * Ensure we show the file extension in the UI even if extensions are hidden in Windows Explorer * Update PowerRenameExt.cpp Fix missed line to set parent HWND
This commit is contained in:
@@ -8,8 +8,11 @@
|
|||||||
|
|
||||||
extern HINSTANCE g_hInst;
|
extern HINSTANCE g_hInst;
|
||||||
|
|
||||||
HWND g_hwndParent = 0;
|
struct InvokeStruct
|
||||||
|
{
|
||||||
|
HWND hwndParent;
|
||||||
|
IStream* pstrm;
|
||||||
|
};
|
||||||
|
|
||||||
const wchar_t powerRenameRegPath[] = L"Software\\Microsoft\\PowerRename";
|
const wchar_t powerRenameRegPath[] = L"Software\\Microsoft\\PowerRename";
|
||||||
const wchar_t powerRenameRegEnabledName[] = L"Enabled";
|
const wchar_t powerRenameRegEnabledName[] = L"Enabled";
|
||||||
@@ -73,15 +76,12 @@ HRESULT CPowerRenameMenu::QueryContextMenu(HMENU hMenu, UINT index, UINT uIDFirs
|
|||||||
return E_FAIL;
|
return E_FAIL;
|
||||||
|
|
||||||
HRESULT hr = E_UNEXPECTED;
|
HRESULT hr = E_UNEXPECTED;
|
||||||
if (m_spdo)
|
if (m_spdo && !(uFlags & (CMF_DEFAULTONLY | CMF_VERBSONLY | CMF_OPTIMIZEFORINVOKE)))
|
||||||
{
|
{
|
||||||
if ((uFlags & ~CMF_OPTIMIZEFORINVOKE) && (uFlags & ~(CMF_DEFAULTONLY | CMF_VERBSONLY)))
|
wchar_t menuName[64] = { 0 };
|
||||||
{
|
LoadString(g_hInst, IDS_POWERRENAME, menuName, ARRAYSIZE(menuName));
|
||||||
wchar_t menuName[64] = { 0 };
|
InsertMenu(hMenu, index, MF_STRING | MF_BYPOSITION, uIDFirst++, menuName);
|
||||||
LoadString(g_hInst, IDS_POWERRENAME, menuName, ARRAYSIZE(menuName));
|
hr = MAKE_HRESULT(SEVERITY_SUCCESS, FACILITY_NULL, 1);
|
||||||
InsertMenu(hMenu, index, MF_STRING | MF_BYPOSITION, uIDFirst++, menuName);
|
|
||||||
hr = MAKE_HRESULT(SEVERITY_SUCCESS, FACILITY_NULL, 1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return hr;
|
return hr;
|
||||||
@@ -96,14 +96,24 @@ HRESULT CPowerRenameMenu::InvokeCommand(_In_ LPCMINVOKECOMMANDINFO pici)
|
|||||||
(LOWORD(pici->lpVerb) == 0))
|
(LOWORD(pici->lpVerb) == 0))
|
||||||
{
|
{
|
||||||
Trace::Invoked();
|
Trace::Invoked();
|
||||||
IStream* pstrm = nullptr;
|
InvokeStruct* pInvokeData = new InvokeStruct;
|
||||||
hr = CoMarshalInterThreadInterfaceInStream(__uuidof(m_spdo), m_spdo, &pstrm);
|
hr = pInvokeData ? S_OK : E_OUTOFMEMORY;
|
||||||
if (SUCCEEDED(hr))
|
if (SUCCEEDED(hr))
|
||||||
{
|
{
|
||||||
if (!SHCreateThread(s_PowerRenameUIThreadProc, pstrm, CTF_COINIT | CTF_PROCESS_REF, nullptr))
|
pInvokeData->hwndParent = pici->hwnd;
|
||||||
|
hr = CoMarshalInterThreadInterfaceInStream(__uuidof(m_spdo), m_spdo, &(pInvokeData->pstrm));
|
||||||
|
if (SUCCEEDED(hr))
|
||||||
{
|
{
|
||||||
pstrm->Release(); // if we failed to create the thread, then we must release the stream
|
hr = SHCreateThread(s_PowerRenameUIThreadProc, pInvokeData, CTF_COINIT | CTF_PROCESS_REF, nullptr) ? S_OK : E_FAIL;
|
||||||
hr = E_FAIL;
|
if (FAILED(hr))
|
||||||
|
{
|
||||||
|
pInvokeData->pstrm->Release(); // if we failed to create the thread, then we must release the stream
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (FAILED(hr))
|
||||||
|
{
|
||||||
|
delete pInvokeData;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Trace::InvokedRet(hr);
|
Trace::InvokedRet(hr);
|
||||||
@@ -114,9 +124,9 @@ HRESULT CPowerRenameMenu::InvokeCommand(_In_ LPCMINVOKECOMMANDINFO pici)
|
|||||||
|
|
||||||
DWORD WINAPI CPowerRenameMenu::s_PowerRenameUIThreadProc(_In_ void* pData)
|
DWORD WINAPI CPowerRenameMenu::s_PowerRenameUIThreadProc(_In_ void* pData)
|
||||||
{
|
{
|
||||||
IStream* pstrm = static_cast<IStream*>(pData);
|
InvokeStruct* pInvokeData = static_cast<InvokeStruct*>(pData);
|
||||||
CComPtr<IDataObject> spdo;
|
CComPtr<IDataObject> spdo;
|
||||||
HRESULT hr = CoGetInterfaceAndReleaseStream(pstrm, IID_PPV_ARGS(&spdo));
|
HRESULT hr = CoGetInterfaceAndReleaseStream(pInvokeData->pstrm, IID_PPV_ARGS(&spdo));
|
||||||
if (SUCCEEDED(hr))
|
if (SUCCEEDED(hr))
|
||||||
{
|
{
|
||||||
// Create the smart rename manager
|
// Create the smart rename manager
|
||||||
@@ -139,7 +149,7 @@ DWORD WINAPI CPowerRenameMenu::s_PowerRenameUIThreadProc(_In_ void* pData)
|
|||||||
if (SUCCEEDED(hr))
|
if (SUCCEEDED(hr))
|
||||||
{
|
{
|
||||||
// Call blocks until we are done
|
// Call blocks until we are done
|
||||||
spsrui->Show();
|
spsrui->Show(pInvokeData->hwndParent);
|
||||||
spsrui->Close();
|
spsrui->Close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -150,6 +160,8 @@ DWORD WINAPI CPowerRenameMenu::s_PowerRenameUIThreadProc(_In_ void* pData)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
delete pInvokeData;
|
||||||
|
|
||||||
Trace::UIShownRet(hr);
|
Trace::UIShownRet(hr);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
@@ -101,7 +101,7 @@ BOOL WINAPI DllMain(HINSTANCE hInstance, DWORD dwReason, void*)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case DLL_PROCESS_DETACH:
|
case DLL_PROCESS_DETACH:
|
||||||
Trace::RegisterProvider();
|
Trace::UnregisterProvider();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|||||||
@@ -102,7 +102,7 @@ public:
|
|||||||
interface __declspec(uuid("E6679DEB-460D-42C1-A7A8-E25897061C99")) IPowerRenameUI : public IUnknown
|
interface __declspec(uuid("E6679DEB-460D-42C1-A7A8-E25897061C99")) IPowerRenameUI : public IUnknown
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
IFACEMETHOD(Show)() = 0;
|
IFACEMETHOD(Show)(_In_opt_ HWND hwndParent) = 0;
|
||||||
IFACEMETHOD(Close)() = 0;
|
IFACEMETHOD(Close)() = 0;
|
||||||
IFACEMETHOD(Update)() = 0;
|
IFACEMETHOD(Update)() = 0;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -203,7 +203,7 @@ HRESULT CPowerRenameItem::_Init(_In_ IShellItem* psi)
|
|||||||
HRESULT hr = psi->GetDisplayName(SIGDN_FILESYSPATH, &m_path);
|
HRESULT hr = psi->GetDisplayName(SIGDN_FILESYSPATH, &m_path);
|
||||||
if (SUCCEEDED(hr))
|
if (SUCCEEDED(hr))
|
||||||
{
|
{
|
||||||
hr = psi->GetDisplayName(SIGDN_NORMALDISPLAY, &m_originalName);
|
hr = SHStrDup(PathFindFileName(m_path), &m_originalName);
|
||||||
if (SUCCEEDED(hr))
|
if (SUCCEEDED(hr))
|
||||||
{
|
{
|
||||||
// Check if we are a folder now so we can check this attribute quickly later
|
// Check if we are a folder now so we can check this attribute quickly later
|
||||||
|
|||||||
@@ -47,7 +47,7 @@ int APIENTRY wWinMain(
|
|||||||
if (SUCCEEDED(CPowerRenameUI::s_CreateInstance(spsrm, nullptr, true, &spsrui)))
|
if (SUCCEEDED(CPowerRenameUI::s_CreateInstance(spsrm, nullptr, true, &spsrui)))
|
||||||
{
|
{
|
||||||
// Call blocks until we are done
|
// Call blocks until we are done
|
||||||
spsrui->Show();
|
spsrui->Show(NULL);
|
||||||
spsrui->Close();
|
spsrui->Close();
|
||||||
|
|
||||||
// Need to call shutdown to break circular dependencies
|
// Need to call shutdown to break circular dependencies
|
||||||
|
|||||||
@@ -89,9 +89,9 @@ HRESULT CPowerRenameUI::s_CreateInstance(_In_ IPowerRenameManager* psrm, _In_opt
|
|||||||
}
|
}
|
||||||
|
|
||||||
// IPowerRenameUI
|
// IPowerRenameUI
|
||||||
IFACEMETHODIMP CPowerRenameUI::Show()
|
IFACEMETHODIMP CPowerRenameUI::Show(_In_opt_ HWND hwndParent)
|
||||||
{
|
{
|
||||||
return _DoModal(NULL);
|
return _DoModal(hwndParent);
|
||||||
}
|
}
|
||||||
|
|
||||||
IFACEMETHODIMP CPowerRenameUI::Close()
|
IFACEMETHODIMP CPowerRenameUI::Close()
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ public:
|
|||||||
IFACEMETHODIMP_(ULONG) Release();
|
IFACEMETHODIMP_(ULONG) Release();
|
||||||
|
|
||||||
// IPowerRenameUI
|
// IPowerRenameUI
|
||||||
IFACEMETHODIMP Show();
|
IFACEMETHODIMP Show(_In_opt_ HWND hwndParent);
|
||||||
IFACEMETHODIMP Close();
|
IFACEMETHODIMP Close();
|
||||||
IFACEMETHODIMP Update();
|
IFACEMETHODIMP Update();
|
||||||
IFACEMETHODIMP get_hwnd(_Out_ HWND* hwnd);
|
IFACEMETHODIMP get_hwnd(_Out_ HWND* hwnd);
|
||||||
|
|||||||
Reference in New Issue
Block a user