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
fb934347
Commit
fb934347
authored
Feb 23, 2009
by
Rob Shearman
Committed by
Alexandre Julliard
Feb 23, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
widl: Use type_get_type to determine the types during statement enumeration.
parent
ba91ee60
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
20 additions
and
20 deletions
+20
-20
client.c
tools/widl/client.c
+1
-1
header.c
tools/widl/header.c
+8
-8
parser.y
tools/widl/parser.y
+2
-2
proxy.c
tools/widl/proxy.c
+3
-3
server.c
tools/widl/server.c
+1
-1
typegen.c
tools/widl/typegen.c
+3
-3
widl.c
tools/widl/widl.c
+2
-2
No files found.
tools/widl/client.c
View file @
fb934347
...
@@ -469,7 +469,7 @@ static void write_client_ifaces(const statement_list_t *stmts, int expr_eval_rou
...
@@ -469,7 +469,7 @@ static void write_client_ifaces(const statement_list_t *stmts, int expr_eval_rou
const
statement_t
*
stmt
;
const
statement_t
*
stmt
;
if
(
stmts
)
LIST_FOR_EACH_ENTRY
(
stmt
,
stmts
,
const
statement_t
,
entry
)
if
(
stmts
)
LIST_FOR_EACH_ENTRY
(
stmt
,
stmts
,
const
statement_t
,
entry
)
{
{
if
(
stmt
->
type
==
STMT_TYPE
&&
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
if
(
stmt
->
type
==
STMT_TYPE
&&
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
{
{
int
has_func
=
0
;
int
has_func
=
0
;
const
statement_t
*
stmt2
;
const
statement_t
*
stmt2
;
...
...
tools/widl/header.c
View file @
fb934347
...
@@ -824,7 +824,7 @@ static void write_local_stubs_stmts(FILE *local_stubs, const statement_list_t *s
...
@@ -824,7 +824,7 @@ static void write_local_stubs_stmts(FILE *local_stubs, const statement_list_t *s
const
statement_t
*
stmt
;
const
statement_t
*
stmt
;
if
(
stmts
)
LIST_FOR_EACH_ENTRY
(
stmt
,
stmts
,
const
statement_t
,
entry
)
if
(
stmts
)
LIST_FOR_EACH_ENTRY
(
stmt
,
stmts
,
const
statement_t
,
entry
)
{
{
if
(
stmt
->
type
==
STMT_TYPE
&&
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
if
(
stmt
->
type
==
STMT_TYPE
&&
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
write_locals
(
local_stubs
,
stmt
->
u
.
type
,
TRUE
);
write_locals
(
local_stubs
,
stmt
->
u
.
type
,
TRUE
);
else
if
(
stmt
->
type
==
STMT_LIBRARY
)
else
if
(
stmt
->
type
==
STMT_LIBRARY
)
write_local_stubs_stmts
(
local_stubs
,
stmt
->
u
.
lib
->
stmts
);
write_local_stubs_stmts
(
local_stubs
,
stmt
->
u
.
lib
->
stmts
);
...
@@ -1047,7 +1047,7 @@ static void write_imports(FILE *header, const statement_list_t *stmts)
...
@@ -1047,7 +1047,7 @@ static void write_imports(FILE *header, const statement_list_t *stmts)
switch
(
stmt
->
type
)
switch
(
stmt
->
type
)
{
{
case
STMT_TYPE
:
case
STMT_TYPE
:
if
(
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
if
(
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
write_imports
(
header
,
type_iface_get_stmts
(
stmt
->
u
.
type
));
write_imports
(
header
,
type_iface_get_stmts
(
stmt
->
u
.
type
));
break
;
break
;
case
STMT_TYPEREF
:
case
STMT_TYPEREF
:
...
@@ -1078,12 +1078,12 @@ static void write_forward_decls(FILE *header, const statement_list_t *stmts)
...
@@ -1078,12 +1078,12 @@ static void write_forward_decls(FILE *header, const statement_list_t *stmts)
switch
(
stmt
->
type
)
switch
(
stmt
->
type
)
{
{
case
STMT_TYPE
:
case
STMT_TYPE
:
if
(
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
if
(
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
{
{
if
(
is_object
(
stmt
->
u
.
type
->
attrs
)
||
is_attr
(
stmt
->
u
.
type
->
attrs
,
ATTR_DISPINTERFACE
))
if
(
is_object
(
stmt
->
u
.
type
->
attrs
)
||
is_attr
(
stmt
->
u
.
type
->
attrs
,
ATTR_DISPINTERFACE
))
write_forward
(
header
,
stmt
->
u
.
type
);
write_forward
(
header
,
stmt
->
u
.
type
);
}
}
else
if
(
stmt
->
u
.
type
->
type
==
RPC_FC
_COCLASS
)
else
if
(
type_get_type
(
stmt
->
u
.
type
)
==
TYPE
_COCLASS
)
write_coclass_forward
(
header
,
stmt
->
u
.
type
);
write_coclass_forward
(
header
,
stmt
->
u
.
type
);
break
;
break
;
case
STMT_TYPEREF
:
case
STMT_TYPEREF
:
...
@@ -1112,7 +1112,7 @@ static void write_header_stmts(FILE *header, const statement_list_t *stmts, cons
...
@@ -1112,7 +1112,7 @@ static void write_header_stmts(FILE *header, const statement_list_t *stmts, cons
switch
(
stmt
->
type
)
switch
(
stmt
->
type
)
{
{
case
STMT_TYPE
:
case
STMT_TYPE
:
if
(
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
if
(
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
{
{
type_t
*
iface
=
stmt
->
u
.
type
;
type_t
*
iface
=
stmt
->
u
.
type
;
if
(
is_attr
(
stmt
->
u
.
type
->
attrs
,
ATTR_DISPINTERFACE
)
||
is_object
(
stmt
->
u
.
type
->
attrs
))
if
(
is_attr
(
stmt
->
u
.
type
->
attrs
,
ATTR_DISPINTERFACE
)
||
is_object
(
stmt
->
u
.
type
->
attrs
))
...
@@ -1128,7 +1128,7 @@ static void write_header_stmts(FILE *header, const statement_list_t *stmts, cons
...
@@ -1128,7 +1128,7 @@ static void write_header_stmts(FILE *header, const statement_list_t *stmts, cons
write_rpc_interface_end
(
header
,
iface
);
write_rpc_interface_end
(
header
,
iface
);
}
}
}
}
else
if
(
stmt
->
u
.
type
->
type
==
RPC_FC
_COCLASS
)
else
if
(
type_get_type
(
stmt
->
u
.
type
)
==
TYPE
_COCLASS
)
write_coclass
(
header
,
stmt
->
u
.
type
);
write_coclass
(
header
,
stmt
->
u
.
type
);
else
else
{
{
...
@@ -1139,7 +1139,7 @@ static void write_header_stmts(FILE *header, const statement_list_t *stmts, cons
...
@@ -1139,7 +1139,7 @@ static void write_header_stmts(FILE *header, const statement_list_t *stmts, cons
case
STMT_TYPEREF
:
case
STMT_TYPEREF
:
/* FIXME: shouldn't write out forward declarations for undefined
/* FIXME: shouldn't write out forward declarations for undefined
* interfaces but a number of our IDL files depend on this */
* interfaces but a number of our IDL files depend on this */
if
(
stmt
->
u
.
type
->
type
==
RPC_FC_IP
&&
!
stmt
->
u
.
type
->
written
)
if
(
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
&&
!
stmt
->
u
.
type
->
written
)
write_forward
(
header
,
stmt
->
u
.
type
);
write_forward
(
header
,
stmt
->
u
.
type
);
break
;
break
;
case
STMT_IMPORTLIB
:
case
STMT_IMPORTLIB
:
...
@@ -1164,7 +1164,7 @@ static void write_header_stmts(FILE *header, const statement_list_t *stmts, cons
...
@@ -1164,7 +1164,7 @@ static void write_header_stmts(FILE *header, const statement_list_t *stmts, cons
fprintf
(
header
,
"%s
\n
"
,
stmt
->
u
.
str
);
fprintf
(
header
,
"%s
\n
"
,
stmt
->
u
.
str
);
break
;
break
;
case
STMT_DECLARATION
:
case
STMT_DECLARATION
:
if
(
iface
&&
stmt
->
u
.
var
->
type
->
type
==
RPC_FC
_FUNCTION
)
if
(
iface
&&
type_get_type
(
stmt
->
u
.
var
->
type
)
==
TYPE
_FUNCTION
)
{
{
if
(
!
ignore_funcs
)
if
(
!
ignore_funcs
)
{
{
...
...
tools/widl/parser.y
View file @
fb934347
...
@@ -2533,7 +2533,7 @@ static void check_statements(const statement_list_t *stmts, int is_inside_librar
...
@@ -2533,7 +2533,7 @@ static void check_statements(const statement_list_t *stmts, int is_inside_librar
{
{
if (stmt->type == STMT_LIBRARY)
if (stmt->type == STMT_LIBRARY)
check_statements(stmt->u.lib->stmts, TRUE);
check_statements(stmt->u.lib->stmts, TRUE);
else if (stmt->type == STMT_TYPE &&
stmt->u.type->type == RPC_FC_IP
)
else if (stmt->type == STMT_TYPE &&
type_get_type(stmt->u.type) == TYPE_INTERFACE
)
check_functions(stmt->u.type, is_inside_library);
check_functions(stmt->u.type, is_inside_library);
}
}
}
}
...
@@ -2546,7 +2546,7 @@ static void check_all_user_types(const statement_list_t *stmts)
...
@@ -2546,7 +2546,7 @@ static void check_all_user_types(const statement_list_t *stmts)
{
{
if (stmt->type == STMT_LIBRARY)
if (stmt->type == STMT_LIBRARY)
check_all_user_types(stmt->u.lib->stmts);
check_all_user_types(stmt->u.lib->stmts);
else if (stmt->type == STMT_TYPE &&
stmt->u.type->type == RPC_FC_IP
&&
else if (stmt->type == STMT_TYPE &&
type_get_type(stmt->u.type) == TYPE_INTERFACE
&&
!is_local(stmt->u.type->attrs))
!is_local(stmt->u.type->attrs))
{
{
const statement_t *stmt_func;
const statement_t *stmt_func;
...
...
tools/widl/proxy.c
View file @
fb934347
...
@@ -709,7 +709,7 @@ static int does_any_iface(const statement_list_t *stmts, type_pred_t pred)
...
@@ -709,7 +709,7 @@ static int does_any_iface(const statement_list_t *stmts, type_pred_t pred)
if
(
does_any_iface
(
stmt
->
u
.
lib
->
stmts
,
pred
))
if
(
does_any_iface
(
stmt
->
u
.
lib
->
stmts
,
pred
))
return
TRUE
;
return
TRUE
;
}
}
else
if
(
stmt
->
type
==
STMT_TYPE
&&
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
else
if
(
stmt
->
type
==
STMT_TYPE
&&
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
{
{
if
(
pred
(
stmt
->
u
.
type
))
if
(
pred
(
stmt
->
u
.
type
))
return
TRUE
;
return
TRUE
;
...
@@ -746,7 +746,7 @@ static void write_proxy_stmts(const statement_list_t *stmts, unsigned int *proc_
...
@@ -746,7 +746,7 @@ static void write_proxy_stmts(const statement_list_t *stmts, unsigned int *proc_
{
{
if
(
stmt
->
type
==
STMT_LIBRARY
)
if
(
stmt
->
type
==
STMT_LIBRARY
)
write_proxy_stmts
(
stmt
->
u
.
lib
->
stmts
,
proc_offset
);
write_proxy_stmts
(
stmt
->
u
.
lib
->
stmts
,
proc_offset
);
else
if
(
stmt
->
type
==
STMT_TYPE
&&
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
else
if
(
stmt
->
type
==
STMT_TYPE
&&
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
{
{
if
(
need_proxy
(
stmt
->
u
.
type
))
if
(
need_proxy
(
stmt
->
u
.
type
))
write_proxy
(
stmt
->
u
.
type
,
proc_offset
);
write_proxy
(
stmt
->
u
.
type
,
proc_offset
);
...
@@ -772,7 +772,7 @@ static void build_iface_list( const statement_list_t *stmts, type_t **ifaces[],
...
@@ -772,7 +772,7 @@ static void build_iface_list( const statement_list_t *stmts, type_t **ifaces[],
{
{
if
(
stmt
->
type
==
STMT_LIBRARY
)
if
(
stmt
->
type
==
STMT_LIBRARY
)
build_iface_list
(
stmt
->
u
.
lib
->
stmts
,
ifaces
,
count
);
build_iface_list
(
stmt
->
u
.
lib
->
stmts
,
ifaces
,
count
);
else
if
(
stmt
->
type
==
STMT_TYPE
&&
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
else
if
(
stmt
->
type
==
STMT_TYPE
&&
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
{
{
type_t
*
iface
=
stmt
->
u
.
type
;
type_t
*
iface
=
stmt
->
u
.
type
;
if
(
type_iface_get_inherit
(
iface
)
&&
need_proxy
(
iface
))
if
(
type_iface_get_inherit
(
iface
)
&&
need_proxy
(
iface
))
...
...
tools/widl/server.c
View file @
fb934347
...
@@ -407,7 +407,7 @@ static void write_server_stmts(const statement_list_t *stmts, int expr_eval_rout
...
@@ -407,7 +407,7 @@ static void write_server_stmts(const statement_list_t *stmts, int expr_eval_rout
{
{
if
(
stmt
->
type
==
STMT_LIBRARY
)
if
(
stmt
->
type
==
STMT_LIBRARY
)
write_server_stmts
(
stmt
->
u
.
lib
->
stmts
,
expr_eval_routines
,
proc_offset
);
write_server_stmts
(
stmt
->
u
.
lib
->
stmts
,
expr_eval_routines
,
proc_offset
);
else
if
(
stmt
->
type
==
STMT_TYPE
&&
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
else
if
(
stmt
->
type
==
STMT_TYPE
&&
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
{
{
type_t
*
iface
=
stmt
->
u
.
type
;
type_t
*
iface
=
stmt
->
u
.
type
;
if
(
!
need_stub
(
iface
))
if
(
!
need_stub
(
iface
))
...
...
tools/widl/typegen.c
View file @
fb934347
...
@@ -724,7 +724,7 @@ static void write_procformatstring_stmts(FILE *file, int indent, const statement
...
@@ -724,7 +724,7 @@ static void write_procformatstring_stmts(FILE *file, int indent, const statement
const
statement_t
*
stmt
;
const
statement_t
*
stmt
;
if
(
stmts
)
LIST_FOR_EACH_ENTRY
(
stmt
,
stmts
,
const
statement_t
,
entry
)
if
(
stmts
)
LIST_FOR_EACH_ENTRY
(
stmt
,
stmts
,
const
statement_t
,
entry
)
{
{
if
(
stmt
->
type
==
STMT_TYPE
&&
stmt
->
u
.
type
->
type
==
RPC_FC_IP
)
if
(
stmt
->
type
==
STMT_TYPE
&&
type_get_type
(
stmt
->
u
.
type
)
==
TYPE_INTERFACE
)
{
{
const
statement_t
*
stmt_func
;
const
statement_t
*
stmt_func
;
if
(
!
pred
(
stmt
->
u
.
type
))
if
(
!
pred
(
stmt
->
u
.
type
))
...
@@ -2655,7 +2655,7 @@ static unsigned int process_tfs_stmts(FILE *file, const statement_list_t *stmts,
...
@@ -2655,7 +2655,7 @@ static unsigned int process_tfs_stmts(FILE *file, const statement_list_t *stmts,
process_tfs_stmts
(
file
,
stmt
->
u
.
lib
->
stmts
,
pred
,
typeformat_offset
);
process_tfs_stmts
(
file
,
stmt
->
u
.
lib
->
stmts
,
pred
,
typeformat_offset
);
continue
;
continue
;
}
}
else
if
(
stmt
->
type
!=
STMT_TYPE
||
stmt
->
u
.
type
->
type
!=
RPC_FC_IP
)
else
if
(
stmt
->
type
!=
STMT_TYPE
||
type_get_type
(
stmt
->
u
.
type
)
!=
TYPE_INTERFACE
)
continue
;
continue
;
iface
=
stmt
->
u
.
type
;
iface
=
stmt
->
u
.
type
;
...
@@ -3420,7 +3420,7 @@ unsigned int get_size_procformatstring(const statement_list_t *stmts, type_pred_
...
@@ -3420,7 +3420,7 @@ unsigned int get_size_procformatstring(const statement_list_t *stmts, type_pred_
size
+=
get_size_procformatstring
(
stmt
->
u
.
lib
->
stmts
,
pred
)
-
1
;
size
+=
get_size_procformatstring
(
stmt
->
u
.
lib
->
stmts
,
pred
)
-
1
;
continue
;
continue
;
}
}
else
if
(
stmt
->
type
!=
STMT_TYPE
||
stmt
->
u
.
type
->
type
!=
RPC_FC_IP
)
else
if
(
stmt
->
type
!=
STMT_TYPE
||
type_get_type
(
stmt
->
u
.
type
)
!=
TYPE_INTERFACE
)
continue
;
continue
;
iface
=
stmt
->
u
.
type
;
iface
=
stmt
->
u
.
type
;
...
...
tools/widl/widl.c
View file @
fb934347
...
@@ -349,7 +349,7 @@ static void write_id_data_stmts(const statement_list_t *stmts)
...
@@ -349,7 +349,7 @@ static void write_id_data_stmts(const statement_list_t *stmts)
if
(
stmt
->
type
==
STMT_TYPE
)
if
(
stmt
->
type
==
STMT_TYPE
)
{
{
const
type_t
*
type
=
stmt
->
u
.
type
;
const
type_t
*
type
=
stmt
->
u
.
type
;
if
(
type
->
type
==
RPC_FC_IP
)
if
(
type
_get_type
(
type
)
==
TYPE_INTERFACE
)
{
{
const
UUID
*
uuid
;
const
UUID
*
uuid
;
if
(
!
is_object
(
type
->
attrs
)
&&
!
is_attr
(
type
->
attrs
,
ATTR_DISPINTERFACE
))
if
(
!
is_object
(
type
->
attrs
)
&&
!
is_attr
(
type
->
attrs
,
ATTR_DISPINTERFACE
))
...
@@ -358,7 +358,7 @@ static void write_id_data_stmts(const statement_list_t *stmts)
...
@@ -358,7 +358,7 @@ static void write_id_data_stmts(const statement_list_t *stmts)
write_guid
(
idfile
,
is_attr
(
type
->
attrs
,
ATTR_DISPINTERFACE
)
?
"DIID"
:
"IID"
,
write_guid
(
idfile
,
is_attr
(
type
->
attrs
,
ATTR_DISPINTERFACE
)
?
"DIID"
:
"IID"
,
type
->
name
,
uuid
);
type
->
name
,
uuid
);
}
}
else
if
(
type
->
type
==
RPC_FC
_COCLASS
)
else
if
(
type
_get_type
(
type
)
==
TYPE
_COCLASS
)
{
{
const
UUID
*
uuid
=
get_attrp
(
type
->
attrs
,
ATTR_UUID
);
const
UUID
*
uuid
=
get_attrp
(
type
->
attrs
,
ATTR_UUID
);
write_guid
(
idfile
,
"CLSID"
,
type
->
name
,
uuid
);
write_guid
(
idfile
,
"CLSID"
,
type
->
name
,
uuid
);
...
...
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