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
b613ee7a
Commit
b613ee7a
authored
Mar 23, 2004
by
Dimitrie O. Paun
Committed by
Alexandre Julliard
Mar 23, 2004
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
First cut at -shared support.
parent
d81e8db3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
58 additions
and
25 deletions
+58
-25
utils.c
tools/winegcc/utils.c
+4
-3
utils.h
tools/winegcc/utils.h
+2
-2
winegcc.c
tools/winegcc/winegcc.c
+52
-20
No files found.
tools/winegcc/utils.c
View file @
b613ee7a
...
...
@@ -221,7 +221,8 @@ file_type get_file_type(const char* filename)
if
(
strendswith
(
filename
,
".res"
))
return
file_res
;
if
(
strendswith
(
filename
,
".so"
))
return
file_so
;
if
(
strendswith
(
filename
,
".dylib"
))
return
file_so
;
if
(
strendswith
(
filename
,
".def"
))
return
file_dll
;
if
(
strendswith
(
filename
,
".def"
))
return
file_def
;
if
(
strendswith
(
filename
,
".spec"
))
return
file_spec
;
if
(
strendswith
(
filename
,
".rc"
))
return
file_rc
;
return
file_other
;
...
...
@@ -254,9 +255,9 @@ static file_type guess_lib_type(const char* dir, const char* library, char** fil
return
file_so
;
/* Windows DLL */
if
((
*
file
=
try_lib_path
(
dir
,
"lib"
,
library
,
".def"
,
file_d
ll
)))
if
((
*
file
=
try_lib_path
(
dir
,
"lib"
,
library
,
".def"
,
file_d
ef
)))
return
file_dll
;
if
((
*
file
=
try_lib_path
(
dir
,
""
,
library
,
".def"
,
file_d
ll
)))
if
((
*
file
=
try_lib_path
(
dir
,
""
,
library
,
".def"
,
file_d
ef
)))
return
file_dll
;
/* Unix static archives */
...
...
tools/winegcc/utils.h
View file @
b613ee7a
...
...
@@ -54,8 +54,8 @@ strarray* strarray_fromstring(const char* str, const char* delim);
char
*
strarray_tostring
(
const
strarray
*
arr
,
const
char
*
sep
);
typedef
enum
{
file_na
,
file_other
,
file_obj
,
file_res
,
file_
rc
,
file_arh
,
file_dll
,
file_so
file_na
,
file_other
,
file_obj
,
file_res
,
file_rc
,
file_
arh
,
file_dll
,
file_so
,
file_def
,
file_spec
}
file_type
;
char
*
get_basename
(
const
char
*
file
);
...
...
tools/winegcc/winegcc.c
View file @
b613ee7a
...
...
@@ -153,6 +153,7 @@ static strarray* tmp_files;
struct
options
{
enum
{
proc_cc
=
0
,
proc_cxx
=
1
,
proc_cpp
=
2
}
processor
;
int
shared
;
int
use_msvcrt
;
int
nostdinc
;
int
nostdlib
;
...
...
@@ -345,9 +346,9 @@ static void build(struct options* opts)
static
const
char
*
stdlibpath
[]
=
{
DLLDIR
,
LIBDIR
,
"/usr/lib"
,
"/usr/local/lib"
,
"/lib"
};
strarray
*
lib_dirs
,
*
files
;
strarray
*
spec_args
,
*
comp_args
,
*
link_args
;
char
*
base_file
,
*
base_nam
e
;
char
*
output_fil
e
;
const
char
*
spec_c_name
,
*
spec_o_name
;
const
char
*
output_name
;
const
char
*
output_name
,
*
spec_file
,
*
def_ext
;
const
char
*
winebuild
=
getenv
(
"WINEBUILD"
);
int
generate_app_loader
=
1
;
int
j
;
...
...
@@ -363,35 +364,40 @@ static void build(struct options* opts)
if
(
!
winebuild
)
winebuild
=
"winebuild"
;
output_name
=
opts
->
output_name
?
opts
->
output_name
:
"a.out"
;
/* get base filename by removing the .exe extension, if present */
base_file
=
strdup
(
output_name
);
if
(
strendswith
(
base_file
,
".exe.so"
))
{
base_file
[
strlen
(
base_file
)
-
7
]
=
0
;
generate_app_loader
=
0
;
}
else
if
(
strendswith
(
base_file
,
".exe"
))
base_file
[
strlen
(
base_file
)
-
4
]
=
0
;
if
((
base_name
=
strrchr
(
base_file
,
'/'
)))
base_name
++
;
else
base_name
=
base_file
;
output_file
=
strdup
(
opts
->
output_name
?
opts
->
output_name
:
"a.out"
);
/* 'winegcc -o app xxx.exe.so' only creates the load script */
if
(
opts
->
files
->
size
==
1
&&
strendswith
(
opts
->
files
->
base
[
0
],
".exe.so"
))
{
create_file
(
base
_file
,
0755
,
app_loader_template
,
opts
->
files
->
base
[
0
]);
create_file
(
output
_file
,
0755
,
app_loader_template
,
opts
->
files
->
base
[
0
]);
return
;
}
/* generate app loader only for .exe */
if
(
opts
->
shared
||
strendswith
(
output_file
,
".exe.so"
))
generate_app_loader
=
0
;
/* normalize the filename a bit: strip .so, ensure it has proper ext */
def_ext
=
opts
->
shared
?
".dll"
:
".exe"
;
if
(
strendswith
(
output_file
,
".so"
))
output_file
[
strlen
(
output_file
)
-
3
]
=
0
;
if
(
!
strendswith
(
output_file
,
def_ext
))
output_file
=
strmake
(
"%s%s"
,
output_file
,
def_ext
);
/* get the filename by the path, if present */
if
((
output_name
=
strrchr
(
output_file
,
'/'
)))
output_name
++
;
else
output_name
=
output_file
;
/* prepare the linking path */
lib_dirs
=
strarray_dup
(
opts
->
lib_dirs
);
if
(
!
opts
->
wine_mode
)
{
for
(
j
=
0
;
j
<
sizeof
(
stdlibpath
)
/
sizeof
(
stdlibpath
[
0
]);
j
++
)
for
(
j
=
0
;
j
<
sizeof
(
stdlibpath
)
/
sizeof
(
stdlibpath
[
0
]);
j
++
)
strarray_add
(
lib_dirs
,
stdlibpath
[
j
]);
}
/* mark the files with their appropriate type */
spec_file
=
0
;
files
=
strarray_alloc
();
for
(
j
=
0
;
j
<
opts
->
files
->
size
;
j
++
)
{
...
...
@@ -400,6 +406,14 @@ static void build(struct options* opts)
{
switch
(
get_file_type
(
file
))
{
case
file_def
:
case
file_spec
:
if
(
!
opts
->
shared
)
error
(
"Spec file %s not supported in non-shared mode"
,
file
);
if
(
spec_file
)
error
(
"Only one spec file can be specified in shared mode"
);
spec_file
=
file
;
break
;
case
file_rc
:
/* FIXME: invoke wrc to build it */
error
(
"Can't compile .rc file at the moment: %s"
,
file
);
...
...
@@ -441,6 +455,8 @@ static void build(struct options* opts)
free
(
fullname
);
}
}
if
(
opts
->
shared
&&
!
spec_file
)
error
(
"A spec file is currently needed in shared mode"
);
/* add the default libraries, if needed */
if
(
!
opts
->
nostdlib
)
...
...
@@ -463,13 +479,21 @@ static void build(struct options* opts)
/* run winebuild to generate the .spec.c file */
spec_args
=
strarray_alloc
();
spec_c_name
=
get_temp_file
(
base
_name
,
".spec.c"
);
spec_c_name
=
get_temp_file
(
output
_name
,
".spec.c"
);
strarray_add
(
spec_args
,
winebuild
);
strarray_add
(
spec_args
,
"-o"
);
strarray_add
(
spec_args
,
spec_c_name
);
if
(
opts
->
shared
)
{
strarray_add
(
spec_args
,
"--dll"
);
strarray_add
(
spec_args
,
spec_file
);
}
else
{
strarray_add
(
spec_args
,
"--exe"
);
strarray_add
(
spec_args
,
strmake
(
"%s.exe"
,
base_name
)
);
strarray_add
(
spec_args
,
output_name
);
strarray_add
(
spec_args
,
opts
->
gui_app
?
"-mgui"
:
"-mcui"
);
}
for
(
j
=
0
;
j
<
lib_dirs
->
size
;
j
++
)
strarray_add
(
spec_args
,
strmake
(
"-L%s"
,
lib_dirs
->
base
[
j
]));
...
...
@@ -507,7 +531,7 @@ static void build(struct options* opts)
strarray_addall
(
link_args
,
strarray_fromstring
(
LDDLLFLAGS
,
" "
));
strarray_add
(
link_args
,
"-o"
);
strarray_add
(
link_args
,
strmake
(
"%s.
exe.so"
,
base
_file
));
strarray_add
(
link_args
,
strmake
(
"%s.
so"
,
output
_file
));
for
(
j
=
0
;
j
<
opts
->
linker_args
->
size
;
j
++
)
strarray_add
(
link_args
,
opts
->
linker_args
->
base
[
j
]);
...
...
@@ -544,7 +568,10 @@ static void build(struct options* opts)
/* create the loader script */
if
(
generate_app_loader
)
create_file
(
base_file
,
0755
,
app_loader_template
,
strmake
(
"%s.exe.so"
,
base_name
));
{
if
(
strendswith
(
output_file
,
".exe"
))
output_file
[
strlen
(
output_file
)
-
4
]
=
0
;
create_file
(
output_file
,
0755
,
app_loader_template
,
strmake
(
"%s.so"
,
output_name
));
}
}
...
...
@@ -775,6 +802,11 @@ int main(int argc, char **argv)
linking
=
-
1
;
else
if
(
strcmp
(
"-save-temps"
,
argv
[
i
])
==
0
)
keep_generated
=
1
;
else
if
(
strcmp
(
"-shared"
,
argv
[
i
])
==
0
)
{
opts
.
shared
=
1
;
raw_compiler_arg
=
raw_linker_arg
=
0
;
}
break
;
case
'v'
:
if
(
argv
[
i
][
2
]
==
0
)
verbose
++
;
...
...
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