Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
78bf6946
Commit
78bf6946
authored
May 14, 2007
by
Huw Davies
Committed by
Alexandre Julliard
May 18, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
oleaut32: GetRefTypeOfImplType(0) on TKIND_DISPATCH typeinfos should always…
oleaut32: GetRefTypeOfImplType(0) on TKIND_DISPATCH typeinfos should always return an href to IDispatch.
parent
356970e5
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
38 additions
and
38 deletions
+38
-38
typelib.c
dlls/oleaut32/tests/typelib.c
+3
-14
typelib.c
dlls/oleaut32/typelib.c
+35
-24
No files found.
dlls/oleaut32/tests/typelib.c
View file @
78bf6946
...
@@ -615,9 +615,7 @@ if(use_midl_tlb) {
...
@@ -615,9 +615,7 @@ if(use_midl_tlb) {
hr
=
ITypeInfo_GetRefTypeInfo
(
pTI
,
href
,
&
pTI_p
);
hr
=
ITypeInfo_GetRefTypeInfo
(
pTI
,
href
,
&
pTI_p
);
ok
(
hr
==
S_OK
,
"hr %08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"hr %08x
\n
"
,
hr
);
hr
=
ITypeInfo_GetTypeAttr
(
pTI_p
,
&
pTA
);
hr
=
ITypeInfo_GetTypeAttr
(
pTI_p
,
&
pTA
);
todo_wine
{
ok
(
IsEqualGUID
(
&
pTA
->
guid
,
&
IID_IDispatch
),
"guid {%08x-....
\n
"
,
pTA
->
guid
.
Data1
);
ok
(
IsEqualGUID
(
&
pTA
->
guid
,
&
IID_IDispatch
),
"guid {%08x-....
\n
"
,
pTA
->
guid
.
Data1
);
}
ITypeInfo_ReleaseTypeAttr
(
pTI_p
,
pTA
);
ITypeInfo_ReleaseTypeAttr
(
pTI_p
,
pTA
);
ITypeInfo_Release
(
pTI_p
);
ITypeInfo_Release
(
pTI_p
);
...
@@ -625,15 +623,10 @@ todo_wine {
...
@@ -625,15 +623,10 @@ todo_wine {
hr
=
ITypeInfo_GetFuncDesc
(
pTI
,
6
,
&
pFD
);
hr
=
ITypeInfo_GetFuncDesc
(
pTI
,
6
,
&
pFD
);
ok
(
hr
==
TYPE_E_ELEMENTNOTFOUND
,
"hr %08x
\n
"
,
hr
);
ok
(
hr
==
TYPE_E_ELEMENTNOTFOUND
,
"hr %08x
\n
"
,
hr
);
hr
=
ITypeInfo_GetFuncDesc
(
pTI
,
5
,
&
pFD
);
hr
=
ITypeInfo_GetFuncDesc
(
pTI
,
5
,
&
pFD
);
todo_wine
{
ok
(
hr
==
S_OK
,
"hr %08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"hr %08x
\n
"
,
hr
);
}
ok
(
pFD
->
memid
==
0x60020000
,
"memid %08x
\n
"
,
pFD
->
memid
);
if
(
SUCCEEDED
(
hr
))
ok
(
pFD
->
oVft
==
20
,
"oVft %d
\n
"
,
pFD
->
oVft
);
{
ITypeInfo_ReleaseFuncDesc
(
pTI
,
pFD
);
ok
(
pFD
->
memid
==
0x60020000
,
"memid %08x
\n
"
,
pFD
->
memid
);
ok
(
pFD
->
oVft
==
20
,
"oVft %d
\n
"
,
pFD
->
oVft
);
ITypeInfo_ReleaseFuncDesc
(
pTI
,
pFD
);
}
}
}
ITypeInfo_Release
(
pTI
);
ITypeInfo_Release
(
pTI
);
...
@@ -688,9 +681,7 @@ if(use_midl_tlb) {
...
@@ -688,9 +681,7 @@ if(use_midl_tlb) {
hr
=
ITypeInfo_GetRefTypeInfo
(
pTI
,
href
,
&
pTI_p
);
hr
=
ITypeInfo_GetRefTypeInfo
(
pTI
,
href
,
&
pTI_p
);
ok
(
hr
==
S_OK
,
"hr %08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"hr %08x
\n
"
,
hr
);
hr
=
ITypeInfo_GetTypeAttr
(
pTI_p
,
&
pTA
);
hr
=
ITypeInfo_GetTypeAttr
(
pTI_p
,
&
pTA
);
todo_wine
{
ok
(
IsEqualGUID
(
&
pTA
->
guid
,
&
IID_IDispatch
),
"guid {%08x-....
\n
"
,
pTA
->
guid
.
Data1
);
ok
(
IsEqualGUID
(
&
pTA
->
guid
,
&
IID_IDispatch
),
"guid {%08x-....
\n
"
,
pTA
->
guid
.
Data1
);
}
ITypeInfo_ReleaseTypeAttr
(
pTI_p
,
pTA
);
ITypeInfo_ReleaseTypeAttr
(
pTI_p
,
pTA
);
ITypeInfo_Release
(
pTI_p
);
ITypeInfo_Release
(
pTI_p
);
if
(
use_midl_tlb
)
{
if
(
use_midl_tlb
)
{
...
@@ -719,9 +710,7 @@ if(use_midl_tlb) {
...
@@ -719,9 +710,7 @@ if(use_midl_tlb) {
hr
=
ITypeInfo_GetRefTypeInfo
(
pTI
,
href
,
&
pTI_p
);
hr
=
ITypeInfo_GetRefTypeInfo
(
pTI
,
href
,
&
pTI_p
);
ok
(
hr
==
S_OK
,
"hr %08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"hr %08x
\n
"
,
hr
);
hr
=
ITypeInfo_GetTypeAttr
(
pTI_p
,
&
pTA
);
hr
=
ITypeInfo_GetTypeAttr
(
pTI_p
,
&
pTA
);
todo_wine
{
ok
(
IsEqualGUID
(
&
pTA
->
guid
,
&
IID_IDispatch
),
"guid {%08x-....
\n
"
,
pTA
->
guid
.
Data1
);
ok
(
IsEqualGUID
(
&
pTA
->
guid
,
&
IID_IDispatch
),
"guid {%08x-....
\n
"
,
pTA
->
guid
.
Data1
);
}
ITypeInfo_ReleaseTypeAttr
(
pTI_p
,
pTA
);
ITypeInfo_ReleaseTypeAttr
(
pTI_p
,
pTA
);
ITypeInfo_Release
(
pTI_p
);
ITypeInfo_Release
(
pTI_p
);
...
...
dlls/oleaut32/typelib.c
View file @
78bf6946
...
@@ -898,6 +898,9 @@ typedef struct tagITypeLibImpl
...
@@ -898,6 +898,9 @@ typedef struct tagITypeLibImpl
library. Only used while reading MSFT
library. Only used while reading MSFT
typelibs */
typelibs */
struct
list
ref_list
;
/* list of ref types in this typelib */
struct
list
ref_list
;
/* list of ref types in this typelib */
HREFTYPE
dispatch_href
;
/* reference to IDispatch, -1 if unused */
/* typelibs are cached, keyed by path and index, so store the linked list info within them */
/* typelibs are cached, keyed by path and index, so store the linked list info within them */
struct
tagITypeLibImpl
*
next
,
*
prev
;
struct
tagITypeLibImpl
*
next
,
*
prev
;
WCHAR
*
path
;
WCHAR
*
path
;
...
@@ -2083,7 +2086,6 @@ static void MSFT_DoImplTypes(TLBContext *pcx, ITypeInfoImpl *pTI, int count,
...
@@ -2083,7 +2086,6 @@ static void MSFT_DoImplTypes(TLBContext *pcx, ITypeInfoImpl *pTI, int count,
static
ITypeInfoImpl
*
MSFT_DoTypeInfo
(
static
ITypeInfoImpl
*
MSFT_DoTypeInfo
(
TLBContext
*
pcx
,
TLBContext
*
pcx
,
int
count
,
int
count
,
INT
dispatch_href
,
ITypeLibImpl
*
pLibInfo
)
ITypeLibImpl
*
pLibInfo
)
{
{
MSFT_TypeInfoBase
tiBase
;
MSFT_TypeInfoBase
tiBase
;
...
@@ -2153,19 +2155,19 @@ static ITypeInfoImpl * MSFT_DoTypeInfo(
...
@@ -2153,19 +2155,19 @@ static ITypeInfoImpl * MSFT_DoTypeInfo(
tiBase
.
datatype1
);
tiBase
.
datatype1
);
break
;
break
;
case
TKIND_DISPATCH
:
case
TKIND_DISPATCH
:
ptiRet
->
impltypelist
=
TLB_Alloc
(
sizeof
(
TLBImplType
));
/* This is not -1 when the interface is a non-base dual interface or
when a dispinterface wraps an interface ie the idl 'dispinterface x {interface y;};'.
Note however that GetRefTypeOfImplType(0) always returns a ref to IDispatch and
not this interface.
*/
if
(
tiBase
.
datatype1
!=
-
1
)
if
(
tiBase
.
datatype1
!=
-
1
)
{
{
MSFT_DoRefType
(
pcx
,
pLibInfo
,
tiBase
.
datatype1
);
ptiRet
->
impltypelist
=
TLB_Alloc
(
sizeof
(
TLBImplType
));
ptiRet
->
impltypelist
->
hRef
=
tiBase
.
datatype1
;
ptiRet
->
impltypelist
->
hRef
=
tiBase
.
datatype1
;
MSFT_DoRefType
(
pcx
,
pLibInfo
,
tiBase
.
datatype1
);
}
}
else
break
;
{
MSFT_DoRefType
(
pcx
,
pLibInfo
,
dispatch_href
);
ptiRet
->
impltypelist
->
hRef
=
dispatch_href
;
}
break
;
default:
default:
ptiRet
->
impltypelist
=
TLB_Alloc
(
sizeof
(
TLBImplType
));
ptiRet
->
impltypelist
=
TLB_Alloc
(
sizeof
(
TLBImplType
));
MSFT_DoRefType
(
pcx
,
pLibInfo
,
tiBase
.
datatype1
);
MSFT_DoRefType
(
pcx
,
pLibInfo
,
tiBase
.
datatype1
);
...
@@ -2363,6 +2365,7 @@ static ITypeLibImpl* TypeLibImpl_Constructor(void)
...
@@ -2363,6 +2365,7 @@ static ITypeLibImpl* TypeLibImpl_Constructor(void)
pTypeLibImpl
->
ref
=
1
;
pTypeLibImpl
->
ref
=
1
;
list_init
(
&
pTypeLibImpl
->
ref_list
);
list_init
(
&
pTypeLibImpl
->
ref_list
);
pTypeLibImpl
->
dispatch_href
=
-
1
;
return
pTypeLibImpl
;
return
pTypeLibImpl
;
}
}
...
@@ -2558,6 +2561,10 @@ static ITypeLib2* ITypeLib2_Constructor_MSFT(LPVOID pLib, DWORD dwTLBLength)
...
@@ -2558,6 +2561,10 @@ static ITypeLib2* ITypeLib2_Constructor_MSFT(LPVOID pLib, DWORD dwTLBLength)
}
}
}
}
pTypeLibImpl
->
dispatch_href
=
tlbHeader
.
dispatchpos
;
if
(
pTypeLibImpl
->
dispatch_href
!=
-
1
)
MSFT_DoRefType
(
&
cx
,
pTypeLibImpl
,
pTypeLibImpl
->
dispatch_href
);
/* type info's */
/* type info's */
if
(
tlbHeader
.
nrtypeinfos
>=
0
)
if
(
tlbHeader
.
nrtypeinfos
>=
0
)
{
{
...
@@ -2567,7 +2574,7 @@ static ITypeLib2* ITypeLib2_Constructor_MSFT(LPVOID pLib, DWORD dwTLBLength)
...
@@ -2567,7 +2574,7 @@ static ITypeLib2* ITypeLib2_Constructor_MSFT(LPVOID pLib, DWORD dwTLBLength)
for
(
i
=
0
;
i
<
(
int
)
tlbHeader
.
nrtypeinfos
;
i
++
)
for
(
i
=
0
;
i
<
(
int
)
tlbHeader
.
nrtypeinfos
;
i
++
)
{
{
*
ppTI
=
MSFT_DoTypeInfo
(
&
cx
,
i
,
tlbHeader
.
dispatchpos
,
pTypeLibImpl
);
*
ppTI
=
MSFT_DoTypeInfo
(
&
cx
,
i
,
pTypeLibImpl
);
ppTI
=
&
((
*
ppTI
)
->
next
);
ppTI
=
&
((
*
ppTI
)
->
next
);
(
pTypeLibImpl
->
TypeInfoCount
)
++
;
(
pTypeLibImpl
->
TypeInfoCount
)
++
;
...
@@ -2836,6 +2843,11 @@ static void SLTG_DoRefs(SLTG_RefInfo *pRef, ITypeLibImpl *pTL,
...
@@ -2836,6 +2843,11 @@ static void SLTG_DoRefs(SLTG_RefInfo *pRef, ITypeLibImpl *pTL,
(
*
import
)
->
name
=
TLB_MultiByteToBSTR
(
fname
);
(
*
import
)
->
name
=
TLB_MultiByteToBSTR
(
fname
);
}
}
ref_type
->
pImpTLInfo
=
*
import
;
ref_type
->
pImpTLInfo
=
*
import
;
/* Store a reference to IDispatch */
if
(
pTL
->
dispatch_href
==
-
1
&&
IsEqualGUID
(
&
(
*
import
)
->
guid
,
&
IID_StdOle
)
&&
type_num
==
4
)
pTL
->
dispatch_href
=
ref
;
}
else
{
/* internal ref */
}
else
{
/* internal ref */
ref_type
->
pImpTLInfo
=
TLB_REF_INTERNAL
;
ref_type
->
pImpTLInfo
=
TLB_REF_INTERNAL
;
}
}
...
@@ -4702,22 +4714,17 @@ static HRESULT ITypeInfoImpl_GetInternalDispatchFuncDesc( ITypeInfo *iface,
...
@@ -4702,22 +4714,17 @@ static HRESULT ITypeInfoImpl_GetInternalDispatchFuncDesc( ITypeInfo *iface,
{
{
ITypeInfoImpl
*
This
=
(
ITypeInfoImpl
*
)
iface
;
ITypeInfoImpl
*
This
=
(
ITypeInfoImpl
*
)
iface
;
HRESULT
hr
;
HRESULT
hr
;
UINT
i
;
UINT
implemented_funcs
=
0
;
UINT
implemented_funcs
=
0
;
if
(
funcs
)
if
(
funcs
)
*
funcs
=
0
;
*
funcs
=
0
;
for
(
i
=
0
;
i
<
This
->
TypeAttr
.
cImplTypes
;
i
++
)
if
(
This
->
impltypelist
)
{
{
HREFTYPE
href
;
ITypeInfo
*
pSubTypeInfo
;
ITypeInfo
*
pSubTypeInfo
;
UINT
sub_funcs
;
UINT
sub_funcs
;
hr
=
ITypeInfo_GetRefTypeOfImplType
(
iface
,
i
,
&
href
);
hr
=
ITypeInfo_GetRefTypeInfo
(
iface
,
This
->
impltypelist
->
hRef
,
&
pSubTypeInfo
);
if
(
FAILED
(
hr
))
return
hr
;
hr
=
ITypeInfo_GetRefTypeInfo
(
iface
,
href
,
&
pSubTypeInfo
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
return
hr
;
return
hr
;
...
@@ -4755,8 +4762,7 @@ static HRESULT WINAPI ITypeInfo_fnGetFuncDesc( ITypeInfo2 *iface, UINT index,
...
@@ -4755,8 +4762,7 @@ static HRESULT WINAPI ITypeInfo_fnGetFuncDesc( ITypeInfo2 *iface, UINT index,
TRACE
(
"(%p) index %d
\n
"
,
This
,
index
);
TRACE
(
"(%p) index %d
\n
"
,
This
,
index
);
if
((
This
->
TypeAttr
.
typekind
==
TKIND_DISPATCH
)
&&
if
(
This
->
TypeAttr
.
typekind
==
TKIND_DISPATCH
)
(
This
->
TypeAttr
.
wTypeFlags
&
TYPEFLAG_FDUAL
))
hr
=
ITypeInfoImpl_GetInternalDispatchFuncDesc
((
ITypeInfo
*
)
iface
,
index
,
hr
=
ITypeInfoImpl_GetInternalDispatchFuncDesc
((
ITypeInfo
*
)
iface
,
index
,
&
internal_funcdesc
,
NULL
);
&
internal_funcdesc
,
NULL
);
else
else
...
@@ -4887,7 +4893,7 @@ static HRESULT WINAPI ITypeInfo_fnGetNames( ITypeInfo2 *iface, MEMBERID memid,
...
@@ -4887,7 +4893,7 @@ static HRESULT WINAPI ITypeInfo_fnGetNames( ITypeInfo2 *iface, MEMBERID memid,
}
}
else
else
{
{
if
(
This
->
TypeAttr
.
cImplTypes
&&
if
(
This
->
impltypelist
&&
(
This
->
TypeAttr
.
typekind
==
TKIND_INTERFACE
||
This
->
TypeAttr
.
typekind
==
TKIND_DISPATCH
))
{
(
This
->
TypeAttr
.
typekind
==
TKIND_INTERFACE
||
This
->
TypeAttr
.
typekind
==
TKIND_DISPATCH
))
{
/* recursive search */
/* recursive search */
ITypeInfo
*
pTInfo
;
ITypeInfo
*
pTInfo
;
...
@@ -4952,6 +4958,11 @@ static HRESULT WINAPI ITypeInfo_fnGetRefTypeOfImplType(
...
@@ -4952,6 +4958,11 @@ static HRESULT WINAPI ITypeInfo_fnGetRefTypeOfImplType(
hr
=
TYPE_E_ELEMENTNOTFOUND
;
hr
=
TYPE_E_ELEMENTNOTFOUND
;
}
}
}
}
else
if
(
index
==
0
&&
This
->
TypeAttr
.
typekind
==
TKIND_DISPATCH
)
{
/* All TKIND_DISPATCHs are made to look like they inherit from IDispatch */
*
pRefType
=
This
->
pTypeLib
->
dispatch_href
;
}
else
else
{
{
/* get element n from linked list */
/* get element n from linked list */
...
@@ -5045,7 +5056,7 @@ static HRESULT WINAPI ITypeInfo_fnGetIDsOfNames( ITypeInfo2 *iface,
...
@@ -5045,7 +5056,7 @@ static HRESULT WINAPI ITypeInfo_fnGetIDsOfNames( ITypeInfo2 *iface,
}
}
}
}
/* not found, see if it can be found in an inherited interface */
/* not found, see if it can be found in an inherited interface */
if
(
This
->
TypeAttr
.
cImplTypes
)
{
if
(
This
->
impltypelist
)
{
/* recursive search */
/* recursive search */
ITypeInfo
*
pTInfo
;
ITypeInfo
*
pTInfo
;
ret
=
ITypeInfo_GetRefTypeInfo
(
iface
,
ret
=
ITypeInfo_GetRefTypeInfo
(
iface
,
...
@@ -5883,7 +5894,7 @@ static HRESULT WINAPI ITypeInfo_fnGetDocumentation( ITypeInfo2 *iface,
...
@@ -5883,7 +5894,7 @@ static HRESULT WINAPI ITypeInfo_fnGetDocumentation( ITypeInfo2 *iface,
}
}
}
}
if
(
This
->
TypeAttr
.
cImplTypes
&&
if
(
This
->
impltypelist
&&
(
This
->
TypeAttr
.
typekind
==
TKIND_INTERFACE
||
This
->
TypeAttr
.
typekind
==
TKIND_DISPATCH
))
{
(
This
->
TypeAttr
.
typekind
==
TKIND_INTERFACE
||
This
->
TypeAttr
.
typekind
==
TKIND_DISPATCH
))
{
/* recursive search */
/* recursive search */
ITypeInfo
*
pTInfo
;
ITypeInfo
*
pTInfo
;
...
@@ -6998,7 +7009,7 @@ static HRESULT WINAPI ITypeComp_fnBind(
...
@@ -6998,7 +7009,7 @@ static HRESULT WINAPI ITypeComp_fnBind(
}
}
}
}
/* FIXME: search each inherited interface, not just the first */
/* FIXME: search each inherited interface, not just the first */
if
(
hr
==
DISP_E_MEMBERNOTFOUND
&&
This
->
TypeAttr
.
cImplTypes
)
{
if
(
hr
==
DISP_E_MEMBERNOTFOUND
&&
This
->
impltypelist
)
{
/* recursive search */
/* recursive search */
ITypeInfo
*
pTInfo
;
ITypeInfo
*
pTInfo
;
ITypeComp
*
pTComp
;
ITypeComp
*
pTComp
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment