windows-nt/Source/XPSP1/NT/admin/activec/test/snapins/sample/ocxcaching.cpp
2020-09-26 16:20:57 +08:00

401 lines
10 KiB
C++

//+-------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1994 - 1999
//
// File: ocxcaching.cpp
//
// Contents: Classes that implement OCX caching snapin using the framework.
//
//--------------------------------------------------------------------
#include "stdafx.hxx"
//+-------------------------------------------------------------------
//
// Member: COCXCachingSnapinRootItem::ScInit
//
// Synopsis: Called immeadiately after the item is created to init
// displayname, icon index etc...
//
// Arguments: [CBaseSnapin] -
// [CColumnInfoEx] - Any columns to be displayed for this item.
// [INT] - # of columns
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXCachingSnapinRootItem::ScInit(CBaseSnapin *pSnapin, CColumnInfoEx *pcolinfoex, INT ccolinfoex, BOOL fIsRoot)
{
DECLARE_SC(sc, _T("COCXCachingSnapinRootItem::ScInit"));
sc = CBaseSnapinItem::ScInit(pSnapin, pcolinfoex, ccolinfoex, fIsRoot);
if (sc)
return sc;
// Init following
// a. Icon index.
// b. Load display name.
m_uIconIndex = 3; // use an enum instead of 3
m_strDisplayName.LoadString(_Module.GetResourceInstance(), IDS_OCXCachingRoot);
return sc;
}
//+-------------------------------------------------------------------
//
// Member: COCXCachingSnapinRootItem::ScGetField
//
// Synopsis: Get the string representation for given field to display
// it in result pane.
//
// Arguments: [DAT] - The column requested (this is an enumeration).
// [tstring] - Out string.
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXCachingSnapinRootItem::ScGetField (DAT dat, tstring& strField)
{
DECLARE_SC(sc, _T("COCXCachingSnapinRootItem::ScGetField"));
switch(dat)
{
case datString1:
strField = _T("OCX Caching Snapin Root Node");
break;
default:
E_INVALIDARG;
break;
}
return (sc);
}
//+-------------------------------------------------------------------
//
// Member: COCXCachingSnapinRootItem::ScCreateChildren
//
// Synopsis: Create any children (nodes & leaf items) for this item.
//
// Arguments: None
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXCachingSnapinRootItem::ScCreateChildren ()
{
DECLARE_SC(sc, _T("COCXCachingSnapinRootItem::ScCreateChildren"));
COCXContainer * pitemChild = NULL;
COCXContainer * pitemPrevious = NULL;
// Create the 1st child node for calendar OCX.
sc = COCXContainer::ScCreateLVContainer(this, pitemPrevious, &pitemChild, FALSE); // Why FALSE???
if (sc)
return sc;
pitemChild->SetOCXGUID(TEXT("{8E27C92B-1264-101C-8A2F-040224009C02}"));
pitemPrevious = pitemChild;
// Create the 2nd child node for calendar OCX.
sc = COCXContainer::ScCreateLVContainer(this, pitemPrevious, &pitemChild, FALSE); // Why FALSE???
if (sc)
return sc;
pitemChild->SetOCXGUID(TEXT("{2179C5D3-EBFF-11CF-B6FD-00AA00B4E220}"));
pitemPrevious = pitemChild;
return (sc);
}
// Initialize context menu structures. Let us have one item for demonstration.
SnapinMenuItem COCXCachingSnapinRootItem::s_rgmenuitem[] =
{
{IDS_EnableOCXCaching, IDS_EnableOCXCaching, IDS_EnableOCXCaching, CCM_INSERTIONPOINTID_PRIMARY_TOP, NULL, dwMenuAlwaysEnable, dwMenuNeverGray, 0},
};
INT COCXCachingSnapinRootItem::s_cmenuitem = CMENUITEM(s_rgmenuitem);
// -----------------------------------------------------------------------------
SnapinMenuItem *COCXCachingSnapinRootItem::Pmenuitem(void)
{
return s_rgmenuitem;
}
// -----------------------------------------------------------------------------
INT COCXCachingSnapinRootItem::CMenuItem(void)
{
return s_cmenuitem;
}
//+-------------------------------------------------------------------
//
// Member: COCXCachingSnapinRootItem::ScCommand
//
// Synopsis:
//
// Arguments:
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXCachingSnapinRootItem::ScCommand (long nCommandID, CComponent *pComponent)
{
DECLARE_SC(sc, _T("COCXCachingSnapinRootItem::ScCommand"));
COCXCachingSnapin *pSnapin = dynamic_cast<COCXCachingSnapin*>(Psnapin());
if (!pSnapin)
return sc;
switch(nCommandID)
{
case IDS_EnableOCXCaching:
{
bool bCachingEnabled = pSnapin->FCacheOCX();
pSnapin->SetCacheOCX(! bCachingEnabled);
for (int i = 0; i < CMenuItem(); ++i)
{
if (s_rgmenuitem[i].lCommandID == IDS_EnableOCXCaching)
s_rgmenuitem[i].dwFlagsChecked = (!bCachingEnabled);
}
}
break;
default:
sc = E_INVALIDARG;
break;
}
return (sc);
}
//+-------------------------------------------------------------------
//
// Member: COCXContainer::ScInit
//
// Synopsis: Called immeadiately after the item is created to init
// displayname, icon index etc...
//
// Arguments: [CBaseSnapin] -
// [CColumnInfoEx] - Any columns to be displayed for this item.
// [INT] - # of columns
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXContainer::ScInit(CBaseSnapin *pSnapin, CColumnInfoEx *pcolinfoex, INT ccolinfoex, BOOL fIsRoot)
{
DECLARE_SC(sc, _T("COCXContainer::ScInit"));
sc = CBaseSnapinItem::ScInit(pSnapin, pcolinfoex, ccolinfoex, fIsRoot);
if (sc)
return sc;
// Init following
// a. Icon index.
// b. Load display name.
m_uIconIndex = 4; // use an enum instead of 4
m_strDisplayName.LoadString(_Module.GetResourceInstance(), IDS_OCXContainer);
return sc;
}
BOOL COCXContainer::FCacheOCX()
{
COCXCachingSnapin *pSnapin = dynamic_cast<COCXCachingSnapin*>(Psnapin());
if (!pSnapin)
return FALSE;
return pSnapin->FCacheOCX();
}
//+-------------------------------------------------------------------
//
// Member: COCXContainer::ScGetField
//
// Synopsis: Get the string representation for given field to display
// it in result pane.
//
// Arguments: [DAT] - The column requested (this is an enumeration).
// [tstring] - Out string.
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXContainer::ScGetField (DAT dat, tstring& strField)
{
DECLARE_SC(sc, _T("COCXContainer::ScGetField"));
switch(dat)
{
case datString1:
strField = _T("OCX Container");
break;
default:
E_INVALIDARG;
break;
}
return (sc);
}
//+-------------------------------------------------------------------
//
// Member: COCXContainer::ScInitOCX
//
// Synopsis: OCX is created & attached to host. Now MMC has asked
// us to initialize the OCX.
//
// Arguments: [pUnkOCX] - IUnknown of the OCX.
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXContainer::ScInitOCX (LPUNKNOWN pUnkOCX, IConsole* pConsole)
{
DECLARE_SC(sc, _T("COCXContainer::ScInitOCX"));
sc = ScCheckPointers(pUnkOCX, pConsole);
if (sc)
return sc;
// Store the cached OCX ptr to provide it later in GetResultViewType2.
if (FCacheOCX())
m_mapOCXs.insert(CachedOCXs::value_type(pConsole, pUnkOCX));
CComQIPtr <IPersistStreamInit> spPerStm(pUnkOCX);
if (spPerStm)
spPerStm->InitNew();
return (sc);
}
IUnknown* COCXContainer::GetCachedOCX(IConsole* pConsole)
{
CachedOCXs::iterator it = m_mapOCXs.find(pConsole);
if (it != m_mapOCXs.end())
return it->second;
return NULL;
}
//+-------------------------------------------------------------------
//
// Member: COCXContainer::ScCreateChildren
//
// Synopsis: Create any children (nodes & leaf items) for this item.
//
// Arguments: None
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXContainer::ScCreateChildren ()
{
DECLARE_SC(sc, _T("COCXContainer::ScCreateChildren"));
return (sc);
}
//+-------------------------------------------------------------------
//
// Member: COCXContainer::ScCreateLVContainer
//
// Synopsis: Do we really need this method?
//
// Arguments:
//
// Returns: SC
//
//--------------------------------------------------------------------
SC COCXContainer::ScCreateLVContainer(CBaseSnapinItem *pitemParent, CBaseSnapinItem *pitemPrevious, COCXContainer ** ppitem, BOOL fNew)
{
DECLARE_SC(sc, _T("COCXCachingSnapinRootItem::ScCreateLVContainer"));
t_item * pitem = NULL;
*ppitem = NULL;
// What to do here?
sc = ::ScCreateItem(pitemParent, pitemPrevious, &pitem, fNew);
if (sc)
return sc;
*ppitem = pitem;
return (sc);
}
//-------------------------------------------------------------------------------------
// class COCXCachingSnapin
#pragma BEGIN_CODESPACE_DATA
SNR COCXCachingSnapin::s_rgsnr[] =
{
SNR(&nodetypeOCXCachingRoot, snrEnumSP ), // Standalone snapin.
SNR(&nodetypeOCXCachingContainer1, snrEnumSP ), // enumerates this node in the scope pane
SNR(&nodetypeOCXCachingContainer2, snrEnumSP ), // enumerates this node in the scope pane
};
LONG COCXCachingSnapin::s_rgiconid[] = {3};
LONG COCXCachingSnapin::s_iconidStatic = 2;
CColumnInfoEx COCXCachingSnapin::s_colinfo[] =
{
CColumnInfoEx(_T("Column Name0"), LVCFMT_LEFT, 180, datString1),
CColumnInfoEx(_T("Column Name1"), LVCFMT_LEFT, 180, datString2),
CColumnInfoEx(_T("Column Name2"), LVCFMT_LEFT, 180, datString3),
};
INT COCXCachingSnapin::s_ccolinfo = sizeof(s_colinfo) / sizeof(CColumnInfoEx);
INT COCXCachingSnapin::s_colwidths[1];
#pragma END_CODESPACE_DATA
// include members needed for every snapin.
SNAPIN_DEFINE( COCXCachingSnapin);
/* COCXCachingSnapin::COCXCachingSnapin
*
* PURPOSE: Constructor
*
* PARAMETERS: None
*
*/
COCXCachingSnapin::COCXCachingSnapin()
{
m_pstrDisplayName = new tstring();
m_bCacheOCX = false;
*m_pstrDisplayName = _T("OCX Caching Snapin Root");
}
/* COCXCachingSnapin::~COCXCachingSnapin
*
* PURPOSE: Destructor
*
* PARAMETERS: None
*
*/
COCXCachingSnapin::~COCXCachingSnapin()
{
delete m_pstrDisplayName;
}