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
a9183c7e
Commit
a9183c7e
authored
Nov 22, 2022
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
makedep: Assume that all modules are built with msvcrt.
parent
5884e98f
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
24 additions
and
32 deletions
+24
-32
makedep.c
tools/makedep.c
+24
-32
No files found.
tools/makedep.c
View file @
a9183c7e
...
@@ -198,7 +198,6 @@ struct makefile
...
@@ -198,7 +198,6 @@ struct makefile
const
char
*
staticlib
;
const
char
*
staticlib
;
const
char
*
importlib
;
const
char
*
importlib
;
const
char
*
unixlib
;
const
char
*
unixlib
;
int
use_msvcrt
;
int
data_only
;
int
data_only
;
int
is_win16
;
int
is_win16
;
int
is_exe
;
int
is_exe
;
...
@@ -599,6 +598,17 @@ static int is_multiarch( unsigned int arch )
...
@@ -599,6 +598,17 @@ static int is_multiarch( unsigned int arch )
/*******************************************************************
/*******************************************************************
* is_using_msvcrt
*
* Check if the files of a makefile use msvcrt by default.
*/
static
int
is_using_msvcrt
(
struct
makefile
*
make
)
{
return
make
->
module
||
make
->
testdll
;
}
/*******************************************************************
* arch_module_name
* arch_module_name
*/
*/
static
char
*
arch_module_name
(
const
char
*
module
,
unsigned
int
arch
)
static
char
*
arch_module_name
(
const
char
*
module
,
unsigned
int
arch
)
...
@@ -856,7 +866,7 @@ static struct incl_file *add_generated_source( struct makefile *make, const char
...
@@ -856,7 +866,7 @@ static struct incl_file *add_generated_source( struct makefile *make, const char
file
->
basename
=
xstrdup
(
filename
?
filename
:
name
);
file
->
basename
=
xstrdup
(
filename
?
filename
:
name
);
file
->
filename
=
obj_dir_path
(
make
,
file
->
basename
);
file
->
filename
=
obj_dir_path
(
make
,
file
->
basename
);
file
->
file
->
flags
=
FLAG_GENERATED
;
file
->
file
->
flags
=
FLAG_GENERATED
;
file
->
use_msvcrt
=
make
->
use_msvcrt
;
file
->
use_msvcrt
=
is_using_msvcrt
(
make
)
;
list_add_tail
(
&
make
->
sources
,
&
file
->
entry
);
list_add_tail
(
&
make
->
sources
,
&
file
->
entry
);
if
(
make
==
include_makefile
)
if
(
make
==
include_makefile
)
{
{
...
@@ -1605,7 +1615,7 @@ static struct incl_file *add_src_file( struct makefile *make, const char *name )
...
@@ -1605,7 +1615,7 @@ static struct incl_file *add_src_file( struct makefile *make, const char *name )
memset
(
file
,
0
,
sizeof
(
*
file
)
);
memset
(
file
,
0
,
sizeof
(
*
file
)
);
file
->
name
=
xstrdup
(
name
);
file
->
name
=
xstrdup
(
name
);
file
->
use_msvcrt
=
make
->
use_msvcrt
;
file
->
use_msvcrt
=
is_using_msvcrt
(
make
)
;
file
->
is_external
=
!!
make
->
extlib
;
file
->
is_external
=
!!
make
->
extlib
;
list_add_tail
(
&
make
->
sources
,
&
file
->
entry
);
list_add_tail
(
&
make
->
sources
,
&
file
->
entry
);
if
(
make
==
include_makefile
)
if
(
make
==
include_makefile
)
...
@@ -1804,13 +1814,12 @@ static void add_generated_sources( struct makefile *make )
...
@@ -1804,13 +1814,12 @@ static void add_generated_sources( struct makefile *make )
unsigned
int
i
,
arch
;
unsigned
int
i
,
arch
;
struct
incl_file
*
source
,
*
next
,
*
file
,
*
dlldata
=
NULL
;
struct
incl_file
*
source
,
*
next
,
*
file
,
*
dlldata
=
NULL
;
struct
strarray
objs
=
get_expanded_make_var_array
(
make
,
"EXTRA_OBJS"
);
struct
strarray
objs
=
get_expanded_make_var_array
(
make
,
"EXTRA_OBJS"
);
int
multiarch
=
archs
.
count
>
1
&&
make
->
use_msvcrt
;
LIST_FOR_EACH_ENTRY_SAFE
(
source
,
next
,
&
make
->
sources
,
struct
incl_file
,
entry
)
LIST_FOR_EACH_ENTRY_SAFE
(
source
,
next
,
&
make
->
sources
,
struct
incl_file
,
entry
)
{
{
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
{
{
if
(
!
arch
!=
!
multiarch
)
continue
;
if
(
!
is_multiarch
(
arch
)
)
continue
;
if
(
source
->
file
->
flags
&
FLAG_IDL_CLIENT
)
if
(
source
->
file
->
flags
&
FLAG_IDL_CLIENT
)
{
{
file
=
add_generated_source
(
make
,
replace_extension
(
source
->
name
,
".idl"
,
"_c.c"
),
NULL
,
arch
);
file
=
add_generated_source
(
make
,
replace_extension
(
source
->
name
,
".idl"
,
"_c.c"
),
NULL
,
arch
);
...
@@ -1914,7 +1923,7 @@ static void add_generated_sources( struct makefile *make )
...
@@ -1914,7 +1923,7 @@ static void add_generated_sources( struct makefile *make )
{
{
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
{
{
if
(
!
arch
!=
!
multiarch
)
continue
;
if
(
!
is_multiarch
(
arch
)
)
continue
;
file
=
add_generated_source
(
make
,
"testlist.o"
,
"testlist.c"
,
arch
);
file
=
add_generated_source
(
make
,
"testlist.o"
,
"testlist.c"
,
arch
);
add_dependency
(
file
->
file
,
"wine/test.h"
,
INCL_NORMAL
);
add_dependency
(
file
->
file
,
"wine/test.h"
,
INCL_NORMAL
);
add_all_includes
(
make
,
file
,
file
->
file
);
add_all_includes
(
make
,
file
,
file
->
file
);
...
@@ -2161,7 +2170,6 @@ static int is_crt_module( const char *file )
...
@@ -2161,7 +2170,6 @@ static int is_crt_module( const char *file )
*/
*/
static
const
char
*
get_default_crt
(
const
struct
makefile
*
make
)
static
const
char
*
get_default_crt
(
const
struct
makefile
*
make
)
{
{
if
(
!
make
->
use_msvcrt
)
return
NULL
;
if
(
make
->
module
&&
is_crt_module
(
make
->
module
))
return
NULL
;
/* don't add crt import to crt dlls */
if
(
make
->
module
&&
is_crt_module
(
make
->
module
))
return
NULL
;
/* don't add crt import to crt dlls */
return
!
make
->
testdll
&&
(
!
make
->
staticlib
||
make
->
extlib
)
?
"ucrtbase"
:
"msvcrt"
;
return
!
make
->
testdll
&&
(
!
make
->
staticlib
||
make
->
extlib
)
?
"ucrtbase"
:
"msvcrt"
;
}
}
...
@@ -2362,6 +2370,7 @@ static struct strarray get_source_defines( struct makefile *make, struct incl_fi
...
@@ -2362,6 +2370,7 @@ static struct strarray get_source_defines( struct makefile *make, struct incl_fi
strarray_add
(
&
ret
,
strmake
(
"-I%s"
,
root_src_dir_path
(
"include/msvcrt"
)));
strarray_add
(
&
ret
,
strmake
(
"-I%s"
,
root_src_dir_path
(
"include/msvcrt"
)));
for
(
i
=
0
;
i
<
make
->
include_paths
.
count
;
i
++
)
for
(
i
=
0
;
i
<
make
->
include_paths
.
count
;
i
++
)
strarray_add
(
&
ret
,
strmake
(
"-I%s"
,
make
->
include_paths
.
str
[
i
]
));
strarray_add
(
&
ret
,
strmake
(
"-I%s"
,
make
->
include_paths
.
str
[
i
]
));
strarray_add
(
&
ret
,
get_crt_define
(
make
));
}
}
strarray_addall
(
&
ret
,
make
->
define_args
);
strarray_addall
(
&
ret
,
make
->
define_args
);
strarray_addall
(
&
ret
,
get_expanded_file_local_var
(
make
,
obj
,
"EXTRADEFS"
));
strarray_addall
(
&
ret
,
get_expanded_file_local_var
(
make
,
obj
,
"EXTRADEFS"
));
...
@@ -2422,7 +2431,9 @@ static void output_winegcc_command( struct makefile *make, unsigned int arch )
...
@@ -2422,7 +2431,9 @@ static void output_winegcc_command( struct makefile *make, unsigned int arch )
output_filename
(
tools_path
(
make
,
"winebuild"
));
output_filename
(
tools_path
(
make
,
"winebuild"
));
}
}
output_filenames
(
target_flags
[
arch
]
);
output_filenames
(
target_flags
[
arch
]
);
if
(
!
arch
)
output_filenames
(
lddll_flags
);
if
(
arch
)
return
;
output_filename
(
"-mno-cygwin"
);
output_filenames
(
lddll_flags
);
}
}
...
@@ -2815,7 +2826,6 @@ static void output_source_idl( struct makefile *make, struct incl_file *source,
...
@@ -2815,7 +2826,6 @@ static void output_source_idl( struct makefile *make, struct incl_file *source,
struct
strarray
multiarch_targets
[
MAX_ARCHS
]
=
{
empty_strarray
};
struct
strarray
multiarch_targets
[
MAX_ARCHS
]
=
{
empty_strarray
};
const
char
*
dest
;
const
char
*
dest
;
unsigned
int
i
,
arch
;
unsigned
int
i
,
arch
;
int
multiarch
;
if
(
find_include_file
(
make
,
strmake
(
"%s.h"
,
obj
)))
source
->
file
->
flags
|=
FLAG_IDL_HEADER
;
if
(
find_include_file
(
make
,
strmake
(
"%s.h"
,
obj
)))
source
->
file
->
flags
|=
FLAG_IDL_HEADER
;
if
(
!
source
->
file
->
flags
)
return
;
if
(
!
source
->
file
->
flags
)
return
;
...
@@ -2839,10 +2849,9 @@ static void output_source_idl( struct makefile *make, struct incl_file *source,
...
@@ -2839,10 +2849,9 @@ static void output_source_idl( struct makefile *make, struct incl_file *source,
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
idl_outputs
);
i
++
)
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
idl_outputs
);
i
++
)
{
{
if
(
!
(
source
->
file
->
flags
&
idl_outputs
[
i
].
flag
))
continue
;
if
(
!
(
source
->
file
->
flags
&
idl_outputs
[
i
].
flag
))
continue
;
multiarch
=
(
make
->
use_msvcrt
&&
archs
.
count
>
1
);
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
{
{
if
(
!
arch
!=
!
multiarch
)
continue
;
if
(
!
is_multiarch
(
arch
)
)
continue
;
dest
=
strmake
(
"%s%s%s"
,
arch_dirs
[
arch
],
obj
,
idl_outputs
[
i
].
ext
);
dest
=
strmake
(
"%s%s%s"
,
arch_dirs
[
arch
],
obj
,
idl_outputs
[
i
].
ext
);
if
(
!
find_src_file
(
make
,
dest
))
strarray_add
(
&
make
->
clean_files
,
dest
);
if
(
!
find_src_file
(
make
,
dest
))
strarray_add
(
&
make
->
clean_files
,
dest
);
strarray_add
(
&
multiarch_targets
[
arch
],
dest
);
strarray_add
(
&
multiarch_targets
[
arch
],
dest
);
...
@@ -3123,13 +3132,13 @@ static void output_source_one_arch( struct makefile *make, struct incl_file *sou
...
@@ -3123,13 +3132,13 @@ static void output_source_one_arch( struct makefile *make, struct incl_file *sou
if
(
arch
)
if
(
arch
)
{
{
if
(
source
->
file
->
flags
&
FLAG_C_UNIX
)
return
;
if
(
source
->
file
->
flags
&
FLAG_C_UNIX
)
return
;
if
(
!
make
->
use_msvcrt
&&
!
make
->
staticlib
&&
!
(
source
->
file
->
flags
&
FLAG_C_IMPLIB
))
return
;
if
(
!
is_using_msvcrt
(
make
)
&&
!
make
->
staticlib
&&
!
(
source
->
file
->
flags
&
FLAG_C_IMPLIB
))
return
;
}
}
else
if
(
source
->
file
->
flags
&
FLAG_C_UNIX
)
else
if
(
source
->
file
->
flags
&
FLAG_C_UNIX
)
{
{
if
(
!*
dll_ext
)
return
;
if
(
!*
dll_ext
)
return
;
}
}
else
if
(
archs
.
count
>
1
&&
make
->
use_msvcrt
&&
else
if
(
archs
.
count
>
1
&&
is_using_msvcrt
(
make
)
&&
!
(
source
->
file
->
flags
&
FLAG_C_IMPLIB
)
&&
!
(
source
->
file
->
flags
&
FLAG_C_IMPLIB
)
&&
(
!
make
->
staticlib
||
make
->
extlib
))
return
;
(
!
make
->
staticlib
||
make
->
extlib
))
return
;
...
@@ -3315,12 +3324,6 @@ static void output_module( struct makefile *make, unsigned int arch )
...
@@ -3315,12 +3324,6 @@ static void output_module( struct makefile *make, unsigned int arch )
strarray_addall
(
&
all_libs
,
add_import_libs
(
make
,
&
dep_libs
,
make
->
delayimports
,
IMPORT_TYPE_DELAYED
,
arch
));
strarray_addall
(
&
all_libs
,
add_import_libs
(
make
,
&
dep_libs
,
make
->
delayimports
,
IMPORT_TYPE_DELAYED
,
arch
));
strarray_addall
(
&
all_libs
,
add_import_libs
(
make
,
&
dep_libs
,
default_imports
,
IMPORT_TYPE_DEFAULT
,
arch
)
);
strarray_addall
(
&
all_libs
,
add_import_libs
(
make
,
&
dep_libs
,
default_imports
,
IMPORT_TYPE_DEFAULT
,
arch
)
);
if
(
!
make
->
use_msvcrt
)
{
strarray_addall
(
&
all_libs
,
get_expanded_make_var_array
(
make
,
"UNIX_LIBS"
));
strarray_addall
(
&
all_libs
,
libs
);
}
if
(
delay_load_flags
[
arch
])
if
(
delay_load_flags
[
arch
])
{
{
for
(
i
=
0
;
i
<
make
->
delayimports
.
count
;
i
++
)
for
(
i
=
0
;
i
<
make
->
delayimports
.
count
;
i
++
)
...
@@ -3548,7 +3551,7 @@ static void output_test_module( struct makefile *make, unsigned int arch )
...
@@ -3548,7 +3551,7 @@ static void output_test_module( struct makefile *make, unsigned int arch )
output
(
": %s"
,
obj_dir_path
(
make
,
testmodule
));
output
(
": %s"
,
obj_dir_path
(
make
,
testmodule
));
if
(
parent
)
if
(
parent
)
{
{
char
*
parent_module
=
arch_module_name
(
make
->
testdll
,
parent
->
use_msvcrt
?
arch
:
0
);
char
*
parent_module
=
arch_module_name
(
make
->
testdll
,
arch
);
output_filename
(
obj_dir_path
(
parent
,
parent_module
));
output_filename
(
obj_dir_path
(
parent
,
parent_module
));
if
(
parent
->
unixlib
)
output_filename
(
obj_dir_path
(
parent
,
parent
->
unixlib
));
if
(
parent
->
unixlib
)
output_filename
(
obj_dir_path
(
parent
,
parent
->
unixlib
));
}
}
...
@@ -3799,12 +3802,7 @@ static void output_sources( struct makefile *make )
...
@@ -3799,12 +3802,7 @@ static void output_sources( struct makefile *make )
}
}
else
if
(
make
->
module
)
else
if
(
make
->
module
)
{
{
if
(
!
make
->
use_msvcrt
)
output_module
(
make
,
0
);
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
if
(
is_multiarch
(
arch
))
output_module
(
make
,
arch
);
else
{
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
if
(
is_multiarch
(
arch
))
output_module
(
make
,
arch
);
}
if
(
make
->
unixlib
)
output_unix_lib
(
make
);
if
(
make
->
unixlib
)
output_unix_lib
(
make
);
if
(
make
->
importlib
)
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
output_import_lib
(
make
,
arch
);
if
(
make
->
importlib
)
for
(
arch
=
0
;
arch
<
archs
.
count
;
arch
++
)
output_import_lib
(
make
,
arch
);
if
(
make
->
is_exe
&&
!
make
->
is_win16
&&
*
dll_ext
&&
strendswith
(
make
->
module
,
".exe"
))
if
(
make
->
is_exe
&&
!
make
->
is_win16
&&
*
dll_ext
&&
strendswith
(
make
->
module
,
".exe"
))
...
@@ -4246,13 +4244,9 @@ static void load_sources( struct makefile *make )
...
@@ -4246,13 +4244,9 @@ static void load_sources( struct makefile *make )
}
}
make
->
is_win16
=
strarray_exists
(
&
make
->
extradllflags
,
"-m16"
);
make
->
is_win16
=
strarray_exists
(
&
make
->
extradllflags
,
"-m16"
);
make
->
data_only
=
strarray_exists
(
&
make
->
extradllflags
,
"-Wb,--data-only"
);
make
->
data_only
=
strarray_exists
(
&
make
->
extradllflags
,
"-Wb,--data-only"
);
make
->
use_msvcrt
=
(
make
->
module
||
make
->
testdll
||
make
->
is_win16
)
&&
!
strarray_exists
(
&
make
->
extradllflags
,
"-mcygwin"
);
make
->
is_exe
=
strarray_exists
(
&
make
->
extradllflags
,
"-mconsole"
)
||
make
->
is_exe
=
strarray_exists
(
&
make
->
extradllflags
,
"-mconsole"
)
||
strarray_exists
(
&
make
->
extradllflags
,
"-mwindows"
);
strarray_exists
(
&
make
->
extradllflags
,
"-mwindows"
);
if
(
make
->
use_msvcrt
)
strarray_add_uniq
(
&
make
->
extradllflags
,
"-mno-cygwin"
);
if
(
make
->
module
)
if
(
make
->
module
)
{
{
/* add default install rules if nothing was specified */
/* add default install rules if nothing was specified */
...
@@ -4309,8 +4303,6 @@ static void load_sources( struct makefile *make )
...
@@ -4309,8 +4303,6 @@ static void load_sources( struct makefile *make )
add_generated_sources
(
make
);
add_generated_sources
(
make
);
if
(
make
->
use_msvcrt
)
strarray_add
(
&
make
->
define_args
,
get_crt_define
(
make
));
LIST_FOR_EACH_ENTRY
(
file
,
&
make
->
includes
,
struct
incl_file
,
entry
)
parse_file
(
make
,
file
,
0
);
LIST_FOR_EACH_ENTRY
(
file
,
&
make
->
includes
,
struct
incl_file
,
entry
)
parse_file
(
make
,
file
,
0
);
LIST_FOR_EACH_ENTRY
(
file
,
&
make
->
sources
,
struct
incl_file
,
entry
)
get_dependencies
(
file
,
file
);
LIST_FOR_EACH_ENTRY
(
file
,
&
make
->
sources
,
struct
incl_file
,
entry
)
get_dependencies
(
file
,
file
);
...
...
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