123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373 |
- #include <streams.h>
- #include <initguid.h>
- #include "combase.h"
- #ifdef DEBUG
- #ifdef UNICODE
- #ifndef _UNICODE
- #define _UNICODE
- #endif
- #endif
- #include <tchar.h>
- #endif
- #include <strsafe.h>
- HINSTANCE g_hInst;
- DWORD g_amPlatform;
- OSVERSIONINFO g_osInfo;
- class CClassFactory : public IClassFactory, public CBaseObject
- {
- private:
- const CFactoryTemplate *const m_pTemplate;
- ULONG m_cRef;
- static int m_cLocked;
- public:
- CClassFactory(const CFactoryTemplate *);
-
- STDMETHODIMP QueryInterface(REFIID riid, __deref_out void ** ppv);
- STDMETHODIMP_(ULONG)AddRef();
- STDMETHODIMP_(ULONG)Release();
-
- STDMETHODIMP CreateInstance(LPUNKNOWN pUnkOuter, REFIID riid, __deref_out void **pv);
- STDMETHODIMP LockServer(BOOL fLock);
-
- static BOOL IsLocked() {
- return (m_cLocked > 0);
- };
- };
- int CClassFactory::m_cLocked = 0;
- CClassFactory::CClassFactory(const CFactoryTemplate *pTemplate)
- : CBaseObject(NAME("Class Factory"))
- , m_cRef(0)
- , m_pTemplate(pTemplate)
- {
- }
- STDMETHODIMP
- CClassFactory::QueryInterface(REFIID riid,__deref_out void **ppv)
- {
- CheckPointer(ppv,E_POINTER)
- ValidateReadWritePtr(ppv,sizeof(PVOID));
- *ppv = NULL;
-
- if ((riid == IID_IUnknown) || (riid == IID_IClassFactory)) {
- *ppv = (LPVOID) this;
-
- ((LPUNKNOWN) *ppv)->AddRef();
- return NOERROR;
- }
- return ResultFromScode(E_NOINTERFACE);
- }
- STDMETHODIMP_(ULONG)
- CClassFactory::AddRef()
- {
- return ++m_cRef;
- }
- STDMETHODIMP_(ULONG)
- CClassFactory::Release()
- {
- LONG lRef = InterlockedDecrement((volatile LONG *)&m_cRef);
- if (lRef == 0) {
- delete this;
- return 0;
- } else {
- return lRef;
- }
- }
- STDMETHODIMP
- CClassFactory::CreateInstance(
- LPUNKNOWN pUnkOuter,
- REFIID riid,
- __deref_out void **pv)
- {
- CheckPointer(pv,E_POINTER)
- ValidateReadWritePtr(pv,sizeof(void *));
- *pv = NULL;
-
- if (pUnkOuter != NULL) {
- if (IsEqualIID(riid,IID_IUnknown) == FALSE) {
- *pv = NULL;
- return ResultFromScode(E_NOINTERFACE);
- }
- }
-
- HRESULT hr = NOERROR;
- CUnknown *pObj = m_pTemplate->CreateInstance(pUnkOuter, &hr);
- if (pObj == NULL) {
- *pv = NULL;
- if (SUCCEEDED(hr)) {
- hr = E_OUTOFMEMORY;
- }
- return hr;
- }
-
- if (FAILED(hr)) {
- delete pObj;
- *pv = NULL;
- return hr;
- }
-
-
-
-
-
- pObj->NonDelegatingAddRef();
- hr = pObj->NonDelegatingQueryInterface(riid, pv);
- pObj->NonDelegatingRelease();
-
-
-
-
-
- if (SUCCEEDED(hr)) {
- ASSERT(*pv);
- }
- return hr;
- }
- STDMETHODIMP
- CClassFactory::LockServer(BOOL fLock)
- {
- if (fLock) {
- m_cLocked++;
- } else {
- m_cLocked--;
- }
- return NOERROR;
- }
- STDAPI
- DllCanUnloadNow()
- {
- DbgLog((LOG_MEMORY,2,TEXT("DLLCanUnloadNow called - IsLocked = %d, Active objects = %d"),
- CClassFactory::IsLocked(),
- CBaseObject::ObjectsActive()));
- if (CClassFactory::IsLocked() || CBaseObject::ObjectsActive()) {
- return S_FALSE;
- } else {
- return S_OK;
- }
- }
|