|
|
#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 ( NULL == pmedium ) 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( 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( (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;
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;
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;
GUID itemParentGuid; GetParentGuid( &itemParentGuid ); hr = OnSelectAllowDragDrop( pConsole ); ret_exit: return hr; }
HRESULT CMultiSelectItemDataObject::OnSelectAllowDragDrop(IConsole *pConsole) { HRESULT hr = S_OK; CComPtr<IConsoleVerb> pConsoleVerb;
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; return ProcessCommand(lCommandID, bHandled, pObj, type); }
HRESULT CMultiSelectItemDataObject::AddMenuItems(LPCONTEXTMENUCALLBACK piCallback, long *pInsertionAllowed, DATA_OBJECT_TYPES type) { if ( m_bHasGroup ) return S_OK;
//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; }
|