windows-nt/Source/XPSP1/NT/admin/activec/designer/setup/vbsnapcleanup/vbsnapcleanup.cpp
2020-09-26 16:20:57 +08:00

133 lines
4.3 KiB
C++

#include <windows.h>
#include <tchar.h>
#include <atlbase.h>
#include <atlimpl.cpp>
#define CLSID_LENGTH 256
#define MAX_PATH_LEN 2048
const CHAR g_MMCVBSnapinsKey[] = "Software\\Microsoft\\Visual Basic\\6.0\\SnapIns";
const CHAR g_MMCKey[] = "Software\\Microsoft\\MMC";
const CHAR g_SnapIns[] = "SnapIns";
const CHAR g_NodeTypes[] = "NodeTypes";
// Remove the MMC VB snapin entries from the registry
int __cdecl main(int argc, char* argv[])
{
HRESULT hr = CoInitialize(NULL);
if (FAILED(hr))
return 0;
BOOL bOleInitialized = TRUE;
do
{
// Open HKLM\Software\Microsoft\Visual Basic\6.0\SnapIns.
LONG lRetVal = 0;
ATL::CRegKey regVBSnapinsKey;
lRetVal = regVBSnapinsKey.Open(HKEY_LOCAL_MACHINE, g_MMCVBSnapinsKey, KEY_READ);
// If no VB Snapins then return.
if (ERROR_SUCCESS != lRetVal)
break;
ATL::CRegKey regCLSIDKey;
lRetVal = regCLSIDKey.Open(HKEY_CLASSES_ROOT, "CLSID");
ATLASSERT(ERROR_SUCCESS == lRetVal);
if (ERROR_SUCCESS != lRetVal)
break;
ATL::CRegKey regMMCKey;
// Open the other required keys.
lRetVal = regMMCKey.Open(HKEY_LOCAL_MACHINE, g_MMCKey, KEY_READ | KEY_WRITE);
// If MMC Key remove VB Snapins key.
if (ERROR_SUCCESS != lRetVal)
{
// BUGBUG
break;
}
// Enumerate the regVBSnapinsKey, this yields NodeTypeGuid key with
// default value as snapin class id.
CHAR szNodeType[CLSID_LENGTH];
CHAR szClsid[CLSID_LENGTH];
DWORD dwLength;
for (DWORD dwIndex = 0; TRUE; dwIndex++)
{
lRetVal = RegEnumKeyEx( (HKEY)regVBSnapinsKey, 0, szNodeType, &dwLength, NULL, NULL, NULL, NULL);
if ( (lRetVal == ERROR_NO_MORE_ITEMS) ||
(lRetVal != ERROR_SUCCESS) )
break;
// Got the NodeTypeGuid value, now open that key.
ATL::CRegKey regTempKey;
lRetVal = regTempKey.Open((HKEY)regVBSnapinsKey, szNodeType, KEY_READ);
if (ERROR_SUCCESS != lRetVal)
continue;
// Read the default value (Snapin CLSID).
dwLength = CLSID_LENGTH;
lRetVal = regTempKey.QueryValue(szClsid, NULL, &dwLength);
if (ERROR_SUCCESS != lRetVal)
continue;
#if 0 // Disable this code for this release
// Now we have the snapin class id
// Find the inproc server, Load it and call its DllUnRegisterServer
lRetVal = regTempKey.Open((HKEY) regCLSIDKey, szClsid, KEY_READ);
ATLASSERT(ERROR_SUCCESS == lRetVal);
if (ERROR_SUCCESS != lRetVal)
continue;
lRetVal = regTempKey.Open((HKEY) regTempKey, TEXT("InprocServer32"), KEY_READ);
ATLASSERT(ERROR_SUCCESS == lRetVal);
if (ERROR_SUCCESS != lRetVal)
continue;
TCHAR szPath[MAX_PATH_LEN];
dwLength = MAX_PATH_LEN;
lRetVal = regTempKey.QueryValue(szPath, NULL, &dwLength);
ATLASSERT(ERROR_SUCCESS == lRetVal);
if (ERROR_SUCCESS != lRetVal)
continue;
HINSTANCE hInstance = LoadLibraryEx(szPath, NULL, LOAD_WITH_ALTERED_SEARCH_PATH);
if (hInstance && bOleInitialized)
{
HRESULT (STDAPICALLTYPE* lpDllEntryPoint)(void);
(FARPROC&) lpDllEntryPoint = GetProcAddress(hInstance, "DllUnregisterServer");
if (lpDllEntryPoint)
hr = (*lpDllEntryPoint)();
FreeLibrary(hInstance);
}
#endif // #if 0
// Now we have snapin class id and nodetype guid. Delete them under mmc key.
lRetVal = regTempKey.Open((HKEY) regMMCKey, g_NodeTypes);
ATLASSERT(ERROR_SUCCESS == lRetVal);
if (ERROR_SUCCESS != lRetVal)
continue;
regTempKey.RecurseDeleteKey(szNodeType);
lRetVal = regTempKey.Open((HKEY) regMMCKey, g_SnapIns);
ATLASSERT(ERROR_SUCCESS == lRetVal);
if (ERROR_SUCCESS != lRetVal)
continue;
regTempKey.RecurseDeleteKey(szClsid);
regCLSIDKey.RecurseDeleteKey(szClsid);
// Finally delete the key under enumerator
regVBSnapinsKey.RecurseDeleteKey(szNodeType);
}
} while ( FALSE );
if (bOleInitialized)
CoUninitialize();
return 1;
}