The com_interface attribute is not needed on derived classes.

Removed the ICOM_CTHIS* macros.
This commit is contained in:
Alexandre Julliard 2003-04-12 00:09:14 +00:00
parent 31e78f479e
commit 2d5519f15c
7 changed files with 245 additions and 247 deletions

View file

@ -139,7 +139,7 @@ VOID WINAPI IMalloc16_fnFree(IMalloc16* iface,SEGPTR pv)
*/
DWORD WINAPI IMalloc16_fnGetSize(const IMalloc16* iface,SEGPTR pv)
{
ICOM_CTHIS(IMalloc16Impl,iface);
ICOM_THIS(IMalloc16Impl,iface);
TRACE("(%p)->GetSize(%08lx)\n",This,pv);
return HeapSize( GetProcessHeap(), 0, MapSL(pv) );
}
@ -148,7 +148,7 @@ DWORD WINAPI IMalloc16_fnGetSize(const IMalloc16* iface,SEGPTR pv)
* IMalloc16_DidAlloc [COMPOBJ.507]
*/
INT16 WINAPI IMalloc16_fnDidAlloc(const IMalloc16* iface,LPVOID pv) {
ICOM_CTHIS(IMalloc16,iface);
ICOM_THIS(IMalloc16,iface);
TRACE("(%p)->DidAlloc(%p)\n",This,pv);
return (INT16)-1;
}

View file

