winegcc: Also return Windows link flags in get_link_args().

Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Alexandre Julliard 2019-03-09 20:43:43 +01:00
parent 9ce91cd56e
commit 44839493ae
1 changed files with 31 additions and 32 deletions

View File

@ -425,6 +425,36 @@ static strarray *get_link_args( struct options *opts, const char *output_name )
strarray_add( flags, strmake( "-Wl,-soname,%s.so", output_name )); strarray_add( flags, strmake( "-Wl,-soname,%s.so", output_name ));
break; break;
case PLATFORM_WINDOWS:
case PLATFORM_CYGWIN:
if (opts->shared)
{
strarray_add( flags, "-shared" );
strarray_add( flags, "-Wl,--kill-at" );
}
else strarray_add( flags, opts->gui_app ? "-mwindows" : "-mconsole" );
if (opts->unicode_app) strarray_add( flags, "-municode" );
if (opts->nodefaultlibs) strarray_add( flags, "-nodefaultlibs" );
if (opts->nostartfiles) strarray_add( flags, "-nostartfiles" );
if (opts->subsystem)
{
strarray_add( flags, strmake("-Wl,--subsystem,%s", opts->subsystem ));
if (!strcmp( opts->subsystem, "native" ))
{
const char *entry = opts->target_cpu == CPU_x86 ? "_DriverEntry@8" : "DriverEntry";
strarray_add( flags, strmake( "-Wl,--entry,%s", entry ));
}
}
if (opts->image_base) strarray_add( flags, strmake("-Wl,--image-base,%s", opts->image_base ));
if (opts->large_address_aware && opts->target_cpu == CPU_x86)
strarray_add( flags, "-Wl,--large-address-aware" );
return flags;
default: default:
if (opts->image_base) if (opts->image_base)
{ {
@ -906,7 +936,6 @@ static void build(struct options* opts)
/* mark the files with their appropriate type */ /* mark the files with their appropriate type */
spec_file = lang = 0; spec_file = lang = 0;
files = strarray_alloc(); files = strarray_alloc();
link_args = strarray_alloc();
for ( j = 0; j < opts->files->size; j++ ) for ( j = 0; j < opts->files->size; j++ )
{ {
const char* file = opts->files->base[j]; const char* file = opts->files->base[j];
@ -961,7 +990,7 @@ static void build(struct options* opts)
if (opts->win16_app) if (opts->win16_app)
error( "Building 16-bit code is not supported for Windows\n" ); error( "Building 16-bit code is not supported for Windows\n" );
strarray_addall(link_args, get_translator(opts)); link_args = get_link_args( opts, output_name );
if (opts->shared) if (opts->shared)
{ {
@ -979,42 +1008,12 @@ static void build(struct options* opts)
spawn(opts->prefix, spec_args, 0); spawn(opts->prefix, spec_args, 0);
strarray_free(spec_args); strarray_free(spec_args);
strarray_add(link_args, "-shared");
if (verbose) strarray_add(link_args, "-v");
strarray_add(link_args, "-Wl,--kill-at");
strarray_add(link_args, spec_def_name); strarray_add(link_args, spec_def_name);
} }
else
{
strarray_add(link_args, opts->gui_app ? "-mwindows" : "-mconsole");
}
if (opts->unicode_app) strarray_add(link_args, "-municode");
if (opts->nodefaultlibs) strarray_add(link_args, "-nodefaultlibs");
if (opts->nostartfiles) strarray_add(link_args, "-nostartfiles" );
if (opts->subsystem)
{
strarray_add(link_args, strmake("-Wl,--subsystem,%s", opts->subsystem));
if (!strcmp( opts->subsystem, "native" ))
{
const char *entry = opts->target_cpu == CPU_x86 ? "_DriverEntry@8" : "DriverEntry";
strarray_add(link_args, strmake( "-Wl,--entry,%s", entry ));
}
}
for ( j = 0 ; j < opts->linker_args->size ; j++ )
strarray_add(link_args, opts->linker_args->base[j]);
strarray_add(link_args, "-o"); strarray_add(link_args, "-o");
strarray_add(link_args, output_file); strarray_add(link_args, output_file);
if (opts->image_base)
strarray_add(link_args, strmake("-Wl,--image-base,%s", opts->image_base));
if (opts->large_address_aware && opts->target_cpu == CPU_x86)
strarray_add( link_args, "-Wl,--large-address-aware" );
for ( j = 0; j < lib_dirs->size; j++ ) for ( j = 0; j < lib_dirs->size; j++ )
strarray_add(link_args, strmake("-L%s", lib_dirs->base[j])); strarray_add(link_args, strmake("-L%s", lib_dirs->base[j]));