Commit c685acba authored by Alexandre Julliard's avatar Alexandre Julliard

makefiles: Only cross-compile the static libraries that are actually used.

parent bbc30229
...@@ -2086,8 +2086,14 @@ static struct makefile *get_parent_makefile( struct makefile *make ) ...@@ -2086,8 +2086,14 @@ static struct makefile *get_parent_makefile( struct makefile *make )
static int needs_cross_lib( const struct makefile *make ) static int needs_cross_lib( const struct makefile *make )
{ {
if (!crosstarget) return 0; if (!crosstarget) return 0;
if (!make->importlib) return 0; if (make->importlib) return strarray_exists( &cross_import_libs, make->importlib );
return strarray_exists( &cross_import_libs, make->importlib ); if (make->staticlib)
{
const char *name = replace_extension( make->staticlib, ".a", "" );
if (!strncmp( name, "lib", 3 )) name += 3;
return strarray_exists( &cross_import_libs, name );
}
return 0;
} }
...@@ -2974,7 +2980,7 @@ static void output_source_default( struct makefile *make, struct incl_file *sour ...@@ -2974,7 +2980,7 @@ static void output_source_default( struct makefile *make, struct incl_file *sour
(make->is_cross || (make->is_cross ||
((source->file->flags & FLAG_C_IMPLIB) && ((source->file->flags & FLAG_C_IMPLIB) &&
(needs_cross_lib( make ) || needs_delay_lib( make ))) || (needs_cross_lib( make ) || needs_delay_lib( make ))) ||
(make->module && make->staticlib))); (make->staticlib && needs_cross_lib( make ))));
int need_obj = (!need_cross || int need_obj = (!need_cross ||
(source->file->flags & FLAG_C_IMPLIB) || (source->file->flags & FLAG_C_IMPLIB) ||
(make->module && make->staticlib)); (make->module && make->staticlib));
...@@ -3289,7 +3295,7 @@ static void output_static_lib( struct makefile *make ) ...@@ -3289,7 +3295,7 @@ static void output_static_lib( struct makefile *make )
output( "\n\t%s $@\n", ranlib ); output( "\n\t%s $@\n", ranlib );
add_install_rule( make, make->staticlib, make->staticlib, add_install_rule( make, make->staticlib, make->staticlib,
strmake( "d$(dlldir)/%s", make->staticlib )); strmake( "d$(dlldir)/%s", make->staticlib ));
if (crosstarget && make->module) if (needs_cross_lib( make ))
{ {
char *name = replace_extension( make->staticlib, ".a", ".cross.a" ); char *name = replace_extension( make->staticlib, ".a", ".cross.a" );
......
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