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
4f12e61c
Commit
4f12e61c
authored
Dec 14, 2000
by
Jon Griffiths
Committed by
Alexandre Julliard
Dec 14, 2000
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added "ignore" directive for skipping individual symbol resolution.
parent
afee78f3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
73 additions
and
10 deletions
+73
-10
build.h
tools/winebuild/build.h
+1
-0
import.c
tools/winebuild/import.c
+48
-10
parser.c
tools/winebuild/parser.c
+24
-0
No files found.
tools/winebuild/build.h
View file @
4f12e61c
...
@@ -146,6 +146,7 @@ extern void warning( const char *msg, ... );
...
@@ -146,6 +146,7 @@ extern void warning( const char *msg, ... );
extern
void
dump_bytes
(
FILE
*
outfile
,
const
unsigned
char
*
data
,
int
len
,
extern
void
dump_bytes
(
FILE
*
outfile
,
const
unsigned
char
*
data
,
int
len
,
const
char
*
label
,
int
constant
);
const
char
*
label
,
int
constant
);
extern
void
add_import_dll
(
const
char
*
name
);
extern
void
add_import_dll
(
const
char
*
name
);
extern
void
add_ignore_symbol
(
const
char
*
name
);
extern
int
resolve_imports
(
FILE
*
outfile
);
extern
int
resolve_imports
(
FILE
*
outfile
);
extern
int
output_imports
(
FILE
*
outfile
);
extern
int
output_imports
(
FILE
*
outfile
);
extern
void
load_res32_file
(
const
char
*
name
);
extern
void
load_res32_file
(
const
char
*
name
);
...
...
tools/winebuild/import.c
View file @
4f12e61c
...
@@ -26,6 +26,10 @@ static char **undef_symbols; /* list of undefined symbols */
...
@@ -26,6 +26,10 @@ static char **undef_symbols; /* list of undefined symbols */
static
int
nb_undef_symbols
=
-
1
;
static
int
nb_undef_symbols
=
-
1
;
static
int
undef_size
;
static
int
undef_size
;
static
char
**
ignore_symbols
;
/* list of symbols to ignore */
static
int
nb_ignore_symbols
;
static
int
ignore_size
;
static
struct
import
**
dll_imports
=
NULL
;
static
struct
import
**
dll_imports
=
NULL
;
static
int
nb_imports
=
0
;
/* number of imported dlls */
static
int
nb_imports
=
0
;
/* number of imported dlls */
static
int
total_imports
=
0
;
/* total number of imported functions */
static
int
total_imports
=
0
;
/* total number of imported functions */
...
@@ -143,6 +147,17 @@ void add_import_dll( const char *name )
...
@@ -143,6 +147,17 @@ void add_import_dll( const char *name )
dll_imports
[
nb_imports
++
]
=
imp
;
dll_imports
[
nb_imports
++
]
=
imp
;
}
}
/* Add a symbol to the ignored symbol list */
void
add_ignore_symbol
(
const
char
*
name
)
{
if
(
nb_ignore_symbols
==
ignore_size
)
{
ignore_size
+=
32
;
ignore_symbols
=
xrealloc
(
ignore_symbols
,
ignore_size
*
sizeof
(
*
ignore_symbols
)
);
}
ignore_symbols
[
nb_ignore_symbols
++
]
=
xstrdup
(
name
);
}
/* add a function to the list of imports from a given dll */
/* add a function to the list of imports from a given dll */
static
void
add_import_func
(
struct
import
*
imp
,
const
char
*
name
)
static
void
add_import_func
(
struct
import
*
imp
,
const
char
*
name
)
{
{
...
@@ -162,6 +177,19 @@ inline static void add_undef_symbol( const char *name )
...
@@ -162,6 +177,19 @@ inline static void add_undef_symbol( const char *name )
undef_symbols
[
nb_undef_symbols
++
]
=
xstrdup
(
name
);
undef_symbols
[
nb_undef_symbols
++
]
=
xstrdup
(
name
);
}
}
/* remove all the holes in the undefined symbol list; return the number of removed symbols */
static
int
remove_symbol_holes
(
void
)
{
int
i
,
off
;
for
(
i
=
off
=
0
;
i
<
nb_undef_symbols
;
i
++
)
{
if
(
!
undef_symbols
[
i
])
off
++
;
else
undef_symbols
[
i
-
off
]
=
undef_symbols
[
i
];
}
nb_undef_symbols
-=
off
;
return
off
;
}
/* add the extra undefined symbols that will be contained in the generated spec file itself */
/* add the extra undefined symbols that will be contained in the generated spec file itself */
static
void
add_extra_undef_symbols
(
void
)
static
void
add_extra_undef_symbols
(
void
)
{
{
...
@@ -245,15 +273,31 @@ void read_undef_symbols( const char *name )
...
@@ -245,15 +273,31 @@ void read_undef_symbols( const char *name )
if
((
err
=
pclose
(
f
)))
fatal_error
(
"nm -u %s error %d
\n
"
,
name
,
err
);
if
((
err
=
pclose
(
f
)))
fatal_error
(
"nm -u %s error %d
\n
"
,
name
,
err
);
}
}
static
void
remove_ignored_symbols
(
void
)
{
int
i
;
sort_symbols
(
ignore_symbols
,
nb_ignore_symbols
);
for
(
i
=
0
;
i
<
nb_undef_symbols
;
i
++
)
{
if
(
find_symbol
(
undef_symbols
[
i
],
ignore_symbols
,
nb_ignore_symbols
))
{
free
(
undef_symbols
[
i
]
);
undef_symbols
[
i
]
=
NULL
;
}
}
remove_symbol_holes
();
}
/* resolve the imports for a Win32 module */
/* resolve the imports for a Win32 module */
int
resolve_imports
(
FILE
*
outfile
)
int
resolve_imports
(
FILE
*
outfile
)
{
{
int
i
,
j
,
off
;
int
i
,
j
;
char
**
p
;
if
(
nb_undef_symbols
==
-
1
)
return
0
;
/* no symbol file specified */
if
(
nb_undef_symbols
==
-
1
)
return
0
;
/* no symbol file specified */
add_extra_undef_symbols
();
add_extra_undef_symbols
();
remove_ignored_symbols
();
for
(
i
=
0
;
i
<
nb_imports
;
i
++
)
for
(
i
=
0
;
i
<
nb_imports
;
i
++
)
{
{
...
@@ -265,18 +309,12 @@ int resolve_imports( FILE *outfile )
...
@@ -265,18 +309,12 @@ int resolve_imports( FILE *outfile )
if
(
res
)
if
(
res
)
{
{
add_import_func
(
imp
,
res
);
add_import_func
(
imp
,
res
);
free
(
undef_symbols
[
j
]
);
undef_symbols
[
j
]
=
NULL
;
undef_symbols
[
j
]
=
NULL
;
}
}
}
}
/* remove all the holes in the undef symbols list */
/* remove all the holes in the undef symbols list */
p
=
undef_symbols
;
if
(
!
remove_symbol_holes
())
warn_unused
(
imp
);
for
(
j
=
off
=
0
;
j
<
nb_undef_symbols
;
j
++
)
{
if
(
!
undef_symbols
[
j
])
off
++
;
else
undef_symbols
[
j
-
off
]
=
undef_symbols
[
j
];
}
nb_undef_symbols
-=
off
;
if
(
!
off
)
warn_unused
(
imp
);
}
}
return
1
;
return
1
;
}
}
...
...
tools/winebuild/parser.c
View file @
4f12e61c
...
@@ -144,6 +144,24 @@ static void ParseDebug(void)
...
@@ -144,6 +144,24 @@ static void ParseDebug(void)
/*******************************************************************
/*******************************************************************
* ParseIgnore
*
* Parse an 'ignore' definition.
*/
static
void
ParseIgnore
(
void
)
{
char
*
token
=
GetToken
(
0
);
if
(
*
token
!=
'('
)
fatal_error
(
"Expected '(' got '%s'
\n
"
,
token
);
for
(;;)
{
token
=
GetToken
(
0
);
if
(
*
token
==
')'
)
break
;
add_ignore_symbol
(
token
);
}
}
/*******************************************************************
* ParseVariable
* ParseVariable
*
*
* Parse a variable definition.
* Parse a variable definition.
...
@@ -583,6 +601,12 @@ SPEC_TYPE ParseTopLevel( FILE *file )
...
@@ -583,6 +601,12 @@ SPEC_TYPE ParseTopLevel( FILE *file )
fatal_error
(
"debug channels only supported for Win32 spec files
\n
"
);
fatal_error
(
"debug channels only supported for Win32 spec files
\n
"
);
ParseDebug
();
ParseDebug
();
}
}
else
if
(
strcmp
(
token
,
"ignore"
)
==
0
)
{
if
(
SpecType
!=
SPEC_WIN32
)
fatal_error
(
"'ignore' only supported for Win32 spec files
\n
"
);
ParseIgnore
();
}
else
if
(
strcmp
(
token
,
"@"
)
==
0
)
else
if
(
strcmp
(
token
,
"@"
)
==
0
)
{
{
if
(
SpecType
!=
SPEC_WIN32
)
if
(
SpecType
!=
SPEC_WIN32
)
...
...
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