//==============================================================; // // This source code is only intended as a supplement to existing Microsoft documentation. // // // // // THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY // KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE // IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR // PURPOSE. // // Copyright (C) 1999 Microsoft Corporation. All Rights Reserved. // // // //==============================================================; #include "Comp.h" #include "CompData.h" #include "DataObj.h" #include "resource.h" #include CComponentData::CComponentData() : m_cref(0), m_ipConsoleNameSpace(NULL), m_ipConsole(NULL) { OBJECT_CREATED m_pStaticNode = new CStaticNode; } CComponentData::~CComponentData() { if (m_pStaticNode) { delete m_pStaticNode; } OBJECT_DESTROYED } /////////////////////// // IUnknown implementation /////////////////////// STDMETHODIMP CComponentData::QueryInterface(REFIID riid, LPVOID *ppv) { if (!ppv) return E_FAIL; *ppv = NULL; if (IsEqualIID(riid, IID_IUnknown)) *ppv = static_cast(this); else if (IsEqualIID(riid, IID_IComponentData)) *ppv = static_cast(this); else if (IsEqualIID(riid, IID_IPersistStream)) *ppv = static_cast(this); if (*ppv) { reinterpret_cast(*ppv)->AddRef(); return S_OK; } return E_NOINTERFACE; } STDMETHODIMP_(ULONG) CComponentData::AddRef() { return InterlockedIncrement((LONG *)&m_cref); } STDMETHODIMP_(ULONG) CComponentData::Release() { if (InterlockedDecrement((LONG *)&m_cref) == 0) { // we need to decrement our object count in the DLL delete this; return 0; } return m_cref; } /////////////////////////////// // Interface IComponentData /////////////////////////////// HRESULT CComponentData::Initialize( /* [in] */ LPUNKNOWN pUnknown) { HRESULT hr = S_FALSE; // // Get pointer to namespace interface // First try to get pointer to IConsoleNameSpace2. If that fails, we are in // MMC1.0, so get pointer to IConsoleNameSpace instead // hr = pUnknown->QueryInterface(IID_IConsoleNameSpace2, (void **)&m_ipConsoleNameSpace); if (S_OK == hr) { //We are in MMC 1.1 or higher. QI for IConsole2 hr = pUnknown->QueryInterface(IID_IConsole2, (void **)&m_ipConsole); } else //We are in MMC 1.0 { hr = pUnknown->QueryInterface(IID_IConsoleNameSpace, (void **)&m_ipConsoleNameSpace); if (FAILED(hr)) return hr; hr = pUnknown->QueryInterface(IID_IConsole, (void **)&m_ipConsole); } return hr; } HRESULT CComponentData::CreateComponent( /* [out] */ LPCOMPONENT __RPC_FAR *ppComponent) { *ppComponent = NULL; CComponent *pComponent = new CComponent(this); if (NULL == pComponent) return E_OUTOFMEMORY; return pComponent->QueryInterface(IID_IComponent, (void **)ppComponent); } HRESULT CComponentData::Notify( /* [in] */ LPDATAOBJECT lpDataObject, /* [in] */ MMC_NOTIFY_TYPE event, /* [in] */ LPARAM arg, /* [in] */ LPARAM param) { MMCN_Crack(TRUE, lpDataObject, this, NULL, event, arg, param); //Notify doesn't handle any notifications from MMC, so return E_NOTIMPL return E_NOTIMPL; } HRESULT CComponentData::Destroy( void) { // Free interfaces if (m_ipConsoleNameSpace) { m_ipConsoleNameSpace->Release(); m_ipConsoleNameSpace = NULL; } if (m_ipConsole) { m_ipConsole->Release(); m_ipConsole = NULL; } return S_OK; } HRESULT CComponentData::QueryDataObject( /* [in] */ MMC_COOKIE cookie, /* [in] */ DATA_OBJECT_TYPES type, /* [out] */ LPDATAOBJECT *ppDataObject) { CDataObject *pObj = NULL; if (cookie == 0) pObj = new CDataObject((MMC_COOKIE)m_pStaticNode, type); else pObj = new CDataObject(cookie, type); if (!pObj) return E_OUTOFMEMORY; pObj->QueryInterface(IID_IDataObject, (void **)ppDataObject); return S_OK; } HRESULT CComponentData::GetDisplayInfo( /* [out][in] */ SCOPEDATAITEM *pScopeDataItem) { HRESULT hr = S_FALSE; // if they are asking for the SDI_STR we have one of those to give if (pScopeDataItem->lParam) { CDelegationBase *base = (CDelegationBase *)pScopeDataItem->lParam; if (pScopeDataItem->mask & SDI_STR) { LPCTSTR pszT = base->GetDisplayName(); MAKE_WIDEPTR_FROMTSTR_ALLOC(pszW, pszT); pScopeDataItem->displayname = pszW; } if (pScopeDataItem->mask & SDI_IMAGE) { pScopeDataItem->nImage = base->GetBitmapIndex(); } } return hr; } HRESULT CComponentData::CompareObjects( /* [in] */ LPDATAOBJECT lpDataObjectA, /* [in] */ LPDATAOBJECT lpDataObjectB) { CDelegationBase *baseA = GetOurDataObject(lpDataObjectA)->GetBaseNodeObject(); CDelegationBase *baseB = GetOurDataObject(lpDataObjectB)->GetBaseNodeObject(); // compare the object pointers if (baseA->GetCookie() == baseB->GetCookie()) return S_OK; return S_FALSE; } /////////////////////////////// // Interface IPersistStream /////////////////////////////// HRESULT CComponentData::GetClassID( /* [out] */ CLSID __RPC_FAR *pClassID) { *pClassID = m_pStaticNode->getNodeType(); return S_OK; } HRESULT CComponentData::IsDirty( void) { return m_pStaticNode->isDirty() == true ? S_OK : S_FALSE; } HRESULT CComponentData::Load( /* [unique][in] */ IStream __RPC_FAR *pStm) { void *snapInData = m_pStaticNode->getData(); ULONG dataSize = m_pStaticNode->getDataSize(); return pStm->Read(snapInData, dataSize, NULL); } HRESULT CComponentData::Save( /* [unique][in] */ IStream __RPC_FAR *pStm, /* [in] */ BOOL fClearDirty) { void *snapInData = m_pStaticNode->getData(); ULONG dataSize = m_pStaticNode->getDataSize(); if (fClearDirty) m_pStaticNode->clearDirty(); return pStm->Write(snapInData, dataSize, NULL); } HRESULT CComponentData::GetSizeMax( /* [out] */ ULARGE_INTEGER __RPC_FAR *pcbSize) { return m_pStaticNode->getDataSize(); }