@ -583,8 +583,8 @@ typedef IDispatch *LPDISPATCH;
*/
DEFINE_GUID(IID_IDispatch, 0x00020400, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IDispatch: IUnknown {
struct IDispatch : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetTypeInfoCount(
UINT* pctinfo) = 0;
@ -610,7 +610,7 @@ struct IDispatch: IUnknown {
EXCEPINFO* pExcepInfo,
UINT* puArgErr) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IDispatchVtbl IDispatchVtbl;
struct IDispatch {
@ -767,8 +767,8 @@ typedef IEnumVARIANT *LPENUMVARIANT;
*/
DEFINE_GUID(IID_IEnumVARIANT, 0x00020404, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumVARIANT: IUnknown {
struct IEnumVARIANT : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
VARIANT* rgVar,
@ -783,7 +783,7 @@ struct IEnumVARIANT: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumVARIANT** ppEnum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumVARIANTVtbl IEnumVARIANTVtbl;
struct IEnumVARIANT {
@ -915,8 +915,8 @@ typedef union tagBINDPTR {
*/
DEFINE_GUID(IID_ITypeComp, 0x00020403, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ITypeComp: IUnknown {
struct ITypeComp : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Bind(
LPOLESTR szName,
ULONG lHashVal,
@ -931,7 +931,7 @@ struct ITypeComp: IUnknown {
ITypeInfo** ppTInfo,
ITypeComp** ppTComp) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ITypeCompVtbl ITypeCompVtbl;
struct ITypeComp {
@ -1055,8 +1055,8 @@ typedef ITypeInfo *LPTYPEINFO;
*/
DEFINE_GUID(IID_ITypeInfo, 0x00020401, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ITypeInfo: IUnknown {
struct ITypeInfo : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetTypeAttr(
TYPEATTR** ppTypeAttr) = 0;
@ -1144,7 +1144,7 @@ struct ITypeInfo: IUnknown {
virtual void STDMETHODCALLTYPE ReleaseVarDesc(
VARDESC* pVarDesc) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ITypeInfoVtbl ITypeInfoVtbl;
struct ITypeInfo {
@ -1631,8 +1631,8 @@ typedef ITypeInfo2 *LPTYPEINFO2;
*/
DEFINE_GUID(IID_ITypeInfo2, 0x00020412, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ITypeInfo2: ITypeInfo {
struct ITypeInfo2 : public ITypeInfo
{
virtual HRESULT STDMETHODCALLTYPE GetTypeKind(
TYPEKIND* pTypeKind) = 0;
@ -1700,7 +1700,7 @@ struct ITypeInfo2: ITypeInfo {
UINT index,
CUSTDATA* pCustData) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ITypeInfo2Vtbl ITypeInfo2Vtbl;
struct ITypeInfo2 {
@ -2187,8 +2187,8 @@ typedef struct tagTLIBATTR {
*/
DEFINE_GUID(IID_ITypeLib, 0x00020402, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ITypeLib: IUnknown {
struct ITypeLib : public IUnknown
{
virtual UINT STDMETHODCALLTYPE GetTypeInfoCount(
) = 0;
@ -2232,7 +2232,7 @@ struct ITypeLib: IUnknown {
virtual void STDMETHODCALLTYPE ReleaseTLibAttr(
TLIBATTR* pTLibAttr) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ITypeLibVtbl ITypeLibVtbl;
struct ITypeLib {
@ -2507,8 +2507,8 @@ typedef ITypeLib2 *LPTYPELIB2;
*/
DEFINE_GUID(IID_ITypeLib2, 0x00020411, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ITypeLib2: ITypeLib {
struct ITypeLib2 : public ITypeLib
{
virtual HRESULT STDMETHODCALLTYPE GetCustData(
REFGUID guid,
VARIANT* pVarVal) = 0;
@ -2527,7 +2527,7 @@ struct ITypeLib2: ITypeLib {
virtual HRESULT STDMETHODCALLTYPE GetAllCustData(
CUSTDATA* pCustData) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ITypeLib2Vtbl ITypeLib2Vtbl;
struct ITypeLib2 {
@ -2754,8 +2754,8 @@ typedef enum tagCHANGEKIND {
*/
DEFINE_GUID(IID_ITypeChangeEvents, 0x00020410, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ITypeChangeEvents: IUnknown {
struct ITypeChangeEvents : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE RequestTypeChange(
CHANGEKIND changeKind,
ITypeInfo* pTInfoBefore,
@ -2767,7 +2767,7 @@ struct ITypeChangeEvents: IUnknown {
ITypeInfo* pTInfoAfter,
LPOLESTR pStrName) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ITypeChangeEventsVtbl ITypeChangeEventsVtbl;
struct ITypeChangeEvents {
@ -2854,8 +2854,8 @@ typedef IErrorInfo *LPERRORINFO;
*/
DEFINE_GUID(IID_IErrorInfo, 0x1cf2b120, 0x547d, 0x101b, 0x8e,0x65, 0x08,0x00,0x2b,0x2b,0xd1,0x19);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IErrorInfo: IUnknown {
struct IErrorInfo : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetGUID(
GUID* pGUID) = 0;
@ -2871,7 +2871,7 @@ struct IErrorInfo: IUnknown {
virtual HRESULT STDMETHODCALLTYPE GetHelpContext(
DWORD* pdwHelpContext) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IErrorInfoVtbl IErrorInfoVtbl;
struct IErrorInfo {
@ -2990,8 +2990,8 @@ typedef ICreateErrorInfo *LPCREATEERRORINFO;
*/
DEFINE_GUID(IID_ICreateErrorInfo, 0x22f03340, 0x547d, 0x101b, 0x8e,0x65, 0x08,0x00,0x2b,0x2b,0xd1,0x19);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ICreateErrorInfo: IUnknown {
struct ICreateErrorInfo : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE SetGUID(
REFGUID rguid) = 0;
@ -3007,7 +3007,7 @@ struct ICreateErrorInfo: IUnknown {
virtual HRESULT STDMETHODCALLTYPE SetHelpContext(
DWORD dwHelpContext) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ICreateErrorInfoVtbl ICreateErrorInfoVtbl;
struct ICreateErrorInfo {
@ -3126,12 +3126,12 @@ typedef ISupportErrorInfo *LPSUPPORTERRORINFO;
*/
DEFINE_GUID(IID_ISupportErrorInfo, 0xdf0b3d60, 0x548f, 0x101b, 0x8e,0x65, 0x08,0x00,0x2b,0x2b,0xd1,0x19);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ISupportErrorInfo: IUnknown {
struct ISupportErrorInfo : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE InterfaceSupportsErrorInfo(
REFIID riid) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ISupportErrorInfoVtbl ISupportErrorInfoVtbl;
struct ISupportErrorInfo {
@ -3192,14 +3192,14 @@ typedef struct ITypeFactory ITypeFactory;
*/
DEFINE_GUID(IID_ITypeFactory, 0x0000002e, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ITypeFactory: IUnknown {
struct ITypeFactory : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE CreateFromTypeInfo(
ITypeInfo* pTypeInfo,
REFIID riid,
IUnknown** ppv) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ITypeFactoryVtbl ITypeFactoryVtbl;
struct ITypeFactory {
@ -3264,8 +3264,8 @@ typedef struct ITypeMarshal ITypeMarshal;
*/
DEFINE_GUID(IID_ITypeMarshal, 0x0000002d, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ITypeMarshal: IUnknown {
struct ITypeMarshal : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Size(
PVOID pvType,
DWORD dwDestContext,
@ -3290,7 +3290,7 @@ struct ITypeMarshal: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Free(
PVOID pvType) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ITypeMarshalVtbl ITypeMarshalVtbl;
struct ITypeMarshal {
@ -3418,8 +3418,8 @@ typedef IRecordInfo *LPRECORDINFO;
*/
DEFINE_GUID(IID_IRecordInfo, 0x0000002f, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRecordInfo: IUnknown {
struct IRecordInfo : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE RecordInit(
PVOID pvNew) = 0;
@ -3482,7 +3482,7 @@ struct IRecordInfo: IUnknown {
virtual HRESULT STDMETHODCALLTYPE RecordDestroy(
PVOID pvRecord) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRecordInfoVtbl IRecordInfoVtbl;
struct IRecordInfo {
@ -3781,8 +3781,8 @@ typedef ICreateTypeInfo *LPCREATETYPEINFO;
*/
DEFINE_GUID(IID_ICreateTypeInfo, 0x00020405, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ICreateTypeInfo: IUnknown {
struct ICreateTypeInfo : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE SetGuid(
REFGUID guid) = 0;
@ -3868,7 +3868,7 @@ struct ICreateTypeInfo: IUnknown {
virtual HRESULT STDMETHODCALLTYPE LayOut(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ICreateTypeInfoVtbl ICreateTypeInfoVtbl;
struct ICreateTypeInfo {
@ -4269,8 +4269,8 @@ typedef ICreateTypeInfo2 *LPCREATETYPEINFO2;
*/
DEFINE_GUID(IID_ICreateTypeInfo2, 0x0002040e, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ICreateTypeInfo2: ICreateTypeInfo {
struct ICreateTypeInfo2 : public ICreateTypeInfo
{
virtual HRESULT STDMETHODCALLTYPE DeleteFuncDesc(
UINT index) = 0;
@ -4329,7 +4329,7 @@ struct ICreateTypeInfo2: ICreateTypeInfo {
virtual HRESULT STDMETHODCALLTYPE SetName(
LPOLESTR szName) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ICreateTypeInfo2Vtbl ICreateTypeInfo2Vtbl;
struct ICreateTypeInfo2 {
@ -4768,8 +4768,8 @@ typedef ICreateTypeLib *LPCREATETYPELIB;
*/
DEFINE_GUID(IID_ICreateTypeLib, 0x00020406, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ICreateTypeLib: IUnknown {
struct ICreateTypeLib : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE CreateTypeInfo(
LPOLESTR szName,
TYPEKIND tkind,
@ -4803,7 +4803,7 @@ struct ICreateTypeLib: IUnknown {
virtual HRESULT STDMETHODCALLTYPE SaveAllChanges(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ICreateTypeLibVtbl ICreateTypeLibVtbl;
struct ICreateTypeLib {
@ -4996,8 +4996,8 @@ typedef ICreateTypeLib2 *LPCREATETYPELIB2;
*/
DEFINE_GUID(IID_ICreateTypeLib2, 0x0002040f, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ICreateTypeLib2: ICreateTypeLib {
struct ICreateTypeLib2 : public ICreateTypeLib
{
virtual HRESULT STDMETHODCALLTYPE DeleteTypeInfo(
LPOLESTR szName) = 0;
@ -5011,7 +5011,7 @@ struct ICreateTypeLib2: ICreateTypeLib {
virtual HRESULT STDMETHODCALLTYPE SetHelpStringDll(
LPOLESTR szFileName) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ICreateTypeLib2Vtbl ICreateTypeLib2Vtbl;
struct ICreateTypeLib2 {

View file

@ -246,7 +246,11 @@
#define THIS void
#define interface struct
#ifdef ICOM_USE_COM_INTERFACE_ATTRIBUTE
#define DECLARE_INTERFACE(iface) interface __attribute__((com_interface)) iface
#else
#define DECLARE_INTERFACE(iface) interface iface
#endif
#define DECLARE_INTERFACE_(iface,ibase) interface iface : public ibase
#define BEGIN_INTERFACE
@ -293,17 +297,11 @@
/* Wine-specific macros */
#define ICOM_DEFINE(iface,ibase) \
DECLARE_INTERFACE_(iface,ibase) { iface##_METHODS } ICOM_COM_INTERFACE_ATTRIBUTE;
#define ICOM_DEFINE(iface,ibase) DECLARE_INTERFACE_(iface,ibase) { iface##_METHODS };
#define ICOM_VTABLE(iface) iface##Vtbl
#define ICOM_VFIELD(iface) ICOM_VTABLE(iface)* lpVtbl
#define ICOM_THIS(impl,iface) impl* const This=(impl*)(iface)
#define ICOM_CTHIS(impl,iface) const impl* const This=(const impl*)(iface)
#define ICOM_THIS(impl,iface) impl* const This=(impl*)(iface)
#define ICOM_THIS_MULTI(impl,field,iface) impl* const This=(impl*)((char*)(iface) - offsetof(impl,field))
#define ICOM_CTHIS_MULTI(impl,field,iface) const impl* const This=(const impl*)((char*)(iface) - offsetof(impl,field))
#include "objidl.h"

View file

@ -23,8 +23,8 @@ typedef IMarshal *LPMARSHAL;
*/
DEFINE_GUID(IID_IMarshal, 0x00000003, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IMarshal: IUnknown {
struct IMarshal : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetUnmarshalClass(
REFIID riid,
void* pv,
@ -60,7 +60,7 @@ struct IMarshal: IUnknown {
virtual HRESULT STDMETHODCALLTYPE DisconnectObject(
DWORD dwReserved) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IMarshalVtbl IMarshalVtbl;
struct IMarshal {
@ -227,14 +227,14 @@ typedef IStdMarshalInfo *LPSTDMARSHALINFO;
*/
DEFINE_GUID(IID_IStdMarshalInfo, 0x00000018, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IStdMarshalInfo: IUnknown {
struct IStdMarshalInfo : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetClassForHandler(
DWORD dwDestContext,
void* pvDestContext,
CLSID* pClsid) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IStdMarshalInfoVtbl IStdMarshalInfoVtbl;
struct IStdMarshalInfo {
@ -307,8 +307,8 @@ typedef enum tagEXTCONN {
*/
DEFINE_GUID(IID_IExternalConnection, 0x00000019, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IExternalConnection: IUnknown {
struct IExternalConnection : public IUnknown
{
virtual DWORD STDMETHODCALLTYPE AddConnection(
DWORD extconn,
DWORD reserved) = 0;
@ -318,7 +318,7 @@ struct IExternalConnection: IUnknown {
DWORD reserved,
BOOL fLastReleaseCloses) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IExternalConnectionVtbl IExternalConnectionVtbl;
struct IExternalConnection {
@ -407,13 +407,13 @@ typedef struct tagMULTI_QI {
*/
DEFINE_GUID(IID_IMultiQI, 0x00000020, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IMultiQI: IUnknown {
struct IMultiQI : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE QueryMultipleInterfaces(
ULONG cMQIs,
MULTI_QI* pMQIs) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IMultiQIVtbl IMultiQIVtbl;
struct IMultiQI {
@ -478,8 +478,8 @@ typedef IMalloc *LPMALLOC;
*/
DEFINE_GUID(IID_IMalloc, 0x00000002, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IMalloc: IUnknown {
struct IMalloc : public IUnknown
{
virtual LPVOID STDMETHODCALLTYPE Alloc(
ULONG cb) = 0;
@ -499,7 +499,7 @@ struct IMalloc: IUnknown {
virtual void STDMETHODCALLTYPE HeapMinimize(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IMallocVtbl IMallocVtbl;
struct IMalloc {
@ -632,8 +632,8 @@ typedef IMallocSpy *LPMALLOCSPY;
*/
DEFINE_GUID(IID_IMallocSpy, 0x0000001d, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IMallocSpy: IUnknown {
struct IMallocSpy : public IUnknown
{
virtual ULONG STDMETHODCALLTYPE PreAlloc(
ULONG cbRequest) = 0;
@ -680,7 +680,7 @@ struct IMallocSpy: IUnknown {
virtual void STDMETHODCALLTYPE PostHeapMinimize(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IMallocSpyVtbl IMallocSpyVtbl;
struct IMallocSpy {
@ -913,8 +913,8 @@ typedef IEnumUnknown *LPENUMUNKNOWN;
*/
DEFINE_GUID(IID_IEnumUnknown, 0x00000100, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumUnknown: IUnknown {
struct IEnumUnknown : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
IUnknown** rgelt,
@ -929,7 +929,7 @@ struct IEnumUnknown: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumUnknown** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumUnknownVtbl IEnumUnknownVtbl;
struct IEnumUnknown {
@ -1046,15 +1046,15 @@ typedef ISurrogate *LPSURROGATE;
*/
DEFINE_GUID(IID_ISurrogate, 0x00000022, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ISurrogate: IUnknown {
struct ISurrogate : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE LoadDllServer(
REFCLSID Clsid) = 0;
virtual HRESULT STDMETHODCALLTYPE FreeSurrogate(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ISurrogateVtbl ISurrogateVtbl;
struct ISurrogate {
@ -1129,8 +1129,8 @@ typedef IGlobalInterfaceTable *LPGLOBALINTERFACETABLE;
*/
DEFINE_GUID(IID_IGlobalInterfaceTable, 0x00000146, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IGlobalInterfaceTable: IUnknown {
struct IGlobalInterfaceTable : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE RegisterInterfaceInGlobal(
IUnknown* pUnk,
REFIID riid,
@ -1144,7 +1144,7 @@ struct IGlobalInterfaceTable: IUnknown {
REFIID riid,
void** ppv) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IGlobalInterfaceTableVtbl IGlobalInterfaceTableVtbl;
struct IGlobalInterfaceTable {
@ -1268,8 +1268,8 @@ typedef enum tagBIND_FLAGS {
*/
DEFINE_GUID(IID_IBindCtx, 0x0000000e, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IBindCtx: IUnknown {
struct IBindCtx : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE RegisterObjectBound(
IUnknown* punk) = 0;
@ -1302,7 +1302,7 @@ struct IBindCtx: IUnknown {
virtual HRESULT STDMETHODCALLTYPE RevokeObjectParam(
LPOLESTR pszKey) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IBindCtxVtbl IBindCtxVtbl;
struct IBindCtx {
@ -1505,8 +1505,8 @@ typedef IEnumMoniker *LPENUMMONIKER;
*/
DEFINE_GUID(IID_IEnumMoniker, 0x00000102, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumMoniker: IUnknown {
struct IEnumMoniker : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
IMoniker** rgelt,
@ -1521,7 +1521,7 @@ struct IEnumMoniker: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumMoniker** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumMonikerVtbl IEnumMonikerVtbl;
struct IEnumMoniker {
@ -1638,8 +1638,8 @@ typedef IRunnableObject *LPRUNNABLEOBJECT;
*/
DEFINE_GUID(IID_IRunnableObject, 0x00000126, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRunnableObject: IUnknown {
struct IRunnableObject : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetRunningClass(
LPCLSID lpClsid) = 0;
@ -1656,7 +1656,7 @@ struct IRunnableObject: IUnknown {
virtual HRESULT STDMETHODCALLTYPE SetContainedObject(
BOOL fContained) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRunnableObjectVtbl IRunnableObjectVtbl;
struct IRunnableObject {
@ -1781,8 +1781,8 @@ typedef IRunningObjectTable *LPRUNNINGOBJECTTABLE;
*/
DEFINE_GUID(IID_IRunningObjectTable, 0x00000010, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRunningObjectTable: IUnknown {
struct IRunningObjectTable : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Register(
DWORD grfFlags,
IUnknown* punkObject,
@ -1810,7 +1810,7 @@ struct IRunningObjectTable: IUnknown {
virtual HRESULT STDMETHODCALLTYPE EnumRunning(
IEnumMoniker** ppenumMoniker) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRunningObjectTableVtbl IRunningObjectTableVtbl;
struct IRunningObjectTable {
@ -1969,12 +1969,12 @@ typedef IPersist *LPPERSIST;
*/
DEFINE_GUID(IID_IPersist, 0x0000010c, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IPersist: IUnknown {
struct IPersist : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetClassID(
CLSID* pClassID) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IPersistVtbl IPersistVtbl;
struct IPersist {
@ -2037,8 +2037,8 @@ typedef IPersistStream *LPPERSISTSTREAM;
*/
DEFINE_GUID(IID_IPersistStream, 0x00000109, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IPersistStream: IPersist {
struct IPersistStream : public IPersist
{
virtual HRESULT STDMETHODCALLTYPE IsDirty(
) = 0;
@ -2052,7 +2052,7 @@ struct IPersistStream: IPersist {
virtual HRESULT STDMETHODCALLTYPE GetSizeMax(
ULARGE_INTEGER* pcbSize) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IPersistStreamVtbl IPersistStreamVtbl;
struct IPersistStream {
@ -2182,8 +2182,8 @@ typedef enum tagMKREDUCE {
*/
DEFINE_GUID(IID_IMoniker, 0x0000000f, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IMoniker: IPersistStream {
struct IMoniker : public IPersistStream
{
virtual HRESULT STDMETHODCALLTYPE BindToObject(
IBindCtx* pbc,
IMoniker* pmkToLeft,
@ -2253,7 +2253,7 @@ struct IMoniker: IPersistStream {
virtual HRESULT STDMETHODCALLTYPE IsSystemMoniker(
DWORD* pdwMksys) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IMonikerVtbl IMonikerVtbl;
struct IMoniker {
@ -2618,14 +2618,14 @@ typedef struct IROTData IROTData;
*/
DEFINE_GUID(IID_IROTData, 0xf29f6bc0, 0x5021, 0x11ce, 0xaa,0x15, 0x00,0x00,0x69,0x01,0x29,0x3f);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IROTData: IUnknown {
struct IROTData : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetComparisonData(
byte* pbData,
ULONG cbMax,
ULONG* pcbData) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IROTDataVtbl IROTDataVtbl;
struct IROTData {
@ -2691,8 +2691,8 @@ typedef IEnumString *LPENUMSTRING;
*/
DEFINE_GUID(IID_IEnumString, 0x00000101, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumString: IUnknown {
struct IEnumString : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
LPOLESTR* rgelt,
@ -2707,7 +2707,7 @@ struct IEnumString: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumString** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumStringVtbl IEnumStringVtbl;
struct IEnumString {
@ -2822,8 +2822,8 @@ typedef struct IClassActivator IClassActivator;
*/
DEFINE_GUID(IID_IClassActivator, 0x00000140, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IClassActivator: IUnknown {
struct IClassActivator : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetClassObject(
REFCLSID rclsid,
DWORD dwClassContext,
@ -2831,7 +2831,7 @@ struct IClassActivator: IUnknown {
REFIID riid,
void** ppv) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IClassActivatorVtbl IClassActivatorVtbl;
struct IClassActivator {
@ -2900,8 +2900,8 @@ typedef struct ISequentialStream ISequentialStream;
*/
DEFINE_GUID(IID_ISequentialStream, 0x0c733a30, 0x2a1c, 0x11ce, 0xad,0xe5, 0x00,0xaa,0x00,0x44,0x77,0x3d);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ISequentialStream: IUnknown {
struct ISequentialStream : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Read(
void* pv,
ULONG cb,
@ -2912,7 +2912,7 @@ struct ISequentialStream: IUnknown {
ULONG cb,
ULONG* pcbWritten) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ISequentialStreamVtbl ISequentialStreamVtbl;
struct ISequentialStream {
@ -3053,8 +3053,8 @@ typedef enum tagLOCKTYPE {
*/
DEFINE_GUID(IID_IStream, 0x0000000c, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IStream: ISequentialStream {
struct IStream : public ISequentialStream
{
virtual HRESULT STDMETHODCALLTYPE Seek(
LARGE_INTEGER dlibMove,
DWORD dwOrigin,
@ -3092,7 +3092,7 @@ struct IStream: ISequentialStream {
virtual HRESULT STDMETHODCALLTYPE Clone(
IStream** ppstm) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IStreamVtbl IStreamVtbl;
struct IStream {
@ -3338,8 +3338,8 @@ typedef struct tagSTATSTG16 {
* IStream16 interface
*/
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IStream16: ISequentialStream {
struct IStream16 : public ISequentialStream
{
virtual HRESULT STDMETHODCALLTYPE Seek(
LARGE_INTEGER dlibMove,
DWORD dwOrigin,
@ -3377,7 +3377,7 @@ struct IStream16: ISequentialStream {
virtual HRESULT STDMETHODCALLTYPE Clone(
IStream16** ppstm) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IStream16Vtbl IStream16Vtbl;
struct IStream16 {
@ -3611,8 +3611,8 @@ typedef IEnumSTATSTG *LPENUMSTATSTG;
*/
DEFINE_GUID(IID_IEnumSTATSTG, 0x0000000d, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumSTATSTG: IUnknown {
struct IEnumSTATSTG : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
STATSTG* rgelt,
@ -3627,7 +3627,7 @@ struct IEnumSTATSTG: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumSTATSTG** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumSTATSTGVtbl IEnumSTATSTGVtbl;
struct IEnumSTATSTG {
@ -3758,8 +3758,8 @@ void __RPC_USER SNB_UserFree (unsigned long *, SNB *);
*/
DEFINE_GUID(IID_IStorage, 0x0000000b, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IStorage: IUnknown {
struct IStorage : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE CreateStream(
LPCOLESTR pwcsName,
DWORD grfMode,
@ -3837,7 +3837,7 @@ struct IStorage: IUnknown {
STATSTG* pstatstg,
DWORD grfStatFlag) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IStorageVtbl IStorageVtbl;
struct IStorage {
@ -4201,8 +4201,8 @@ void __RPC_USER SNB16_UserFree (unsigned long *, SNB16 *);
* IStorage16 interface
*/
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IStorage16: IUnknown {
struct IStorage16 : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE CreateStream(
LPCOLESTR16 pwcsName,
DWORD grfMode,
@ -4280,7 +4280,7 @@ struct IStorage16: IUnknown {
STATSTG* pstatstg,
DWORD grfStatFlag) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IStorage16Vtbl IStorage16Vtbl;
struct IStorage16 {
@ -4631,8 +4631,8 @@ typedef IPersistFile *LPPERSISTFILE;
*/
DEFINE_GUID(IID_IPersistFile, 0x0000010b, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IPersistFile: IPersist {
struct IPersistFile : public IPersist
{
virtual HRESULT STDMETHODCALLTYPE IsDirty(
) = 0;
@ -4650,7 +4650,7 @@ struct IPersistFile: IPersist {
virtual HRESULT STDMETHODCALLTYPE GetCurFile(
LPOLESTR* ppszFileName) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IPersistFileVtbl IPersistFileVtbl;
struct IPersistFile {
@ -4780,8 +4780,8 @@ typedef IPersistStorage *LPPERSISTSTORAGE;
*/
DEFINE_GUID(IID_IPersistStorage, 0x0000010a, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IPersistStorage: IPersist {
struct IPersistStorage : public IPersist
{
virtual HRESULT STDMETHODCALLTYPE IsDirty(
) = 0;
@ -4801,7 +4801,7 @@ struct IPersistStorage: IPersist {
virtual HRESULT STDMETHODCALLTYPE HandsOffStorage(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IPersistStorageVtbl IPersistStorageVtbl;
struct IPersistStorage {
@ -4941,12 +4941,12 @@ typedef IRootStorage *LPROOTSTORAGE;
*/
DEFINE_GUID(IID_IRootStorage, 0x00000012, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRootStorage: IUnknown {
struct IRootStorage : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE SwitchToFile(
LPOLESTR pszFile) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRootStorageVtbl IRootStorageVtbl;
struct IRootStorage {
@ -5009,8 +5009,8 @@ typedef ILockBytes *LPLOCKBYTES;
*/
DEFINE_GUID(IID_ILockBytes, 0x0000000a, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ILockBytes: IUnknown {
struct ILockBytes : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE ReadAt(
ULARGE_INTEGER ulOffset,
void* pv,
@ -5043,7 +5043,7 @@ struct ILockBytes: IUnknown {
STATSTG* pstatstg,
DWORD grfStatFlag) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ILockBytesVtbl ILockBytesVtbl;
struct ILockBytes {
@ -5232,8 +5232,8 @@ typedef struct IFillLockBytes IFillLockBytes;
*/
DEFINE_GUID(IID_IFillLockBytes, 0x99caf010, 0x415e, 0x11cf, 0x88,0x14, 0x00,0xaa,0x00,0xb5,0x69,0xf5);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IFillLockBytes: IUnknown {
struct IFillLockBytes : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE FillAppend(
const void* pv,
ULONG cb,
@ -5251,7 +5251,7 @@ struct IFillLockBytes: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Terminate(
BOOL bCanceled) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IFillLockBytesVtbl IFillLockBytesVtbl;
struct IFillLockBytes {
@ -5386,15 +5386,15 @@ typedef struct IProgressNotify IProgressNotify;
*/
DEFINE_GUID(IID_IProgressNotify, 0xa9d758a0, 0x4617, 0x11cf, 0x95,0xfc, 0x00,0xaa,0x00,0x68,0x0d,0xb4);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IProgressNotify: IUnknown {
struct IProgressNotify : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE OnProgress(
DWORD dwProgressCurrent,
DWORD dwProgressMaximum,
BOOL fAccurate,
BOOL fOwner) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IProgressNotifyVtbl IProgressNotifyVtbl;
struct IProgressNotify {
@ -5468,8 +5468,8 @@ typedef struct tagStorageLayout {
*/
DEFINE_GUID(IID_ILayoutStorage, 0x0e6d4d90, 0x6738, 0x11cf, 0x96,0x08, 0x00,0xaa,0x00,0x68,0x0d,0xb4);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct ILayoutStorage: IUnknown {
struct ILayoutStorage : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE LayoutScript(
StorageLayout* pStorageLayout,
DWORD nEntries,
@ -5487,7 +5487,7 @@ struct ILayoutStorage: IUnknown {
virtual HRESULT STDMETHODCALLTYPE ReLayoutDocfileOnILockBytes(
ILockBytes* pILockBytes) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct ILayoutStorageVtbl ILayoutStorageVtbl;
struct ILayoutStorage {
@ -5625,8 +5625,8 @@ typedef struct tagFORMATETC {
*/
DEFINE_GUID(IID_IEnumFORMATETC, 0x00000103, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumFORMATETC: IUnknown {
struct IEnumFORMATETC : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
FORMATETC* rgelt,
@ -5641,7 +5641,7 @@ struct IEnumFORMATETC: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumFORMATETC** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumFORMATETCVtbl IEnumFORMATETCVtbl;
struct IEnumFORMATETC {
@ -5775,8 +5775,8 @@ typedef struct tagSTATDATA {
*/
DEFINE_GUID(IID_IEnumSTATDATA, 0x00000105, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumSTATDATA: IUnknown {
struct IEnumSTATDATA : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
STATDATA* rgelt,
@ -5791,7 +5791,7 @@ struct IEnumSTATDATA: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumSTATDATA** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumSTATDATAVtbl IEnumSTATDATAVtbl;
struct IEnumSTATDATA {
@ -6002,8 +6002,8 @@ void __RPC_USER FLAG_STGMEDIUM_UserFree (unsigned long *, FLAG_ST
*/
DEFINE_GUID(IID_IAdviseSink, 0x0000010f, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IAdviseSink: IUnknown {
struct IAdviseSink : public IUnknown
{
virtual void STDMETHODCALLTYPE OnDataChange(
FORMATETC* pFormatetc,
STGMEDIUM* pStgmed) = 0;
@ -6021,7 +6021,7 @@ struct IAdviseSink: IUnknown {
virtual void STDMETHODCALLTYPE OnClose(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IAdviseSinkVtbl IAdviseSinkVtbl;
struct IAdviseSink {
@ -6178,12 +6178,12 @@ typedef IAdviseSink2 *LPADVISESINK2;
*/
DEFINE_GUID(IID_IAdviseSink2, 0x00000125, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IAdviseSink2: IAdviseSink {
struct IAdviseSink2 : public IAdviseSink
{
virtual void STDMETHODCALLTYPE OnLinkSrcChange(
IMoniker* pmk) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IAdviseSink2Vtbl IAdviseSink2Vtbl;
struct IAdviseSink2 {
@ -6292,8 +6292,8 @@ typedef enum tagDATADIR {
*/
DEFINE_GUID(IID_IDataObject, 0x0000010e, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IDataObject: IUnknown {
struct IDataObject : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetData(
FORMATETC* pformatetcIn,
STGMEDIUM* pmedium) = 0;
@ -6330,7 +6330,7 @@ struct IDataObject: IUnknown {
virtual HRESULT STDMETHODCALLTYPE EnumDAdvise(
IEnumSTATDATA** ppenumAdvise) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IDataObjectVtbl IDataObjectVtbl;
struct IDataObject {
@ -6549,8 +6549,8 @@ typedef IDataAdviseHolder *LPDATAADVISEHOLDER;
*/
DEFINE_GUID(IID_IDataAdviseHolder, 0x00000110, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IDataAdviseHolder: IUnknown {
struct IDataAdviseHolder : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Advise(
IDataObject* pDataObject,
FORMATETC* pFetc,
@ -6569,7 +6569,7 @@ struct IDataAdviseHolder: IUnknown {
DWORD dwReserved,
DWORD advf) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IDataAdviseHolderVtbl IDataAdviseHolderVtbl;
struct IDataAdviseHolder {
@ -6717,8 +6717,8 @@ typedef struct tagINTERFACEINFO {
*/
DEFINE_GUID(IID_IMessageFilter, 0x00000016, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IMessageFilter: IUnknown {
struct IMessageFilter : public IUnknown
{
virtual DWORD STDMETHODCALLTYPE HandleInComingCall(
DWORD dwCallType,
HTASK htaskCaller,
@ -6735,7 +6735,7 @@ struct IMessageFilter: IUnknown {
DWORD dwTickCount,
DWORD dwPendingType) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IMessageFilterVtbl IMessageFilterVtbl;
struct IMessageFilter {
@ -6854,8 +6854,8 @@ typedef RPCOLEMESSAGE *PRPCOLEMESSAGE;
*/
DEFINE_GUID(IID_IRpcChannelBuffer, 0xd5f56b60, 0x593b, 0x101a, 0xb5,0x69, 0x08,0x00,0x2b,0x2d,0xbf,0x7a);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRpcChannelBuffer: IUnknown {
struct IRpcChannelBuffer : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetBuffer(
RPCOLEMESSAGE* pMessage,
REFIID riid) = 0;
@ -6874,7 +6874,7 @@ struct IRpcChannelBuffer: IUnknown {
virtual HRESULT STDMETHODCALLTYPE IsConnected(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRpcChannelBufferVtbl IRpcChannelBufferVtbl;
struct IRpcChannelBuffer {
@ -6997,12 +6997,12 @@ typedef IRpcChannelBuffer2 *LPRPCCHANNELBUFFER2;
*/
DEFINE_GUID(IID_IRpcChannelBuffer2, 0x594f31d0, 0x7f19, 0x11d0, 0xb1,0x94, 0x00,0xa0,0xc9,0x0d,0xc8,0xbf);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRpcChannelBuffer2: IRpcChannelBuffer {
struct IRpcChannelBuffer2 : public IRpcChannelBuffer
{
virtual HRESULT STDMETHODCALLTYPE GetProtocolVersion(
DWORD* pdwVersion) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRpcChannelBuffer2Vtbl IRpcChannelBuffer2Vtbl;
struct IRpcChannelBuffer2 {
@ -7100,8 +7100,8 @@ typedef IRpcChannelBuffer3 *LPRPCCHANNELBUFFER3;
*/
DEFINE_GUID(IID_IRpcChannelBuffer3, 0x25b15600, 0x0115, 0x11d0, 0xbf,0x0d, 0x00,0xaa,0x00,0xb8,0xdf,0xd2);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRpcChannelBuffer3: IRpcChannelBuffer2 {
struct IRpcChannelBuffer3 : public IRpcChannelBuffer2
{
virtual HRESULT STDMETHODCALLTYPE Send(
RPCOLEMESSAGE* pMsg,
ULONG* pulStatus) = 0;
@ -7132,7 +7132,7 @@ struct IRpcChannelBuffer3: IRpcChannelBuffer2 {
RPCOLEMESSAGE* pMsg,
IAsyncManager* pAsyncMgr) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRpcChannelBuffer3Vtbl IRpcChannelBuffer3Vtbl;
struct IRpcChannelBuffer3 {
@ -7341,15 +7341,15 @@ typedef IRpcProxyBuffer *LPRPCPROXYBUFFER;
*/
DEFINE_GUID(IID_IRpcProxyBuffer, 0xd5f56a34, 0x593b, 0x101a, 0xb5,0x69, 0x08,0x00,0x2b,0x2d,0xbf,0x7a);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRpcProxyBuffer: IUnknown {
struct IRpcProxyBuffer : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Connect(
IRpcChannelBuffer* pRpcChannelBuffer) = 0;
virtual void STDMETHODCALLTYPE Disconnect(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRpcProxyBufferVtbl IRpcProxyBufferVtbl;
struct IRpcProxyBuffer {
@ -7424,8 +7424,8 @@ typedef IRpcStubBuffer *LPRPCSTUBBUFFER;
*/
DEFINE_GUID(IID_IRpcStubBuffer, 0xd5f56afc, 0x593b, 0x101a, 0xb5,0x69, 0x08,0x00,0x2b,0x2d,0xbf,0x7a);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IRpcStubBuffer: IUnknown {
struct IRpcStubBuffer : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Connect(
IUnknown* pUnkServer) = 0;
@ -7448,7 +7448,7 @@ struct IRpcStubBuffer: IUnknown {
virtual void STDMETHODCALLTYPE DebugServerRelease(
void* pv) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IRpcStubBufferVtbl IRpcStubBufferVtbl;
struct IRpcStubBuffer {
@ -7593,8 +7593,8 @@ typedef IPSFactoryBuffer *LPPSFACTORYBUFFER;
*/
DEFINE_GUID(IID_IPSFactoryBuffer, 0xd5f569d0, 0x593b, 0x101a, 0xb5,0x69, 0x08,0x00,0x2b,0x2d,0xbf,0x7a);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IPSFactoryBuffer: IUnknown {
struct IPSFactoryBuffer : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE CreateProxy(
IUnknown* pUnkOuter,
REFIID riid,
@ -7606,7 +7606,7 @@ struct IPSFactoryBuffer: IUnknown {
IUnknown* pUnkServer,
IRpcStubBuffer** ppStub) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IPSFactoryBufferVtbl IPSFactoryBufferVtbl;
struct IPSFactoryBuffer {
@ -7702,8 +7702,8 @@ typedef struct SChannelHookCallInfo {
*/
DEFINE_GUID(IID_IChannelHook, 0x1008c4a0, 0x7613, 0x11cf, 0x9a,0xf1, 0x00,0x20,0xaf,0x6e,0x72,0xf4);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IChannelHook: IUnknown {
struct IChannelHook : public IUnknown
{
virtual void STDMETHODCALLTYPE ClientGetSize(
REFGUID uExtent,
REFIID riid,
@ -7743,7 +7743,7 @@ struct IChannelHook: IUnknown {
void* pDataBuffer,
HRESULT hrFault) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IChannelHookVtbl IChannelHookVtbl;
struct IChannelHook {
@ -8126,8 +8126,8 @@ typedef struct tagSTATPROPSETSTG {
*/
DEFINE_GUID(IID_IPropertyStorage, 0x00000138, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IPropertyStorage: IUnknown {
struct IPropertyStorage : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE ReadMultiple(
ULONG cpspec,
const PROPSPEC rgpspec[],
@ -8177,7 +8177,7 @@ struct IPropertyStorage: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Stat(
STATPROPSETSTG* statpsstg) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IPropertyStorageVtbl IPropertyStorageVtbl;
struct IPropertyStorage {
@ -8418,8 +8418,8 @@ typedef IPropertySetStorage *LPPROPERTYSETSTORAGE;
*/
DEFINE_GUID(IID_IPropertySetStorage, 0x0000013a, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IPropertySetStorage: IUnknown {
struct IPropertySetStorage : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Create(
REFFMTID rfmtid,
const CLSID* pclsid,
@ -8438,7 +8438,7 @@ struct IPropertySetStorage: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Enum(
IEnumSTATPROPSETSTG** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IPropertySetStorageVtbl IPropertySetStorageVtbl;
struct IPropertySetStorage {
@ -8554,8 +8554,8 @@ typedef IEnumSTATPROPSTG *LPENUMSTATPROPSTG;
*/
DEFINE_GUID(IID_IEnumSTATPROPSTG, 0x00000139, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumSTATPROPSTG: IUnknown {
struct IEnumSTATPROPSTG : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
STATPROPSTG* rgelt,
@ -8570,7 +8570,7 @@ struct IEnumSTATPROPSTG: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumSTATPROPSTG** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumSTATPROPSTGVtbl IEnumSTATPROPSTGVtbl;
struct IEnumSTATPROPSTG {
@ -8686,8 +8686,8 @@ typedef IEnumSTATPROPSETSTG *LPENUMSTATPROPSETSTG;
*/
DEFINE_GUID(IID_IEnumSTATPROPSETSTG, 0x0000013b, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IEnumSTATPROPSETSTG: IUnknown {
struct IEnumSTATPROPSETSTG : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE Next(
ULONG celt,
STATPROPSETSTG* rgelt,
@ -8702,7 +8702,7 @@ struct IEnumSTATPROPSETSTG: IUnknown {
virtual HRESULT STDMETHODCALLTYPE Clone(
IEnumSTATPROPSETSTG** ppenum) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IEnumSTATPROPSETSTGVtbl IEnumSTATPROPSETSTGVtbl;
struct IEnumSTATPROPSETSTG {
@ -8835,8 +8835,8 @@ typedef enum tagEOLE_AUTHENTICATION_CAPABILITIES {
*/
DEFINE_GUID(IID_IClientSecurity, 0x0000013d, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IClientSecurity: IUnknown {
struct IClientSecurity : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE QueryBlanket(
IUnknown* pProxy,
DWORD* pAuthnSvc,
@ -8861,7 +8861,7 @@ struct IClientSecurity: IUnknown {
IUnknown* pProxy,
IUnknown** ppCopy) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IClientSecurityVtbl IClientSecurityVtbl;
struct IClientSecurity {
@ -8980,8 +8980,8 @@ typedef struct IServerSecurity IServerSecurity;
*/
DEFINE_GUID(IID_IServerSecurity, 0x0000013e, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IServerSecurity: IUnknown {
struct IServerSecurity : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE QueryBlanket(
DWORD* pAuthnSvc,
DWORD* pAuthzSvc,
@ -9000,7 +9000,7 @@ struct IServerSecurity: IUnknown {
virtual BOOL STDMETHODCALLTYPE IsImpersonating(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IServerSecurityVtbl IServerSecurityVtbl;
struct IServerSecurity {
@ -9109,8 +9109,8 @@ typedef struct IAsyncSetup IAsyncSetup;
*/
DEFINE_GUID(IID_IAsyncSetup, 0x00000024, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IAsyncSetup: IUnknown {
struct IAsyncSetup : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE GetAsyncManager(
REFIID riid,
IUnknown* pOuter,
@ -9118,7 +9118,7 @@ struct IAsyncSetup: IUnknown {
IUnknown** ppInner,
IAsyncManager** ppAsyncMgr) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IAsyncSetupVtbl IAsyncSetupVtbl;
struct IAsyncSetup {
@ -9192,8 +9192,8 @@ typedef enum tagDCOM_CALL_STATE {
*/
DEFINE_GUID(IID_IAsyncManager, 0x0000002a, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IAsyncManager: IUnknown {
struct IAsyncManager : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE CompleteCall(
HRESULT Result) = 0;
@ -9204,7 +9204,7 @@ struct IAsyncManager: IUnknown {
virtual HRESULT STDMETHODCALLTYPE GetState(
ULONG* pulStateFlags) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IAsyncManagerVtbl IAsyncManagerVtbl;
struct IAsyncManager {

View file

@ -8,11 +8,6 @@
extern "C" {
#endif
#include "wtypes.h"
#if defined(ICOM_USE_COM_INTERFACE_ATTRIBUTE) && defined(__cplusplus) && !defined(CINTERFACE)
# define ICOM_COM_INTERFACE_ATTRIBUTE __attribute__((com_interface))
#else
# define ICOM_COM_INTERFACE_ATTRIBUTE
#endif
#if defined(ICOM_MSVTABLE_COMPAT) && (!defined(__cplusplus) || defined(CINTERFACE))
# define ICOM_MSVTABLE_COMPAT_FIELDS long dummyRTTI1,dummyRTTI2;
# define ICOM_MSVTABLE_COMPAT_DummyRTTIVALUE 0,0,
@ -28,8 +23,12 @@ typedef IUnknown *LPUNKNOWN;
*/
DEFINE_GUID(IID_IUnknown, 0x00000000, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IUnknown {
#ifdef ICOM_USE_COM_INTERFACE_ATTRIBUTE
struct __attribute__((com_interface)) IUnknown
#else
struct IUnknown
#endif
{
virtual HRESULT STDMETHODCALLTYPE QueryInterface(
REFIID riid,
void** ppvObject) = 0;
@ -40,7 +39,7 @@ struct IUnknown {
virtual ULONG STDMETHODCALLTYPE Release(
) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IUnknownVtbl IUnknownVtbl;
struct IUnknown {
@ -109,8 +108,8 @@ typedef IClassFactory *LPCLASSFACTORY;
*/
DEFINE_GUID(IID_IClassFactory, 0x00000001, 0x0000, 0x0000, 0xc0,0x00, 0x00,0x00,0x00,0x00,0x00,0x46);
#if defined(__cplusplus) && !defined(CINTERFACE)
struct IClassFactory: IUnknown {
struct IClassFactory : public IUnknown
{
virtual HRESULT STDMETHODCALLTYPE CreateInstance(
IUnknown* pUnkOuter,
REFIID riid,
@ -119,7 +118,7 @@ struct IClassFactory: IUnknown {
virtual HRESULT STDMETHODCALLTYPE LockServer(
BOOL fLock) = 0;
} ICOM_COM_INTERFACE_ATTRIBUTE;
};
#else
typedef struct IClassFactoryVtbl IClassFactoryVtbl;
struct IClassFactory {

View file

@ -21,11 +21,6 @@ import "wtypes.idl";
/* COM vtable compatibility macros for g++ */
/* Included here because the generated header needs them */
cpp_quote("#if defined(ICOM_USE_COM_INTERFACE_ATTRIBUTE) && defined(__cplusplus) && !defined(CINTERFACE)")
cpp_quote("# define ICOM_COM_INTERFACE_ATTRIBUTE __attribute__((com_interface))")
cpp_quote("#else")
cpp_quote("# define ICOM_COM_INTERFACE_ATTRIBUTE")
cpp_quote("#endif")
cpp_quote("#if defined(ICOM_MSVTABLE_COMPAT) && (!defined(__cplusplus) || defined(CINTERFACE))")
cpp_quote("# define ICOM_MSVTABLE_COMPAT_FIELDS long dummyRTTI1,dummyRTTI2;")
cpp_quote("# define ICOM_MSVTABLE_COMPAT_DummyRTTIVALUE 0,0,")

View file

@ -688,15 +688,21 @@ void write_com_interface(type_t *iface)
write_forward(iface);
/* C++ interface */
fprintf(header, "#if defined(__cplusplus) && !defined(CINTERFACE)\n");
fprintf(header, "struct %s", iface->name);
if (iface->ref)
fprintf(header, ": %s", iface->ref->name);
fprintf(header, " {\n");
fprintf(header, "struct %s : public %s\n", iface->name, iface->ref->name);
else
{
fprintf(header, "#ifdef ICOM_USE_COM_INTERFACE_ATTRIBUTE\n");
fprintf(header, "struct __attribute__((com_interface)) %s\n", iface->name);
fprintf(header, "#else\n");
fprintf(header, "struct %s\n", iface->name);
fprintf(header, "#endif\n");
}
fprintf(header, "{\n");
indentation++;
fprintf(header, "\n");
write_cpp_method_def(iface);
indentation--;
fprintf(header, "} ICOM_COM_INTERFACE_ATTRIBUTE;\n");
fprintf(header, "};\n");
fprintf(header, "#else\n");
/* C interface */
fprintf(header, "typedef struct %sVtbl %sVtbl;\n", iface->name, iface->name);