Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
b6313c70
Commit
b6313c70
authored
Dec 25, 2010
by
Nikolay Sivov
Committed by
Alexandre Julliard
Dec 27, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
oleaut32: Add a helper to return INVOKEKIND flags value.
parent
cecddb32
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
14 additions
and
6 deletions
+14
-6
typelib2.c
dlls/oleaut32/typelib2.c
+14
-6
No files found.
dlls/oleaut32/typelib2.c
View file @
b6313c70
...
@@ -240,6 +240,13 @@ static inline UINT cti2_get_func_count(const MSFT_TypeInfoBase *typeinfo)
...
@@ -240,6 +240,13 @@ static inline UINT cti2_get_func_count(const MSFT_TypeInfoBase *typeinfo)
return
typeinfo
->
cElement
&
0xFFFF
;
return
typeinfo
->
cElement
&
0xFFFF
;
}
}
/* NOTE: entry always assumed to be a function */
static
inline
INVOKEKIND
ctl2_get_invokekind
(
const
CyclicList
*
func
)
{
/* INVOKEKIND uses bit flags up to 8 */
return
(
func
->
u
.
data
[
4
]
>>
3
)
&
0xF
;
}
/****************************************************************************
/****************************************************************************
* ctl2_init_header
* ctl2_init_header
*
*
...
@@ -2348,17 +2355,19 @@ static HRESULT WINAPI ICreateTypeInfo2_fnSetFuncAndParamNames(
...
@@ -2348,17 +2355,19 @@ static HRESULT WINAPI ICreateTypeInfo2_fnSetFuncAndParamNames(
break
;
break
;
/* cNames == cParams for put or putref accessor, cParams+1 otherwise */
/* cNames == cParams for put or putref accessor, cParams+1 otherwise */
if
(
cNames
!=
iter
->
u
.
data
[
5
]
+
(
(
iter
->
u
.
data
[
4
]
>>
3
)
&
(
INVOKE_PROPERTYPUT
|
INVOKE_PROPERTYPUTREF
)
?
0
:
1
))
if
(
cNames
!=
iter
->
u
.
data
[
5
]
+
(
ctl2_get_invokekind
(
iter
)
&
(
INVOKE_PROPERTYPUT
|
INVOKE_PROPERTYPUTREF
)
?
0
:
1
))
return
TYPE_E_ELEMENTNOTFOUND
;
return
TYPE_E_ELEMENTNOTFOUND
;
TRACE
(
"function name %s
\n
"
,
debugstr_w
(
names
[
0
]));
len
=
ctl2_encode_name
(
This
->
typelib
,
names
[
0
],
&
namedata
);
len
=
ctl2_encode_name
(
This
->
typelib
,
names
[
0
],
&
namedata
);
for
(
iter2
=
This
->
typedata
->
next
->
next
;
iter2
!=
This
->
typedata
->
next
;
iter2
=
iter2
->
next
)
{
for
(
iter2
=
This
->
typedata
->
next
->
next
;
iter2
!=
This
->
typedata
->
next
;
iter2
=
iter2
->
next
)
{
if
(
iter2
->
name
!=-
1
&&
!
memcmp
(
namedata
,
if
(
iter2
->
name
!=-
1
&&
!
memcmp
(
namedata
,
This
->
typelib
->
typelib_segment_data
[
MSFT_SEG_NAME
]
+
iter2
->
name
+
8
,
len
))
{
This
->
typelib
->
typelib_segment_data
[
MSFT_SEG_NAME
]
+
iter2
->
name
+
8
,
len
))
{
/* getters/setters can have a same name */
/* getters/setters can have a same name */
if
(
iter2
->
type
==
CyclicListFunc
)
{
if
(
iter2
->
type
==
CyclicListFunc
)
{
INT
inv1
=
iter2
->
u
.
data
[
4
]
>>
3
;
INVOKEKIND
inv1
=
ctl2_get_invokekind
(
iter2
);
INT
inv2
=
iter
->
u
.
data
[
4
]
>>
3
;
INVOKEKIND
inv2
=
ctl2_get_invokekind
(
iter
);
if
(((
inv1
&
(
INVOKE_PROPERTYPUT
|
INVOKE_PROPERTYPUTREF
))
&&
(
inv2
&
INVOKE_PROPERTYGET
))
||
if
(((
inv1
&
(
INVOKE_PROPERTYPUT
|
INVOKE_PROPERTYPUTREF
))
&&
(
inv2
&
INVOKE_PROPERTYGET
))
||
((
inv2
&
(
INVOKE_PROPERTYPUT
|
INVOKE_PROPERTYPUTREF
))
&&
(
inv1
&
INVOKE_PROPERTYGET
)))
((
inv2
&
(
INVOKE_PROPERTYPUT
|
INVOKE_PROPERTYPUTREF
))
&&
(
inv1
&
INVOKE_PROPERTYGET
)))
continue
;
continue
;
...
@@ -2801,13 +2810,12 @@ static HRESULT WINAPI ICreateTypeInfo2_fnLayOut(
...
@@ -2801,13 +2810,12 @@ static HRESULT WINAPI ICreateTypeInfo2_fnLayOut(
for
(
i
=
0
;
i
<
cti2_get_func_count
(
This
->
typeinfo
);
i
++
)
{
for
(
i
=
0
;
i
<
cti2_get_func_count
(
This
->
typeinfo
);
i
++
)
{
if
(
typedata
[
i
]
->
u
.
data
[
4
]
>>
16
>
i
)
{
if
(
typedata
[
i
]
->
u
.
data
[
4
]
>>
16
>
i
)
{
int
inv
;
INVOKEKIND
inv
=
ctl2_get_invokekind
(
typedata
[
i
])
;
inv
=
(
typedata
[
i
]
->
u
.
data
[
4
]
>>
3
)
&
0xf
;
i
=
typedata
[
i
]
->
u
.
data
[
4
]
>>
16
;
i
=
typedata
[
i
]
->
u
.
data
[
4
]
>>
16
;
while
(
i
>
typedata
[
i
]
->
u
.
data
[
4
]
>>
16
)
{
while
(
i
>
typedata
[
i
]
->
u
.
data
[
4
]
>>
16
)
{
int
invkind
=
(
typedata
[
i
]
->
u
.
data
[
4
]
>>
3
)
&
0xf
;
INVOKEKIND
invkind
=
ctl2_get_invokekind
(
typedata
[
i
])
;
if
(
inv
&
invkind
)
{
if
(
inv
&
invkind
)
{
HeapFree
(
GetProcessHeap
(),
0
,
typedata
);
HeapFree
(
GetProcessHeap
(),
0
,
typedata
);
...
...
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