Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

485 lines
13 KiB

#include "stdafx.h"
#include "DomMigSI.h"
#include "DomMigr.h"
#include "Globals.h"
#include "MultiSel.h"
UINT CMultiSelectItemDataObject::s_cfMsObjTypes = 0; // MultiSelect clipformat
UINT CMultiSelectItemDataObject::s_cfMsDataObjs = 0; // MultiSelect clipformat
CMultiSelectItemDataObject::CMultiSelectItemDataObject()
{
m_objectDataArray.RemoveAll();
m_ddStatusArray.RemoveAll();
m_pParentItem = NULL;
s_cfMsObjTypes = RegisterClipboardFormat(CCF_OBJECT_TYPES_IN_MULTI_SELECT);
s_cfMsDataObjs = RegisterClipboardFormat(CCF_MULTI_SELECT_SNAPINS);
m_bHasGroup = false;
}
CMultiSelectItemDataObject::~CMultiSelectItemDataObject()
{
for ( int i = 0; i < m_objectDataArray.GetSize(); i++ )
{
delete (CObjectData *)(m_objectDataArray[i]);
}
}
DWORD CMultiSelectItemDataObject::GetItemCount()
{
return (DWORD)m_objectDataArray.GetSize();
}
HRESULT CMultiSelectItemDataObject::AddMultiSelectItem( CObjectData *pDataObject )
{
m_objectDataArray.Add(pDataObject);
m_ddStatusArray.Add(DD_NONE);
return S_OK;
}
void CMultiSelectItemDataObject::SetParentItem( CSnapInItem *pParentItem )
{
m_pParentItem = pParentItem;
}
CSnapInItem *CMultiSelectItemDataObject::GetParentItem()
{
return m_pParentItem;
}
void CMultiSelectItemDataObject::GetParentGuid(GUID *guid)
{
memcpy( guid, &m_parentGuid, sizeof( GUID ) );
}
void CMultiSelectItemDataObject::SetParentGuid(GUID *guid)
{
memcpy( &m_parentGuid, guid, sizeof( GUID ) );
}
CSnapInItem *CMultiSelectItemDataObject::GetSnapInItem(DWORD index)
{
if ( GetItemCount() <= index )
return NULL;
return ((CObjectData *)m_objectDataArray[index])->m_pItem;
}
BYTE CMultiSelectItemDataObject::GetDDStatus(DWORD index)
{
if ( GetItemCount() <= index )
return DD_NONE;
return m_ddStatusArray[index];
}
void CMultiSelectItemDataObject::SetDDStatus(DWORD index, BYTE status)
{
if ( GetItemCount() <= index )
return;
m_ddStatusArray[index] = status;
}
STDMETHODIMP CMultiSelectItemDataObject::GetDataHere(FORMATETC *pformatetc, STGMEDIUM *pmedium)
{
if (( pmedium == NULL ) || ( pformatetc == NULL ))
return E_POINTER;
pmedium->pUnkForRelease = NULL; // by OLE spec
HRESULT hr = DV_E_TYMED;
// Make sure the type medium is HGLOBAL
if (pmedium->tymed == TYMED_HGLOBAL )
{
if ( s_cfMsObjTypes == pformatetc->cfFormat )
{
// Create the stream on the hGlobal passed in
CComPtr<IStream> spStream;
hr = CreateStreamOnHGlobal(pmedium->hGlobal, FALSE, &spStream);
if (SUCCEEDED(hr))
{
hr = DV_E_CLIPFORMAT;
if (pformatetc->cfFormat == s_cfMsObjTypes)
{
DWORD objCount = (DWORD)m_objectDataArray.GetSize();
spStream->Write( &objCount, sizeof(DWORD), NULL );
for ( DWORD i = 0; i < objCount; i++ )
{
CSnapInItem* pItem;
pItem = (CSnapInItem*)((CObjectData*)m_objectDataArray[i])->m_pItem;
pItem->FillData( pItem->m_CCF_NODETYPE, spStream);
}
}
}
}
}
return hr;
}
STDMETHODIMP CMultiSelectItemDataObject::GetData
(
FORMATETC *pformatetc, // [in] Pointer to the FORMATETC structure
STGMEDIUM *pmedium // [out] Pointer to the STGMEDIUM structure
)
{
HRESULT hr = DATA_E_FORMATETC;
if (( pmedium == NULL ) || ( pformatetc == NULL ))
return E_POINTER;
if( s_cfMsObjTypes == pformatetc->cfFormat )
{
HGLOBAL hMem = NULL;
DWORD objCount = GetItemCount();
ATLTRACE( L"CMultiSelectItemDataObject::GetData - asked for MultiSelect Object \n" );
hMem = ::GlobalAlloc(GMEM_SHARE | GMEM_MOVEABLE, sizeof(GUID)*objCount + sizeof(DWORD));
if( NULL == hMem )
hr = STG_E_MEDIUMFULL;
else
{
CComPtr<IStream> spStream;
hr = CreateStreamOnHGlobal(hMem, FALSE, &spStream);
if (SUCCEEDED(hr))
{
spStream->Write( &objCount, sizeof(DWORD), NULL );
for ( DWORD i = 0; i < objCount; i++ )
{
CSnapInItem* pItem;
pItem = (CSnapInItem*)((CObjectData*)m_objectDataArray[i])->m_pItem;
pItem->FillData( pItem->m_CCF_NODETYPE, spStream);
}
pmedium->hGlobal = hMem; // StgMedium variables
pmedium->tymed = TYMED_HGLOBAL;
pmedium->pUnkForRelease = NULL;
}
}
}
ATLTRACE( L"CMultiSelectItemDataObject::GetData returned 0x%X \n", hr );
return hr;
} // end GetData()
STDMETHODIMP CMultiSelectItemDataObject::QueryGetData(FORMATETC *pformatetc)
{
HRESULT hr = S_FALSE;
if ( pformatetc == NULL )
return E_POINTER;
if( (0 != s_cfMsObjTypes) && (s_cfMsObjTypes == pformatetc->cfFormat) )
{
hr = S_OK;
}
ATLTRACE( L"CMultiSelectItemDataObject::QueryGetData() called with ClipFormat 0x%X \n", pformatetc->cfFormat );
return hr;
}
HRESULT CMultiSelectItemDataObject::OnNotify(CDomMigratorComponent *pComponent, MMC_NOTIFY_TYPE event, long arg, long param )
{
HRESULT hr = E_NOTIMPL;
DWORD objCount = (DWORD)m_objectDataArray.GetSize();
CComPtr<IConsole> spConsole;
if ( 0 == objCount )
return hr;
if ( pComponent == NULL )
return E_POINTER;
spConsole = ((CDomMigratorComponent*)pComponent)->m_spConsole;
switch (event)
{
case MMCN_SELECT:
{
bool bSelect = (HIWORD(arg) != 0 );
if ( bSelect )
{
hr = OnSelect(spConsole);
}
break;
}
case MMCN_DELETE:
//hr = OnDelete(spConsole);
break;
case MMCN_CUTORMOVE:
hr = OnCutOrMove(spConsole);
break;
default:
break;
}
return hr;
}
HRESULT CMultiSelectItemDataObject::OnCutOrMove( IConsole* pConsole )
{
HRESULT hr = S_OK;//E_NOTIMPL;
DWORD objCount = (DWORD)m_objectDataArray.GetSize();
if ( 0 == objCount )
goto ret_exit;
if ( pConsole == NULL )
return E_POINTER;
GUID itemParentGuid;
GetParentGuid( &itemParentGuid );
ret_exit:
return hr;
}
HRESULT CMultiSelectItemDataObject::OnSelect(IConsole *pConsole)
{
HRESULT hr = S_OK;//E_NOTIMPL;
DWORD objCount = (DWORD)m_objectDataArray.GetSize();
if ( 0 == objCount )
goto ret_exit;
if ( pConsole == NULL )
return E_POINTER;
GUID itemParentGuid;
GetParentGuid( &itemParentGuid );
hr = OnSelectAllowDragDrop( pConsole );
ret_exit:
return hr;
}
HRESULT CMultiSelectItemDataObject::OnSelectAllowDragDrop(IConsole *pConsole)
{
HRESULT hr = S_OK;
CComPtr<IConsoleVerb> pConsoleVerb;
if ( pConsole == NULL )
return E_POINTER;
hr = pConsole->QueryConsoleVerb( &pConsoleVerb );
if ( FAILED( hr ) )
goto ret_exit;
//
// Enable the delete verb.
//
hr = pConsoleVerb->SetVerbState( MMC_VERB_DELETE, ENABLED, TRUE );
if ( FAILED( hr ) )
goto ret_exit;
hr = pConsoleVerb->SetVerbState( MMC_VERB_DELETE, HIDDEN, TRUE );
if ( FAILED( hr ) )
goto ret_exit;
//
// Enable the copy verb.
//
hr = pConsoleVerb->SetVerbState( MMC_VERB_COPY, ENABLED, TRUE );
if ( FAILED( hr ) )
goto ret_exit;
hr = pConsoleVerb->SetVerbState( MMC_VERB_COPY, HIDDEN, TRUE );
if ( FAILED( hr ) )
goto ret_exit;
ret_exit:
return hr;
}
SMMCDataObjects *CMultiSelectItemDataObject::ExtractMSDataObjects( LPDATAOBJECT lpDataObject )
{
HRESULT hr = S_OK;
SMMCDataObjects *p = NULL;
STGMEDIUM stgmedium = { TYMED_HGLOBAL, NULL };
FORMATETC formatetc = { (CLIPFORMAT)s_cfMsDataObjs, NULL,
DVASPECT_CONTENT, -1, TYMED_HGLOBAL
};
hr = lpDataObject->GetData(&formatetc, &stgmedium);
if (FAILED(hr))
goto ret_exit;
p = reinterpret_cast<SMMCDataObjects*>(stgmedium.hGlobal);
//ReleaseStgMedium(&stgmedium);
ret_exit:
return p;
}
HRESULT CMultiSelectItemDataObject::Command(long lCommandID,
CSnapInObjectRootBase* pObj,
DATA_OBJECT_TYPES type)
{
bool bHandled = false;
return ProcessCommand(lCommandID, bHandled, pObj, type);
}
HRESULT CMultiSelectItemDataObject::AddMenuItems(LPCONTEXTMENUCALLBACK piCallback,
long *pInsertionAllowed,
DATA_OBJECT_TYPES type)
{
if ( m_bHasGroup )
return S_OK;
if ( piCallback == NULL )
return E_POINTER;
//ATLTRACE2(atlTraceSnapin, 0, _T("CSnapInItemImpl::AddMenuItems\n"));
//T* pT = static_cast<T*>(this);
bool bIsExtension = false;
if (!bIsExtension)
/*pT->*/SetMenuInsertionFlags(true, pInsertionAllowed);
UINT menuID = /*pT->*/GetMenuID();
if (menuID == 0)
return S_OK;
HMENU hMenu = LoadMenu(_Module.GetResourceInstance(), MAKEINTRESOURCE(menuID));
long insertionID;
if (hMenu)
{
for (int i = 0; 1; i++)
{
HMENU hSubMenu = GetSubMenu(hMenu, i);
if (hSubMenu == NULL)
break;
MENUITEMINFO menuItemInfo;
memset(&menuItemInfo, 0, sizeof(menuItemInfo));
menuItemInfo.cbSize = sizeof(menuItemInfo);
switch (i)
{
case 0:
if (! (*pInsertionAllowed & CCM_INSERTIONALLOWED_TOP) )
continue;
insertionID = CCM_INSERTIONPOINTID_PRIMARY_TOP;
break;
case 1:
if (! (*pInsertionAllowed & CCM_INSERTIONALLOWED_NEW) )
continue;
if (bIsExtension)
insertionID = CCM_INSERTIONPOINTID_3RDPARTY_NEW;
else
insertionID = CCM_INSERTIONPOINTID_PRIMARY_NEW;
break;
case 2:;
if (! (*pInsertionAllowed & CCM_INSERTIONALLOWED_TASK) )
continue;
if (bIsExtension)
insertionID = CCM_INSERTIONPOINTID_3RDPARTY_TASK;
else
insertionID = CCM_INSERTIONPOINTID_PRIMARY_TASK;
break;
case 3:;
if (! (*pInsertionAllowed & CCM_INSERTIONALLOWED_VIEW) )
continue;
insertionID = CCM_INSERTIONPOINTID_PRIMARY_VIEW;
break;
default:
{
insertionID = 0;
continue;
}
break;
}
menuItemInfo.fMask = MIIM_TYPE | MIIM_STATE | MIIM_ID;
menuItemInfo.fType = MFT_STRING;
TCHAR szMenuText[128];
for (int j = 0; 1; j++)
{
menuItemInfo.fMask = MIIM_TYPE | MIIM_STATE | MIIM_ID;
menuItemInfo.fType = MFT_STRING;
menuItemInfo.cch = 128;
menuItemInfo.dwTypeData = szMenuText;
TCHAR szStatusBar[256];
if (!GetMenuItemInfo(hSubMenu, j, TRUE, &menuItemInfo))
break;
if (menuItemInfo.fType != MFT_STRING)
continue;
/*pT->*/UpdateMenuState(menuItemInfo.wID, szMenuText, &menuItemInfo.fState);
LoadString(_Module.GetResourceInstance(), menuItemInfo.wID, szStatusBar, 256);
OLECHAR wszStatusBar[256];
OLECHAR wszMenuText[128];
USES_CONVERSION;
ocscpy(wszMenuText, T2OLE(szMenuText));
ocscpy(wszStatusBar, T2OLE(szStatusBar));
CONTEXTMENUITEM contextMenuItem;
contextMenuItem.strName = wszMenuText;
contextMenuItem.strStatusBarText = wszStatusBar;
contextMenuItem.lCommandID = menuItemInfo.wID;
contextMenuItem.lInsertionPointID = insertionID;
contextMenuItem.fFlags = menuItemInfo.fState;
contextMenuItem.fSpecialFlags = 0;
HRESULT hr = piCallback->AddItem(&contextMenuItem);
ATLASSERT(SUCCEEDED(hr));
}
}
DestroyMenu(hMenu);
}
if (!bIsExtension)
/*pT->*/SetMenuInsertionFlags(true, pInsertionAllowed);
return S_OK;
}
HRESULT CMultiSelectItemDataObject::OnVersionInfo(bool &bHandled, CSnapInObjectRootBase* pObj)
{
HRESULT hr=S_OK;
/* CVersionInfoDlg dlg;
dlg.DoModal();
*/ hr = S_OK;
return hr;
}
HRESULT CMultiSelectItemDataObject::OnMoveMultipleObjs(bool &bHandled, CSnapInObjectRootBase* pObj)
{
HRESULT hr = S_OK;
CComPtr<IConsole> pConsole;
hr = GetConsoleFromCSnapInObjectRootBase(pObj, &pConsole);
if (FAILED(hr))
return hr;
return hr;
}