oleaut: Fix function support for SLTG dispinterfaces.
This commit is contained in:
parent
f2eb2d2309
commit
4b6b51ae99
@ -2897,7 +2897,8 @@ static void SLTG_DoFuncs(char *pBlk, char *pFirstItem, ITypeInfoImpl *pTI, unsig
|
|||||||
WORD *pType, *pArg;
|
WORD *pType, *pArg;
|
||||||
|
|
||||||
if(pFunc->magic != SLTG_FUNCTION_MAGIC &&
|
if(pFunc->magic != SLTG_FUNCTION_MAGIC &&
|
||||||
pFunc->magic != SLTG_FUNCTION_WITH_FLAGS_MAGIC) {
|
pFunc->magic != SLTG_FUNCTION_WITH_FLAGS_MAGIC &&
|
||||||
|
pFunc->magic != SLTG_DISPATCH_FUNCTION_MAGIC) {
|
||||||
FIXME("func magic = %02x\n", pFunc->magic);
|
FIXME("func magic = %02x\n", pFunc->magic);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -3070,6 +3071,14 @@ static void SLTG_ProcessDispatch(char *pBlk, ITypeInfoImpl *pTI,
|
|||||||
|
|
||||||
if (pTITail->funcs_off != 0xffff)
|
if (pTITail->funcs_off != 0xffff)
|
||||||
SLTG_DoFuncs(pBlk, pBlk + pTITail->funcs_off, pTI, pTITail->cFuncs, pNameTable);
|
SLTG_DoFuncs(pBlk, pBlk + pTITail->funcs_off, pTI, pTITail->cFuncs, pNameTable);
|
||||||
|
|
||||||
|
/* this is necessary to cope with MSFT typelibs that set cFuncs to the number
|
||||||
|
* of dispinterface functons including the IDispatch ones, so
|
||||||
|
* ITypeInfo::GetFuncDesc takes the real value for cFuncs from cbSizeVft */
|
||||||
|
pTI->TypeAttr.cbSizeVft = pTI->TypeAttr.cFuncs * sizeof(void *);
|
||||||
|
|
||||||
|
if (TRACE_ON(typelib))
|
||||||
|
dump_TLBFuncDesc(pTI->funclist);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void SLTG_ProcessEnum(char *pBlk, ITypeInfoImpl *pTI,
|
static void SLTG_ProcessEnum(char *pBlk, ITypeInfoImpl *pTI,
|
||||||
@ -3317,6 +3326,10 @@ static ITypeLib2* ITypeLib2_Constructor_SLTG(LPVOID pLib, DWORD dwTLBLength)
|
|||||||
|
|
||||||
pTITail = (SLTG_TypeInfoTail*)((char *)(pMemHeader + 1) + pMemHeader->cbExtra);
|
pTITail = (SLTG_TypeInfoTail*)((char *)(pMemHeader + 1) + pMemHeader->cbExtra);
|
||||||
|
|
||||||
|
(*ppTypeInfoImpl)->TypeAttr.cbAlignment = pTITail->cbAlignment;
|
||||||
|
(*ppTypeInfoImpl)->TypeAttr.cbSizeInstance = pTITail->cbSizeInstance;
|
||||||
|
(*ppTypeInfoImpl)->TypeAttr.cbSizeVft = pTITail->cbSizeVft;
|
||||||
|
|
||||||
switch(pTIHeader->typekind) {
|
switch(pTIHeader->typekind) {
|
||||||
case TKIND_ENUM:
|
case TKIND_ENUM:
|
||||||
SLTG_ProcessEnum((char *)(pMemHeader + 1), *ppTypeInfoImpl, pNameTable,
|
SLTG_ProcessEnum((char *)(pMemHeader + 1), *ppTypeInfoImpl, pNameTable,
|
||||||
@ -3356,10 +3369,6 @@ static ITypeLib2* ITypeLib2_Constructor_SLTG(LPVOID pLib, DWORD dwTLBLength)
|
|||||||
|
|
||||||
if(pTITail) { /* could get cFuncs, cVars and cImplTypes from here
|
if(pTITail) { /* could get cFuncs, cVars and cImplTypes from here
|
||||||
but we've already set those */
|
but we've already set those */
|
||||||
(*ppTypeInfoImpl)->TypeAttr.cbAlignment = pTITail->cbAlignment;
|
|
||||||
(*ppTypeInfoImpl)->TypeAttr.cbSizeInstance = pTITail->cbSizeInstance;
|
|
||||||
(*ppTypeInfoImpl)->TypeAttr.cbSizeVft = pTITail->cbSizeVft;
|
|
||||||
|
|
||||||
#define X(x) TRACE_(typelib)("tt "#x": %x\n",pTITail->res##x);
|
#define X(x) TRACE_(typelib)("tt "#x": %x\n",pTITail->res##x);
|
||||||
X(06);
|
X(06);
|
||||||
X(16);
|
X(16);
|
||||||
|
@ -501,6 +501,7 @@ typedef struct {
|
|||||||
|
|
||||||
#define SLTG_FUNCTION_MAGIC 0x4c
|
#define SLTG_FUNCTION_MAGIC 0x4c
|
||||||
#define SLTG_FUNCTION_WITH_FLAGS_MAGIC 0x6c
|
#define SLTG_FUNCTION_WITH_FLAGS_MAGIC 0x6c
|
||||||
|
#define SLTG_DISPATCH_FUNCTION_MAGIC 0xcb
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
/*00*/ BYTE magic; /* 0xdf */
|
/*00*/ BYTE magic; /* 0xdf */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user