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
f4e129ab
Commit
f4e129ab
authored
Mar 04, 2007
by
Eric Pouech
Committed by
Alexandre Julliard
Mar 05, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dbghelp: Fixes for loading circular references on function signature.
parent
ccf0be8e
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
45 additions
and
20 deletions
+45
-20
msc.c
dlls/dbghelp/msc.c
+45
-20
No files found.
dlls/dbghelp/msc.c
View file @
f4e129ab
...
...
@@ -755,12 +755,9 @@ static struct symt* codeview_add_type_struct(struct codeview_type_parse* ctp,
static
struct
symt
*
codeview_new_func_signature
(
struct
codeview_type_parse
*
ctp
,
struct
symt
*
existing
,
unsigned
ret_type
,
unsigned
args_list
,
enum
CV_call_e
call_conv
)
{
struct
symt_function_signature
*
sym
;
const
union
codeview_reftype
*
reftype
;
if
(
existing
)
{
...
...
@@ -769,10 +766,19 @@ static struct symt* codeview_new_func_signature(struct codeview_type_parse* ctp,
}
else
{
sym
=
symt_new_function_signature
(
ctp
->
module
,
codeview_fetch_type
(
ctp
,
ret_type
),
call_conv
);
sym
=
symt_new_function_signature
(
ctp
->
module
,
NULL
,
call_conv
);
}
return
&
sym
->
symt
;
}
static
void
codeview_add_func_signature_args
(
struct
codeview_type_parse
*
ctp
,
struct
symt_function_signature
*
sym
,
unsigned
ret_type
,
unsigned
args_list
)
{
const
union
codeview_reftype
*
reftype
;
sym
->
rettype
=
codeview_fetch_type
(
ctp
,
ret_type
);
if
(
args_list
&&
(
reftype
=
codeview_jump_to_type
(
ctp
,
args_list
)))
{
int
i
;
...
...
@@ -792,8 +798,6 @@ static struct symt* codeview_new_func_signature(struct codeview_type_parse* ctp,
FIXME
(
"Unexpected leaf %x for signature's pmt
\n
"
,
reftype
->
generic
.
id
);
}
}
return
&
sym
->
symt
;
}
static
struct
symt
*
codeview_parse_one_type
(
struct
codeview_type_parse
*
ctp
,
...
...
@@ -979,34 +983,55 @@ static struct symt* codeview_parse_one_type(struct codeview_type_parse* ctp,
break
;
case
LF_PROCEDURE_V1
:
symt
=
codeview_new_func_signature
(
ctp
,
existing
,
symt
=
codeview_new_func_signature
(
ctp
,
existing
,
type
->
procedure_v1
.
call
);
if
(
details
)
{
codeview_add_type
(
curr_type
,
symt
);
codeview_add_func_signature_args
(
ctp
,
(
struct
symt_function_signature
*
)
symt
,
type
->
procedure_v1
.
rvtype
,
details
?
type
->
procedure_v1
.
arglist
:
0
,
type
->
procedure_v1
.
call
);
type
->
procedure_v1
.
arglist
);
}
break
;
case
LF_PROCEDURE_V2
:
symt
=
codeview_new_func_signature
(
ctp
,
existing
,
symt
=
codeview_new_func_signature
(
ctp
,
existing
,
type
->
procedure_v2
.
call
);
if
(
details
)
{
codeview_add_type
(
curr_type
,
symt
);
codeview_add_func_signature_args
(
ctp
,
(
struct
symt_function_signature
*
)
symt
,
type
->
procedure_v2
.
rvtype
,
details
?
type
->
procedure_v2
.
arglist
:
0
,
type
->
procedure_v2
.
call
);
type
->
procedure_v2
.
arglist
);
}
break
;
case
LF_MFUNCTION_V1
:
/* FIXME: for C++, this is plain wrong, but as we don't use arg types
* nor class information, this would just do for now
*/
symt
=
codeview_new_func_signature
(
ctp
,
existing
,
symt
=
codeview_new_func_signature
(
ctp
,
existing
,
type
->
mfunction_v1
.
call
);
if
(
details
)
{
codeview_add_type
(
curr_type
,
symt
);
codeview_add_func_signature_args
(
ctp
,
(
struct
symt_function_signature
*
)
symt
,
type
->
mfunction_v1
.
rvtype
,
details
?
type
->
mfunction_v1
.
arglist
:
0
,
type
->
mfunction_v1
.
call
);
type
->
mfunction_v1
.
arglist
);
}
break
;
case
LF_MFUNCTION_V2
:
/* FIXME: for C++, this is plain wrong, but as we don't use arg types
* nor class information, this would just do for now
*/
symt
=
codeview_new_func_signature
(
ctp
,
existing
,
symt
=
codeview_new_func_signature
(
ctp
,
existing
,
type
->
mfunction_v2
.
call
);
if
(
details
)
{
codeview_add_type
(
curr_type
,
symt
);
codeview_add_func_signature_args
(
ctp
,
(
struct
symt_function_signature
*
)
symt
,
type
->
mfunction_v2
.
rvtype
,
details
?
type
->
mfunction_v2
.
arglist
:
0
,
type
->
mfunction_v2
.
call
);
type
->
mfunction_v2
.
arglist
);
}
break
;
case
LF_VTSHAPE_V1
:
...
...
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