//==============================================================; // // 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 "stdafx.h" #include #include #include #include "globals.h" static TCHAR *MMCN_CrackVerb(MMC_CONSOLE_VERB verb) { static TCHAR error[64]; switch (verb) { case MMC_VERB_NONE: return _T("NONE"); case MMC_VERB_OPEN: return _T("OPEN"); case MMC_VERB_COPY: return _T("COPY"); case MMC_VERB_PASTE: return _T("PASTE"); case MMC_VERB_DELETE: return _T("DELETE"); case MMC_VERB_PROPERTIES: return _T("PROPERTIES"); case MMC_VERB_RENAME: return _T("RENAME"); case MMC_VERB_REFRESH: return _T("REFRESH"); case MMC_VERB_PRINT: return _T("PRINT"); case MMC_VERB_CUT: return _T("CUT"); default: wsprintf(error, _T("Unknown verb id %d"), verb); return error; } } void MMCN_Crack(BOOL bComponentData, IDataObject *pDataObject, IComponentData *pCompData, IComponent *pComp, MMC_NOTIFY_TYPE event, LPARAM arg, LPARAM param) { #ifdef MMC_CRACK_MESSAGES TCHAR message[256] = {0}; if (bComponentData == TRUE) OutputDebugString(_T("IComponentData::Notify( ")); else OutputDebugString(_T("IComponent::Notify( ")); wsprintf(message, _T("DataObject: %08x, CompData: %08x, Comp: %08x ) - "), pDataObject, pCompData, pComp); OutputDebugString(message); switch (event) { case MMCN_ACTIVATE: wsprintf(message, _T("MMCN_ACTIVATE\n\tActivate: %d\n"), arg); break; case MMCN_ADD_IMAGES: wsprintf(message, _T("MMCN_ADD_IMAGES\n\tImage List: %08x\n\tScope Item: %08x\n"), arg, param); break; case MMCN_BTN_CLICK: wsprintf(message, _T("MMCN_BTN_CLICK\n\tVerb: %ws\n"), MMCN_CrackVerb((MMC_CONSOLE_VERB)param)); break; case MMCN_COLUMN_CLICK: wsprintf(message, _T("MMCN_COLUMN_CLICK\n\tColumn: %d\n\tSort Option: %d\n"), arg, param); break; case MMCN_COLUMNS_CHANGED: wsprintf(message, _T("MMCN_COLUMNS_CHANGED\n")); break; case MMCN_CONTEXTHELP: wsprintf(message, _T("MMCN_CONTEXTHELP\n")); break; case MMCN_CONTEXTMENU: wsprintf(message, _T("MMCN_CONTEXTMENU\n")); break; case MMCN_CUTORMOVE: wsprintf(message, _T("MMCN_CUTORMOVE\n")); break; case MMCN_DBLCLICK: wsprintf(message, _T("MMCN_DBLCLICK\n")); break; case MMCN_DELETE: wsprintf(message, _T("MMCN_DELETE\n")); break; case MMCN_DESELECT_ALL: wsprintf(message, _T("MMCN_DESELECT_ALL\n")); break; case MMCN_EXPAND: wsprintf(message, _T("MMCN_EXPAND\n\tExpand: %d\n\tScope Item: %08x\n"), arg, param); break; case MMCN_EXPANDSYNC: wsprintf(message, _T("MMCN_EXPANDSYNC\n")); break; case MMCN_FILTERBTN_CLICK: wsprintf(message, _T("MMCN_FILTERBTN_CLICK\n\tColumn: %d\n"), arg); break; case MMCN_FILTER_CHANGE: wsprintf(message, _T("MMCN_FILTER_CHANGE\n\tColumn: %d\n"), param); break; case MMCN_HELP: wsprintf(message, _T("MMCN_HELP\n")); break; case MMCN_INITOCX: wsprintf(message, _T("MMCN_INITOCX\n\tIUnknown: %08x\n"), param); break; case MMCN_LISTPAD: wsprintf(message, _T("MMCN_LISTPAD\n\tConnect: %d\n"), arg); break; case MMCN_MENU_BTNCLICK: wsprintf(message, _T("MMCN_MENU_BTNCLICK\n")); break; case MMCN_MINIMIZED: wsprintf(message, _T("MMCN_MINIMIZED\n\tMinimized: %d\n"), arg); break; case MMCN_PASTE: wsprintf(message, _T("MMCN_PASTE\n\tCopy: %d\n"), param == NULL); break; case MMCN_PRELOAD: wsprintf(message, _T("MMCN_PRELOAD\n\tScope Item: %08x\n"), arg); break; case MMCN_PRINT: wsprintf(message, _T("MMCN_PRINT\n")); break; case MMCN_PROPERTY_CHANGE: wsprintf(message, _T("MMCN_PROPERTY_CHANGE\n\tScope: %d\n\tArg: %08x\n"), arg, param); break; case MMCN_QUERY_PASTE: wsprintf(message, _T("MMCN_QUERY_PASTE\n")); break; case MMCN_REFRESH: wsprintf(message, _T("MMCN_REFRESH\n")); break; case MMCN_REMOVE_CHILDREN: wsprintf(message, _T("MMCN_REMOVE_CHILDREN\n\tScope Item: %08x\n"), arg); break; case MMCN_RENAME: wsprintf(message, _T("MMCN_RENAME\n\tNew Name: '%ws'\n"), (LPOLESTR)param); break; case MMCN_RESTORE_VIEW: wsprintf(message, _T("MMCN_RESTORE_VIEW\n")); break; case MMCN_SELECT: wsprintf(message, _T("MMCN_SELECT\n\tScope: %d\n\tSelect: %08x\n"), LOWORD(arg), HIWORD(arg)); break; case MMCN_SHOW: wsprintf(message, _T("MMCN_SHOW\n\tShow: %d\n\tScope Item: %08x\n"), arg, param); break; case MMCN_SNAPINHELP: wsprintf(message, _T("MMCN_SNAPINHELP\n")); break; case MMCN_VIEW_CHANGE: wsprintf(message, _T("MMCN_VIEW_CHANGE\n\tData: %08x\n\tHint: %08x\n"), arg, param); break; } if (message[0] != 0) OutputDebugString(message); else OutputDebugString(_T("unknown event\n")); #endif return; }