@@ -231,6 +231,7 @@ pub fn invalid_output_for_target(sess: &Session,
231
231
crate_type : config:: CrateType ) -> bool {
232
232
match ( sess. target . target . options . dynamic_linking ,
233
233
sess. target . target . options . executables , crate_type) {
234
+ ( false , _, config:: CrateTypeCdylib ) |
234
235
( false , _, config:: CrateTypeDylib ) => true ,
235
236
( _, false , config:: CrateTypeExecutable ) => true ,
236
237
_ => false
@@ -253,6 +254,7 @@ pub fn filename_for_input(sess: &Session,
253
254
config:: CrateTypeRlib => {
254
255
outputs. out_directory . join ( & format ! ( "lib{}.rlib" , libname) )
255
256
}
257
+ config:: CrateTypeCdylib |
256
258
config:: CrateTypeDylib => {
257
259
let ( prefix, suffix) = ( & sess. target . target . options . dll_prefix ,
258
260
& sess. target . target . options . dll_suffix ) ;
@@ -281,9 +283,10 @@ pub fn each_linked_rlib(sess: &Session,
281
283
f : & mut FnMut ( ast:: CrateNum , & Path ) ) {
282
284
let crates = sess. cstore . used_crates ( LinkagePreference :: RequireStatic ) . into_iter ( ) ;
283
285
let fmts = sess. dependency_formats . borrow ( ) ;
284
- let fmts = fmts. get ( & config:: CrateTypeExecutable ) . or_else ( || {
285
- fmts. get ( & config:: CrateTypeStaticlib )
286
- } ) . unwrap_or_else ( || {
286
+ let fmts = fmts. get ( & config:: CrateTypeExecutable )
287
+ . or_else ( || fmts. get ( & config:: CrateTypeStaticlib ) )
288
+ . or_else ( || fmts. get ( & config:: CrateTypeCdylib ) ) ;
289
+ let fmts = fmts. unwrap_or_else ( || {
287
290
bug ! ( "could not find formats for rlibs" )
288
291
} ) ;
289
292
for ( cnum, path) in crates {
@@ -338,13 +341,9 @@ fn link_binary_output(sess: &Session,
338
341
config:: CrateTypeStaticlib => {
339
342
link_staticlib ( sess, & objects, & out_filename, tmpdir. path ( ) ) ;
340
343
}
341
- config:: CrateTypeExecutable => {
342
- link_natively ( sess, false , & objects, & out_filename, trans, outputs,
343
- tmpdir. path ( ) ) ;
344
- }
345
- config:: CrateTypeDylib => {
346
- link_natively ( sess, true , & objects, & out_filename, trans, outputs,
347
- tmpdir. path ( ) ) ;
344
+ _ => {
345
+ link_natively ( sess, crate_type, & objects, & out_filename, trans,
346
+ outputs, tmpdir. path ( ) ) ;
348
347
}
349
348
}
350
349
@@ -612,13 +611,14 @@ fn link_staticlib(sess: &Session, objects: &[PathBuf], out_filename: &Path,
612
611
//
613
612
// This will invoke the system linker/cc to create the resulting file. This
614
613
// links to all upstream files as well.
615
- fn link_natively ( sess : & Session , dylib : bool ,
616
- objects : & [ PathBuf ] , out_filename : & Path ,
614
+ fn link_natively ( sess : & Session ,
615
+ crate_type : config:: CrateType ,
616
+ objects : & [ PathBuf ] ,
617
+ out_filename : & Path ,
617
618
trans : & CrateTranslation ,
618
619
outputs : & OutputFilenames ,
619
620
tmpdir : & Path ) {
620
- info ! ( "preparing dylib? ({}) from {:?} to {:?}" , dylib, objects,
621
- out_filename) ;
621
+ info ! ( "preparing {:?} from {:?} to {:?}" , crate_type, objects, out_filename) ;
622
622
623
623
// The invocations of cc share some flags across platforms
624
624
let ( pname, mut cmd) = get_linker ( sess) ;
@@ -627,10 +627,10 @@ fn link_natively(sess: &Session, dylib: bool,
627
627
let root = sess. target_filesearch ( PathKind :: Native ) . get_lib_path ( ) ;
628
628
cmd. args ( & sess. target . target . options . pre_link_args ) ;
629
629
630
- let pre_link_objects = if dylib {
631
- & sess. target . target . options . pre_link_objects_dll
632
- } else {
630
+ let pre_link_objects = if crate_type == config:: CrateTypeExecutable {
633
631
& sess. target . target . options . pre_link_objects_exe
632
+ } else {
633
+ & sess. target . target . options . pre_link_objects_dll
634
634
} ;
635
635
for obj in pre_link_objects {
636
636
cmd. arg ( root. join ( obj) ) ;
@@ -642,7 +642,7 @@ fn link_natively(sess: &Session, dylib: bool,
642
642
} else {
643
643
Box :: new ( GnuLinker { cmd : & mut cmd, sess : & sess } ) as Box < Linker >
644
644
} ;
645
- link_args ( & mut * linker, sess, dylib , tmpdir,
645
+ link_args ( & mut * linker, sess, crate_type , tmpdir,
646
646
objects, out_filename, trans, outputs) ;
647
647
if !sess. target . target . options . no_compiler_rt {
648
648
linker. link_staticlib ( "compiler-rt" ) ;
@@ -708,7 +708,7 @@ fn link_natively(sess: &Session, dylib: bool,
708
708
709
709
fn link_args ( cmd : & mut Linker ,
710
710
sess : & Session ,
711
- dylib : bool ,
711
+ crate_type : config :: CrateType ,
712
712
tmpdir : & Path ,
713
713
objects : & [ PathBuf ] ,
714
714
out_filename : & Path ,
@@ -730,26 +730,28 @@ fn link_args(cmd: &mut Linker,
730
730
731
731
// If we're building a dynamic library then some platforms need to make sure
732
732
// that all symbols are exported correctly from the dynamic library.
733
- if dylib {
734
- cmd. export_symbols ( sess, trans, tmpdir) ;
733
+ if crate_type != config :: CrateTypeExecutable {
734
+ cmd. export_symbols ( sess, trans, tmpdir, crate_type ) ;
735
735
}
736
736
737
737
// When linking a dynamic library, we put the metadata into a section of the
738
738
// executable. This metadata is in a separate object file from the main
739
739
// object file, so we link that in here.
740
- if dylib {
740
+ if crate_type == config :: CrateTypeDylib {
741
741
cmd. add_object ( & outputs. with_extension ( "metadata.o" ) ) ;
742
742
}
743
743
744
744
// Try to strip as much out of the generated object by removing unused
745
745
// sections if possible. See more comments in linker.rs
746
746
if !sess. opts . cg . link_dead_code {
747
- cmd. gc_sections ( dylib) ;
747
+ let keep_metadata = crate_type == config:: CrateTypeDylib ;
748
+ cmd. gc_sections ( keep_metadata) ;
748
749
}
749
750
750
751
let used_link_args = sess. cstore . used_link_args ( ) ;
751
752
752
- if !dylib && t. options . position_independent_executables {
753
+ if crate_type == config:: CrateTypeExecutable &&
754
+ t. options . position_independent_executables {
753
755
let empty_vec = Vec :: new ( ) ;
754
756
let empty_str = String :: new ( ) ;
755
757
let args = sess. opts . cg . link_args . as_ref ( ) . unwrap_or ( & empty_vec) ;
@@ -804,12 +806,12 @@ fn link_args(cmd: &mut Linker,
804
806
// in this DAG so far because they're only dylibs and dylibs can only depend
805
807
// on other dylibs (e.g. other native deps).
806
808
add_local_native_libraries ( cmd, sess) ;
807
- add_upstream_rust_crates ( cmd, sess, dylib , tmpdir) ;
809
+ add_upstream_rust_crates ( cmd, sess, crate_type , tmpdir) ;
808
810
add_upstream_native_libraries ( cmd, sess) ;
809
811
810
812
// # Telling the linker what we're doing
811
813
812
- if dylib {
814
+ if crate_type != config :: CrateTypeExecutable {
813
815
cmd. build_dylib ( out_filename) ;
814
816
}
815
817
@@ -907,8 +909,10 @@ fn add_local_native_libraries(cmd: &mut Linker, sess: &Session) {
907
909
// Rust crates are not considered at all when creating an rlib output. All
908
910
// dependencies will be linked when producing the final output (instead of
909
911
// the intermediate rlib version)
910
- fn add_upstream_rust_crates ( cmd : & mut Linker , sess : & Session ,
911
- dylib : bool , tmpdir : & Path ) {
912
+ fn add_upstream_rust_crates ( cmd : & mut Linker ,
913
+ sess : & Session ,
914
+ crate_type : config:: CrateType ,
915
+ tmpdir : & Path ) {
912
916
// All of the heavy lifting has previously been accomplished by the
913
917
// dependency_format module of the compiler. This is just crawling the
914
918
// output of that module, adding crates as necessary.
@@ -918,11 +922,7 @@ fn add_upstream_rust_crates(cmd: &mut Linker, sess: &Session,
918
922
// involves just passing the right -l flag.
919
923
920
924
let formats = sess. dependency_formats . borrow ( ) ;
921
- let data = if dylib {
922
- formats. get ( & config:: CrateTypeDylib ) . unwrap ( )
923
- } else {
924
- formats. get ( & config:: CrateTypeExecutable ) . unwrap ( )
925
- } ;
925
+ let data = formats. get ( & crate_type) . unwrap ( ) ;
926
926
927
927
// Invoke get_used_crates to ensure that we get a topological sorting of
928
928
// crates.
@@ -937,7 +937,8 @@ fn add_upstream_rust_crates(cmd: &mut Linker, sess: &Session,
937
937
Linkage :: NotLinked |
938
938
Linkage :: IncludedFromDylib => { }
939
939
Linkage :: Static => {
940
- add_static_crate ( cmd, sess, tmpdir, dylib, & src. rlib . unwrap ( ) . 0 )
940
+ add_static_crate ( cmd, sess, tmpdir, crate_type,
941
+ & src. rlib . unwrap ( ) . 0 )
941
942
}
942
943
Linkage :: Dynamic => {
943
944
add_dynamic_crate ( cmd, sess, & src. dylib . unwrap ( ) . 0 )
@@ -982,9 +983,12 @@ fn add_upstream_rust_crates(cmd: &mut Linker, sess: &Session,
982
983
// (aka we're making an executable), we can just pass the rlib blindly to
983
984
// the linker (fast) because it's fine if it's not actually included as
984
985
// we're at the end of the dependency chain.
985
- fn add_static_crate ( cmd : & mut Linker , sess : & Session , tmpdir : & Path ,
986
- dylib : bool , cratepath : & Path ) {
987
- if !sess. lto ( ) && !dylib {
986
+ fn add_static_crate ( cmd : & mut Linker ,
987
+ sess : & Session ,
988
+ tmpdir : & Path ,
989
+ crate_type : config:: CrateType ,
990
+ cratepath : & Path ) {
991
+ if !sess. lto ( ) && crate_type != config:: CrateTypeDylib {
988
992
cmd. link_rlib ( & fix_windows_verbatim_for_gcc ( cratepath) ) ;
989
993
return
990
994
}
@@ -1020,7 +1024,7 @@ fn add_upstream_rust_crates(cmd: &mut Linker, sess: &Session,
1020
1024
1021
1025
if any_objects {
1022
1026
archive. build ( ) ;
1023
- if dylib {
1027
+ if crate_type == config :: CrateTypeDylib {
1024
1028
cmd. link_whole_rlib ( & fix_windows_verbatim_for_gcc ( & dst) ) ;
1025
1029
} else {
1026
1030
cmd. link_rlib ( & fix_windows_verbatim_for_gcc ( & dst) ) ;
0 commit comments