Commit c670df97 authored by Alexandre Julliard's avatar Alexandre Julliard

makefiles: Don't use default imports for Unix libraries.

parent c73ae99f
...@@ -2219,11 +2219,7 @@ static struct strarray add_import_libs( const struct makefile *make, struct stra ...@@ -2219,11 +2219,7 @@ static struct strarray add_import_libs( const struct makefile *make, struct stra
const char *lib = NULL; const char *lib = NULL;
/* skip module's own importlib, its object files will be linked directly */ /* skip module's own importlib, its object files will be linked directly */
if (make->importlib && !strcmp( make->importlib, imports.str[i] )) if (make->importlib && !strcmp( make->importlib, imports.str[i] )) continue;
{
if (!is_unix) continue;
if (strarray_exists( &make->extradllflags, "-nodefaultlibs" )) continue;
}
for (j = 0; j < subdirs.count; j++) for (j = 0; j < subdirs.count; j++)
{ {
...@@ -3325,6 +3321,7 @@ static void output_module( struct makefile *make ) ...@@ -3325,6 +3321,7 @@ static void output_module( struct makefile *make )
if (make->unixobj_files.count) if (make->unixobj_files.count)
{ {
struct strarray unix_imports = empty_strarray;
struct strarray unix_libs = empty_strarray; struct strarray unix_libs = empty_strarray;
struct strarray unix_deps = empty_strarray; struct strarray unix_deps = empty_strarray;
char *ext, *unix_lib = xmalloc( strlen( make->module ) + strlen( dll_ext ) + 1 ); char *ext, *unix_lib = xmalloc( strlen( make->module ) + strlen( dll_ext ) + 1 );
...@@ -3332,15 +3329,11 @@ static void output_module( struct makefile *make ) ...@@ -3332,15 +3329,11 @@ static void output_module( struct makefile *make )
if ((ext = get_extension( unix_lib ))) *ext = 0; if ((ext = get_extension( unix_lib ))) *ext = 0;
strcat( unix_lib, dll_ext ); strcat( unix_lib, dll_ext );
if (make->importlib) if (!strarray_exists( &make->extradllflags, "-nodefaultlibs" ))
{ strarray_add( &unix_imports, "ntdll" );
struct strarray imp = empty_strarray; strarray_add( &unix_imports, "winecrt0" );
strarray_add( &imp, make->importlib );
strarray_addall( &unix_libs, add_import_libs( make, &unix_deps, imp, 1, 1 )); strarray_addall( &unix_libs, add_import_libs( make, &unix_deps, unix_imports, 0, 1 ));
}
strarray_addall( &unix_libs, add_import_libs( make, &unix_deps, make->delayimports, 1, 1 ));
strarray_addall( &unix_libs, add_import_libs( make, &unix_deps, make->imports, 0, 1 ));
add_import_libs( make, &unix_deps, get_default_imports( make ), 0, 1 ); /* dependencies only */
strarray_addall( &unix_libs, add_unix_libraries( make, &unix_deps )); strarray_addall( &unix_libs, add_unix_libraries( make, &unix_deps ));
strarray_add( &make->all_targets, unix_lib ); strarray_add( &make->all_targets, unix_lib );
......
...@@ -1219,7 +1219,7 @@ static void build(struct options* opts) ...@@ -1219,7 +1219,7 @@ static void build(struct options* opts)
add_library(opts, lib_dirs, files, "user32"); add_library(opts, lib_dirs, files, "user32");
} }
if (!opts->nodefaultlibs) if (!opts->nodefaultlibs && !opts->unix_lib)
{ {
add_library(opts, lib_dirs, files, "winecrt0"); add_library(opts, lib_dirs, files, "winecrt0");
if (opts->use_msvcrt) if (opts->use_msvcrt)
......
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