@@ -351,6 +351,7 @@ pub struct Build {
351351 shell_escaped_flags : Option < bool > ,
352352 build_cache : Arc < BuildCache > ,
353353 inherit_rustflags : bool ,
354+ prefer_clang_cl_over_msvc : bool ,
354355}
355356
356357/// Represents the types of errors that may occur while using cc-rs.
@@ -479,6 +480,7 @@ impl Build {
479480 shell_escaped_flags : None ,
480481 build_cache : Arc :: default ( ) ,
481482 inherit_rustflags : true ,
483+ prefer_clang_cl_over_msvc : false ,
482484 }
483485 }
484486
@@ -1290,6 +1292,14 @@ impl Build {
12901292 self
12911293 }
12921294
1295+ /// Prefer to use clang-cl over msvc.
1296+ ///
1297+ /// This option defaults to `false`.
1298+ pub fn prefer_clang_cl_over_msvc ( & mut self , prefer_clang_cl_over_msvc : bool ) -> & mut Build {
1299+ self . prefer_clang_cl_over_msvc = prefer_clang_cl_over_msvc;
1300+ self
1301+ }
1302+
12931303 #[ doc( hidden) ]
12941304 pub fn __set_env < A , B > ( & mut self , a : A , b : B ) -> & mut Build
12951305 where
@@ -2871,10 +2881,17 @@ impl Build {
28712881 }
28722882 let target = self . get_target ( ) ?;
28732883 let raw_target = self . get_raw_target ( ) ?;
2874- let ( env, msvc, gnu, traditional, clang) = if self . cpp {
2875- ( "CXX" , "cl.exe" , "g++" , "c++" , "clang++" )
2884+
2885+ let msvc = if self . prefer_clang_cl_over_msvc {
2886+ "clang-cl.exe"
2887+ } else {
2888+ "cl.exe"
2889+ } ;
2890+
2891+ let ( env, gnu, traditional, clang) = if self . cpp {
2892+ ( "CXX" , "g++" , "c++" , "clang++" )
28762893 } else {
2877- ( "CC" , "cl.exe" , " gcc", "cc" , "clang" )
2894+ ( "CC" , "gcc" , "cc" , "clang" )
28782895 } ;
28792896
28802897 // On historical Solaris systems, "cc" may have been Sun Studio, which
@@ -2887,7 +2904,7 @@ impl Build {
28872904 traditional
28882905 } ;
28892906
2890- let cl_exe = self . windows_registry_find_tool ( & target, "cl.exe" ) ;
2907+ let cl_exe = self . windows_registry_find_tool ( & target, msvc ) ;
28912908
28922909 let tool_opt: Option < Tool > = self
28932910 . env_tool ( env)
0 commit comments