// dllmain.cpp : Defines the entry point for the DLL application. #include "pch.h" #include "ClassFactory.h" HINSTANCE g_hInst = NULL; long g_cDllRef = 0; // {FCDD4EED-41AA-492F-8A84-31A1546226E0} static const GUID CLSID_SvgPreviewHandler = { 0xfcdd4eed, 0x41aa, 0x492f, { 0x8a, 0x84, 0x31, 0xa1, 0x54, 0x62, 0x26, 0xe0 } }; BOOL APIENTRY DllMain(HMODULE hModule, DWORD ul_reason_for_call, LPVOID lpReserved) { switch (ul_reason_for_call) { case DLL_PROCESS_ATTACH: g_hInst = hModule; DisableThreadLibraryCalls(hModule); break; case DLL_THREAD_ATTACH: case DLL_THREAD_DETACH: case DLL_PROCESS_DETACH: break; } return TRUE; } // // FUNCTION: DllGetClassObject // // PURPOSE: Create the class factory and query to the specific interface. // // PARAMETERS: // * rclsid - The CLSID that will associate the correct data and code. // * riid - A reference to the identifier of the interface that the caller // is to use to communicate with the class object. // * ppv - The address of a pointer variable that receives the interface // pointer requested in riid. Upon successful return, *ppv contains the // requested interface pointer. If an error occurs, the interface pointer // is NULL. // STDAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, void** ppv) { HRESULT hr = CLASS_E_CLASSNOTAVAILABLE; if (IsEqualCLSID(CLSID_SvgPreviewHandler, rclsid)) { hr = E_OUTOFMEMORY; ClassFactory* pClassFactory = new ClassFactory(); if (pClassFactory) { hr = pClassFactory->QueryInterface(riid, ppv); pClassFactory->Release(); } } return hr; } // // FUNCTION: DllCanUnloadNow // // PURPOSE: Check if we can unload the component from the memory. // // NOTE: The component can be unloaded from the memory when its reference // count is zero (i.e. nobody is still using the component). // STDAPI DllCanUnloadNow(void) { return g_cDllRef > 0 ? S_FALSE : S_OK; }