Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

1975 lines
65 KiB

// This is a part of the Microsoft Foundation Classes C++ library.
// Copyright (C) 1992-1998 Microsoft Corporation
// All rights reserved.
//
// This source code is only intended as a supplement to the
// Microsoft Foundation Classes Reference and related
// electronic documentation provided with the library.
// See these sources for detailed information regarding the
// Microsoft Foundation Classes product.
#ifndef __AFXOLE_H__
#define __AFXOLE_H__
#ifdef _AFX_NO_OLE_SUPPORT
#error OLE classes not supported in this library variant.
#endif
#ifndef __AFXEXT_H__
#include <afxext.h>
#endif
#ifndef __AFXDISP_H__
#include <afxdisp.h>
#endif
// include OLE Compound Document headers
#ifndef _OLE2_H_
#include <ole2.h>
#endif
// ActiveX Document support
#ifndef __docobj_h__
#include <docobj.h>
#endif
// URL Monikers support
#ifndef __urlmon_h__
#include <urlmon.h>
#endif
#ifndef __AFXCOM_H__
#include <afxcom_.h>
#endif
#ifdef _AFX_MINREBUILD
#pragma component(minrebuild, off)
#endif
#ifndef _AFX_FULLTYPEINFO
#pragma component(mintypeinfo, on)
#endif
#ifdef _AFX_PACKING
#pragma pack(push, _AFX_PACKING)
#endif
#ifndef _AFX_NOFORCE_LIBS
#pragma comment(lib, "urlmon.lib")
#endif // !_AFX_NOFORCE_LIBS
/////////////////////////////////////////////////////////////////////////////
// AFXOLE.H - MFC OLE support
// Classes declared in this file
//CDocument
class COleDocument; // OLE container document
class COleLinkingDoc; // supports links to embeddings
class COleServerDoc; // OLE server document
class CDocObjectServer; // might be owned by a COleServerDoc
//CCmdTarget
class CDocItem; // part of a document
class COleClientItem; // embedded ole object from outside
#if _MFC_VER >= 0x0600
class COleDocObjectItem;// ActiveX Document item
#endif
class COleServerItem; // ole object to export
class COleDataSource; // clipboard data source mechanism
class COleDropSource; // drag/drop source
class COleDropTarget; // drag/drop target
class COleMessageFilter; // concurrency management
//CFrameWnd
class COleIPFrameWnd; // frame window for in-place servers
//CControlBar
class COleResizeBar; // implements in-place resizing
//CFile
class COleStreamFile; // CFile wrapper for IStream interface
class CMonikerFile; // bound to via IMoniker
class CAsyncMonikerFile;// asynchronous IMoniker
class COleDataObject; // wrapper for IDataObject interface
/////////////////////////////////////////////////////////////////////////////
// AFXDLL support
#undef AFX_DATA
#define AFX_DATA AFX_OLE_DATA
/////////////////////////////////////////////////////////////////////////////
// backward compatibility
// COleClientDoc is now obsolete -- use COleDocument instead
#define COleClientDoc COleDocument
// COleServer has been replaced by the more general COleObjectFactory
#define COleServer COleObjectFactory
/////////////////////////////////////////////////////////////////////////////
// Useful OLE specific types (some from OLE 1.0 headers)
// Codes for CallBack events
enum OLE_NOTIFICATION
{
OLE_CHANGED, // representation of a draw aspect has changed
OLE_SAVED, // the item has committed its storage
OLE_CLOSED, // the item has closed
OLE_RENAMED, // the item has changed its moniker
OLE_CHANGED_STATE, // the item state (open, active, etc.) has changed
OLE_CHANGED_ASPECT, // the item draw aspect has changed
};
// Object types
enum OLE_OBJTYPE
{
OT_UNKNOWN = 0,
// These are OLE 1.0 types and OLE 2.0 types as returned from GetType().
OT_LINK = 1,
OT_EMBEDDED = 2,
OT_STATIC = 3,
// All OLE2 objects are written with this tag when serialized. This
// differentiates them from OLE 1.0 objects written with MFC 2.0.
// This value will never be returned from GetType().
OT_OLE2 = 256,
};
/////////////////////////////////////////////////////////////////////////////
// COleDataObject -- simple wrapper for IDataObject
class COleDataObject
{
// Constructors
public:
COleDataObject();
// Operations
void Attach(LPDATAOBJECT lpDataObject, BOOL bAutoRelease = TRUE);
LPDATAOBJECT Detach(); // detach and get ownership of m_lpDataObject
void Release(); // detach and Release ownership of m_lpDataObject
BOOL AttachClipboard(); // attach to current clipboard object
// Attributes
void BeginEnumFormats();
BOOL GetNextFormat(LPFORMATETC lpFormatEtc);
CFile* GetFileData(CLIPFORMAT cfFormat, LPFORMATETC lpFormatEtc = NULL);
HGLOBAL GetGlobalData(CLIPFORMAT cfFormat, LPFORMATETC lpFormatEtc = NULL);
BOOL GetData(CLIPFORMAT cfFormat, LPSTGMEDIUM lpStgMedium,
LPFORMATETC lpFormatEtc = NULL);
BOOL IsDataAvailable(CLIPFORMAT cfFormat, LPFORMATETC lpFormatEtc = NULL);
// Implementation
public:
LPDATAOBJECT m_lpDataObject;
LPENUMFORMATETC m_lpEnumerator;
~COleDataObject();
// advanced use and implementation
LPDATAOBJECT GetIDataObject(BOOL bAddRef);
void EnsureClipboardObject();
BOOL m_bClipboard; // TRUE if represents the Win32 clipboard
protected:
BOOL m_bAutoRelease; // TRUE if destructor should call Release
private:
// Disable the copy constructor and assignment by default so you will get
// compiler errors instead of unexpected behaviour if you pass objects
// by value or assign objects.
COleDataObject(const COleDataObject&); // no implementation
void operator=(const COleDataObject&); // no implementation
};
/////////////////////////////////////////////////////////////////////////////
// COleDataSource -- wrapper for implementing IDataObject
// (works similar to how data is provided on the clipboard)
struct AFX_DATACACHE_ENTRY;
class COleDropSource;
class COleDataSource : public CCmdTarget
{
// Constructors
public:
COleDataSource();
// Operations
void Empty(); // empty cache (similar to ::EmptyClipboard)
// CacheData & DelayRenderData operations similar to ::SetClipboardData
void CacheGlobalData(CLIPFORMAT cfFormat, HGLOBAL hGlobal,
LPFORMATETC lpFormatEtc = NULL); // for HGLOBAL based data
void DelayRenderFileData(CLIPFORMAT cfFormat,
LPFORMATETC lpFormatEtc = NULL); // for CFile* based delayed render
// Clipboard and Drag/Drop access
DROPEFFECT DoDragDrop(
DWORD dwEffects = DROPEFFECT_COPY|DROPEFFECT_MOVE|DROPEFFECT_LINK,
LPCRECT lpRectStartDrag = NULL,
COleDropSource* pDropSource = NULL);
void SetClipboard();
static void PASCAL FlushClipboard();
static COleDataSource* PASCAL GetClipboardOwner();
// Advanced: STGMEDIUM based cached data
void CacheData(CLIPFORMAT cfFormat, LPSTGMEDIUM lpStgMedium,
LPFORMATETC lpFormatEtc = NULL); // for LPSTGMEDIUM based data
// Advanced: STGMEDIUM or HGLOBAL based delayed render
void DelayRenderData(CLIPFORMAT cfFormat, LPFORMATETC lpFormatEtc = NULL);
// Advanced: support for SetData in COleServerItem
// (not generally useful for clipboard or drag/drop operations)
void DelaySetData(CLIPFORMAT cfFormat, LPFORMATETC lpFormatEtc = NULL);
// Overidables
virtual BOOL OnRenderGlobalData(LPFORMATETC lpFormatEtc, HGLOBAL* phGlobal);
virtual BOOL OnRenderFileData(LPFORMATETC lpFormatEtc, CFile* pFile);
virtual BOOL OnRenderData(LPFORMATETC lpFormatEtc, LPSTGMEDIUM lpStgMedium);
// OnRenderFileData and OnRenderGlobalData are called by
// the default implementation of OnRenderData.
virtual BOOL OnSetData(LPFORMATETC lpFormatEtc, LPSTGMEDIUM lpStgMedium,
BOOL bRelease);
// used only in COleServerItem implementation
// Implementation
public:
virtual ~COleDataSource();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
protected:
AFX_DATACACHE_ENTRY* m_pDataCache; // data cache itself
UINT m_nMaxSize; // current allocated size
UINT m_nSize; // current size of the cache
UINT m_nGrowBy; // number of cache elements to grow by for new allocs
AFX_DATACACHE_ENTRY* Lookup(
LPFORMATETC lpFormatEtc, DATADIR nDataDir) const;
AFX_DATACACHE_ENTRY* GetCacheEntry(
LPFORMATETC lpFormatEtc, DATADIR nDataDir);
// Interface Maps
public:
BEGIN_INTERFACE_PART(DataObject, IDataObject)
INIT_INTERFACE_PART(COleDataSource, DataObject)
STDMETHOD(GetData)(LPFORMATETC, LPSTGMEDIUM);
STDMETHOD(GetDataHere)(LPFORMATETC, LPSTGMEDIUM);
STDMETHOD(QueryGetData)(LPFORMATETC);
STDMETHOD(GetCanonicalFormatEtc)(LPFORMATETC, LPFORMATETC);
STDMETHOD(SetData)(LPFORMATETC, LPSTGMEDIUM, BOOL);
STDMETHOD(EnumFormatEtc)(DWORD, LPENUMFORMATETC*);
STDMETHOD(DAdvise)(LPFORMATETC, DWORD, LPADVISESINK, LPDWORD);
STDMETHOD(DUnadvise)(DWORD);
STDMETHOD(EnumDAdvise)(LPENUMSTATDATA*);
END_INTERFACE_PART(DataObject)
DECLARE_INTERFACE_MAP()
friend class COleServerItem;
};
//////////////////////////////////////////////////////////////////////////////
// DocItem support
#ifdef _AFXDLL
class CDocItem : public CCmdTarget
#else
class AFX_NOVTABLE CDocItem : public CCmdTarget
#endif
{
DECLARE_SERIAL(CDocItem)
// Constructors
protected: // abstract class
CDocItem();
// Attributes
public:
CDocument* GetDocument() const; // return container document
// Overridables
public:
// Raw data access (native format)
virtual BOOL IsBlank() const;
// Implementation
protected:
COleDocument* m_pDocument;
public:
virtual void Serialize(CArchive& ar); // for Native data
virtual ~CDocItem();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
friend class COleDocument; // for access to back pointer
};
//////////////////////////////////////////////////////////////////////////////
// COleDocument - common OLE container behavior (enables server functionality)
class COleDocument : public CDocument
{
DECLARE_DYNAMIC(COleDocument)
// Constructors
public:
COleDocument();
// Attributes
BOOL HasBlankItems() const; // check for BLANK items
virtual COleClientItem* GetInPlaceActiveItem(CWnd* pWnd);
// return in-place active item for this view or NULL if none
// Operations
// iterating over existing items
virtual POSITION GetStartPosition() const;
virtual CDocItem* GetNextItem(POSITION& pos) const;
// iterator helpers (helpers use virtual GetNextItem above)
COleClientItem* GetNextClientItem(POSITION& pos) const;
COleServerItem* GetNextServerItem(POSITION& pos) const;
// adding new items - called from item constructors
virtual void AddItem(CDocItem* pItem);
virtual void RemoveItem(CDocItem* pItem);
void EnableCompoundFile(BOOL bEnable = TRUE);
// enable compound file support (only call during constructor)
virtual void UpdateModifiedFlag();
// scan for modified items -- mark document modified
// printer-device caching/control
BOOL ApplyPrintDevice(const DVTARGETDEVICE* ptd);
BOOL ApplyPrintDevice(const PRINTDLG* ppd);
// these apply the target device to all COleClientItem objects
// Overridables
virtual COleClientItem* GetPrimarySelectedItem(CView* pView);
// return primary selected item or NULL if none
virtual void OnShowViews(BOOL bVisible);
// called during app-idle when visibility of a document has changed
// Implementation
public:
CObList m_docItemList; // not owned items
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
CFrameWnd* GetFirstFrame();
// document handling overrides
virtual void SetPathName(LPCTSTR lpszPathName, BOOL bAddToMRU = TRUE);
virtual ~COleDocument();
virtual void DeleteContents(); // delete client items in list
virtual void Serialize(CArchive& ar); // serialize items to file
virtual void PreCloseFrame(CFrameWnd* pFrame);
virtual BOOL SaveModified();
virtual void OnIdle();
// compound file implementation
virtual BOOL OnNewDocument();
virtual BOOL OnOpenDocument(LPCTSTR lpszPathName);
virtual BOOL OnSaveDocument(LPCTSTR lpszPathName);
virtual void OnCloseDocument();
void CommitItems(BOOL bSuccess); // called during File.Save & File.Save As
// minimal linking protocol
virtual LPMONIKER GetMoniker(OLEGETMONIKER nAssign);
virtual LPOLEITEMCONTAINER GetContainer();
protected:
// document state implementation
UINT m_dwNextItemNumber;// serial number for next item in this document
BOOL m_bLastVisible; // TRUE if one or more views was last visible
// 'docfile' support
BOOL m_bCompoundFile; // TRUE if use compound files
LPSTORAGE m_lpRootStg; // root storage for the document
BOOL m_bSameAsLoad; // TRUE = file-save, FALSE = Save [Copy] As
BOOL m_bRemember; // if FALSE, indicates Save Copy As
DVTARGETDEVICE* m_ptd; // current document target device
// implementation helpers
virtual void LoadFromStorage();
virtual void SaveToStorage(CObject* pObject = NULL);
CDocItem* GetNextItemOfKind(POSITION& pos, CRuntimeClass* pClass) const;
// command handling
#if _MFC_VER >= 0x600
public:
#endif
virtual BOOL OnCmdMsg(UINT nID, int nCode, void* pExtra,
AFX_CMDHANDLERINFO* pHandlerInfo);
#if _MFC_VER >= 0x600
protected:
#endif
afx_msg void OnUpdatePasteMenu(CCmdUI* pCmdUI);
afx_msg void OnUpdatePasteLinkMenu(CCmdUI* pCmdUI);
afx_msg void OnUpdateEditLinksMenu(CCmdUI* pCmdUI);
afx_msg void OnEditLinks();
afx_msg void OnEditConvert();
afx_msg void OnUpdateEditChangeIcon(CCmdUI* pCmdUI);
afx_msg void OnEditChangeIcon();
afx_msg void OnUpdateObjectVerbMenu(CCmdUI* pCmdUI);
afx_msg void OnFileSendMail();
friend class COleClientItem;
friend class COleServerItem;
};
/////////////////////////////////////////////////////////////////////////////
// COleClientItem - Supports OLE2 non-inplace editing.
// implements IOleClientSite, IAdviseSink, and IOleInPlaceSite
class COleFrameHook; // forward reference (see ..\src\oleimpl2.h)
class COleClientItem : public CDocItem
{
DECLARE_DYNAMIC(COleClientItem)
// Constructors
public:
COleClientItem(COleDocument* pContainerDoc = NULL);
// create from the clipboard
BOOL CreateFromClipboard(OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
BOOL CreateLinkFromClipboard(OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
BOOL CreateStaticFromClipboard(OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
// create from a class ID (Insert New Object dialog)
BOOL CreateNewItem(REFCLSID clsid, OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
// create from COleDataObject
BOOL CreateFromData(COleDataObject* pDataObject,
OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
BOOL CreateLinkFromData(COleDataObject* pDataObject,
OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
BOOL CreateStaticFromData(COleDataObject* pDataObject,
OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
// create from file (package support)
BOOL CreateFromFile(LPCTSTR lpszFileName, REFCLSID clsid = CLSID_NULL,
OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
BOOL CreateLinkFromFile(LPCTSTR lpszFileName,
OLERENDER render = OLERENDER_DRAW,
CLIPFORMAT cfFormat = 0, LPFORMATETC lpFormatEtc = NULL);
// create a copy
BOOL CreateCloneFrom(const COleClientItem* pSrcItem);
// General Attributes
public:
#if _MFC_VER >= 0x0600
HICON GetIconFromRegistry() const;
static HICON GetIconFromRegistry(CLSID& clsid);
#endif
SCODE GetLastStatus() const;
OLE_OBJTYPE GetType() const; // OT_LINK, OT_EMBEDDED, OT_STATIC
void GetClassID(CLSID* pClassID) const;
void GetUserType(USERCLASSTYPE nUserClassType, CString& rString);
BOOL GetExtent(LPSIZE lpSize, DVASPECT nDrawAspect = (DVASPECT)-1);
// will return FALSE if item is BLANK
BOOL GetCachedExtent(LPSIZE lpSize, DVASPECT nDrawAspect = (DVASPECT)-1);
// getting/setting iconic cache
HGLOBAL GetIconicMetafile();
BOOL SetIconicMetafile(HGLOBAL hMetaPict);
// setting/getting default display aspect
DVASPECT GetDrawAspect() const;
virtual void SetDrawAspect(DVASPECT nDrawAspect);
// for printer presentation cache
BOOL SetPrintDevice(const DVTARGETDEVICE* ptd);
BOOL SetPrintDevice(const PRINTDLG* ppd);
// Item state
enum ItemState
{ emptyState, loadedState, openState, activeState, activeUIState };
UINT GetItemState() const;
BOOL IsModified() const;
BOOL IsRunning() const;
BOOL IsInPlaceActive() const;
BOOL IsOpen() const;
CView* GetActiveView() const;
// Data access
void AttachDataObject(COleDataObject& rDataObject) const;
// other rare access information
COleDocument* GetDocument() const; // return container
// helpers for checking clipboard data availability
static BOOL PASCAL CanPaste();
static BOOL PASCAL CanPasteLink();
// helpers for checking COleDataObject, useful in drag drop
static BOOL PASCAL CanCreateFromData(const COleDataObject* pDataObject);
static BOOL PASCAL CanCreateLinkFromData(const COleDataObject* pDataObject);
// General Operations
virtual void Release(OLECLOSE dwCloseOption = OLECLOSE_NOSAVE);
// cleanup, detach (close if needed)
void Close(OLECLOSE dwCloseOption = OLECLOSE_SAVEIFDIRTY);
// close without releasing the item
void Delete(BOOL bAutoDelete = TRUE);
// logically delete from file -- not part of the document anymore
void Run(); // insure item is in running state
// Drawing
BOOL Draw(CDC* pDC, LPCRECT lpBounds,
DVASPECT nDrawAspect = (DVASPECT)-1); // defaults to m_nDrawAspect
// Activation
virtual BOOL DoVerb(LONG nVerb, CView* pView, LPMSG lpMsg = NULL);
void Activate(LONG nVerb, CView* pView, LPMSG lpMsg = NULL);
// In-place Activation
void Deactivate(); // completely deactivate
void DeactivateUI(); // deactivate the user interface
BOOL ReactivateAndUndo(); // reactivate then perform undo command
BOOL SetItemRects(LPCRECT lpPosRect = NULL, LPCRECT lpClipRect = NULL);
CWnd* GetInPlaceWindow();
// Clipboard operations
void CopyToClipboard(BOOL bIncludeLink = FALSE);
DROPEFFECT DoDragDrop(LPCRECT lpItemRect, CPoint ptOffset,
BOOL bIncludeLink = FALSE,
DWORD dwEffects = DROPEFFECT_COPY|DROPEFFECT_MOVE,
LPCRECT lpRectStartDrag = NULL);
void GetClipboardData(COleDataSource* pDataSource,
BOOL bIncludeLink = FALSE, LPPOINT lpOffset = NULL,
LPSIZE lpSize = NULL);
// called for creating a COleDataSource by CopyToClipboard and DoDragDrop
virtual COleDataSource* OnGetClipboardData(BOOL bIncludeLink,
LPPOINT lpOffset, LPSIZE lpSize);
// Operations that apply to embedded items only
void SetHostNames(LPCTSTR lpszHost, LPCTSTR lpszHostObj);
void SetExtent(const CSize& size, DVASPECT nDrawAspect = DVASPECT_CONTENT);
// Operations that apply to linked items only
// (link options are rarely changed, except through Links dialog)
OLEUPDATE GetLinkUpdateOptions();
void SetLinkUpdateOptions(OLEUPDATE dwUpdateOpt);
// Link-source update status (also useful for embeddings that contain links)
BOOL UpdateLink(); // make up-to-date
BOOL IsLinkUpToDate() const; // is link up-to-date
// object conversion
virtual BOOL ConvertTo(REFCLSID clsidNew);
virtual BOOL ActivateAs(LPCTSTR lpszUserType, REFCLSID clsidOld, REFCLSID clsidNew);
BOOL Reload(); // for lazy reload after ActivateAs
// Overridables (notifications of IAdviseSink, IOleClientSite and IOleInPlaceSite)
// Callbacks/notifications from the server you must/should implement
virtual void OnChange(OLE_NOTIFICATION nCode, DWORD dwParam);
// implement OnChange to invalidate when item changes
protected:
virtual void OnGetItemPosition(CRect& rPosition);
// implement OnGetItemPosition if you support in-place activation
// Common overrides for in-place activation
virtual BOOL OnScrollBy(CSize sizeExtent);
// Common overrides for applications supporting undo
virtual void OnDiscardUndoState();
virtual void OnDeactivateAndUndo();
public:
virtual void OnDeactivateUI(BOOL bUndoable);
protected:
// Common overrides for applications supporting links to embeddings
virtual void OnShowItem();
// Advanced overrides for in-place activation
virtual void OnGetClipRect(CRect& rClipRect);
virtual BOOL CanActivate();
public:
virtual void OnActivate();
virtual void OnActivateUI();
virtual void OnDeactivate();
protected:
virtual BOOL OnGetWindowContext(CFrameWnd** ppMainFrame,
CFrameWnd** ppDocFrame, LPOLEINPLACEFRAMEINFO lpFrameInfo);
virtual BOOL OnChangeItemPosition(const CRect& rectPos);
// default calls SetItemRects and caches the pos rect
public:
// Advanced overrides for menu/title handling (rarely overridden)
virtual void OnInsertMenus(CMenu* pMenuShared,
LPOLEMENUGROUPWIDTHS lpMenuWidths);
virtual void OnSetMenu(CMenu* pMenuShared, HOLEMENU holemenu,
HWND hwndActiveObject);
virtual void OnRemoveMenus(CMenu* pMenuShared);
virtual BOOL OnUpdateFrameTitle();
// Advanced override for control bar handling
virtual BOOL OnShowControlBars(CFrameWnd* pFrameWnd, BOOL bShow);
// Implementation
public:
// data to support non-inplace activated items
LPOLEOBJECT m_lpObject; // in case you want direct access to the OLE object
LPVIEWOBJECT2 m_lpViewObject;// IViewObject for IOleObject above
DWORD m_dwItemNumber; // serial number for this item in this document
DVASPECT m_nDrawAspect; // current default display aspect
SCODE m_scLast; // last error code encountered
LPSTORAGE m_lpStorage; // provides storage for m_lpObject
LPLOCKBYTES m_lpLockBytes; // part of implementation of m_lpStorage
DWORD m_dwConnection; // advise connection to the m_lpObject
BYTE m_bLinkUnavail; // TRUE if link is currently unavailable
BYTE m_bMoniker; // TRUE if moniker is assigned
BYTE m_bLocked; // TRUE if object has external lock
BYTE m_bNeedCommit; // TRUE if need CommitItem
BYTE m_bClosing; // TRUE if currently doing COleClientItem::Close
BYTE m_bReserved[3]; // (reserved for future use)
// for compound file support
LPSTORAGE m_lpNewStorage; // used during Save As situations
// item state & item type
ItemState m_nItemState; // item state (see ItemState enumeration)
OLE_OBJTYPE m_nItemType; // item type (depends on how created)
// data valid when in-place activated
CView* m_pView; // view when object is in-place activated
DWORD m_dwContainerStyle; // style of the container wnd before activation
COleFrameHook* m_pInPlaceFrame;// frame window when in-place active
COleFrameHook* m_pInPlaceDoc; // doc window when in-place (may be NULL)
HWND m_hWndServer; // HWND of in-place server window
public:
virtual ~COleClientItem();
virtual void Serialize(CArchive& ar);
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
// Implementation
public:
virtual BOOL ReportError(SCODE sc) const;
virtual BOOL FreezeLink(); // converts to static: for edit links dialog
DWORD GetNewItemNumber(); // generates new item number
void GetItemName(LPTSTR lpszItemName) const; // gets readable item name
void UpdateItemType(); // update m_nItemType
protected:
// clipboard helpers
void GetEmbeddedItemData(LPSTGMEDIUM lpStgMedium);
void AddCachedData(COleDataSource* pDataSource);
BOOL GetLinkSourceData(LPSTGMEDIUM lpStgMedium);
void GetObjectDescriptorData(LPPOINT lpOffset, LPSIZE lpSize,
LPSTGMEDIUM lpStgMedium);
// interface helpers
virtual LPOLECLIENTSITE GetClientSite();
// helpers for printer-cached representation
BOOL GetPrintDeviceInfo(LPOLECACHE* plpOleCache,
DVTARGETDEVICE** pptd, DWORD* pdwConnection);
// Advanced Overridables for implementation
protected:
virtual BOOL FinishCreate(SCODE sc);
virtual void CheckGeneral(SCODE sc);
virtual void OnDataChange(LPFORMATETC lpFormatEtc,
LPSTGMEDIUM lpStgMedium);
public:
// for storage hookability (override to use 'docfiles')
virtual void GetItemStorage(); // allocate storage for new item
virtual void ReadItem(CArchive& ar); // read item from archive
virtual void WriteItem(CArchive& ar); // write item to archive
virtual void CommitItem(BOOL bSuccess); // commit item's storage
// compound & flat file implementations of above
void GetItemStorageFlat();
void ReadItemFlat(CArchive& ar);
void WriteItemFlat(CArchive& ar);
void GetItemStorageCompound();
void ReadItemCompound(CArchive& ar);
void WriteItemCompound(CArchive& ar);
// Interface Maps
public:
BEGIN_INTERFACE_PART(OleClientSite, IOleClientSite)
INIT_INTERFACE_PART(COleClientItem, OleClientSite)
STDMETHOD(SaveObject)();
STDMETHOD(GetMoniker)(DWORD, DWORD, LPMONIKER*);
STDMETHOD(GetContainer)(LPOLECONTAINER*);
STDMETHOD(ShowObject)();
STDMETHOD(OnShowWindow)(BOOL);
STDMETHOD(RequestNewObjectLayout)();
END_INTERFACE_PART(OleClientSite)
BEGIN_INTERFACE_PART(AdviseSink, IAdviseSink)
INIT_INTERFACE_PART(COleClientItem, AdviseSink)
STDMETHOD_(void,OnDataChange)(LPFORMATETC, LPSTGMEDIUM);
STDMETHOD_(void,OnViewChange)(DWORD, LONG);
STDMETHOD_(void,OnRename)(LPMONIKER);
STDMETHOD_(void,OnSave)();
STDMETHOD_(void,OnClose)();
END_INTERFACE_PART(AdviseSink)
BEGIN_INTERFACE_PART(OleIPSite, IOleInPlaceSite)
INIT_INTERFACE_PART(COleClientItem, OleIPSite)
STDMETHOD(GetWindow)(HWND*);
STDMETHOD(ContextSensitiveHelp)(BOOL);
STDMETHOD(CanInPlaceActivate)();
STDMETHOD(OnInPlaceActivate)();
STDMETHOD(OnUIActivate)();
STDMETHOD(GetWindowContext)(LPOLEINPLACEFRAME*,
LPOLEINPLACEUIWINDOW*, LPRECT, LPRECT, LPOLEINPLACEFRAMEINFO);
STDMETHOD(Scroll)(SIZE);
STDMETHOD(OnUIDeactivate)(BOOL);
STDMETHOD(OnInPlaceDeactivate)();
STDMETHOD(DiscardUndoState)();
STDMETHOD(DeactivateAndUndo)();
STDMETHOD(OnPosRectChange)(LPCRECT);
END_INTERFACE_PART(OleIPSite)
DECLARE_INTERFACE_MAP()
// Friendship declarations (to avoid many public members)
friend class COleUIWindow;
friend class COleFrameWindow;
friend class COleLinkingDoc;
};
#if _MFC_VER >= 0x0600
class COleDocObjectItem : public COleClientItem
{
friend class COleFrameHook;
DECLARE_DYNAMIC(COleDocObjectItem)
// Constructors
public:
COleDocObjectItem(COleDocument* pContainerDoc = NULL);
//Overridables
public:
LPOLEDOCUMENTVIEW GetActiveView() const;
virtual void Release(OLECLOSE dwCloseOption = OLECLOSE_NOSAVE);
virtual void OnInsertMenus(CMenu* pMenuShared,
LPOLEMENUGROUPWIDTHS lpMenuWidths);
virtual void OnRemoveMenus(CMenu *pMenuShared);
// Operations
public:
static BOOL OnPreparePrinting(CView* pCaller, CPrintInfo* pInfo,
BOOL bPrintAll = TRUE);
static void OnPrint(CView* pCaller, CPrintInfo* pInfo,
BOOL bPrintAll = TRUE);
BOOL GetPageCount(LPLONG pnFirstPage, LPLONG pcPages);
HRESULT ExecCommand(DWORD nCmdID,
DWORD nCmdExecOpt = OLECMDEXECOPT_DONTPROMPTUSER,
const GUID* pguidCmdGroup = NULL);
// Implementation
public:
virtual ~COleDocObjectItem();
CMenu* m_pHelpPopupMenu;
protected:
virtual void OnGetItemPosition(CRect& rPosition);
virtual CMenu* GetHelpMenu(UINT& nPosition);
void ActivateAndShow();
LPOLEDOCUMENTVIEW m_pActiveView;
LPPRINT m_pIPrint;
BOOL SupportsIPrint();
BOOL m_bInHelpMenu;
BEGIN_INTERFACE_PART(OleDocumentSite, IOleDocumentSite)
INIT_INTERFACE_PART(COleDocObjectItem, OleDocumentSite)
STDMETHOD(ActivateMe)(LPOLEDOCUMENTVIEW pViewToActivate);
END_INTERFACE_PART(OleDocumentSite)
DECLARE_INTERFACE_MAP()
};
#endif
/////////////////////////////////////////////////////////////////////////////
// COleServerItem - IOleObject & IDataObject OLE component
#ifdef _AFXDLL
class COleServerItem : public CDocItem
#else
class AFX_NOVTABLE COleServerItem : public CDocItem
#endif
{
DECLARE_DYNAMIC(COleServerItem)
protected:
// NOTE: many members in this class are protected - since everything
// in this class is designed for implementing an OLE server.
// Requests will come from OLE containers through non-C++ mechanisms,
// which will result in virtual functions in this class being called.
// Constructors
COleServerItem(COleServerDoc* pServerDoc, BOOL bAutoDelete);
// If your COleServerItem is an integral part of your data,
// bAutoDelete should be FALSE. If your COleServerItem can be
// deleted when a link is released, it can be TRUE.
COleDataSource* GetDataSource();
// Use this data source to add conversion formats that your
// server should support. Usually such formats are
// added in the item's constructor.
// Public Attributes
public:
COleServerDoc* GetDocument() const; // return server document
// naming (for links only)
const CString& GetItemName() const; // get name of linked item
void SetItemName(LPCTSTR lpszItemName); // set name of linked item
// link state
BOOL IsConnected() const; // returns TRUE if item has a client
BOOL IsLinkedItem() const; // returns TRUE if item is not embedded item
// extents
CSize m_sizeExtent;
// HIMETRIC size -- the default implementation of OnSetExtent
// updates this member variable. This member tells the server how
// much of the object is visible in the container document.
// Operations
public:
void NotifyChanged(DVASPECT nDrawAspect = DVASPECT_CONTENT);
// call this after you change item
void CopyToClipboard(BOOL bIncludeLink = FALSE);
// helper for implementing server 'copy to clipboard'
DROPEFFECT DoDragDrop(LPCRECT lpRectItem, CPoint ptOffset,
BOOL bIncludeLink = FALSE,
DWORD dwEffects = DROPEFFECT_COPY|DROPEFFECT_MOVE,
LPCRECT lpRectStartDrag = NULL);
void GetClipboardData(COleDataSource* pDataSource,
BOOL bIncludeLink = FALSE, LPPOINT lpOffset = NULL,
LPSIZE lpSize = NULL);
// Overridables
// overridables you must implement for yourself
virtual BOOL OnDraw(CDC* pDC, CSize& rSize) = 0;
// drawing for metafile format (return FALSE if not supported or error)
// (called for DVASPECT_CONTENT only)
// overridables you may want to implement yourself
virtual void OnUpdate(COleServerItem* pSender,
LPARAM lHint, CObject* pHint, DVASPECT nDrawAspect);
// the default implementation always calls NotifyChanged
virtual BOOL OnDrawEx(CDC* pDC, DVASPECT nDrawAspect, CSize& rSize);
// advanced drawing -- called for DVASPECT other than DVASPECT_CONTENT
virtual BOOL OnSetExtent(DVASPECT nDrawAspect, const CSize& size);
virtual BOOL OnGetExtent(DVASPECT nDrawAspect, CSize& rSize);
// default implementation uses m_sizeExtent
// overridables you do not have to implement
virtual void OnDoVerb(LONG iVerb);
// default routes to OnShow &/or OnOpen
virtual BOOL OnSetColorScheme(const LOGPALETTE* lpLogPalette);
// default does nothing
virtual COleDataSource* OnGetClipboardData(BOOL bIncludeLink,
LPPOINT lpOffset, LPSIZE lpSize);
// called for access to clipboard data
virtual BOOL OnQueryUpdateItems();
// called to determine if there are any contained out-of-date links
virtual void OnUpdateItems();
// called to update any out-of-date links
protected:
virtual void OnShow();
// show item in the user interface (may edit in-place)
virtual void OnOpen();
// show item in the user interface (must open fully)
virtual void OnHide();
// hide document (and sometimes application)
// very advanced overridables
public:
virtual BOOL OnInitFromData(COleDataObject* pDataObject, BOOL bCreation);
// initialize object from IDataObject
// see COleDataSource for a description of these overridables
virtual BOOL OnRenderGlobalData(LPFORMATETC lpFormatEtc, HGLOBAL* phGlobal);
virtual BOOL OnRenderFileData(LPFORMATETC lpFormatEtc, CFile* pFile);
virtual BOOL OnRenderData(LPFORMATETC lpFormatEtc, LPSTGMEDIUM lpStgMedium);
// HGLOBAL version will be called first, then CFile* version
virtual BOOL OnSetData(LPFORMATETC lpFormatEtc, LPSTGMEDIUM lpStgMedium,
BOOL bRelease);
// Rare -- only if you support SetData (programmatic paste)
// advanced helpers for CopyToClipboard
void GetEmbedSourceData(LPSTGMEDIUM lpStgMedium);
void AddOtherClipboardData(COleDataSource* pDataSource);
BOOL GetLinkSourceData(LPSTGMEDIUM lpStgMedium);
void GetObjectDescriptorData(LPPOINT lpOffset, LPSIZE lpSize,
LPSTGMEDIUM lpStgMedium);
// Implementation
public:
BOOL m_bNeedUnlock; // if TRUE need to pDoc->LockExternal(FALSE)
BOOL m_bAutoDelete; // if TRUE will OnRelease will 'delete this'
// special version of OnFinalRelease to implement document locking
virtual void OnFinalRelease();
protected:
CString m_strItemName; // simple item name
public:
LPOLEADVISEHOLDER m_lpOleAdviseHolder; // may be NULL
LPDATAADVISEHOLDER m_lpDataAdviseHolder; // may be NULL
virtual ~COleServerItem();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
// implementation helpers
void NotifyClient(OLE_NOTIFICATION wNotification, DWORD_PTR dwParam);
LPDATAOBJECT GetDataObject();
LPOLEOBJECT GetOleObject();
LPMONIKER GetMoniker(OLEGETMONIKER nAssign);
protected:
virtual BOOL GetMetafileData(LPFORMATETC lpFormatEtc, LPSTGMEDIUM pmedium);
// calls OnDraw or OnDrawEx
virtual void OnSaveEmbedding(LPSTORAGE lpStorage);
virtual BOOL IsBlank() const;
// CItemDataSource implements OnRender reflections to COleServerItem
class CItemDataSource : public COleDataSource
{
protected:
// the GetData and SetData interfaces forward to m_pItem
virtual BOOL OnRenderGlobalData(LPFORMATETC lpFormatEtc, HGLOBAL* phGlobal);
virtual BOOL OnRenderFileData(LPFORMATETC lpFormatEtc, CFile* pFile);
virtual BOOL OnRenderData(LPFORMATETC lpFormatEtc, LPSTGMEDIUM lpStgMedium);
// HGLOBAL version will be called first, then CFile* version
virtual BOOL OnSetData(LPFORMATETC lpFormatEtc, LPSTGMEDIUM lpStgMedium,
BOOL bRelease);
};
CItemDataSource m_dataSource;
// data source used to implement IDataObject
// Interface Maps
// (Note: these interface maps are used just for link implementation)
public:
BEGIN_INTERFACE_PART(OleObject, IOleObject)
INIT_INTERFACE_PART(COleServerItem, OleObject)
STDMETHOD(SetClientSite)(LPOLECLIENTSITE);
STDMETHOD(GetClientSite)(LPOLECLIENTSITE*);
STDMETHOD(SetHostNames)(LPCOLESTR, LPCOLESTR);
STDMETHOD(Close)(DWORD);
STDMETHOD(SetMoniker)(DWORD, LPMONIKER);
STDMETHOD(GetMoniker)(DWORD, DWORD, LPMONIKER*);
STDMETHOD(InitFromData)(LPDATAOBJECT, BOOL, DWORD);
STDMETHOD(GetClipboardData)(DWORD, LPDATAOBJECT*);
STDMETHOD(DoVerb)(LONG, LPMSG, LPOLECLIENTSITE, LONG, HWND, LPCRECT);
STDMETHOD(EnumVerbs)(LPENUMOLEVERB*);
STDMETHOD(Update)();
STDMETHOD(IsUpToDate)();
STDMETHOD(GetUserClassID)(LPCLSID);
STDMETHOD(GetUserType)(DWORD, LPOLESTR*);
STDMETHOD(SetExtent)(DWORD, LPSIZEL);
STDMETHOD(GetExtent)(DWORD, LPSIZEL);
STDMETHOD(Advise)(LPADVISESINK, LPDWORD);
STDMETHOD(Unadvise)(DWORD);
STDMETHOD(EnumAdvise)(LPENUMSTATDATA*);
STDMETHOD(GetMiscStatus)(DWORD, LPDWORD);
STDMETHOD(SetColorScheme)(LPLOGPALETTE);
END_INTERFACE_PART(OleObject)
BEGIN_INTERFACE_PART(DataObject, IDataObject)
INIT_INTERFACE_PART(COleServerItem, DataObject)
STDMETHOD(GetData)(LPFORMATETC, LPSTGMEDIUM);
STDMETHOD(GetDataHere)(LPFORMATETC, LPSTGMEDIUM);
STDMETHOD(QueryGetData)(LPFORMATETC);
STDMETHOD(GetCanonicalFormatEtc)(LPFORMATETC, LPFORMATETC);
STDMETHOD(SetData)(LPFORMATETC, LPSTGMEDIUM, BOOL);
STDMETHOD(EnumFormatEtc)(DWORD, LPENUMFORMATETC*);
STDMETHOD(DAdvise)(LPFORMATETC, DWORD, LPADVISESINK, LPDWORD);
STDMETHOD(DUnadvise)(DWORD);
STDMETHOD(EnumDAdvise)(LPENUMSTATDATA*);
END_INTERFACE_PART(DataObject)
DECLARE_INTERFACE_MAP()
friend class CItemDataSource;
friend class COleServerDoc;
friend class COleLinkingDoc;
};
/////////////////////////////////////////////////////////////////////////////
// COleLinkingDoc -
// (enables linking to embeddings - beginnings of server fuctionality)
class COleLinkingDoc : public COleDocument
{
DECLARE_DYNAMIC(COleLinkingDoc)
// Constructors
public:
COleLinkingDoc();
// Operations
BOOL Register(COleObjectFactory* pFactory, LPCTSTR lpszPathName);
// notify the running object table and connect to pServer
void Revoke();
// revoke from running object table
// Overridables
protected:
virtual COleServerItem* OnGetLinkedItem(LPCTSTR lpszItemName);
// return item for the named linked item (for supporting links)
virtual COleClientItem* OnFindEmbeddedItem(LPCTSTR lpszItemName);
// return item for the named embedded item (for links to embeddings)
// Implementation
public:
COleObjectFactory* m_pFactory; // back-pointer to server
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
virtual ~COleLinkingDoc();
// overrides for updating of monikers & running object table registration
virtual BOOL OnNewDocument();
virtual BOOL OnOpenDocument(LPCTSTR lpszPathName);
virtual BOOL OnSaveDocument(LPCTSTR lpszPathName);
virtual void OnCloseDocument();
virtual LPOLEITEMCONTAINER GetContainer();
virtual LPMONIKER GetMoniker(OLEGETMONIKER nAssign);
// special handling of error messages during save/load
virtual void ReportSaveLoadException(LPCTSTR lpszPathName,
CException* e, BOOL bSaving, UINT nIDPDefault);
void BeginDeferErrors();
SCODE EndDeferErrors(SCODE sc);
protected:
BOOL m_bDeferErrors; // TRUE if in non-interactive OLE mode
CException* m_pLastException;
DWORD m_dwRegister; // file moniker's registration in the ROT
LPMONIKER m_lpMonikerROT; // file moniker that is registered
CString m_strMoniker; // filename used to create moniker
BOOL m_bVisibleLock; // TRUE if user is holding lock on document
// implementation helpers
virtual BOOL RegisterIfServerAttached(LPCTSTR lpszPathName, BOOL bMessage);
void LockExternal(BOOL bLock, BOOL bRemoveRefs);
void UpdateVisibleLock(BOOL bVisible, BOOL bRemoveRefs);
virtual void OnShowViews(BOOL bVisible);
virtual void SaveToStorage(CObject* pObject = NULL);
// Interface Maps
public:
BEGIN_INTERFACE_PART(PersistFile, IPersistFile)
INIT_INTERFACE_PART(COleLinkingDoc, PersistFile)
STDMETHOD(GetClassID)(LPCLSID);
STDMETHOD(IsDirty)();
STDMETHOD(Load)(LPCOLESTR, DWORD);
STDMETHOD(Save)(LPCOLESTR, BOOL);
STDMETHOD(SaveCompleted)(LPCOLESTR);
STDMETHOD(GetCurFile)(LPOLESTR*);
END_INTERFACE_PART(PersistFile)
BEGIN_INTERFACE_PART(OleItemContainer, IOleItemContainer)
INIT_INTERFACE_PART(COleLinkingDoc, OleItemContainer)
STDMETHOD(ParseDisplayName)(LPBC, LPOLESTR, ULONG*, LPMONIKER*);
STDMETHOD(EnumObjects)(DWORD, LPENUMUNKNOWN*);
STDMETHOD(LockContainer)(BOOL);
STDMETHOD(GetObject)(LPOLESTR, DWORD, LPBINDCTX, REFIID, LPVOID*);
STDMETHOD(GetObjectStorage)(LPOLESTR, LPBINDCTX, REFIID, LPVOID*);
STDMETHOD(IsRunning)(LPOLESTR);
END_INTERFACE_PART(OleItemContainer)
DECLARE_INTERFACE_MAP()
friend class COleClientItem;
friend class COleClientItem::XOleClientSite;
friend class COleServerItem::XOleObject;
};
//////////////////////////////////////////////////////////////////////////////
// COleServerDoc - registered server document containing COleServerItems
#ifdef _AFXDLL
class COleServerDoc : public COleLinkingDoc
#else
class AFX_NOVTABLE COleServerDoc : public COleLinkingDoc
#endif
{
DECLARE_DYNAMIC(COleServerDoc)
// Constructors and Destructors
public:
COleServerDoc();
// Attributes
BOOL IsEmbedded() const; // TRUE if document is an embedding
BOOL IsDocObject() const; // TRUE if document is a DocObject
COleServerItem* GetEmbeddedItem();
// return embedded item for document (will allocate if necessary)
// attributes specific to in-place activation
BOOL IsInPlaceActive() const;
void GetItemPosition(LPRECT lpPosRect) const;
// get current position rectangle of in-place edit
void GetItemClipRect(LPRECT lpClipRect) const;
// get current clipping rectangle of in-place edit
BOOL GetZoomFactor(LPSIZE lpSizeNum = NULL, LPSIZE lpSizeDenom = NULL,
LPCRECT lpPosRect = NULL) const;
// returns the zoom factor in pixels
// Operations
void NotifyChanged();
// call this after you change some global attribute like
// document dimensions
void UpdateAllItems(COleServerItem* pSender,
LPARAM lHint = 0L, CObject* pHint = NULL,
DVASPECT nDrawAspect = DVASPECT_CONTENT);
// changes to the entire document (automatically notifies clients)
void NotifyRename(LPCTSTR lpszNewName);
void NotifySaved();
void NotifyClosed(); // call this after you close document
// specific operations for embedded documents
void SaveEmbedding(); // call this to save embedded (before closing)
// specific to in-place activation
BOOL ActivateInPlace();
void ActivateDocObject();
void RequestPositionChange(LPCRECT lpPosRect);
BOOL ScrollContainerBy(CSize sizeScroll);
BOOL DeactivateAndUndo();
BOOL DiscardUndoState();
public:
// Overridables for standard user interface (full server)
virtual BOOL OnUpdateDocument(); // implementation of embedded update
protected:
// Overridables you must implement for yourself
virtual COleServerItem* OnGetEmbeddedItem() = 0;
// return item representing entire (embedded) document
// Overridables you do not have to implement
virtual void OnClose(OLECLOSE dwCloseOption);
virtual void OnSetHostNames(LPCTSTR lpszHost, LPCTSTR lpszHostObj);
virtual HRESULT OnExecOleCmd(const GUID* pguidCmdGroup, DWORD nCmdID,
DWORD nCmdExecOpt, VARIANTARG* pvarargIn, VARIANTARG* pvarargOut);
virtual CDocObjectServer* GetDocObjectServer(LPOLEDOCUMENTSITE pDocSite);
// Advanced overridables
LPUNKNOWN GetInterfaceHook(const void* piid);
virtual void OnShowDocument(BOOL bShow);
// show first frame for document or hide all frames for document
// Advanced overridables for in-place activation
public:
virtual void OnDeactivate();
virtual void OnDeactivateUI(BOOL bUndoable);
protected:
virtual void OnSetItemRects(LPCRECT lpPosRect, LPCRECT lpClipRect);
virtual BOOL OnReactivateAndUndo();
virtual void OnFrameWindowActivate(BOOL bActivate);
virtual void OnDocWindowActivate(BOOL bActivate);
virtual void OnShowControlBars(CFrameWnd* pFrameWnd, BOOL bShow);
virtual COleIPFrameWnd* CreateInPlaceFrame(CWnd* pParentWnd);
virtual void DestroyInPlaceFrame(COleIPFrameWnd* pFrameWnd);
public:
virtual void OnResizeBorder(LPCRECT lpRectBorder,
LPOLEINPLACEUIWINDOW lpUIWindow, BOOL bFrame);
// Implementation
protected:
LPOLECLIENTSITE m_lpClientSite; // for embedded item
CString m_strHostObj; // name of document in container
BOOL m_bCntrVisible; // TRUE if OnShowWindow(TRUE) called
BOOL m_bClosing; // TRUE if shutting down
COleServerItem* m_pEmbeddedItem; // pointer to embedded item for document
COleIPFrameWnd* m_pInPlaceFrame; // not NULL if in-place activated
CWnd* m_pOrigParent; // not NULL if existing view used
DWORD m_dwOrigStyle; // original style of in-place view
DWORD m_dwOrigStyleEx; // original extended style
CDocObjectServer* m_pDocObjectServer; // if DocObject, ptr to doc site
public:
virtual ~COleServerDoc();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
// overridables for implementation
virtual BOOL OnSaveDocument(LPCTSTR lpszPathName);
virtual void OnCloseDocument();
virtual void DeleteContents(); // delete auto-delete server items
virtual LPMONIKER GetMoniker(OLEGETMONIKER nAssign);
virtual COleServerItem* OnGetLinkedItem(LPCTSTR lpszItemName);
// return item for the named linked item (only if supporting links)
virtual BOOL CanCloseFrame(CFrameWnd* pFrame);
protected:
// overrides to handle server user-interface
virtual BOOL SaveModified(); // return TRUE if ok to continue
virtual HMENU GetDefaultMenu(); // return menu based on doc type
virtual HACCEL GetDefaultAccelerator(); // return accel table based on doc type
virtual BOOL GetFileTypeString(CString& rString);
// IPersistStorage implementation
virtual void OnNewEmbedding(LPSTORAGE lpStorage);
virtual void OnOpenEmbedding(LPSTORAGE lpStorage);
virtual void OnSaveEmbedding(LPSTORAGE lpStorage);
// Implementation helpers
void NotifyAllItems(OLE_NOTIFICATION wNotification, DWORD_PTR dwParam);
BOOL SaveModifiedPrompt();
void ConnectView(CWnd* pParentWnd, CView* pView);
void UpdateUsingHostObj(UINT nIDS, CCmdUI* pCmdUI);
// Message Maps
//{{AFX_MSG(COleServerDoc)
afx_msg void OnFileUpdate();
afx_msg void OnFileSaveCopyAs();
afx_msg void OnUpdateFileUpdate(CCmdUI* pCmdUI);
afx_msg void OnUpdateFileExit(CCmdUI* pCmdUI);
//}}AFX_MSG
DECLARE_MESSAGE_MAP()
// Interface Maps
public:
BEGIN_INTERFACE_PART(PersistStorage, IPersistStorage)
INIT_INTERFACE_PART(COleServerDoc, PersistStorage)
STDMETHOD(GetClassID)(LPCLSID);
STDMETHOD(IsDirty)();
STDMETHOD(InitNew)(LPSTORAGE);
STDMETHOD(Load)(LPSTORAGE);
STDMETHOD(Save)(LPSTORAGE, BOOL);
STDMETHOD(SaveCompleted)(LPSTORAGE);
STDMETHOD(HandsOffStorage)();
END_INTERFACE_PART(PersistStorage)
BEGIN_INTERFACE_PART(OleObject, IOleObject)
INIT_INTERFACE_PART(COleServerDoc, OleObject)
STDMETHOD(SetClientSite)(LPOLECLIENTSITE);
STDMETHOD(GetClientSite)(LPOLECLIENTSITE*);
STDMETHOD(SetHostNames)(LPCOLESTR, LPCOLESTR);
STDMETHOD(Close)(DWORD);
STDMETHOD(SetMoniker)(DWORD, LPMONIKER);
STDMETHOD(GetMoniker)(DWORD, DWORD, LPMONIKER*);
STDMETHOD(InitFromData)(LPDATAOBJECT, BOOL, DWORD);
STDMETHOD(GetClipboardData)(DWORD, LPDATAOBJECT*);
STDMETHOD(DoVerb)(LONG, LPMSG, LPOLECLIENTSITE, LONG, HWND, LPCRECT);
STDMETHOD(EnumVerbs)(IEnumOLEVERB**);
STDMETHOD(Update)();
STDMETHOD(IsUpToDate)();
STDMETHOD(GetUserClassID)(CLSID*);
STDMETHOD(GetUserType)(DWORD, LPOLESTR*);
STDMETHOD(SetExtent)(DWORD, LPSIZEL);
STDMETHOD(GetExtent)(DWORD, LPSIZEL);
STDMETHOD(Advise)(LPADVISESINK, LPDWORD);
STDMETHOD(Unadvise)(DWORD);
STDMETHOD(EnumAdvise)(LPENUMSTATDATA*);
STDMETHOD(GetMiscStatus)(DWORD, LPDWORD);
STDMETHOD(SetColorScheme)(LPLOGPALETTE);
END_INTERFACE_PART(OleObject)
BEGIN_INTERFACE_PART(DataObject, IDataObject)
INIT_INTERFACE_PART(COleServerDoc, DataObject)
STDMETHOD(GetData)(LPFORMATETC, LPSTGMEDIUM);
STDMETHOD(GetDataHere)(LPFORMATETC, LPSTGMEDIUM);
STDMETHOD(QueryGetData)(LPFORMATETC);
STDMETHOD(GetCanonicalFormatEtc)(LPFORMATETC, LPFORMATETC);
STDMETHOD(SetData)(LPFORMATETC, LPSTGMEDIUM, BOOL);
STDMETHOD(EnumFormatEtc)(DWORD, LPENUMFORMATETC*);
STDMETHOD(DAdvise)(LPFORMATETC, DWORD, LPADVISESINK, LPDWORD);
STDMETHOD(DUnadvise)(DWORD);
STDMETHOD(EnumDAdvise)(LPENUMSTATDATA*);
END_INTERFACE_PART(DataObject)
BEGIN_INTERFACE_PART(OleInPlaceObject, IOleInPlaceObject)
INIT_INTERFACE_PART(COleServerDoc, OleInPlaceObject)
STDMETHOD(GetWindow)(HWND*);
STDMETHOD(ContextSensitiveHelp)(BOOL);
STDMETHOD(InPlaceDeactivate)();
STDMETHOD(UIDeactivate)();
STDMETHOD(SetObjectRects)(LPCRECT, LPCRECT);
STDMETHOD(ReactivateAndUndo)();
END_INTERFACE_PART(OleInPlaceObject)
BEGIN_INTERFACE_PART(OleInPlaceActiveObject, IOleInPlaceActiveObject)
INIT_INTERFACE_PART(COleServerDoc, OleInPlaceActiveObject)
STDMETHOD(GetWindow)(HWND*);
STDMETHOD(ContextSensitiveHelp)(BOOL);
STDMETHOD(TranslateAccelerator)(LPMSG);
STDMETHOD(OnFrameWindowActivate)(BOOL);
STDMETHOD(OnDocWindowActivate)(BOOL);
STDMETHOD(ResizeBorder)(LPCRECT, LPOLEINPLACEUIWINDOW, BOOL);
STDMETHOD(EnableModeless)(BOOL);
END_INTERFACE_PART(OleInPlaceActiveObject)
DECLARE_INTERFACE_MAP()
friend class COleServer;
friend class COleServerItem;
friend class CDocObjectServer;
};
//////////////////////////////////////////////////////////////////////////////
// COleIPFrameWnd
class COleCntrFrameWnd;
class COleIPFrameWnd : public CFrameWnd
{
DECLARE_DYNCREATE(COleIPFrameWnd)
// Constructors
public:
COleIPFrameWnd();
// Overridables
public:
virtual BOOL OnCreateControlBars(CWnd* pWndFrame, CWnd* pWndDoc);
// create control bars on container windows (pWndDoc can be NULL)
virtual BOOL OnCreateControlBars(CFrameWnd* pWndFrame, CFrameWnd* pWndDoc);
// create control bars on container windows (pWndDoc can be NULL)
virtual void RepositionFrame(LPCRECT lpPosRect, LPCRECT lpClipRect);
// Advanced: reposition frame to wrap around new lpPosRect
// Implementation
public:
BOOL m_bUIActive; // TRUE if currently in uiacitve state
virtual BOOL LoadFrame(UINT nIDResource,
DWORD dwDefaultStyle = WS_CHILD|WS_BORDER|WS_CLIPSIBLINGS,
CWnd* pParentWnd = NULL,
CCreateContext* pContext = NULL);
virtual void RecalcLayout(BOOL bNotify = TRUE);
virtual BOOL PreTranslateMessage(MSG* pMsg);
virtual LRESULT OnSetMessageString(WPARAM wParam, LPARAM lParam);
virtual ~COleIPFrameWnd();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
protected:
// in-place state
OLEINPLACEFRAMEINFO m_frameInfo;
LPOLEINPLACEFRAME m_lpFrame;
LPOLEINPLACEUIWINDOW m_lpDocFrame;
COleCntrFrameWnd* m_pMainFrame;
COleCntrFrameWnd* m_pDocFrame;
HMENU m_hSharedMenu;
OLEMENUGROUPWIDTHS m_menuWidths;
HOLEMENU m_hOleMenu;
CRect m_rectPos; // client area rect of the item
CRect m_rectClip; // area to which frame should be clipped
BOOL m_bInsideRecalc;
#if _MFC_VER >= 0x0600
HMENU _m_Reserved;
#else
HMENU m_hMenuHelpPopup; // shared Help menu for DocObjects
#endif
// Advanced: in-place activation virtual implementation
virtual BOOL BuildSharedMenu();
virtual void DestroySharedMenu();
virtual HMENU GetInPlaceMenu();
// Advanced: possible override to change in-place sizing behavior
virtual void OnRequestPositionChange(LPCRECT lpRect);
protected:
//{{AFX_MSG(COleIPFrameWnd)
afx_msg void OnSize(UINT nType, int cx, int cy);
afx_msg LRESULT OnRecalcParent(WPARAM wParam, LPARAM lParam);
afx_msg void OnIdleUpdateCmdUI();
afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct);
afx_msg void OnDestroy();
afx_msg LRESULT OnResizeChild(WPARAM wParam, LPARAM lParam);
afx_msg void OnContextHelp();
afx_msg void OnUpdateControlBarMenu(CCmdUI* pCmdUI);
afx_msg BOOL OnBarCheck(UINT nID);
afx_msg void OnWindowPosChanging(LPWINDOWPOS lpWndPos);
//}}AFX_MSG
DECLARE_MESSAGE_MAP()
friend class COleServerDoc;
friend class COleCntrFrameWnd;
friend class CDocObjectServer;
};
/////////////////////////////////////////////////////////////////////////////
// COleResizeBar - supports in-place resizing in server applications
class COleResizeBar : public CControlBar
{
DECLARE_DYNAMIC(COleResizeBar)
// Constructors
public:
COleResizeBar();
BOOL Create(CWnd* pParentWnd, DWORD dwStyle = WS_CHILD | WS_VISIBLE,
UINT nID = AFX_IDW_RESIZE_BAR);
// Implementation
public:
virtual ~COleResizeBar();
virtual void OnUpdateCmdUI(CFrameWnd* pTarget, BOOL bDisableIfNoHndler);
protected:
CRectTracker m_tracker; // implemented with a tracker
protected:
//{{AFX_MSG(COleResizeBar)
afx_msg BOOL OnEraseBkgnd(CDC* pDC);
afx_msg void OnPaint();
afx_msg void OnSize(UINT nType, int cx, int cy);
afx_msg BOOL OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message);
afx_msg void OnLButtonDown(UINT, CPoint point);
afx_msg LRESULT OnSizeParent(WPARAM wParam, LPARAM lParam);
//}}AFX_MSG
DECLARE_MESSAGE_MAP()
};
/////////////////////////////////////////////////////////////////////////////
// COleStreamFile - implementation of CFile which uses an IStream
class COleStreamFile : public CFile
{
DECLARE_DYNAMIC(COleStreamFile)
// Constructors and Destructors
public:
COleStreamFile(LPSTREAM lpStream = NULL);
// Operations
// Note: OpenStream and CreateStream can accept eith STGM_ flags or
// CFile::OpenFlags bits since common values are guaranteed to have
// the same semantics.
BOOL OpenStream(LPSTORAGE lpStorage, LPCTSTR lpszStreamName,
DWORD nOpenFlags = modeReadWrite|shareExclusive,
CFileException* pError = NULL);
BOOL CreateStream(LPSTORAGE lpStorage, LPCTSTR lpszStreamName,
DWORD nOpenFlags = modeReadWrite|shareExclusive|modeCreate,
CFileException* pError = NULL);
BOOL CreateMemoryStream(CFileException* pError = NULL);
// attach & detach can be used when Open/Create functions aren't adequate
void Attach(LPSTREAM lpStream);
LPSTREAM Detach();
IStream* GetStream() const;
// Returns the current stream
// Implementation
public:
LPSTREAM m_lpStream;
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
virtual ~COleStreamFile();
// attributes for implementation
BOOL GetStatus(CFileStatus& rStatus) const;
virtual DWORD GetPosition() const;
virtual const CString GetStorageName() const;
// overrides for implementation
virtual CFile* Duplicate() const;
virtual LONG Seek(LONG lOff, UINT nFrom);
virtual void SetLength(DWORD dwNewLen);
virtual DWORD GetLength() const;
virtual UINT Read(void* lpBuf, UINT nCount);
virtual void Write(const void* lpBuf, UINT nCount);
virtual void LockRange(DWORD dwPos, DWORD dwCount);
virtual void UnlockRange(DWORD dwPos, DWORD dwCount);
virtual void Abort();
virtual void Flush();
virtual void Close();
protected:
CString m_strStorageName;
};
/////////////////////////////////////////////////////////////////////////////
// CMonikerFile - implementation of COleStreamFile that uses an IMoniker to
// get the IStream
class CMonikerFile: public COleStreamFile
{
DECLARE_DYNAMIC(CMonikerFile)
public:
CMonikerFile();
virtual BOOL Open(LPCTSTR lpszURL, CFileException* pError=NULL);
// Uses synchronous URLMonikers to create a moniker.
// Opens the URL specified.
// If provided, pError will be set in case of error.
// Return value: TRUE if successful, FALSE otherwise.
virtual BOOL Open(IMoniker* pMoniker, CFileException* pError=NULL);
// Binds to the provided moniker to obtain a stream.
// If provided, pError will be set in case of error.
// Return value: TRUE if successful, FALSE otherwise.
virtual void Close();
// Detaches the stream, Release()s it, and the moniker. Close may be
// called on unopened, or already closed streams.
BOOL Detach(CFileException* pError = NULL);
// Closes the stream. If there is an error when closing, then the
// error code will be placed in pError and the function will return FALSE.
IMoniker* GetMoniker() const;
// Returns the current moniker. The moniker returned is not AddRef()'ed.
protected:
// Overidables
IBindCtx* CreateBindContext(CFileException* pError);
// A hook so users can provide a particular IBindCtx, potentially one
// on which the user has registered one or more objects.
// Implementation
protected:
virtual BOOL Open(LPCTSTR lpszUrl, IBindHost* pBindHost,
IBindStatusCallback* pBSC, IBindCtx* pBindCtx, CFileException* pError);
BOOL Attach(LPCTSTR lpszUrl, IBindHost* pBindHost,
IBindStatusCallback* pBSC, IBindCtx* pBindCtx, CFileException* pError);
virtual BOOL Open(IMoniker* pMoniker, IBindHost* pBindHost,
IBindStatusCallback* pBSC, IBindCtx* pBindCtx, CFileException* pError);
BOOL Attach(IMoniker* pMoniker, IBindHost* pBindHost,
IBindStatusCallback* pBSC, IBindCtx* pBindCtx, CFileException* pError);
virtual BOOL PostBindToStream(CFileException* pError);
static IBindHost* CreateBindHost();
public:
virtual ~CMonikerFile();
// Closes the stream, and releases the moniker if needed.
virtual void Flush();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
// Calls COleStreamFile::Dump(), and prints out moniker value.
#endif
protected:
IPTR(IMoniker) m_Moniker;
// The moniker provided or created to which this class is bound.
CMonikerFile(const CMonikerFile&);
// Prevents copying.
};
/////////////////////////////////////////////////////////////////////////////
// CAsyncMonikerFile - implementation of COleStreamFile that uses an
// asynchronous IMoniker to get the IStream
class _AfxBindStatusCallback; // Forward declaration
class CAsyncMonikerFile: public CMonikerFile
{
DECLARE_DYNAMIC(CAsyncMonikerFile)
public:
CAsyncMonikerFile();
// Creates the IBindStatusCallback used internally to provide asynchronous
// operation.
//All Open overloads call one of these two.
virtual BOOL Open(LPCTSTR lpszURL, IBindHost* pBindHost,
CFileException* pError=NULL);
virtual BOOL Open(IMoniker* pMoniker, IBindHost* pBindHost,
CFileException* pError=NULL);
//Open overloads that take monikers
virtual BOOL Open(IMoniker* pMoniker, CFileException* pError=NULL);
virtual BOOL Open(IMoniker* pMoniker, IServiceProvider* pServiceProvider,
CFileException* pError=NULL);
virtual BOOL Open(IMoniker* pMoniker, IUnknown* pUnknown,
CFileException* pError=NULL);
//Open overloads that take strings
virtual BOOL Open(LPCTSTR lpszURL, CFileException* pError=NULL);
virtual BOOL Open(LPCTSTR lpszURL, IServiceProvider* pServiceProvider,
CFileException* pError=NULL);
virtual BOOL Open(LPCTSTR lpszURL, IUnknown* pUnknown,
CFileException* pError=NULL);
virtual void Close();
IBinding* GetBinding() const;
// Returns the binding provided when the asychronous transfer begins.
// With the IBinding*, the user may abort, or pause the transfer.
// NULL may be returned if for any reason the transfer could not be
// made asynchronous, or if the IBinding* has not yet been provided by
// the system.
FORMATETC* GetFormatEtc() const;
// Returns the FORMATETC for the currently opened stream. NULL will be
// returned if this is called from outside the context of OnDataAvailable.
// If you want to keep the FORMATETC beyond this call, make a copy of it.
// The FORMATETC indicates the format of the data in the stream.
protected:
// Overidables
virtual IUnknown* CreateBindStatusCallback(IUnknown* pUnkControlling);
virtual DWORD GetBindInfo() const;
// Returns the settings returned by IBindStatusCallback::GetBindInfo.
// The default values returned should work for most cases and should not
// be changed lightly.
virtual LONG GetPriority() const;
// Returns the priority at which the asynchronous transfer will take
// place. The value is one of the standard thread priority flags.
// By default THREAD_PRIORITY_NORMAL is returned.
virtual void OnDataAvailable(DWORD dwSize, DWORD bscfFlag);
// Called when there is data available to be read. dwSize indicates
// the cumulative number of bytes which can be read. The bscfFlag may be used
// to identify first, last, and intermediate blocks of data.
virtual void OnLowResource();
// This is called when resources are low.
virtual void OnStartBinding();
// Called when the binding is starting up.
virtual void OnProgress(ULONG ulProgress, ULONG ulProgressMax,
ULONG ulStatusCode, LPCTSTR szStatusText);
virtual void OnStopBinding(HRESULT hresult, LPCTSTR szError);
// Called when the transfer is stopped. This function releases the
// IBinding and should nearly always be call when overidden.
// Implementation
public:
virtual ~CAsyncMonikerFile();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
// Calls CMonikerFile::Dump(), and prints out IBinding,
// IBindStatusCallback, and m_pFormatEtc values.
#endif
virtual UINT Read(void* lpBuf, UINT nCount);
protected:
friend class _AfxBindStatusCallback;
_AfxBindStatusCallback* m_pAfxBSCCurrent;
BOOL m_bStopBindingReceived;
void EndCallbacks();
IPTR(IBinding) m_Binding;
FORMATETC* m_pFormatEtc;
void SetBinding(IBinding* pBinding);
// Sets and AddRefs m_Binding
void SetFormatEtc(FORMATETC* pFormatEtc);
// Sets the FORMATETC for the current stream.
virtual BOOL PostBindToStream(CFileException* pError);
};
/////////////////////////////////////////////////////////////////////////////
// COleDropSource (advanced drop source support)
class COleDropSource : public CCmdTarget
{
// Constructors
public:
COleDropSource();
// Overridables
virtual SCODE QueryContinueDrag(BOOL bEscapePressed, DWORD dwKeyState);
virtual SCODE GiveFeedback(DROPEFFECT dropEffect);
virtual BOOL OnBeginDrag(CWnd* pWnd);
// Implementation
public:
#ifdef _DEBUG
virtual void Dump(CDumpContext& dc) const;
#endif
public:
BEGIN_INTERFACE_PART(DropSource, IDropSource)
INIT_INTERFACE_PART(COleDropSource, DropSource)
STDMETHOD(QueryContinueDrag)(BOOL, DWORD);
STDMETHOD(GiveFeedback)(DWORD);
END_INTERFACE_PART(DropSource)
DECLARE_INTERFACE_MAP()
CRect m_rectStartDrag; // when mouse leaves this rect, drag drop starts
BOOL m_bDragStarted; // has drag really started yet?
DWORD m_dwButtonCancel; // which button will cancel (going down)
DWORD m_dwButtonDrop; // which button will confirm (going up)
// metrics for drag start determination
static AFX_DATA UINT nDragMinDist; // min. amount mouse must move for drag
static AFX_DATA UINT nDragDelay; // delay before drag starts
friend class COleDataSource;
};
/////////////////////////////////////////////////////////////////////////////
// COleDropTarget (advanced drop target support)
class COleDropTarget : public CCmdTarget
{
// Constructors
public:
COleDropTarget();
// Operations
BOOL Register(CWnd* pWnd);
virtual void Revoke(); // virtual for implementation
// Overridables
virtual DROPEFFECT OnDragEnter(CWnd* pWnd, COleDataObject* pDataObject,
DWORD dwKeyState, CPoint point);
virtual DROPEFFECT OnDragOver(CWnd* pWnd, COleDataObject* pDataObject,
DWORD dwKeyState, CPoint point);
virtual BOOL OnDrop(CWnd* pWnd, COleDataObject* pDataObject,
DROPEFFECT dropEffect, CPoint point);
virtual DROPEFFECT OnDropEx(CWnd* pWnd, COleDataObject* pDataObject,
DROPEFFECT dropDefault, DROPEFFECT dropList, CPoint point);
virtual void OnDragLeave(CWnd* pWnd);
virtual DROPEFFECT OnDragScroll(CWnd* pWnd, DWORD dwKeyState,
CPoint point);
// Implementation
public:
virtual ~COleDropTarget();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
protected:
HWND m_hWnd; // HWND this IDropTarget is attached to
LPDATAOBJECT m_lpDataObject; // != NULL between OnDragEnter, OnDragLeave
UINT m_nTimerID; // != MAKEWORD(-1, -1) when in scroll area
DWORD m_dwLastTick; // only valid when m_nTimerID valid
UINT m_nScrollDelay; // time to next scroll
// metrics for drag-scrolling
static AFX_DATA int nScrollInset;
static AFX_DATA UINT nScrollDelay;
static AFX_DATA UINT nScrollInterval;
// implementation helpers
void SetupTimer(CView* pView, UINT nTimerID);
void CancelTimer(CWnd* pWnd);
// Interface Maps
public:
BEGIN_INTERFACE_PART(DropTarget, IDropTarget)
INIT_INTERFACE_PART(COleDropTarget, DropTarget)
STDMETHOD(DragEnter)(LPDATAOBJECT, DWORD, POINTL, LPDWORD);
STDMETHOD(DragOver)(DWORD, POINTL, LPDWORD);
STDMETHOD(DragLeave)();
STDMETHOD(Drop)(LPDATAOBJECT, DWORD, POINTL pt, LPDWORD);
END_INTERFACE_PART(DropTarget)
DECLARE_INTERFACE_MAP()
};
/////////////////////////////////////////////////////////////////////////////
// COleMessageFilter (implements IMessageFilter)
class COleMessageFilter : public CCmdTarget
{
// Constructors
public:
COleMessageFilter();
// Operations
BOOL Register();
void Revoke();
// for controlling the busy state of the server application (called app)
virtual void BeginBusyState();
virtual void EndBusyState();
void SetBusyReply(SERVERCALL nBusyReply);
// for controlling actions taken against rejected/retried calls
void SetRetryReply(DWORD nRetryReply = 0);
// only used when the "not responding" dialog is disabled
void SetMessagePendingDelay(DWORD nTimeout = 5000);
// used to determine amount of time before significant message
void EnableBusyDialog(BOOL bEnableBusy = TRUE);
void EnableNotRespondingDialog(BOOL bEnableNotResponding = TRUE);
// used to enable/disable the two types of busy dialogs
// Overridables
virtual BOOL OnMessagePending(const MSG* pMsg);
// return TRUE to eat the message (usually only if processed)
// Implementation
public:
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
virtual ~COleMessageFilter();
virtual BOOL IsSignificantMessage(MSG* pMsg);
// determine if any significant messages are present in the queue
virtual int OnBusyDialog(HTASK htaskBusy);
virtual int OnNotRespondingDialog(HTASK htaskBusy);
// these functions display the busy dialog
protected:
BOOL m_bRegistered;
LONG m_nBusyCount; // for BeginBusyState & EndBusyState
BOOL m_bEnableBusy;
BOOL m_bEnableNotResponding;
BOOL m_bUnblocking;
DWORD m_nRetryReply; // only used if m_bEnableNotResponding == FALSE
DWORD m_nBusyReply;
DWORD m_nTimeout;
// Interface Maps
public:
BEGIN_INTERFACE_PART(MessageFilter, IMessageFilter)
INIT_INTERFACE_PART(COleMessageFilter, MessageFilter)
STDMETHOD_(DWORD, HandleInComingCall)(DWORD, HTASK, DWORD,
LPINTERFACEINFO);
STDMETHOD_(DWORD, RetryRejectedCall)(HTASK, DWORD, DWORD);
STDMETHOD_(DWORD, MessagePending)(HTASK, DWORD, DWORD);
END_INTERFACE_PART(MessageFilter)
DECLARE_INTERFACE_MAP()
};
/////////////////////////////////////////////////////////////////////////////
// message map entries for OLE verbs
#define ON_STDOLEVERB(iVerb, memberFxn) \
{ 0xC002, 0, (UINT)iVerb, (UINT)iVerb, (UINT)-1, \
(AFX_PMSG)(BOOL (AFX_MSG_CALL CCmdTarget::*)(LPMSG, HWND, LPCRECT))&memberFxn },
#define ON_OLEVERB(idsVerbName, memberFxn) \
{ 0xC002, 0, 1, 1, idsVerbName, \
(AFX_PMSG)(BOOL (AFX_MSG_CALL CCmdTarget::*)(LPMSG, HWND, LPCRECT))&memberFxn },
/////////////////////////////////////////////////////////////////////////////
// global helpers and debugging
void AFXAPI AfxOleSetEditMenu(COleClientItem* pClient, CMenu* pMenu,
UINT iMenuItem, UINT nIDVerbMin, UINT nIDVerbMax = 0, UINT nIDConvert = 0);
#ifdef _DEBUG
// Mapping SCODEs to readable text
LPCTSTR AFXAPI AfxGetFullScodeString(SCODE sc);
LPCTSTR AFXAPI AfxGetScodeString(SCODE sc);
LPCTSTR AFXAPI AfxGetScodeRangeString(SCODE sc);
LPCTSTR AFXAPI AfxGetSeverityString(SCODE sc);
LPCTSTR AFXAPI AfxGetFacilityString(SCODE sc);
// Mapping IIDs to readable text
LPCTSTR AFXAPI AfxGetIIDString(REFIID iid);
#endif
/////////////////////////////////////////////////////////////////////////////
// Inline function declarations
#ifdef _AFX_PACKING
#pragma pack(pop)
#endif
#ifdef _AFX_ENABLE_INLINES
#define _AFXOLE_INLINE AFX_INLINE
#define _AFXOLECLI_INLINE AFX_INLINE
#define _AFXOLESVR_INLINE AFX_INLINE
#define _AFXOLEDOBJ_INLINE AFX_INLINE
#define _AFXOLEMONIKER_INLINE AFX_INLINE
#include <afxole.inl>
#undef _AFXOLE_INLINE
#undef _AFXOLECLI_INLINE
#undef _AFXOLESVR_INLINE
#undef _AFXOLEDOBJ_INLINE
#undef _AFXOLEMONIKER_INLINE
#endif
#undef AFX_DATA
#define AFX_DATA
#ifdef _AFX_MINREBUILD
#pragma component(minrebuild, on)
#endif
#ifndef _AFX_FULLTYPEINFO
#pragma component(mintypeinfo, off)
#endif
#endif //__AFXOLE_H__
/////////////////////////////////////////////////////////////////////////////