1 ///////////////////////////////////////////////////////////////////////////////
3 // Purpose: OLE helper routines, OLE debugging support &c
4 // Author: Vadim Zeitlin
8 // Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
9 // Licence: wxWindows licence
10 ///////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_OLEUTILS_H
13 #define _WX_OLEUTILS_H
15 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
16 #pragma interface "oleutils.h"
23 // get IUnknown, REFIID &c
27 // ============================================================================
28 // General purpose functions and macros
29 // ============================================================================
31 // ----------------------------------------------------------------------------
32 // initialize/cleanup OLE
33 // ----------------------------------------------------------------------------
35 // call OleInitialize() or CoInitialize[Ex]() depending on the platform
37 // return true if ok, false otherwise
38 inline bool wxOleInitialize()
40 // we need to initialize OLE library
42 if ( FAILED(::CoInitializeEx(NULL
, COINIT_MULTITHREADED
)) )
44 if ( FAILED(::OleInitialize(NULL
)) )
47 wxLogError(_("Cannot initialize OLE"));
55 inline void wxOleUninitialize()
64 // ----------------------------------------------------------------------------
65 // misc helper functions/macros
66 // ----------------------------------------------------------------------------
68 // release the interface pointer (if !NULL)
69 inline void ReleaseInterface(IUnknown
*pIUnk
)
75 // release the interface pointer (if !NULL) and make it NULL
76 #define RELEASE_AND_NULL(p) if ( (p) != NULL ) { p->Release(); p = NULL; };
78 // return true if the iid is in the array
79 extern bool IsIidFromList(REFIID riid
, const IID
*aIids
[], size_t nCount
);
81 // ============================================================================
82 // IUnknown implementation helpers
83 // ============================================================================
86 The most dumb implementation of IUnknown methods. We don't support
87 aggregation nor containment, but for 99% of cases this simple
88 implementation is quite enough.
90 Usage is trivial: here is all you should have
91 1) DECLARE_IUNKNOWN_METHODS in your (IUnknown derived!) class declaration
92 2) BEGIN/END_IID_TABLE with ADD_IID in between for all interfaces you
93 support (at least all for which you intent to return 'this' from QI,
94 i.e. you should derive from IFoo if you have ADD_IID(Foo)) somewhere else
95 3) IMPLEMENT_IUNKNOWN_METHODS somewhere also
97 These macros are quite simple: AddRef and Release are trivial and QI does
98 lookup in a static member array of IIDs and returns 'this' if it founds
99 the requested interface in it or E_NOINTERFACE if not.
103 wxAutoULong: this class is used for automatically initalising m_cRef to 0
108 wxAutoULong(ULONG value
= 0) : m_Value(value
) { }
110 operator ULONG
&() { return m_Value
; }
111 ULONG
& operator=(ULONG value
) { m_Value
= value
; return m_Value
; }
113 wxAutoULong
& operator++() { ++m_Value
; return *this; }
114 const wxAutoULong
operator++( int ) { wxAutoULong temp
= *this; ++m_Value
; return temp
; }
116 wxAutoULong
& operator--() { --m_Value
; return *this; }
117 const wxAutoULong
operator--( int ) { wxAutoULong temp
= *this; --m_Value
; return temp
; }
123 // declare the methods and the member variable containing reference count
124 // you must also define the ms_aIids array somewhere with BEGIN_IID_TABLE
125 // and friends (see below)
127 #define DECLARE_IUNKNOWN_METHODS \
129 STDMETHODIMP QueryInterface(REFIID, void **); \
130 STDMETHODIMP_(ULONG) AddRef(); \
131 STDMETHODIMP_(ULONG) Release(); \
133 static const IID *ms_aIids[]; \
136 // macros for declaring supported interfaces
137 // NB: you should write ADD_INTERFACE(Foo) and not ADD_INTERFACE(IID_IFoo)!
138 #define BEGIN_IID_TABLE(cname) const IID *cname::ms_aIids[] = {
139 #define ADD_IID(iid) &IID_I##iid,
140 #define END_IID_TABLE }
142 // implementation is as straightforward as possible
143 // Parameter: classname - the name of the class
144 #define IMPLEMENT_IUNKNOWN_METHODS(classname) \
145 STDMETHODIMP classname::QueryInterface(REFIID riid, void **ppv) \
147 wxLogQueryInterface(_T(#classname), riid); \
149 if ( IsIidFromList(riid, ms_aIids, WXSIZEOF(ms_aIids)) ) { \
158 return (HRESULT) E_NOINTERFACE; \
162 STDMETHODIMP_(ULONG) classname::AddRef() \
164 wxLogAddRef(_T(#classname), m_cRef); \
169 STDMETHODIMP_(ULONG) classname::Release() \
171 wxLogRelease(_T(#classname), m_cRef); \
173 if ( --m_cRef == wxAutoULong(0) ) { \
181 // ============================================================================
183 // ============================================================================
185 // VZ: I don't know it's not done for compilers other than VC++ but I leave it
186 // as is. Please note, though, that tracing OLE interface calls may be
187 // incredibly useful when debugging OLE programs.
188 #if defined(__WXDEBUG__) && ( ( defined(__VISUALC__) && (__VISUALC__ >= 1000) ) || defined(__MWERKS__) )
189 // ----------------------------------------------------------------------------
190 // All OLE specific log functions have DebugTrace level (as LogTrace)
191 // ----------------------------------------------------------------------------
193 // tries to translate riid into a symbolic name, if possible
194 void wxLogQueryInterface(const wxChar
*szInterface
, REFIID riid
);
196 // these functions print out the new value of reference counter
197 void wxLogAddRef (const wxChar
*szInterface
, ULONG cRef
);
198 void wxLogRelease(const wxChar
*szInterface
, ULONG cRef
);
201 #define wxLogQueryInterface(szInterface, riid)
202 #define wxLogAddRef(szInterface, cRef)
203 #define wxLogRelease(szInterface, cRef)
206 // wrapper around BSTR type (by Vadim Zeitlin)
208 class WXDLLEXPORT wxBasicString
212 wxBasicString(const char *sz
);
213 wxBasicString(const wxString
& str
);
216 void Init(const char* sz
);
219 // just get the string
220 operator BSTR() const { return m_wzBuf
; }
221 // retrieve a copy of our string - caller must SysFreeString() it later!
222 BSTR
Get() const { return SysAllocString(m_wzBuf
); }
225 // @@@ not implemented (but should be)
226 wxBasicString(const wxBasicString
&);
227 wxBasicString
& operator=(const wxBasicString
&);
229 OLECHAR
*m_wzBuf
; // actual string
233 class WXDLLEXPORT wxVariant
;
235 bool wxConvertVariantToOle(const wxVariant
& variant
, VARIANTARG
& oleVariant
) ;
236 bool wxConvertOleToVariant(const VARIANTARG
& oleVariant
, wxVariant
& variant
) ;
238 // Convert string to Unicode
239 BSTR
wxConvertStringToOle(const wxString
& str
);
241 // Convert string from BSTR to wxString
242 wxString
wxConvertStringFromOle(BSTR bStr
);
246 // ----------------------------------------------------------------------------
247 // stub functions to avoid #if wxUSE_OLE in the main code
248 // ----------------------------------------------------------------------------
250 inline bool wxOleInitialize() { return false; }
251 inline void wxOleUninitialize() { }
253 #endif // wxUSE_OLE/!wxUSE_OLE
255 #endif //_WX_OLEUTILS_H