Commit a9183c7e authored by Alexandre Julliard's avatar Alexandre Julliard

makedep: Assume that all modules are built with msvcrt.

parent 5884e98f
...@@ -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 );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment