//+------------------------------------------------------------------- // // Class: CBasicBndCF // // Synopsis: Class Factory for CBasicBnd // // Interfaces: IUnknown - QueryInterface, AddRef, Release // IClassFactory - CreateInstance // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- #include #pragma hdrstop #include const GUID CLSID_BasicBnd = {0x99999999,0x0000,0x0008,{0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x49}}; const GUID CLSID_TestEmbed = {0x99999999,0x0000,0x0008,{0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x47}}; ULONG g_UseCount = 0; //+------------------------------------------------------------------- // // Member: CBasicBndCF::CBasicBndCF() // // Synopsis: The constructor for CBAsicBnd. // // Arguments: None // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- CBasicBndCF::CBasicBndCF() : _cRefs(1) { g_UseCount++; } //+------------------------------------------------------------------- // // Member: CBasicBnd::~CBasicBndObj() // // Synopsis: The destructor for CBAsicBnd. // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- CBasicBndCF::~CBasicBndCF() { g_UseCount--; return; } //+------------------------------------------------------------------- // // Method: CBasicBndCF::QueryInterface // // Synopsis: Only IUnknown and IClassFactory supported // //-------------------------------------------------------------------- STDMETHODIMP CBasicBndCF::QueryInterface(REFIID iid, void FAR * FAR * ppv) { if (IsEqualIID(iid, IID_IUnknown) || IsEqualIID(iid, IID_IClassFactory)) { *ppv = this; AddRef(); return S_OK; } else { *ppv = NULL; return E_NOINTERFACE; } } STDMETHODIMP_(ULONG) CBasicBndCF::AddRef(void) { return ++_cRefs; } STDMETHODIMP_(ULONG) CBasicBndCF::Release(void) { if (--_cRefs == 0) { delete this; return 0; } return _cRefs; } //+------------------------------------------------------------------- // // Method: CBasicBndCF::CreateInstance // // Synopsis: This is called by Binding process to create the // actual class object // //-------------------------------------------------------------------- STDMETHODIMP CBasicBndCF::CreateInstance(IUnknown FAR* pUnkOuter, REFIID iidInterface, void FAR* FAR* ppv) { HRESULT hresult = S_OK; class CUnknownBasicBnd *pubb = new FAR CUnknownBasicBnd(pUnkOuter); if (pubb == NULL) { return E_OUTOFMEMORY; } // Because when an aggregate is being requested, the controlling // must be returned, no QI is necessary. if (pUnkOuter == NULL) { hresult = pubb->QueryInterface(iidInterface, ppv); pubb->Release(); } else { *ppv = (void *) pubb; } return hresult; } //+------------------------------------------------------------------- // // Method: CBasicBndCF::LockServer // // Synopsis: Who knows what this is for? // //-------------------------------------------------------------------- STDMETHODIMP CBasicBndCF::LockServer(BOOL fLock) { return E_FAIL; } //+------------------------------------------------------------------- // // Member: CBasicBnd::CBasicBnd() // // Synopsis: The constructor for CBAsicBnd. I // // Arguments: None // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- CBasicBnd::CBasicBnd(IUnknown *punk) : _punk(punk), _pmkContainer(NULL) { // Create storage for "contained" objects SCODE sc = StgCreateDocfile(NULL, STGM_DELETEONRELEASE|STGM_DFRALL|STGM_CREATE, 0, &_psStg1); Win4Assert((sc == S_OK) && "Create of first storage failed"); sc = StgCreateDocfile(NULL, STGM_DELETEONRELEASE|STGM_DFRALL|STGM_CREATE, 0, &_psStg2); Win4Assert((sc == S_OK) && "Create of second storage failed"); } //+------------------------------------------------------------------- // // Member: CBasicBnd::~CBasicBndObj() // // Synopsis: The destructor for CBAsicBnd. // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- CBasicBnd::~CBasicBnd() { if (_pmkContainer) { _pmkContainer->Release(); } if (_psStg1) { _psStg1->Release(); } if (_psStg2) { _psStg2->Release(); } return; } //+------------------------------------------------------------------- // // Member: CBasicBnd::QueryInterface // // Returns: S_OK // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::QueryInterface(REFIID iid, void **ppiuk) { return _punk->QueryInterface(iid, ppiuk); } //+------------------------------------------------------------------- // // Member: CBasicBnd::AddRef // // Synopsis: Standard stuff // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP_(ULONG) CBasicBnd::AddRef(void) { return _punk->AddRef(); } //+------------------------------------------------------------------- // // Member: CBasicBnd::Release // // Synopsis: Standard stuff // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP_(ULONG) CBasicBnd::Release(void) { return _punk->Release(); } //+------------------------------------------------------------------- // // Member: CBasicBnd::Load // // Synopsis: IPeristFile interface - needed 'cause we bind with // file moniker and BindToObject insists on calling this // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::Load(LPCOLESTR lpszFileName, DWORD grfMode) { if (grfMode & ~(STGM_READWRITE | STGM_SHARE_EXCLUSIVE)) { // Test requires default bind storage request and caller // has set some other bits so we fail. return STG_E_INVALIDPARAMETER; } return S_OK; } //+------------------------------------------------------------------- // // Member: CBasicBnd::Save // // Synopsis: IPeristFile interface - save // does little but here for commentry // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::Save(LPCOLESTR lpszFileName, BOOL fRemember) { return S_OK; } //+------------------------------------------------------------------- // // Member: CBasicBnd::SaveCpmpleted // CBasicBnd::GetCurFile // CBasicBnd::IsDirty // // Synopsis: More IPeristFile interface methods // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::SaveCompleted(LPCOLESTR lpszFileName) { return S_OK; } STDMETHODIMP CBasicBnd::GetCurFile(LPOLESTR FAR *lpszFileName) { return S_OK; } STDMETHODIMP CBasicBnd::IsDirty() { return S_OK; } //+------------------------------------------------------------------- // // Interface: IPersist // // Synopsis: IPersist interface methods // Need to return a valid class id here // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::GetClassID(LPCLSID classid) { *classid = CLSID_BasicBnd; return S_OK; } //+------------------------------------------------------------------- // // Interface: IOleObject // // Synopsis: IOleObject interface methods // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::SetClientSite(LPOLECLIENTSITE pClientSite) { return E_FAIL; } STDMETHODIMP CBasicBnd::GetClientSite(LPOLECLIENTSITE FAR* ppClientSite) { return E_FAIL; } STDMETHODIMP CBasicBnd::SetHostNames( LPCOLESTR szContainerApp, LPCOLESTR szContainerObj) { return E_FAIL; } STDMETHODIMP CBasicBnd::Close(DWORD dwSaveOption) { return E_FAIL; } STDMETHODIMP CBasicBnd::SetMoniker(DWORD dwWhichMoniker, LPMONIKER pmk) { if (_pmkContainer) { _pmkContainer->Release(); } _pmkContainer = pmk; pmk->AddRef(); return S_OK; } STDMETHODIMP CBasicBnd::GetMoniker( DWORD dwAssign, DWORD dwWhichMoniker, LPMONIKER FAR* ppmk) { if (_pmkContainer != NULL) { *ppmk = _pmkContainer; _pmkContainer->AddRef(); return S_OK; } return E_FAIL; } STDMETHODIMP CBasicBnd::InitFromData( LPDATAOBJECT pDataObject, BOOL fCreation, DWORD dwReserved) { return E_FAIL; } STDMETHODIMP CBasicBnd::GetClipboardData( DWORD dwReserved, LPDATAOBJECT FAR* ppDataObject) { return E_FAIL; } STDMETHODIMP CBasicBnd::DoVerb( LONG iVerb, LPMSG lpmsg, LPOLECLIENTSITE pActiveSite, LONG reserved, HWND hwndParent, LPCRECT lprcPosRect) { return E_FAIL; } STDMETHODIMP CBasicBnd::EnumVerbs(IEnumOLEVERB FAR* FAR* ppenumOleVerb) { return E_FAIL; } STDMETHODIMP CBasicBnd::Update(void) { return E_FAIL; } STDMETHODIMP CBasicBnd::IsUpToDate(void) { return E_FAIL; } STDMETHODIMP CBasicBnd::GetUserClassID(CLSID FAR* pClsid) { return E_FAIL; } STDMETHODIMP CBasicBnd::GetUserType(DWORD dwFormOfType, LPOLESTR FAR* pszUserType) { return E_FAIL; } STDMETHODIMP CBasicBnd::SetExtent(DWORD dwDrawAspect, LPSIZEL lpsizel) { return E_FAIL; } STDMETHODIMP CBasicBnd::GetExtent(DWORD dwDrawAspect, LPSIZEL lpsizel) { return E_FAIL; } STDMETHODIMP CBasicBnd::Advise( IAdviseSink FAR* pAdvSink, DWORD FAR* pdwConnection) { *pdwConnection = 0; return S_OK; } STDMETHODIMP CBasicBnd::Unadvise(DWORD dwConnection) { return E_FAIL; } STDMETHODIMP CBasicBnd::EnumAdvise(LPENUMSTATDATA FAR* ppenumAdvise) { return E_FAIL; } STDMETHODIMP CBasicBnd::GetMiscStatus(DWORD dwAspect, DWORD FAR* pdwStatus) { return E_FAIL; } STDMETHODIMP CBasicBnd::SetColorScheme(LPLOGPALETTE lpLogpal) { return E_FAIL; } //+------------------------------------------------------------------- // // Interface: IParseDisplayName // // Synopsis: IParseDisplayName interface methods // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::ParseDisplayName( LPBC pbc, LPOLESTR lpszDisplayName, ULONG FAR* pchEaten, LPMONIKER FAR* ppmkOut) { *pchEaten = olestrlen(lpszDisplayName); return CreateItemMoniker(OLESTR("\\"), lpszDisplayName, ppmkOut); } //+------------------------------------------------------------------- // // Interface: IOleContainer // // Synopsis: IOleContainer interface methods // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::EnumObjects( DWORD grfFlags, LPENUMUNKNOWN FAR* ppenumUnknown) { return E_FAIL; } STDMETHODIMP CBasicBnd::LockContainer(BOOL fLock) { return E_FAIL; } //+------------------------------------------------------------------- // // Interface: IOleItemContainer // // Synopsis: IOleItemContainer interface methods // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::GetObject( LPOLESTR lpszItem, DWORD dwSpeedNeeded, LPBINDCTX pbc, REFIID riid, LPVOID FAR* ppvObject) { IStorage *psStorage; IOleObject *poo; IUnknown *punk; if (olestrcmp(lpszItem, OLESTR("1")) == 0) { psStorage = _psStg1; } else if (olestrcmp(lpszItem, OLESTR("2")) == 0) { psStorage = _psStg2; } else { return E_FAIL; } IOleClientSite * pocsObjCliSite; HRESULT hresult = QueryInterface(IID_IOleClientSite, (void **) &pocsObjCliSite); // Call OleCreate to create our embedded object hresult = OleCreate( CLSID_TestEmbed, // Class ID of the object we are // creating IID_IOleObject, // Interface by which we want to talk // to the object OLERENDER_NONE, // We don't want to draw the object // when it is not active NULL, // Used if we do draw the object when // it is non-active pocsObjCliSite, // IOleClientSite the server will use psStorage, // IStorage the server will use (void **) &poo); // Pointer to the object Win4Assert(SUCCEEDED(hresult) && "CBasicBnd::GetObject OlCreate Failed!\n"); // Set the client site hresult = poo->SetClientSite(pocsObjCliSite); hresult = poo->QueryInterface(IID_IUnknown, (void **)&punk); Win4Assert(SUCCEEDED(hresult) && "CBasicBnd::GetObject QI to IUnknown failed!\n"); hresult = OleRun(punk); Win4Assert(SUCCEEDED(hresult) && "CBasicBnd::GetObject OleRun!\n"); punk->Release(); LPRECT lprPosRect = (LPRECT) new RECT; hresult = poo->DoVerb( OLEIVERB_SHOW, // Verb we are invoking NULL, // MSG that causes us to do this verb pocsObjCliSite, // Client site of this object 0, // Reserved - definitive value? 0, // hwndParent - ??? lprPosRect); // lprcPosRect - rectangle wrt hwndParent Win4Assert(SUCCEEDED(hresult) && "CBasicBnd::GetObject DoVerb failed!\n"); delete lprPosRect; pocsObjCliSite->Release(); *ppvObject = (void *) poo; return hresult; } STDMETHODIMP CBasicBnd::GetObjectStorage( LPOLESTR lpszItem, LPBINDCTX pbc, REFIID riid, LPVOID FAR* ppvStorage) { return E_FAIL; } STDMETHODIMP CBasicBnd::IsRunning(LPOLESTR lpszItem) { return E_FAIL; } CUnknownBasicBnd::CUnknownBasicBnd(IUnknown *punk) : _pbasicbnd(NULL), _cRefs(1) { if (punk == NULL) { punk = (IUnknown *) this; } // BUGBUG: No error checking! _pbasicbnd = new CBasicBnd(punk); g_UseCount++; } CUnknownBasicBnd::~CUnknownBasicBnd(void) { g_UseCount--; delete _pbasicbnd; } //+------------------------------------------------------------------- // // Member: CUnknownBasicBnd::QueryInterface // // Returns: S_OK // // History: 21-Nov-92 SarahJ Created // //-------------------------------------------------------------------- STDMETHODIMP CUnknownBasicBnd::QueryInterface( REFIID iid, void **ppiuk) { if (IsEqualIID(iid, IID_IUnknown)) { *ppiuk = (IUnknown *) this; } else if (IsEqualIID(iid, IID_IOleClientSite)) { *ppiuk = (IOleClientSite *) _pbasicbnd; } else if (IsEqualIID(iid, IID_IPersistFile) || IsEqualIID(iid, IID_IPersist)) { *ppiuk = (IPersistFile *) _pbasicbnd; } else if (IsEqualIID(iid, IID_IOleObject)) { *ppiuk = (IOleObject *) _pbasicbnd; } else if (IsEqualIID(iid, IID_IOleItemContainer)) { *ppiuk = (IOleItemContainer *)_pbasicbnd; } else if (IsEqualIID(iid, IID_IOleContainer)) { *ppiuk = (IOleContainer *)_pbasicbnd; } else if (IsEqualIID(iid, IID_IParseDisplayName)) { *ppiuk = (IParseDisplayName *)_pbasicbnd; } else { *ppiuk = NULL; return E_NOINTERFACE; } _pbasicbnd->AddRef(); return S_OK; } STDMETHODIMP_(ULONG) CUnknownBasicBnd::AddRef(void) { return ++_cRefs; } STDMETHODIMP_(ULONG) CUnknownBasicBnd::Release(void) { if (--_cRefs == 0) { delete this; return 0; } return _cRefs; } //+------------------------------------------------------------------- // Method: CBasicBnd::SaveObject // // Synopsis: See spec 2.00.09 p107. This object should be saved. // // Returns: Should always return S_OK. // // History: 04-Dec-92 DeanE Created //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::SaveObject(void) { // BUGBUG - NYI // Returning S_OK tells OLE that we actually saved this object return(S_OK); } //+------------------------------------------------------------------- // Method: CBasicBnd::GetContainer // // Synopsis: See spec 2.00.09 p108. Return the container in which // this object is found. // // Returns: Should return S_OK. // // History: 04-Dec-92 DeanE Created //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::GetContainer(LPOLECONTAINER FAR *ppContainer) { return QueryInterface(IID_IOleContainer, (void **) ppContainer); } //+------------------------------------------------------------------- // Method: CBasicBnd::ShowObject // // Synopsis: See spec 2.00.09 p109. Server for this object is asking // us to display it. Caller should not assume we have // actually worked, but we return S_OK either way. Great! // // Returns: S_OK whether we work or not... // // History: 04-Dec-92 DeanE Created //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::ShowObject(void) { return(S_OK); } //+------------------------------------------------------------------- // Method: CBasicBnd::OnShowWindow // // Synopsis: ??? // // Parameters: [fShow] - // // Returns: S_OK? // // History: 16-Dec-92 DeanE Created //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::OnShowWindow(BOOL fShow) { return(S_OK); } //+------------------------------------------------------------------- // Method: CBasicBnd::RequestNewObjectLayout // // Synopsis: ??? // // Parameters: [fShow] - // // Returns: S_OK? // // History: 16-Dec-92 DeanE Created //-------------------------------------------------------------------- STDMETHODIMP CBasicBnd::RequestNewObjectLayout(void) { return(S_OK); }