@@ -114,6 +114,7 @@ pub struct Build {
114
114
compiler : Option < PathBuf > ,
115
115
archiver : Option < PathBuf > ,
116
116
cargo_metadata : bool ,
117
+ link_lib_modifiers : Option < String > ,
117
118
pic : Option < bool > ,
118
119
use_plt : Option < bool > ,
119
120
static_crt : Option < bool > ,
@@ -312,6 +313,7 @@ impl Build {
312
313
compiler : None ,
313
314
archiver : None ,
314
315
cargo_metadata : true ,
316
+ link_lib_modifiers : None ,
315
317
pic : None ,
316
318
use_plt : None ,
317
319
static_crt : None ,
@@ -898,6 +900,16 @@ impl Build {
898
900
self
899
901
}
900
902
903
+ /// Configures native library modifiers that will be added to the
904
+ /// `rustc-link-lib=static:MODIFIERS=LIBRARY_NAME` metadata line
905
+ /// emitted for cargo if `cargo_metadata` is enabled.
906
+ /// See https://doc.rust-lang.org/rustc/command-line-arguments.html#-l-link-the-generated-crate-to-a-native-library
907
+ /// for the list of modifiers accepted by rustc.
908
+ pub fn link_lib_modifiers ( & mut self , link_lib_modifiers : Option < & str > ) -> & mut Build {
909
+ self . link_lib_modifiers = link_lib_modifiers. map ( ToString :: to_string) ;
910
+ self
911
+ }
912
+
901
913
/// Configures whether the compiler will emit position independent code.
902
914
///
903
915
/// This option defaults to `false` for `windows-gnu` and bare metal targets and
@@ -1014,7 +1026,10 @@ impl Build {
1014
1026
}
1015
1027
}
1016
1028
1017
- self . print ( & format ! ( "cargo:rustc-link-lib=static={}" , lib_name) ) ;
1029
+ match & self . link_lib_modifiers {
1030
+ Some ( m) => self . print ( & format ! ( "cargo:rustc-link-lib=static:{}={}" , m, lib_name) ) ,
1031
+ None => self . print ( & format ! ( "cargo:rustc-link-lib=static={}" , lib_name) ) ,
1032
+ }
1018
1033
self . print ( & format ! ( "cargo:rustc-link-search=native={}" , dst. display( ) ) ) ;
1019
1034
1020
1035
// Add specific C++ libraries, if enabled.
0 commit comments