1use std::collections::BTreeMap;
2use std::num::{IntErrorKind, NonZero};
3use std::path::PathBuf;
4use std::str;
5
6use rustc_abi::Align;
7use rustc_data_structures::fx::FxIndexMap;
8use rustc_data_structures::profiling::TimePassesFormat;
9use rustc_data_structures::stable_hasher::StableHasher;
10use rustc_errors::{ColorConfig, TerminalUrl};
11use rustc_feature::UnstableFeatures;
12use rustc_hashes::Hash64;
13use rustc_hir::attrs::CollapseMacroDebuginfo;
14use rustc_macros::{BlobDecodable, Encodable};
15use rustc_span::edition::Edition;
16use rustc_span::{RealFileName, RemapPathScopeComponents, SourceFileHashAlgorithm};
17use rustc_target::spec::{
18 CodeModel, FramePointer, LinkerFlavorCli, MergeFunctions, OnBrokenPipe, PanicStrategy,
19 RelocModel, RelroLevel, SanitizerSet, SplitDebuginfo, StackProtector, SymbolVisibility,
20 TargetTuple, TlsModel,
21};
22
23use crate::config::*;
24use crate::search_paths::SearchPath;
25use crate::utils::NativeLib;
26use crate::{EarlyDiagCtxt, Session, lint};
27
28macro_rules! insert {
29 ($opt_name:ident, $opt_expr:expr, $sub_hashes:expr) => {
30 if $sub_hashes
31 .insert(stringify!($opt_name), $opt_expr as &dyn dep_tracking::DepTrackingHash)
32 .is_some()
33 {
34 panic!("duplicate key in CLI DepTrackingHash: {}", stringify!($opt_name))
35 }
36 };
37}
38
39macro_rules! hash_opt {
40 ($opt_name:ident, $opt_expr:expr, $sub_hashes:expr, $_for_crate_hash: ident, [UNTRACKED]) => {{}};
41 ($opt_name:ident, $opt_expr:expr, $sub_hashes:expr, $_for_crate_hash: ident, [TRACKED]) => {{ insert!($opt_name, $opt_expr, $sub_hashes) }};
42 ($opt_name:ident, $opt_expr:expr, $sub_hashes:expr, $for_crate_hash: ident, [TRACKED_NO_CRATE_HASH]) => {{
43 if !$for_crate_hash {
44 insert!($opt_name, $opt_expr, $sub_hashes)
45 }
46 }};
47 ($opt_name:ident, $opt_expr:expr, $sub_hashes:expr, $_for_crate_hash: ident, [SUBSTRUCT]) => {{}};
48}
49
50macro_rules! hash_substruct {
51 ($opt_name:ident, $opt_expr:expr, $error_format:expr, $for_crate_hash:expr, $hasher:expr, [UNTRACKED]) => {{}};
52 ($opt_name:ident, $opt_expr:expr, $error_format:expr, $for_crate_hash:expr, $hasher:expr, [TRACKED]) => {{}};
53 ($opt_name:ident, $opt_expr:expr, $error_format:expr, $for_crate_hash:expr, $hasher:expr, [TRACKED_NO_CRATE_HASH]) => {{}};
54 ($opt_name:ident, $opt_expr:expr, $error_format:expr, $for_crate_hash:expr, $hasher:expr, [SUBSTRUCT]) => {
55 use crate::config::dep_tracking::DepTrackingHash;
56 $opt_expr.dep_tracking_hash($for_crate_hash, $error_format).hash(
57 $hasher,
58 $error_format,
59 $for_crate_hash,
60 );
61 };
62}
63
64pub struct ExtendedTargetModifierInfo {
69 pub prefix: String,
71 pub name: String,
73 pub tech_value: String,
75}
76
77#[derive(#[automatically_derived]
impl ::core::fmt::Debug for TargetModifier {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
::core::fmt::Formatter::debug_struct_field2_finish(f,
"TargetModifier", "opt", &self.opt, "value_name",
&&self.value_name)
}
}Debug, #[automatically_derived]
impl ::core::clone::Clone for TargetModifier {
#[inline]
fn clone(&self) -> TargetModifier {
TargetModifier {
opt: ::core::clone::Clone::clone(&self.opt),
value_name: ::core::clone::Clone::clone(&self.value_name),
}
}
}Clone, #[automatically_derived]
impl ::core::cmp::PartialEq for TargetModifier {
#[inline]
fn eq(&self, other: &TargetModifier) -> bool {
self.opt == other.opt && self.value_name == other.value_name
}
}PartialEq, #[automatically_derived]
impl ::core::cmp::Eq for TargetModifier {
#[inline]
#[doc(hidden)]
#[coverage(off)]
fn assert_fields_are_eq(&self) {
let _: ::core::cmp::AssertParamIsEq<OptionsTargetModifiers>;
let _: ::core::cmp::AssertParamIsEq<String>;
}
}Eq, #[automatically_derived]
impl ::core::cmp::PartialOrd for TargetModifier {
#[inline]
fn partial_cmp(&self, other: &TargetModifier)
-> ::core::option::Option<::core::cmp::Ordering> {
match ::core::cmp::PartialOrd::partial_cmp(&self.opt, &other.opt) {
::core::option::Option::Some(::core::cmp::Ordering::Equal) =>
::core::cmp::PartialOrd::partial_cmp(&self.value_name,
&other.value_name),
cmp => cmp,
}
}
}PartialOrd, #[automatically_derived]
impl ::core::cmp::Ord for TargetModifier {
#[inline]
fn cmp(&self, other: &TargetModifier) -> ::core::cmp::Ordering {
match ::core::cmp::Ord::cmp(&self.opt, &other.opt) {
::core::cmp::Ordering::Equal =>
::core::cmp::Ord::cmp(&self.value_name, &other.value_name),
cmp => cmp,
}
}
}Ord, const _: () =
{
impl<__E: ::rustc_span::SpanEncoder> ::rustc_serialize::Encodable<__E>
for TargetModifier {
fn encode(&self, __encoder: &mut __E) {
match *self {
TargetModifier {
opt: ref __binding_0, value_name: ref __binding_1 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
::rustc_serialize::Encodable::<__E>::encode(__binding_1,
__encoder);
}
}
}
}
};Encodable, const _: () =
{
impl<__D: ::rustc_span::BlobDecoder> ::rustc_serialize::Decodable<__D>
for TargetModifier {
fn decode(__decoder: &mut __D) -> Self {
TargetModifier {
opt: ::rustc_serialize::Decodable::decode(__decoder),
value_name: ::rustc_serialize::Decodable::decode(__decoder),
}
}
}
};BlobDecodable)]
80pub struct TargetModifier {
81 pub opt: OptionsTargetModifiers,
83 pub value_name: String,
85}
86
87mod target_modifier_consistency_check {
88 use super::*;
89 pub(super) fn sanitizer(l: &TargetModifier, r: Option<&TargetModifier>) -> bool {
90 let mut lparsed: SanitizerSet = Default::default();
91 let lval = if l.value_name.is_empty() { None } else { Some(l.value_name.as_str()) };
92 parse::parse_sanitizers(&mut lparsed, lval);
93
94 let mut rparsed: SanitizerSet = Default::default();
95 let rval = r.filter(|v| !v.value_name.is_empty()).map(|v| v.value_name.as_str());
96 parse::parse_sanitizers(&mut rparsed, rval);
97
98 let tmod_sanitizers = SanitizerSet::MEMORY
102 | SanitizerSet::THREAD
103 | SanitizerSet::HWADDRESS
104 | SanitizerSet::CFI
105 | SanitizerSet::MEMTAG
106 | SanitizerSet::SHADOWCALLSTACK
107 | SanitizerSet::KCFI
108 | SanitizerSet::KERNELADDRESS
109 | SanitizerSet::KERNELHWADDRESS
110 | SanitizerSet::SAFESTACK
111 | SanitizerSet::DATAFLOW;
112
113 lparsed & tmod_sanitizers == rparsed & tmod_sanitizers
114 }
115 pub(super) fn sanitizer_cfi_normalize_integers(
116 sess: &Session,
117 l: &TargetModifier,
118 r: Option<&TargetModifier>,
119 ) -> bool {
120 if sess.sanitizers().contains(SanitizerSet::KCFI) {
122 if let Some(r) = r {
123 return l.extend().tech_value == r.extend().tech_value;
124 } else {
125 return false;
126 }
127 }
128 true
129 }
130}
131
132impl TargetModifier {
133 pub fn extend(&self) -> ExtendedTargetModifierInfo {
134 self.opt.reparse(&self.value_name)
135 }
136 pub fn consistent(&self, sess: &Session, other: Option<&TargetModifier>) -> bool {
139 if !(other.is_none() || self.opt == other.unwrap().opt) {
::core::panicking::panic("assertion failed: other.is_none() || self.opt == other.unwrap().opt")
};assert!(other.is_none() || self.opt == other.unwrap().opt);
140 match self.opt {
141 OptionsTargetModifiers::UnstableOptions(unstable) => match unstable {
142 UnstableOptionsTargetModifiers::sanitizer => {
143 return target_modifier_consistency_check::sanitizer(self, other);
144 }
145 UnstableOptionsTargetModifiers::sanitizer_cfi_normalize_integers => {
146 return target_modifier_consistency_check::sanitizer_cfi_normalize_integers(
147 sess, self, other,
148 );
149 }
150 _ => {}
151 },
152 _ => {}
153 };
154 match other {
155 Some(other) => self.extend().tech_value == other.extend().tech_value,
156 None => false,
157 }
158 }
159}
160
161fn tmod_push_impl(
162 opt: OptionsTargetModifiers,
163 tmod_vals: &BTreeMap<OptionsTargetModifiers, String>,
164 tmods: &mut Vec<TargetModifier>,
165) {
166 if let Some(v) = tmod_vals.get(&opt) {
167 tmods.push(TargetModifier { opt, value_name: v.clone() })
168 }
169}
170
171macro_rules! tmod_push {
172 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr) => {
173 if *$opt_expr != $init {
174 tmod_push_impl(
175 OptionsTargetModifiers::$struct_name($tmod_enum_name::$opt_name),
176 $tmod_vals,
177 $mods,
178 );
179 }
180 };
181}
182
183macro_rules! gather_tmods {
184 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr,
185 [SUBSTRUCT], [TARGET_MODIFIER]) => {
186 compile_error!("SUBSTRUCT can't be target modifier");
187 };
188 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr,
189 [UNTRACKED], [TARGET_MODIFIER]) => {
190 tmod_push!($struct_name, $tmod_enum_name, $opt_name, $opt_expr, $init, $mods, $tmod_vals)
191 };
192 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr,
193 [TRACKED], [TARGET_MODIFIER]) => {
194 tmod_push!($struct_name, $tmod_enum_name, $opt_name, $opt_expr, $init, $mods, $tmod_vals)
195 };
196 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr,
197 [TRACKED_NO_CRATE_HASH], [TARGET_MODIFIER]) => {
198 tmod_push!($struct_name, $tmod_enum_name, $opt_name, $opt_expr, $init, $mods, $tmod_vals)
199 };
200 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr,
201 [SUBSTRUCT], []) => {
202 $opt_expr.gather_target_modifiers($mods, $tmod_vals);
203 };
204 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr,
205 [UNTRACKED], []) => {{}};
206 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr,
207 [TRACKED], []) => {{}};
208 ($struct_name:ident, $tmod_enum_name:ident, $opt_name:ident, $opt_expr:expr, $init:expr, $mods:expr, $tmod_vals:expr,
209 [TRACKED_NO_CRATE_HASH], []) => {{}};
210}
211
212macro_rules! gather_tmods_top_level {
213 ($_opt_name:ident, $opt_expr:expr, $mods:expr, $tmod_vals:expr, [SUBSTRUCT $substruct_enum:ident]) => {
214 $opt_expr.gather_target_modifiers($mods, $tmod_vals);
215 };
216 ($opt_name:ident, $opt_expr:expr, $mods:expr, $tmod_vals:expr, [$non_substruct:ident TARGET_MODIFIER]) => {
217 compile_error!("Top level option can't be target modifier");
218 };
219 ($opt_name:ident, $opt_expr:expr, $mods:expr, $tmod_vals:expr, [$non_substruct:ident]) => {};
220}
221
222macro_rules! top_level_tmod_enum {
243 ($( {$($optinfo:tt)*} ),* $(,)*) => {
244 top_level_tmod_enum! { @parse {}, (user_value){}; $($($optinfo)*|)* }
245 };
246 (
248 @parse
249 {$($variant:tt($substruct_enum:tt))*},
250 ($user_value:ident){$($pout:tt)*};
251 ) => {
252 #[allow(non_camel_case_types)]
253 #[derive(PartialEq, Eq, PartialOrd, Ord, Debug, Copy, Clone, Encodable, BlobDecodable)]
254 pub enum OptionsTargetModifiers {
255 $($variant($substruct_enum)),*
256 }
257 impl OptionsTargetModifiers {
258 #[allow(unused_variables)]
259 pub fn reparse(&self, $user_value: &str) -> ExtendedTargetModifierInfo {
260 #[allow(unreachable_patterns)]
261 match self {
262 $($pout)*
263 _ => panic!("unknown target modifier option: {:?}", *self)
264 }
265 }
266 pub fn is_target_modifier(flag_name: &str) -> bool {
267 $($substruct_enum::is_target_modifier(flag_name))||*
268 }
269 }
270 };
271 (
273 @parse {$($eout:tt)*}, ($puser_value:ident){$($pout:tt)*};
274 [SUBSTRUCT $substruct_enum:ident $variant:ident] |
275 $($tail:tt)*
276 ) => {
277 top_level_tmod_enum! {
278 @parse
279 {
280 $($eout)*
281 $variant($substruct_enum)
282 },
283 ($puser_value){
284 $($pout)*
285 Self::$variant(v) => v.reparse($puser_value),
286 };
287 $($tail)*
288 }
289 };
290 (
292 @parse {$($eout:tt)*}, ($puser_value:ident){$($pout:tt)*};
293 [$non_substruct:ident] |
294 $($tail:tt)*
295 ) => {
296 top_level_tmod_enum! {
297 @parse
298 {
299 $($eout)*
300 },
301 ($puser_value){
302 $($pout)*
303 };
304 $($tail)*
305 }
306 };
307}
308
309macro_rules! top_level_options {
310 ( $( #[$top_level_attr:meta] )* pub struct Options { $(
311 $( #[$attr:meta] )*
312 $opt:ident : $t:ty [$dep_tracking_marker:ident $( $tmod:ident $variant:ident )?],
313 )* } ) => (
314 top_level_tmod_enum!( {$([$dep_tracking_marker $($tmod $variant),*])|*} );
315
316 #[derive(Clone)]
317 $( #[$top_level_attr] )*
318 pub struct Options {
319 $(
320 $( #[$attr] )*
321 pub $opt: $t
322 ),*,
323 pub target_modifiers: BTreeMap<OptionsTargetModifiers, String>,
324 }
325
326 impl Options {
327 pub fn dep_tracking_hash(&self, for_crate_hash: bool) -> Hash64 {
328 let mut sub_hashes = BTreeMap::new();
329 $({
330 hash_opt!($opt,
331 &self.$opt,
332 &mut sub_hashes,
333 for_crate_hash,
334 [$dep_tracking_marker]);
335 })*
336 let mut hasher = StableHasher::new();
337 dep_tracking::stable_hash(sub_hashes,
338 &mut hasher,
339 self.error_format,
340 for_crate_hash);
341 $({
342 hash_substruct!($opt,
343 &self.$opt,
344 self.error_format,
345 for_crate_hash,
346 &mut hasher,
347 [$dep_tracking_marker]);
348 })*
349 hasher.finish()
350 }
351
352 pub fn gather_target_modifiers(&self) -> Vec<TargetModifier> {
353 let mut mods = Vec::<TargetModifier>::new();
354 $({
355 gather_tmods_top_level!($opt,
356 &self.$opt, &mut mods, &self.target_modifiers,
357 [$dep_tracking_marker $($tmod),*]);
358 })*
359 mods.sort_by(|a, b| a.opt.cmp(&b.opt));
360 mods
361 }
362 }
363 );
364}
365
366#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialEq for OptionsTargetModifiers {
#[inline]
fn eq(&self, other: &OptionsTargetModifiers) -> bool {
let __self_discr = ::core::intrinsics::discriminant_value(self);
let __arg1_discr = ::core::intrinsics::discriminant_value(other);
__self_discr == __arg1_discr &&
match (self, other) {
(OptionsTargetModifiers::UnstableOptions(__self_0),
OptionsTargetModifiers::UnstableOptions(__arg1_0)) =>
__self_0 == __arg1_0,
(OptionsTargetModifiers::CodegenOptions(__self_0),
OptionsTargetModifiers::CodegenOptions(__arg1_0)) =>
__self_0 == __arg1_0,
_ => unsafe { ::core::intrinsics::unreachable() }
}
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::Eq for OptionsTargetModifiers {
#[inline]
#[doc(hidden)]
#[coverage(off)]
fn assert_fields_are_eq(&self) {
let _: ::core::cmp::AssertParamIsEq<UnstableOptionsTargetModifiers>;
let _: ::core::cmp::AssertParamIsEq<CodegenOptionsTargetModifiers>;
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialOrd for OptionsTargetModifiers {
#[inline]
fn partial_cmp(&self, other: &OptionsTargetModifiers)
-> ::core::option::Option<::core::cmp::Ordering> {
let __self_discr = ::core::intrinsics::discriminant_value(self);
let __arg1_discr = ::core::intrinsics::discriminant_value(other);
match (self, other) {
(OptionsTargetModifiers::UnstableOptions(__self_0),
OptionsTargetModifiers::UnstableOptions(__arg1_0)) =>
::core::cmp::PartialOrd::partial_cmp(__self_0, __arg1_0),
(OptionsTargetModifiers::CodegenOptions(__self_0),
OptionsTargetModifiers::CodegenOptions(__arg1_0)) =>
::core::cmp::PartialOrd::partial_cmp(__self_0, __arg1_0),
_ =>
::core::cmp::PartialOrd::partial_cmp(&__self_discr,
&__arg1_discr),
}
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::Ord for OptionsTargetModifiers {
#[inline]
fn cmp(&self, other: &OptionsTargetModifiers) -> ::core::cmp::Ordering {
let __self_discr = ::core::intrinsics::discriminant_value(self);
let __arg1_discr = ::core::intrinsics::discriminant_value(other);
match ::core::cmp::Ord::cmp(&__self_discr, &__arg1_discr) {
::core::cmp::Ordering::Equal =>
match (self, other) {
(OptionsTargetModifiers::UnstableOptions(__self_0),
OptionsTargetModifiers::UnstableOptions(__arg1_0)) =>
::core::cmp::Ord::cmp(__self_0, __arg1_0),
(OptionsTargetModifiers::CodegenOptions(__self_0),
OptionsTargetModifiers::CodegenOptions(__arg1_0)) =>
::core::cmp::Ord::cmp(__self_0, __arg1_0),
_ => unsafe { ::core::intrinsics::unreachable() }
},
cmp => cmp,
}
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::fmt::Debug for OptionsTargetModifiers {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
match self {
OptionsTargetModifiers::UnstableOptions(__self_0) =>
::core::fmt::Formatter::debug_tuple_field1_finish(f,
"UnstableOptions", &__self_0),
OptionsTargetModifiers::CodegenOptions(__self_0) =>
::core::fmt::Formatter::debug_tuple_field1_finish(f,
"CodegenOptions", &__self_0),
}
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::marker::Copy for OptionsTargetModifiers { }
#[automatically_derived]
#[doc(hidden)]
#[allow(non_camel_case_types)]
unsafe impl ::core::clone::TrivialClone for OptionsTargetModifiers { }
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::clone::Clone for OptionsTargetModifiers {
#[inline]
fn clone(&self) -> OptionsTargetModifiers {
let _:
::core::clone::AssertParamIsClone<UnstableOptionsTargetModifiers>;
let _:
::core::clone::AssertParamIsClone<CodegenOptionsTargetModifiers>;
*self
}
}
const _: () =
{
impl<__E: ::rustc_span::SpanEncoder> ::rustc_serialize::Encodable<__E>
for OptionsTargetModifiers {
fn encode(&self, __encoder: &mut __E) {
let disc =
match *self {
OptionsTargetModifiers::UnstableOptions(ref __binding_0) =>
{
0usize
}
OptionsTargetModifiers::CodegenOptions(ref __binding_0) => {
1usize
}
};
::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
match *self {
OptionsTargetModifiers::UnstableOptions(ref __binding_0) =>
{
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
OptionsTargetModifiers::CodegenOptions(ref __binding_0) => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
}
}
}
};
const _: () =
{
impl<__D: ::rustc_span::BlobDecoder> ::rustc_serialize::Decodable<__D>
for OptionsTargetModifiers {
fn decode(__decoder: &mut __D) -> Self {
match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
{
0usize => {
OptionsTargetModifiers::UnstableOptions(::rustc_serialize::Decodable::decode(__decoder))
}
1usize => {
OptionsTargetModifiers::CodegenOptions(::rustc_serialize::Decodable::decode(__decoder))
}
n => {
::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `OptionsTargetModifiers`, expected 0..2, actual {0}",
n));
}
}
}
}
};
impl OptionsTargetModifiers {
#[allow(unused_variables)]
pub fn reparse(&self, user_value: &str) -> ExtendedTargetModifierInfo {
#[allow(unreachable_patterns)]
match self {
Self::UnstableOptions(v) => v.reparse(user_value),
Self::CodegenOptions(v) => v.reparse(user_value),
_ => {
::core::panicking::panic_fmt(format_args!("unknown target modifier option: {0:?}",
*self));
}
}
}
pub fn is_target_modifier(flag_name: &str) -> bool {
UnstableOptionsTargetModifiers::is_target_modifier(flag_name) ||
CodegenOptionsTargetModifiers::is_target_modifier(flag_name)
}
}
#[doc = r" The top-level command-line options struct."]
#[doc = r""]
#[doc =
r" For each option, one has to specify how it behaves with regard to the"]
#[doc =
r" dependency tracking system of incremental compilation. This is done via the"]
#[doc = r" square-bracketed directive after the field type. The options are:"]
#[doc = r""]
#[doc = r" - `[TRACKED]`"]
#[doc =
r" A change in the given field will cause the compiler to completely clear the"]
#[doc = r" incremental compilation cache before proceeding."]
#[doc = r""]
#[doc = r" - `[TRACKED_NO_CRATE_HASH]`"]
#[doc =
r" Same as `[TRACKED]`, but will not affect the crate hash. This is useful for options that"]
#[doc = r" only affect the incremental cache."]
#[doc = r""]
#[doc = r" - `[UNTRACKED]`"]
#[doc = r" Incremental compilation is not influenced by this option."]
#[doc = r""]
#[doc = r" - `[SUBSTRUCT]`"]
#[doc = r" Second-level sub-structs containing more options."]
#[doc = r""]
#[doc =
r" If you add a new option to this struct or one of the sub-structs like"]
#[doc =
r" `CodegenOptions`, think about how it influences incremental compilation. If in"]
#[doc =
r#" doubt, specify `[TRACKED]`, which is always "correct" but might lead to"#]
#[doc = r" unnecessary re-compilation."]
#[rustc_lint_opt_ty]
pub struct Options {
#[doc =
r" The crate config requested for the session, which may be combined"]
#[doc =
r" with additional crate configurations during the compile process."]
#[rustc_lint_opt_deny_field_access("use `TyCtxt::crate_types` instead of this field")]
pub crate_types: Vec<CrateType>,
pub optimize: OptLevel,
#[doc =
r" Include the `debug_assertions` flag in dependency tracking, since it"]
#[doc = r" can influence whether overflow checks are done or not."]
pub debug_assertions: bool,
pub debuginfo: DebugInfo,
pub lint_opts: Vec<(String, lint::Level)>,
pub lint_cap: Option<lint::Level>,
pub describe_lints: bool,
pub output_types: OutputTypes,
pub search_paths: Vec<SearchPath>,
pub libs: Vec<NativeLib>,
pub sysroot: Sysroot,
pub target_triple: TargetTuple,
#[doc =
r" Effective logical environment used by `env!`/`option_env!` macros"]
pub logical_env: FxIndexMap<String, String>,
pub test: bool,
pub error_format: ErrorOutputType,
pub diagnostic_width: Option<usize>,
#[doc = r" If `Some`, enable incremental compilation, using the given"]
#[doc = r" directory to store intermediate results."]
pub incremental: Option<PathBuf>,
#[doc = r" Set based on the result of the `Config::track_state` callback"]
#[doc = r" for custom drivers to invalidate the incremental cache."]
#[rustc_lint_opt_deny_field_access("should only be used via `Config::track_state`")]
pub untracked_state_hash: Hash64,
pub unstable_opts: UnstableOptions,
pub prints: Vec<PrintRequest>,
pub cg: CodegenOptions,
pub externs: Externs,
pub crate_name: Option<String>,
#[doc = r" Indicates how the compiler should treat unstable features."]
pub unstable_features: UnstableFeatures,
#[doc =
r" Indicates whether this run of the compiler is actually rustdoc. This"]
#[doc =
r" is currently just a hack and will be removed eventually, so please"]
#[doc = r" try to not rely on this too much."]
pub actually_rustdoc: bool,
#[doc = r" Whether name resolver should resolve documentation links."]
pub resolve_doc_links: ResolveDocLinks,
#[doc = r" Control path trimming."]
pub trimmed_def_paths: bool,
#[doc =
r" Specifications of codegen units / ThinLTO which are forced as a"]
#[doc =
r" result of parsing command line options. These are not necessarily"]
#[doc = r" what rustc was invoked with, but massaged a bit to agree with"]
#[doc =
r" commands like `--emit llvm-ir` which they're often incompatible with"]
#[doc = r" if we otherwise use the defaults of rustc."]
#[rustc_lint_opt_deny_field_access("use `Session::codegen_units` instead of this field")]
pub cli_forced_codegen_units: Option<usize>,
#[rustc_lint_opt_deny_field_access("use `Session::lto` instead of this field")]
pub cli_forced_local_thinlto_off: bool,
#[doc =
r" Remap source path prefixes in all output (messages, object files, debug, etc.)."]
pub remap_path_prefix: Vec<(PathBuf, PathBuf)>,
#[doc =
r" Defines which scopes of paths should be remapped by `--remap-path-prefix`."]
pub remap_path_scope: RemapPathScopeComponents,
#[doc =
r" Base directory containing the `library/` directory for the Rust standard library."]
#[doc = r" Right now it's always `$sysroot/lib/rustlib/src/rust`"]
#[doc = r" (i.e. the `rustup` `rust-src` component)."]
#[doc = r""]
#[doc =
r" This directory is what the virtual `/rustc/$hash` is translated back to,"]
#[doc =
r" if Rust was built with path remapping to `/rustc/$hash` enabled"]
#[doc = r" (the `rust.remap-debuginfo` option in `bootstrap.toml`)."]
pub real_rust_source_base_dir: Option<PathBuf>,
#[doc =
r" Base directory containing the `compiler/` directory for the rustc sources."]
#[doc = r" Right now it's always `$sysroot/lib/rustlib/rustc-src/rust`"]
#[doc = r" (i.e. the `rustup` `rustc-dev` component)."]
#[doc = r""]
#[doc =
r" This directory is what the virtual `/rustc-dev/$hash` is translated back to,"]
#[doc =
r" if Rust was built with path remapping to `/rustc/$hash` enabled"]
#[doc = r" (the `rust.remap-debuginfo` option in `bootstrap.toml`)."]
pub real_rustc_dev_source_base_dir: Option<PathBuf>,
pub edition: Edition,
#[doc =
r" `true` if we're emitting JSON blobs about each artifact produced"]
#[doc = r" by the compiler."]
pub json_artifact_notifications: bool,
#[doc =
r" `true` if we're emitting JSON timings with the start and end of"]
#[doc = r" high-level compilation sections"]
pub json_timings: bool,
#[doc =
r" `true` if we're emitting a JSON blob containing the unused externs"]
pub json_unused_externs: JsonUnusedExterns,
#[doc =
r" `true` if we're emitting a JSON job containing a future-incompat report for lints"]
pub json_future_incompat: bool,
pub pretty: Option<PpMode>,
#[doc = r" The (potentially remapped) working directory"]
#[rustc_lint_opt_deny_field_access("use `SourceMap::working_dir` instead of this field")]
pub working_dir: RealFileName,
pub color: ColorConfig,
pub verbose: bool,
pub target_modifiers: BTreeMap<OptionsTargetModifiers, String>,
}
#[automatically_derived]
impl ::core::clone::Clone for Options {
#[inline]
fn clone(&self) -> Options {
Options {
crate_types: ::core::clone::Clone::clone(&self.crate_types),
optimize: ::core::clone::Clone::clone(&self.optimize),
debug_assertions: ::core::clone::Clone::clone(&self.debug_assertions),
debuginfo: ::core::clone::Clone::clone(&self.debuginfo),
lint_opts: ::core::clone::Clone::clone(&self.lint_opts),
lint_cap: ::core::clone::Clone::clone(&self.lint_cap),
describe_lints: ::core::clone::Clone::clone(&self.describe_lints),
output_types: ::core::clone::Clone::clone(&self.output_types),
search_paths: ::core::clone::Clone::clone(&self.search_paths),
libs: ::core::clone::Clone::clone(&self.libs),
sysroot: ::core::clone::Clone::clone(&self.sysroot),
target_triple: ::core::clone::Clone::clone(&self.target_triple),
logical_env: ::core::clone::Clone::clone(&self.logical_env),
test: ::core::clone::Clone::clone(&self.test),
error_format: ::core::clone::Clone::clone(&self.error_format),
diagnostic_width: ::core::clone::Clone::clone(&self.diagnostic_width),
incremental: ::core::clone::Clone::clone(&self.incremental),
untracked_state_hash: ::core::clone::Clone::clone(&self.untracked_state_hash),
unstable_opts: ::core::clone::Clone::clone(&self.unstable_opts),
prints: ::core::clone::Clone::clone(&self.prints),
cg: ::core::clone::Clone::clone(&self.cg),
externs: ::core::clone::Clone::clone(&self.externs),
crate_name: ::core::clone::Clone::clone(&self.crate_name),
unstable_features: ::core::clone::Clone::clone(&self.unstable_features),
actually_rustdoc: ::core::clone::Clone::clone(&self.actually_rustdoc),
resolve_doc_links: ::core::clone::Clone::clone(&self.resolve_doc_links),
trimmed_def_paths: ::core::clone::Clone::clone(&self.trimmed_def_paths),
cli_forced_codegen_units: ::core::clone::Clone::clone(&self.cli_forced_codegen_units),
cli_forced_local_thinlto_off: ::core::clone::Clone::clone(&self.cli_forced_local_thinlto_off),
remap_path_prefix: ::core::clone::Clone::clone(&self.remap_path_prefix),
remap_path_scope: ::core::clone::Clone::clone(&self.remap_path_scope),
real_rust_source_base_dir: ::core::clone::Clone::clone(&self.real_rust_source_base_dir),
real_rustc_dev_source_base_dir: ::core::clone::Clone::clone(&self.real_rustc_dev_source_base_dir),
edition: ::core::clone::Clone::clone(&self.edition),
json_artifact_notifications: ::core::clone::Clone::clone(&self.json_artifact_notifications),
json_timings: ::core::clone::Clone::clone(&self.json_timings),
json_unused_externs: ::core::clone::Clone::clone(&self.json_unused_externs),
json_future_incompat: ::core::clone::Clone::clone(&self.json_future_incompat),
pretty: ::core::clone::Clone::clone(&self.pretty),
working_dir: ::core::clone::Clone::clone(&self.working_dir),
color: ::core::clone::Clone::clone(&self.color),
verbose: ::core::clone::Clone::clone(&self.verbose),
target_modifiers: ::core::clone::Clone::clone(&self.target_modifiers),
}
}
}
impl Options {
pub fn dep_tracking_hash(&self, for_crate_hash: bool) -> Hash64 {
let mut sub_hashes = BTreeMap::new();
{
{
if (&mut sub_hashes).insert("crate_types",
&self.crate_types as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"crate_types"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("optimize",
&self.optimize as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"optimize"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("debug_assertions",
&self.debug_assertions as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"debug_assertions"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("debuginfo",
&self.debuginfo as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"debuginfo"));
}
}
};
}
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("lint_opts",
&self.lint_opts as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"lint_opts"));
}
}
}
};
}
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("lint_cap",
&self.lint_cap as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"lint_cap"));
}
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("output_types",
&self.output_types as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"output_types"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("libs",
&self.libs as &dyn dep_tracking::DepTrackingHash).is_some()
{
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"libs"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("target_triple",
&self.target_triple as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"target_triple"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("logical_env",
&self.logical_env as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"logical_env"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("test",
&self.test as &dyn dep_tracking::DepTrackingHash).is_some()
{
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"test"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("untracked_state_hash",
&self.untracked_state_hash as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"untracked_state_hash"));
}
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("crate_name",
&self.crate_name as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"crate_name"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("unstable_features",
&self.unstable_features as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"unstable_features"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("actually_rustdoc",
&self.actually_rustdoc as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"actually_rustdoc"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("resolve_doc_links",
&self.resolve_doc_links as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"resolve_doc_links"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("trimmed_def_paths",
&self.trimmed_def_paths as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"trimmed_def_paths"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("remap_path_prefix",
&self.remap_path_prefix as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"remap_path_prefix"));
}
}
}
};
}
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("remap_path_scope",
&self.remap_path_scope as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"remap_path_scope"));
}
}
}
};
}
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("real_rust_source_base_dir",
&self.real_rust_source_base_dir as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"real_rust_source_base_dir"));
}
}
}
};
}
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("real_rustc_dev_source_base_dir",
&self.real_rustc_dev_source_base_dir as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"real_rustc_dev_source_base_dir"));
}
}
}
};
}
{
{
if (&mut sub_hashes).insert("edition",
&self.edition as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"edition"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("json_artifact_notifications",
&self.json_artifact_notifications as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"json_artifact_notifications"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("json_future_incompat",
&self.json_future_incompat as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"json_future_incompat"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("working_dir",
&self.working_dir as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"working_dir"));
}
}
};
}
{ {}; }
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("verbose",
&self.verbose as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"verbose"));
}
}
}
};
}
let mut hasher = StableHasher::new();
dep_tracking::stable_hash(sub_hashes, &mut hasher, self.error_format,
for_crate_hash);
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
use crate::config::dep_tracking::DepTrackingHash;
(&self.unstable_opts).dep_tracking_hash(for_crate_hash,
self.error_format).hash(&mut hasher, self.error_format,
for_crate_hash);
;
}
{ {}; }
{
use crate::config::dep_tracking::DepTrackingHash;
(&self.cg).dep_tracking_hash(for_crate_hash,
self.error_format).hash(&mut hasher, self.error_format,
for_crate_hash);
;
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
hasher.finish()
}
pub fn gather_target_modifiers(&self) -> Vec<TargetModifier> {
let mut mods = Vec::<TargetModifier>::new();
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{
(&self.unstable_opts).gather_target_modifiers(&mut mods,
&self.target_modifiers);
;
}
{ ; }
{
(&self.cg).gather_target_modifiers(&mut mods,
&self.target_modifiers);
;
}
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
{ ; }
mods.sort_by(|a, b| a.opt.cmp(&b.opt));
mods
}
}top_level_options!(
367 #[rustc_lint_opt_ty]
392 pub struct Options {
393 #[rustc_lint_opt_deny_field_access("use `TyCtxt::crate_types` instead of this field")]
396 crate_types: Vec<CrateType> [TRACKED],
397 optimize: OptLevel [TRACKED],
398 debug_assertions: bool [TRACKED],
401 debuginfo: DebugInfo [TRACKED],
402 lint_opts: Vec<(String, lint::Level)> [TRACKED_NO_CRATE_HASH],
403 lint_cap: Option<lint::Level> [TRACKED_NO_CRATE_HASH],
404 describe_lints: bool [UNTRACKED],
405 output_types: OutputTypes [TRACKED],
406 search_paths: Vec<SearchPath> [UNTRACKED],
407 libs: Vec<NativeLib> [TRACKED],
408 sysroot: Sysroot [UNTRACKED],
409
410 target_triple: TargetTuple [TRACKED],
411
412 logical_env: FxIndexMap<String, String> [TRACKED],
414
415 test: bool [TRACKED],
416 error_format: ErrorOutputType [UNTRACKED],
417 diagnostic_width: Option<usize> [UNTRACKED],
418
419 incremental: Option<PathBuf> [UNTRACKED],
422 #[rustc_lint_opt_deny_field_access("should only be used via `Config::track_state`")]
425 untracked_state_hash: Hash64 [TRACKED_NO_CRATE_HASH],
426
427 unstable_opts: UnstableOptions [SUBSTRUCT UnstableOptionsTargetModifiers UnstableOptions],
428 prints: Vec<PrintRequest> [UNTRACKED],
429 cg: CodegenOptions [SUBSTRUCT CodegenOptionsTargetModifiers CodegenOptions],
430 externs: Externs [UNTRACKED],
431 crate_name: Option<String> [TRACKED],
432 unstable_features: UnstableFeatures [TRACKED],
434
435 actually_rustdoc: bool [TRACKED],
439 resolve_doc_links: ResolveDocLinks [TRACKED],
441
442 trimmed_def_paths: bool [TRACKED],
444
445 #[rustc_lint_opt_deny_field_access("use `Session::codegen_units` instead of this field")]
451 cli_forced_codegen_units: Option<usize> [UNTRACKED],
452 #[rustc_lint_opt_deny_field_access("use `Session::lto` instead of this field")]
453 cli_forced_local_thinlto_off: bool [UNTRACKED],
454
455 remap_path_prefix: Vec<(PathBuf, PathBuf)> [TRACKED_NO_CRATE_HASH],
457 remap_path_scope: RemapPathScopeComponents [TRACKED_NO_CRATE_HASH],
459
460 real_rust_source_base_dir: Option<PathBuf> [TRACKED_NO_CRATE_HASH],
468
469 real_rustc_dev_source_base_dir: Option<PathBuf> [TRACKED_NO_CRATE_HASH],
477
478 edition: Edition [TRACKED],
479
480 json_artifact_notifications: bool [TRACKED],
483
484 json_timings: bool [UNTRACKED],
487
488 json_unused_externs: JsonUnusedExterns [UNTRACKED],
490
491 json_future_incompat: bool [TRACKED],
493
494 pretty: Option<PpMode> [UNTRACKED],
495
496 #[rustc_lint_opt_deny_field_access("use `SourceMap::working_dir` instead of this field")]
498 working_dir: RealFileName [TRACKED],
499
500 color: ColorConfig [UNTRACKED],
501
502 verbose: bool [TRACKED_NO_CRATE_HASH],
503 }
504);
505
506macro_rules! tmod_enum_opt {
507 ($struct_name:ident, $tmod_enum_name:ident, $opt:ident, $v:ident) => {
508 Some(OptionsTargetModifiers::$struct_name($tmod_enum_name::$opt))
509 };
510 ($struct_name:ident, $tmod_enum_name:ident, $opt:ident, ) => {
511 None
512 };
513}
514
515macro_rules! tmod_enum {
516 ($tmod_enum_name:ident, $prefix:expr, $( {$($optinfo:tt)*} ),* $(,)*) => {
517 tmod_enum! { $tmod_enum_name, $prefix, @parse {}, (user_value){}; $($($optinfo)*|)* }
518 };
519 (
521 $tmod_enum_name:ident, $prefix:expr,
522 @parse
523 {$($eout:tt)*},
524 ($user_value:ident){$($pout:tt)*};
525 ) => {
526 #[allow(non_camel_case_types)]
527 #[derive(PartialEq, Eq, PartialOrd, Ord, Debug, Copy, Clone, Encodable, BlobDecodable)]
528 pub enum $tmod_enum_name {
529 $($eout),*
530 }
531 impl $tmod_enum_name {
532 #[allow(unused_variables)]
533 pub fn reparse(&self, $user_value: &str) -> ExtendedTargetModifierInfo {
534 #[allow(unreachable_patterns)]
535 match self {
536 $($pout)*
537 _ => panic!("unknown target modifier option: {:?}", *self)
538 }
539 }
540 pub fn is_target_modifier(flag_name: &str) -> bool {
541 match flag_name.replace('-', "_").as_str() {
542 $(stringify!($eout) => true,)*
543 _ => false,
544 }
545 }
546 }
547 };
548 (
550 $tmod_enum_name:ident, $prefix:expr,
551 @parse {$($eout:tt)*}, ($puser_value:ident){$($pout:tt)*};
552 $opt:ident, $parse:ident, $t:ty, [TARGET_MODIFIER] |
553 $($tail:tt)*
554 ) => {
555 tmod_enum! {
556 $tmod_enum_name, $prefix,
557 @parse
558 {
559 $($eout)*
560 $opt
561 },
562 ($puser_value){
563 $($pout)*
564 Self::$opt => {
565 let mut parsed : $t = Default::default();
566 let val = if $puser_value.is_empty() { None } else { Some($puser_value) };
567 parse::$parse(&mut parsed, val);
568 ExtendedTargetModifierInfo {
569 prefix: $prefix.to_string(),
570 name: stringify!($opt).to_string().replace('_', "-"),
571 tech_value: format!("{:?}", parsed),
572 }
573 },
574 };
575 $($tail)*
576 }
577 };
578 (
580 $tmod_enum_name:ident, $prefix:expr,
581 @parse {$($eout:tt)*}, ($puser_value:ident){$($pout:tt)*};
582 $opt:ident, $parse:ident, $t:ty, [] |
583 $($tail:tt)*
584 ) => {
585 tmod_enum! {
586 $tmod_enum_name, $prefix,
587 @parse
588 {
589 $($eout)*
590 },
591 ($puser_value){
592 $($pout)*
593 };
594 $($tail)*
595 }
596 };
597}
598
599macro_rules! options {
608 ($struct_name:ident, $tmod_enum_name:ident, $stat:ident, $optmod:ident, $prefix:expr, $outputname:expr,
609 $($( #[$attr:meta] )* $opt:ident : $t:ty = (
610 $init:expr,
611 $parse:ident,
612 [$dep_tracking_marker:ident $( $tmod:ident )?],
613 $desc:expr
614 $(, removed: $removed:ident )?)
615 ),* ,) =>
616(
617 #[derive(Clone)]
618 #[rustc_lint_opt_ty]
619 pub struct $struct_name { $( $( #[$attr] )* pub $opt: $t),* }
620
621 tmod_enum!( $tmod_enum_name, $prefix, {$($opt, $parse, $t, [$($tmod),*])|*} );
622
623 impl Default for $struct_name {
624 fn default() -> $struct_name {
625 $struct_name { $($opt: $init),* }
626 }
627 }
628
629 impl $struct_name {
630 pub fn build(
631 early_dcx: &EarlyDiagCtxt,
632 matches: &getopts::Matches,
633 target_modifiers: &mut BTreeMap<OptionsTargetModifiers, String>,
634 ) -> $struct_name {
635 build_options(early_dcx, matches, target_modifiers, $stat, $prefix, $outputname)
636 }
637
638 fn dep_tracking_hash(&self, for_crate_hash: bool, error_format: ErrorOutputType) -> Hash64 {
639 let mut sub_hashes = BTreeMap::new();
640 $({
641 hash_opt!($opt,
642 &self.$opt,
643 &mut sub_hashes,
644 for_crate_hash,
645 [$dep_tracking_marker]);
646 })*
647 let mut hasher = StableHasher::new();
648 dep_tracking::stable_hash(sub_hashes,
649 &mut hasher,
650 error_format,
651 for_crate_hash
652 );
653 hasher.finish()
654 }
655
656 pub fn gather_target_modifiers(
657 &self,
658 _mods: &mut Vec<TargetModifier>,
659 _tmod_vals: &BTreeMap<OptionsTargetModifiers, String>,
660 ) {
661 $({
662 gather_tmods!($struct_name, $tmod_enum_name, $opt, &self.$opt, $init, _mods, _tmod_vals,
663 [$dep_tracking_marker], [$($tmod),*]);
664 })*
665 }
666 }
667
668 pub const $stat: OptionDescrs<$struct_name> =
669 &[ $( OptionDesc{ name: stringify!($opt), setter: $optmod::$opt,
670 type_desc: desc::$parse, desc: $desc, removed: None $( .or(Some(RemovedOption::$removed)) )?,
671 tmod: tmod_enum_opt!($struct_name, $tmod_enum_name, $opt, $($tmod),*) } ),* ];
672
673 mod $optmod {
674 $(
675 pub(super) fn $opt(cg: &mut super::$struct_name, v: Option<&str>) -> bool {
676 super::parse::$parse(&mut redirect_field!(cg.$opt), v)
677 }
678 )*
679 }
680
681) }
682
683impl CodegenOptions {
684 #[allow(rustc::bad_opt_access)]
686 pub fn instrument_coverage(&self) -> InstrumentCoverage {
687 self.instrument_coverage
688 }
689}
690
691macro_rules! redirect_field {
694 ($cg:ident.link_arg) => {
695 $cg.link_args
696 };
697 ($cg:ident.pre_link_arg) => {
698 $cg.pre_link_args
699 };
700 ($cg:ident.$field:ident) => {
701 $cg.$field
702 };
703}
704
705type OptionSetter<O> = fn(&mut O, v: Option<&str>) -> bool;
706type OptionDescrs<O> = &'static [OptionDesc<O>];
707
708enum RemovedOption {
710 Warn,
711 Err,
712}
713
714pub struct OptionDesc<O> {
715 name: &'static str,
716 setter: OptionSetter<O>,
717 type_desc: &'static str,
719 desc: &'static str,
721 removed: Option<RemovedOption>,
722 tmod: Option<OptionsTargetModifiers>,
723}
724
725impl<O> OptionDesc<O> {
726 pub fn name(&self) -> &'static str {
727 self.name
728 }
729
730 pub fn desc(&self) -> &'static str {
731 self.desc
732 }
733}
734
735fn build_options<O: Default>(
736 early_dcx: &EarlyDiagCtxt,
737 matches: &getopts::Matches,
738 target_modifiers: &mut BTreeMap<OptionsTargetModifiers, String>,
739 descrs: OptionDescrs<O>,
740 prefix: &str,
741 outputname: &str,
742) -> O {
743 let mut op = O::default();
744 for option in matches.opt_strs(prefix) {
745 let (key, value) = match option.split_once('=') {
746 None => (option, None),
747 Some((k, v)) => (k.to_string(), Some(v)),
748 };
749
750 let option_to_lookup = key.replace('-', "_");
751 match descrs.iter().find(|opt_desc| opt_desc.name == option_to_lookup) {
752 Some(OptionDesc { name: _, setter, type_desc, desc, removed, tmod }) => {
753 if let Some(removed) = removed {
754 if !!prefix.is_empty() {
::core::panicking::panic("assertion failed: !prefix.is_empty()")
};assert!(!prefix.is_empty());
756 match removed {
757 RemovedOption::Warn => {
758 early_dcx.early_warn(::alloc::__export::must_use({
::alloc::fmt::format(format_args!("`-{0} {1}`: {2}", prefix, key,
desc))
})format!("`-{prefix} {key}`: {desc}"))
759 }
760 RemovedOption::Err => {
761 early_dcx.early_fatal(::alloc::__export::must_use({
::alloc::fmt::format(format_args!("`-{0} {1}`: {2}", prefix, key,
desc))
})format!("`-{prefix} {key}`: {desc}"))
762 }
763 }
764 }
765 if !setter(&mut op, value) {
766 match value {
767 None => early_dcx.early_fatal(
768 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0} option `{1}` requires {2} (`-{3} {1}=<value>`)",
outputname, key, type_desc, prefix))
})format!(
769 "{outputname} option `{key}` requires {type_desc} (`-{prefix} {key}=<value>`)"
770 ),
771 ),
772 Some(value) => early_dcx.early_fatal(
773 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("incorrect value `{0}` for {1} option `{2}` - {3} was expected",
value, outputname, key, type_desc))
})format!(
774 "incorrect value `{value}` for {outputname} option `{key}` - {type_desc} was expected"
775 ),
776 ),
777 }
778 }
779 if let Some(tmod) = *tmod {
780 let v = value.map_or(String::new(), ToOwned::to_owned);
781 target_modifiers.insert(tmod, v);
782 }
783 }
784 None => early_dcx.early_fatal(::alloc::__export::must_use({
::alloc::fmt::format(format_args!("unknown {0} option: `{1}`",
outputname, key))
})format!("unknown {outputname} option: `{key}`")),
785 }
786 }
787 op
788}
789
790#[allow(non_upper_case_globals)]
791mod desc {
792 pub(crate) const parse_ignore: &str = "<ignored>"; pub(crate) const parse_no_value: &str = "no value";
794 pub(crate) const parse_bool: &str =
795 "one of: `y`, `yes`, `on`, `true`, `n`, `no`, `off` or `false`";
796 pub(crate) const parse_opt_bool: &str = parse_bool;
797 pub(crate) const parse_string: &str = "a string";
798 pub(crate) const parse_opt_string: &str = parse_string;
799 pub(crate) const parse_string_push: &str = parse_string;
800 pub(crate) const parse_opt_pathbuf: &str = "a path";
801 pub(crate) const parse_list: &str = "a space-separated list of strings";
802 pub(crate) const parse_list_with_polarity: &str =
803 "a comma-separated list of strings, with elements beginning with + or -";
804 pub(crate) const parse_autodiff: &str = "a comma separated list of settings: `Enable`, `PrintSteps`, `PrintTA`, `PrintTAFn`, `PrintAA`, `PrintPerf`, `PrintModBefore`, `PrintModAfter`, `PrintModFinal`, `PrintPasses`, `NoPostopt`, `LooseTypes`, `Inline`, `NoTT`";
805 pub(crate) const parse_offload: &str =
806 "a comma separated list of settings: `Host=<Absolute-Path>`, `Device`, `Test`";
807 pub(crate) const parse_comma_list: &str = "a comma-separated list of strings";
808 pub(crate) const parse_opt_comma_list: &str = parse_comma_list;
809 pub(crate) const parse_number: &str = "a number";
810 pub(crate) const parse_opt_number: &str = parse_number;
811 pub(crate) const parse_frame_pointer: &str = "one of `true`/`yes`/`on`, `false`/`no`/`off`, or (with -Zunstable-options) `non-leaf` or `always`";
812 pub(crate) const parse_threads: &str = parse_number;
813 pub(crate) const parse_time_passes_format: &str = "`text` (default) or `json`";
814 pub(crate) const parse_passes: &str = "a space-separated list of passes, or `all`";
815 pub(crate) const parse_panic_strategy: &str = "either `unwind`, `abort`, or `immediate-abort`";
816 pub(crate) const parse_on_broken_pipe: &str = "either `kill`, `error`, or `inherit`";
817 pub(crate) const parse_patchable_function_entry: &str = "either two comma separated integers (total_nops,prefix_nops), with prefix_nops <= total_nops, or one integer (total_nops)";
818 pub(crate) const parse_opt_panic_strategy: &str = parse_panic_strategy;
819 pub(crate) const parse_relro_level: &str = "one of: `full`, `partial`, or `off`";
820 pub(crate) const parse_sanitizers: &str = "comma separated list of sanitizers: `address`, `cfi`, `dataflow`, `hwaddress`, `kcfi`, `kernel-address`, `kernel-hwaddress`, `leak`, `memory`, `memtag`, `safestack`, `shadow-call-stack`, `thread`, or 'realtime'";
821 pub(crate) const parse_sanitizer_memory_track_origins: &str = "0, 1, or 2";
822 pub(crate) const parse_cfguard: &str =
823 "either a boolean (`yes`, `no`, `on`, `off`, etc), `checks`, or `nochecks`";
824 pub(crate) const parse_cfprotection: &str = "`none`|`no`|`n` (default), `branch`, `return`, or `full`|`yes`|`y` (equivalent to `branch` and `return`)";
825 pub(crate) const parse_debuginfo: &str = "either an integer (0, 1, 2), `none`, `line-directives-only`, `line-tables-only`, `limited`, or `full`";
826 pub(crate) const parse_debuginfo_compression: &str = "one of `none`, `zlib`, or `zstd`";
827 pub(crate) const parse_mir_strip_debuginfo: &str =
828 "one of `none`, `locals-in-tiny-functions`, or `all-locals`";
829 pub(crate) const parse_collapse_macro_debuginfo: &str = "one of `no`, `external`, or `yes`";
830 pub(crate) const parse_strip: &str = "either `none`, `debuginfo`, or `symbols`";
831 pub(crate) const parse_linker_flavor: &str = ::rustc_target::spec::LinkerFlavorCli::one_of();
832 pub(crate) const parse_dump_mono_stats: &str = "`markdown` (default) or `json`";
833 pub(crate) const parse_instrument_coverage: &str = parse_bool;
834 pub(crate) const parse_coverage_options: &str = "`block` | `branch` | `condition`";
835 pub(crate) const parse_instrument_xray: &str = "either a boolean (`yes`, `no`, `on`, `off`, etc), or a comma separated list of settings: `always` or `never` (mutually exclusive), `ignore-loops`, `instruction-threshold=N`, `skip-entry`, `skip-exit`";
836 pub(crate) const parse_unpretty: &str = "`string` or `string=string`";
837 pub(crate) const parse_treat_err_as_bug: &str = "either no value or a non-negative number";
838 pub(crate) const parse_next_solver_config: &str =
839 "either `globally` (when used without an argument), `coherence` (default) or `no`";
840 pub(crate) const parse_lto: &str =
841 "either a boolean (`yes`, `no`, `on`, `off`, etc), `thin`, `fat`, or omitted";
842 pub(crate) const parse_linker_plugin_lto: &str =
843 "either a boolean (`yes`, `no`, `on`, `off`, etc), or the path to the linker plugin";
844 pub(crate) const parse_location_detail: &str = "either `none`, or a comma separated list of location details to track: `file`, `line`, or `column`";
845 pub(crate) const parse_fmt_debug: &str = "either `full`, `shallow`, or `none`";
846 pub(crate) const parse_switch_with_opt_path: &str =
847 "an optional path to the profiling data output directory";
848 pub(crate) const parse_merge_functions: &str =
849 "one of: `disabled`, `trampolines`, or `aliases`";
850 pub(crate) const parse_symbol_mangling_version: &str =
851 "one of: `legacy`, `v0` (RFC 2603), or `hashed`";
852 pub(crate) const parse_opt_symbol_visibility: &str =
853 "one of: `hidden`, `protected`, or `interposable`";
854 pub(crate) const parse_cargo_src_file_hash: &str =
855 "one of `blake3`, `md5`, `sha1`, or `sha256`";
856 pub(crate) const parse_src_file_hash: &str = "one of `md5`, `sha1`, or `sha256`";
857 pub(crate) const parse_relocation_model: &str =
858 "one of supported relocation models (`rustc --print relocation-models`)";
859 pub(crate) const parse_code_model: &str =
860 "one of supported code models (`rustc --print code-models`)";
861 pub(crate) const parse_tls_model: &str =
862 "one of supported TLS models (`rustc --print tls-models`)";
863 pub(crate) const parse_target_feature: &str = parse_string;
864 pub(crate) const parse_terminal_url: &str =
865 "either a boolean (`yes`, `no`, `on`, `off`, etc), or `auto`";
866 pub(crate) const parse_wasi_exec_model: &str = "either `command` or `reactor`";
867 pub(crate) const parse_split_debuginfo: &str =
868 "one of supported split-debuginfo modes (`off`, `packed`, or `unpacked`)";
869 pub(crate) const parse_split_dwarf_kind: &str =
870 "one of supported split dwarf modes (`split` or `single`)";
871 pub(crate) const parse_link_self_contained: &str = "one of: `y`, `yes`, `on`, `n`, `no`, `off`, or a list of enabled (`+` prefix) and disabled (`-` prefix) \
872 components: `crto`, `libc`, `unwind`, `linker`, `sanitizers`, `mingw`";
873 pub(crate) const parse_linker_features: &str =
874 "a list of enabled (`+` prefix) and disabled (`-` prefix) features: `lld`";
875 pub(crate) const parse_polonius: &str = "either no value or `legacy` (the default), or `next`";
876 pub(crate) const parse_annotate_moves: &str =
877 "either a boolean (`yes`, `no`, `on`, `off`, etc.), or a size limit in bytes";
878 pub(crate) const parse_stack_protector: &str =
879 "one of (`none` (default), `basic`, `strong`, or `all`)";
880 pub(crate) const parse_branch_protection: &str = "a `,` separated combination of `bti`, `gcs`, `pac-ret`, (optionally with `pc`, `b-key`, `leaf` if `pac-ret` is set)";
881 pub(crate) const parse_proc_macro_execution_strategy: &str =
882 "one of supported execution strategies (`same-thread`, or `cross-thread`)";
883 pub(crate) const parse_inlining_threshold: &str =
884 "either a boolean (`yes`, `no`, `on`, `off`, etc), or a non-negative number";
885 pub(crate) const parse_llvm_module_flag: &str = "<key>:<type>:<value>:<behavior>. Type must currently be `u32`. Behavior should be one of (`error`, `warning`, `require`, `override`, `append`, `appendunique`, `max`, `min`)";
886 pub(crate) const parse_function_return: &str = "`keep` or `thunk-extern`";
887 pub(crate) const parse_wasm_c_abi: &str = "`spec`";
888 pub(crate) const parse_mir_include_spans: &str =
889 "either a boolean (`yes`, `no`, `on`, `off`, etc), or `nll` (default: `nll`)";
890 pub(crate) const parse_align: &str = "a number that is a power of 2 between 1 and 2^29";
891 pub(crate) const parse_assert_incr_state: &str = "one of: `loaded`, `not-loaded`";
892}
893
894pub mod parse {
895 use std::str::FromStr;
896
897 pub(crate) use super::*;
898 pub(crate) const MAX_THREADS_CAP: usize = 256;
899
900 pub(crate) fn parse_ignore(_slot: &mut (), _v: Option<&str>) -> bool {
903 true
904 }
905
906 pub(crate) fn parse_no_value(slot: &mut bool, v: Option<&str>) -> bool {
912 match v {
913 None => {
914 *slot = true;
915 true
916 }
917 Some(_) => false,
919 }
920 }
921
922 pub(crate) fn parse_bool(slot: &mut bool, v: Option<&str>) -> bool {
924 match v {
925 Some("y") | Some("yes") | Some("on") | Some("true") | None => {
926 *slot = true;
927 true
928 }
929 Some("n") | Some("no") | Some("off") | Some("false") => {
930 *slot = false;
931 true
932 }
933 _ => false,
934 }
935 }
936
937 pub(crate) fn parse_opt_bool(slot: &mut Option<bool>, v: Option<&str>) -> bool {
941 match v {
942 Some("y") | Some("yes") | Some("on") | Some("true") | None => {
943 *slot = Some(true);
944 true
945 }
946 Some("n") | Some("no") | Some("off") | Some("false") => {
947 *slot = Some(false);
948 true
949 }
950 _ => false,
951 }
952 }
953
954 pub(crate) fn parse_polonius(slot: &mut Polonius, v: Option<&str>) -> bool {
956 match v {
957 Some("legacy") | None => {
958 *slot = Polonius::Legacy;
959 true
960 }
961 Some("next") => {
962 *slot = Polonius::Next;
963 true
964 }
965 _ => false,
966 }
967 }
968
969 pub(crate) fn parse_annotate_moves(slot: &mut AnnotateMoves, v: Option<&str>) -> bool {
970 let mut bslot = false;
971 let mut nslot = 0u64;
972
973 *slot = match v {
974 None => AnnotateMoves::Enabled(None),
976 s @ Some(_) if parse_bool(&mut bslot, s) => {
978 if bslot {
979 AnnotateMoves::Enabled(None)
980 } else {
981 AnnotateMoves::Disabled
982 }
983 }
984 s @ Some(_) if parse_number(&mut nslot, s) => AnnotateMoves::Enabled(Some(nslot)),
986 _ => return false,
987 };
988
989 true
990 }
991
992 pub(crate) fn parse_string(slot: &mut String, v: Option<&str>) -> bool {
994 match v {
995 Some(s) => {
996 *slot = s.to_string();
997 true
998 }
999 None => false,
1000 }
1001 }
1002
1003 pub(crate) fn parse_opt_string(slot: &mut Option<String>, v: Option<&str>) -> bool {
1005 match v {
1006 Some(s) => {
1007 *slot = Some(s.to_string());
1008 true
1009 }
1010 None => false,
1011 }
1012 }
1013
1014 pub(crate) fn parse_opt_pathbuf(slot: &mut Option<PathBuf>, v: Option<&str>) -> bool {
1015 match v {
1016 Some(s) => {
1017 *slot = Some(PathBuf::from(s));
1018 true
1019 }
1020 None => false,
1021 }
1022 }
1023
1024 pub(crate) fn parse_string_push(slot: &mut Vec<String>, v: Option<&str>) -> bool {
1025 match v {
1026 Some(s) => {
1027 slot.push(s.to_string());
1028 true
1029 }
1030 None => false,
1031 }
1032 }
1033
1034 pub(crate) fn parse_list(slot: &mut Vec<String>, v: Option<&str>) -> bool {
1035 match v {
1036 Some(s) => {
1037 slot.extend(s.split_whitespace().map(|s| s.to_string()));
1038 true
1039 }
1040 None => false,
1041 }
1042 }
1043
1044 pub(crate) fn parse_list_with_polarity(
1045 slot: &mut Vec<(String, bool)>,
1046 v: Option<&str>,
1047 ) -> bool {
1048 match v {
1049 Some(s) => {
1050 for s in s.split(',') {
1051 let Some(pass_name) = s.strip_prefix(&['+', '-'][..]) else { return false };
1052 slot.push((pass_name.to_string(), &s[..1] == "+"));
1053 }
1054 true
1055 }
1056 None => false,
1057 }
1058 }
1059
1060 pub(crate) fn parse_fmt_debug(opt: &mut FmtDebug, v: Option<&str>) -> bool {
1061 *opt = match v {
1062 Some("full") => FmtDebug::Full,
1063 Some("shallow") => FmtDebug::Shallow,
1064 Some("none") => FmtDebug::None,
1065 _ => return false,
1066 };
1067 true
1068 }
1069
1070 pub(crate) fn parse_location_detail(ld: &mut LocationDetail, v: Option<&str>) -> bool {
1071 if let Some(v) = v {
1072 ld.line = false;
1073 ld.file = false;
1074 ld.column = false;
1075 if v == "none" {
1076 return true;
1077 }
1078 for s in v.split(',') {
1079 match s {
1080 "file" => ld.file = true,
1081 "line" => ld.line = true,
1082 "column" => ld.column = true,
1083 _ => return false,
1084 }
1085 }
1086 true
1087 } else {
1088 false
1089 }
1090 }
1091
1092 pub(crate) fn parse_comma_list(slot: &mut Vec<String>, v: Option<&str>) -> bool {
1093 match v {
1094 Some(s) => {
1095 let mut v: Vec<_> = s.split(',').map(|s| s.to_string()).collect();
1096 v.sort_unstable();
1097 *slot = v;
1098 true
1099 }
1100 None => false,
1101 }
1102 }
1103
1104 pub(crate) fn parse_opt_comma_list(slot: &mut Option<Vec<String>>, v: Option<&str>) -> bool {
1105 match v {
1106 Some(s) => {
1107 let mut v: Vec<_> = s.split(',').map(|s| s.to_string()).collect();
1108 v.sort_unstable();
1109 *slot = Some(v);
1110 true
1111 }
1112 None => false,
1113 }
1114 }
1115
1116 pub(crate) fn parse_threads(slot: &mut usize, v: Option<&str>) -> bool {
1117 let ret = match v.and_then(|s| s.parse().ok()) {
1118 Some(0) => {
1119 *slot = std::thread::available_parallelism().map_or(1, NonZero::<usize>::get);
1120 true
1121 }
1122 Some(i) => {
1123 *slot = i;
1124 true
1125 }
1126 None => false,
1127 };
1128 *slot = slot.clone().min(MAX_THREADS_CAP);
1131 ret
1132 }
1133
1134 pub(crate) fn parse_number<T: Copy + FromStr>(slot: &mut T, v: Option<&str>) -> bool {
1136 match v.and_then(|s| s.parse().ok()) {
1137 Some(i) => {
1138 *slot = i;
1139 true
1140 }
1141 None => false,
1142 }
1143 }
1144
1145 pub(crate) fn parse_opt_number<T: Copy + FromStr>(
1147 slot: &mut Option<T>,
1148 v: Option<&str>,
1149 ) -> bool {
1150 match v {
1151 Some(s) => {
1152 *slot = s.parse().ok();
1153 slot.is_some()
1154 }
1155 None => false,
1156 }
1157 }
1158
1159 pub(crate) fn parse_frame_pointer(slot: &mut FramePointer, v: Option<&str>) -> bool {
1160 let mut yes = false;
1161 match v {
1162 _ if parse_bool(&mut yes, v) && yes => slot.ratchet(FramePointer::Always),
1163 _ if parse_bool(&mut yes, v) => slot.ratchet(FramePointer::MayOmit),
1164 Some("always") => slot.ratchet(FramePointer::Always),
1165 Some("non-leaf") => slot.ratchet(FramePointer::NonLeaf),
1166 _ => return false,
1167 };
1168 true
1169 }
1170
1171 pub(crate) fn parse_passes(slot: &mut Passes, v: Option<&str>) -> bool {
1172 match v {
1173 Some("all") => {
1174 *slot = Passes::All;
1175 true
1176 }
1177 v => {
1178 let mut passes = ::alloc::vec::Vec::new()vec![];
1179 if parse_list(&mut passes, v) {
1180 slot.extend(passes);
1181 true
1182 } else {
1183 false
1184 }
1185 }
1186 }
1187 }
1188
1189 pub(crate) fn parse_opt_panic_strategy(
1190 slot: &mut Option<PanicStrategy>,
1191 v: Option<&str>,
1192 ) -> bool {
1193 match v {
1194 Some("unwind") => *slot = Some(PanicStrategy::Unwind),
1195 Some("abort") => *slot = Some(PanicStrategy::Abort),
1196 Some("immediate-abort") => *slot = Some(PanicStrategy::ImmediateAbort),
1197 _ => return false,
1198 }
1199 true
1200 }
1201
1202 pub(crate) fn parse_panic_strategy(slot: &mut PanicStrategy, v: Option<&str>) -> bool {
1203 match v {
1204 Some("unwind") => *slot = PanicStrategy::Unwind,
1205 Some("abort") => *slot = PanicStrategy::Abort,
1206 Some("immediate-abort") => *slot = PanicStrategy::ImmediateAbort,
1207 _ => return false,
1208 }
1209 true
1210 }
1211
1212 pub(crate) fn parse_on_broken_pipe(slot: &mut OnBrokenPipe, v: Option<&str>) -> bool {
1213 match v {
1214 Some("kill") => *slot = OnBrokenPipe::Kill,
1216 Some("error") => *slot = OnBrokenPipe::Error,
1217 Some("inherit") => *slot = OnBrokenPipe::Inherit,
1218 _ => return false,
1219 }
1220 true
1221 }
1222
1223 pub(crate) fn parse_patchable_function_entry(
1224 slot: &mut PatchableFunctionEntry,
1225 v: Option<&str>,
1226 ) -> bool {
1227 let mut total_nops = 0;
1228 let mut prefix_nops = 0;
1229
1230 if !parse_number(&mut total_nops, v) {
1231 let parts = v.and_then(|v| v.split_once(',')).unzip();
1232 if !parse_number(&mut total_nops, parts.0) {
1233 return false;
1234 }
1235 if !parse_number(&mut prefix_nops, parts.1) {
1236 return false;
1237 }
1238 }
1239
1240 if let Some(pfe) =
1241 PatchableFunctionEntry::from_total_and_prefix_nops(total_nops, prefix_nops)
1242 {
1243 *slot = pfe;
1244 return true;
1245 }
1246 false
1247 }
1248
1249 pub(crate) fn parse_relro_level(slot: &mut Option<RelroLevel>, v: Option<&str>) -> bool {
1250 match v {
1251 Some(s) => match s.parse::<RelroLevel>() {
1252 Ok(level) => *slot = Some(level),
1253 _ => return false,
1254 },
1255 _ => return false,
1256 }
1257 true
1258 }
1259
1260 pub(crate) fn parse_sanitizers(slot: &mut SanitizerSet, v: Option<&str>) -> bool {
1261 if let Some(v) = v {
1262 for s in v.split(',') {
1263 *slot |= match s {
1264 "address" => SanitizerSet::ADDRESS,
1265 "cfi" => SanitizerSet::CFI,
1266 "dataflow" => SanitizerSet::DATAFLOW,
1267 "kcfi" => SanitizerSet::KCFI,
1268 "kernel-address" => SanitizerSet::KERNELADDRESS,
1269 "kernel-hwaddress" => SanitizerSet::KERNELHWADDRESS,
1270 "leak" => SanitizerSet::LEAK,
1271 "memory" => SanitizerSet::MEMORY,
1272 "memtag" => SanitizerSet::MEMTAG,
1273 "shadow-call-stack" => SanitizerSet::SHADOWCALLSTACK,
1274 "thread" => SanitizerSet::THREAD,
1275 "hwaddress" => SanitizerSet::HWADDRESS,
1276 "safestack" => SanitizerSet::SAFESTACK,
1277 "realtime" => SanitizerSet::REALTIME,
1278 _ => return false,
1279 }
1280 }
1281 true
1282 } else {
1283 false
1284 }
1285 }
1286
1287 pub(crate) fn parse_sanitizer_memory_track_origins(slot: &mut usize, v: Option<&str>) -> bool {
1288 match v {
1289 Some("2") | None => {
1290 *slot = 2;
1291 true
1292 }
1293 Some("1") => {
1294 *slot = 1;
1295 true
1296 }
1297 Some("0") => {
1298 *slot = 0;
1299 true
1300 }
1301 Some(_) => false,
1302 }
1303 }
1304
1305 pub(crate) fn parse_strip(slot: &mut Strip, v: Option<&str>) -> bool {
1306 match v {
1307 Some("none") => *slot = Strip::None,
1308 Some("debuginfo") => *slot = Strip::Debuginfo,
1309 Some("symbols") => *slot = Strip::Symbols,
1310 _ => return false,
1311 }
1312 true
1313 }
1314
1315 pub(crate) fn parse_cfguard(slot: &mut CFGuard, v: Option<&str>) -> bool {
1316 if v.is_some() {
1317 let mut bool_arg = None;
1318 if parse_opt_bool(&mut bool_arg, v) {
1319 *slot = if bool_arg.unwrap() { CFGuard::Checks } else { CFGuard::Disabled };
1320 return true;
1321 }
1322 }
1323
1324 *slot = match v {
1325 None => CFGuard::Checks,
1326 Some("checks") => CFGuard::Checks,
1327 Some("nochecks") => CFGuard::NoChecks,
1328 Some(_) => return false,
1329 };
1330 true
1331 }
1332
1333 pub(crate) fn parse_cfprotection(slot: &mut CFProtection, v: Option<&str>) -> bool {
1334 if v.is_some() {
1335 let mut bool_arg = None;
1336 if parse_opt_bool(&mut bool_arg, v) {
1337 *slot = if bool_arg.unwrap() { CFProtection::Full } else { CFProtection::None };
1338 return true;
1339 }
1340 }
1341
1342 *slot = match v {
1343 None | Some("none") => CFProtection::None,
1344 Some("branch") => CFProtection::Branch,
1345 Some("return") => CFProtection::Return,
1346 Some("full") => CFProtection::Full,
1347 Some(_) => return false,
1348 };
1349 true
1350 }
1351
1352 pub(crate) fn parse_debuginfo(slot: &mut DebugInfo, v: Option<&str>) -> bool {
1353 match v {
1354 Some("0") | Some("none") => *slot = DebugInfo::None,
1355 Some("line-directives-only") => *slot = DebugInfo::LineDirectivesOnly,
1356 Some("line-tables-only") => *slot = DebugInfo::LineTablesOnly,
1357 Some("1") | Some("limited") => *slot = DebugInfo::Limited,
1358 Some("2") | Some("full") => *slot = DebugInfo::Full,
1359 _ => return false,
1360 }
1361 true
1362 }
1363
1364 pub(crate) fn parse_debuginfo_compression(
1365 slot: &mut DebugInfoCompression,
1366 v: Option<&str>,
1367 ) -> bool {
1368 match v {
1369 Some("none") => *slot = DebugInfoCompression::None,
1370 Some("zlib") => *slot = DebugInfoCompression::Zlib,
1371 Some("zstd") => *slot = DebugInfoCompression::Zstd,
1372 _ => return false,
1373 };
1374 true
1375 }
1376
1377 pub(crate) fn parse_mir_strip_debuginfo(slot: &mut MirStripDebugInfo, v: Option<&str>) -> bool {
1378 match v {
1379 Some("none") => *slot = MirStripDebugInfo::None,
1380 Some("locals-in-tiny-functions") => *slot = MirStripDebugInfo::LocalsInTinyFunctions,
1381 Some("all-locals") => *slot = MirStripDebugInfo::AllLocals,
1382 _ => return false,
1383 };
1384 true
1385 }
1386
1387 pub(crate) fn parse_linker_flavor(slot: &mut Option<LinkerFlavorCli>, v: Option<&str>) -> bool {
1388 match v.and_then(|v| LinkerFlavorCli::from_str(v).ok()) {
1389 Some(lf) => *slot = Some(lf),
1390 _ => return false,
1391 }
1392 true
1393 }
1394
1395 pub(crate) fn parse_opt_symbol_visibility(
1396 slot: &mut Option<SymbolVisibility>,
1397 v: Option<&str>,
1398 ) -> bool {
1399 if let Some(v) = v {
1400 if let Ok(vis) = SymbolVisibility::from_str(v) {
1401 *slot = Some(vis);
1402 } else {
1403 return false;
1404 }
1405 }
1406 true
1407 }
1408
1409 pub(crate) fn parse_unpretty(slot: &mut Option<String>, v: Option<&str>) -> bool {
1410 match v {
1411 None => false,
1412 Some(s) if s.split('=').count() <= 2 => {
1413 *slot = Some(s.to_string());
1414 true
1415 }
1416 _ => false,
1417 }
1418 }
1419
1420 pub(crate) fn parse_time_passes_format(slot: &mut TimePassesFormat, v: Option<&str>) -> bool {
1421 match v {
1422 None => true,
1423 Some("json") => {
1424 *slot = TimePassesFormat::Json;
1425 true
1426 }
1427 Some("text") => {
1428 *slot = TimePassesFormat::Text;
1429 true
1430 }
1431 Some(_) => false,
1432 }
1433 }
1434
1435 pub(crate) fn parse_dump_mono_stats(slot: &mut DumpMonoStatsFormat, v: Option<&str>) -> bool {
1436 match v {
1437 None => true,
1438 Some("json") => {
1439 *slot = DumpMonoStatsFormat::Json;
1440 true
1441 }
1442 Some("markdown") => {
1443 *slot = DumpMonoStatsFormat::Markdown;
1444 true
1445 }
1446 Some(_) => false,
1447 }
1448 }
1449
1450 pub(crate) fn parse_offload(slot: &mut Vec<Offload>, v: Option<&str>) -> bool {
1451 let Some(v) = v else {
1452 *slot = ::alloc::vec::Vec::new()vec![];
1453 return true;
1454 };
1455 let mut v: Vec<&str> = v.split(",").collect();
1456 v.sort_unstable();
1457 for &val in v.iter() {
1458 let (key, arg) = match val.split_once('=') {
1460 Some((k, a)) => (k, Some(a)),
1461 None => (val, None),
1462 };
1463
1464 let variant = match key {
1465 "Host" => {
1466 if let Some(p) = arg {
1467 Offload::Host(p.to_string())
1468 } else {
1469 return false;
1470 }
1471 }
1472 "Device" => {
1473 if let Some(_) = arg {
1474 return false;
1476 }
1477 Offload::Device
1478 }
1479 "Test" => {
1480 if let Some(_) = arg {
1481 return false;
1483 }
1484 Offload::Test
1485 }
1486 _ => {
1487 return false;
1489 }
1490 };
1491 slot.push(variant);
1492 }
1493
1494 true
1495 }
1496
1497 pub(crate) fn parse_autodiff(slot: &mut Vec<AutoDiff>, v: Option<&str>) -> bool {
1498 let Some(v) = v else {
1499 *slot = ::alloc::vec::Vec::new()vec![];
1500 return true;
1501 };
1502 let mut v: Vec<&str> = v.split(",").collect();
1503 v.sort_unstable();
1504 for &val in v.iter() {
1505 let (key, arg) = match val.split_once('=') {
1507 Some((k, a)) => (k, Some(a)),
1508 None => (val, None),
1509 };
1510
1511 let variant = match key {
1512 "Enable" => AutoDiff::Enable,
1513 "PrintTA" => AutoDiff::PrintTA,
1514 "PrintTAFn" => {
1515 if let Some(fun) = arg {
1516 AutoDiff::PrintTAFn(fun.to_string())
1517 } else {
1518 return false;
1519 }
1520 }
1521 "PrintAA" => AutoDiff::PrintAA,
1522 "PrintPerf" => AutoDiff::PrintPerf,
1523 "PrintSteps" => AutoDiff::PrintSteps,
1524 "PrintModBefore" => AutoDiff::PrintModBefore,
1525 "PrintModAfter" => AutoDiff::PrintModAfter,
1526 "PrintModFinal" => AutoDiff::PrintModFinal,
1527 "NoPostopt" => AutoDiff::NoPostopt,
1528 "PrintPasses" => AutoDiff::PrintPasses,
1529 "LooseTypes" => AutoDiff::LooseTypes,
1530 "Inline" => AutoDiff::Inline,
1531 "NoTT" => AutoDiff::NoTT,
1532 _ => {
1533 return false;
1535 }
1536 };
1537 slot.push(variant);
1538 }
1539
1540 true
1541 }
1542
1543 pub(crate) fn parse_instrument_coverage(
1544 slot: &mut InstrumentCoverage,
1545 v: Option<&str>,
1546 ) -> bool {
1547 if v.is_some() {
1548 let mut bool_arg = false;
1549 if parse_bool(&mut bool_arg, v) {
1550 *slot = if bool_arg { InstrumentCoverage::Yes } else { InstrumentCoverage::No };
1551 return true;
1552 }
1553 }
1554
1555 let Some(v) = v else {
1556 *slot = InstrumentCoverage::Yes;
1557 return true;
1558 };
1559
1560 *slot = match v {
1563 "all" => InstrumentCoverage::Yes,
1564 "0" => InstrumentCoverage::No,
1565 _ => return false,
1566 };
1567 true
1568 }
1569
1570 pub(crate) fn parse_coverage_options(slot: &mut CoverageOptions, v: Option<&str>) -> bool {
1571 let Some(v) = v else { return true };
1572
1573 for option in v.split(',') {
1574 match option {
1575 "block" => slot.level = CoverageLevel::Block,
1576 "branch" => slot.level = CoverageLevel::Branch,
1577 "condition" => slot.level = CoverageLevel::Condition,
1578 "discard-all-spans-in-codegen" => slot.discard_all_spans_in_codegen = true,
1579 _ => return false,
1580 }
1581 }
1582 true
1583 }
1584
1585 pub(crate) fn parse_instrument_xray(
1586 slot: &mut Option<InstrumentXRay>,
1587 v: Option<&str>,
1588 ) -> bool {
1589 if v.is_some() {
1590 let mut bool_arg = None;
1591 if parse_opt_bool(&mut bool_arg, v) {
1592 *slot = if bool_arg.unwrap() { Some(InstrumentXRay::default()) } else { None };
1593 return true;
1594 }
1595 }
1596
1597 let options = slot.get_or_insert_default();
1598 let mut seen_always = false;
1599 let mut seen_never = false;
1600 let mut seen_ignore_loops = false;
1601 let mut seen_instruction_threshold = false;
1602 let mut seen_skip_entry = false;
1603 let mut seen_skip_exit = false;
1604 for option in v.into_iter().flat_map(|v| v.split(',')) {
1605 match option {
1606 "always" if !seen_always && !seen_never => {
1607 options.always = true;
1608 options.never = false;
1609 seen_always = true;
1610 }
1611 "never" if !seen_never && !seen_always => {
1612 options.never = true;
1613 options.always = false;
1614 seen_never = true;
1615 }
1616 "ignore-loops" if !seen_ignore_loops => {
1617 options.ignore_loops = true;
1618 seen_ignore_loops = true;
1619 }
1620 option
1621 if option.starts_with("instruction-threshold")
1622 && !seen_instruction_threshold =>
1623 {
1624 let Some(("instruction-threshold", n)) = option.split_once('=') else {
1625 return false;
1626 };
1627 match n.parse() {
1628 Ok(n) => options.instruction_threshold = Some(n),
1629 Err(_) => return false,
1630 }
1631 seen_instruction_threshold = true;
1632 }
1633 "skip-entry" if !seen_skip_entry => {
1634 options.skip_entry = true;
1635 seen_skip_entry = true;
1636 }
1637 "skip-exit" if !seen_skip_exit => {
1638 options.skip_exit = true;
1639 seen_skip_exit = true;
1640 }
1641 _ => return false,
1642 }
1643 }
1644 true
1645 }
1646
1647 pub(crate) fn parse_treat_err_as_bug(
1648 slot: &mut Option<NonZero<usize>>,
1649 v: Option<&str>,
1650 ) -> bool {
1651 match v {
1652 Some(s) => match s.parse() {
1653 Ok(val) => {
1654 *slot = Some(val);
1655 true
1656 }
1657 Err(e) => {
1658 *slot = None;
1659 e.kind() == &IntErrorKind::Zero
1660 }
1661 },
1662 None => {
1663 *slot = NonZero::new(1);
1664 true
1665 }
1666 }
1667 }
1668
1669 pub(crate) fn parse_next_solver_config(slot: &mut NextSolverConfig, v: Option<&str>) -> bool {
1670 if let Some(config) = v {
1671 *slot = match config {
1672 "no" => NextSolverConfig { coherence: false, globally: false },
1673 "coherence" => NextSolverConfig { coherence: true, globally: false },
1674 "globally" => NextSolverConfig { coherence: true, globally: true },
1675 _ => return false,
1676 };
1677 } else {
1678 *slot = NextSolverConfig { coherence: true, globally: true };
1679 }
1680
1681 true
1682 }
1683
1684 pub(crate) fn parse_lto(slot: &mut LtoCli, v: Option<&str>) -> bool {
1685 if v.is_some() {
1686 let mut bool_arg = None;
1687 if parse_opt_bool(&mut bool_arg, v) {
1688 *slot = if bool_arg.unwrap() { LtoCli::Yes } else { LtoCli::No };
1689 return true;
1690 }
1691 }
1692
1693 *slot = match v {
1694 None => LtoCli::NoParam,
1695 Some("thin") => LtoCli::Thin,
1696 Some("fat") => LtoCli::Fat,
1697 Some(_) => return false,
1698 };
1699 true
1700 }
1701
1702 pub(crate) fn parse_linker_plugin_lto(slot: &mut LinkerPluginLto, v: Option<&str>) -> bool {
1703 if v.is_some() {
1704 let mut bool_arg = None;
1705 if parse_opt_bool(&mut bool_arg, v) {
1706 *slot = if bool_arg.unwrap() {
1707 LinkerPluginLto::LinkerPluginAuto
1708 } else {
1709 LinkerPluginLto::Disabled
1710 };
1711 return true;
1712 }
1713 }
1714
1715 *slot = match v {
1716 None => LinkerPluginLto::LinkerPluginAuto,
1717 Some(path) => LinkerPluginLto::LinkerPlugin(PathBuf::from(path)),
1718 };
1719 true
1720 }
1721
1722 pub(crate) fn parse_switch_with_opt_path(
1723 slot: &mut SwitchWithOptPath,
1724 v: Option<&str>,
1725 ) -> bool {
1726 *slot = match v {
1727 None => SwitchWithOptPath::Enabled(None),
1728 Some(path) => SwitchWithOptPath::Enabled(Some(PathBuf::from(path))),
1729 };
1730 true
1731 }
1732
1733 pub(crate) fn parse_merge_functions(
1734 slot: &mut Option<MergeFunctions>,
1735 v: Option<&str>,
1736 ) -> bool {
1737 match v.and_then(|s| MergeFunctions::from_str(s).ok()) {
1738 Some(mergefunc) => *slot = Some(mergefunc),
1739 _ => return false,
1740 }
1741 true
1742 }
1743
1744 pub(crate) fn parse_relocation_model(slot: &mut Option<RelocModel>, v: Option<&str>) -> bool {
1745 match v.and_then(|s| RelocModel::from_str(s).ok()) {
1746 Some(relocation_model) => *slot = Some(relocation_model),
1747 None if v == Some("default") => *slot = None,
1748 _ => return false,
1749 }
1750 true
1751 }
1752
1753 pub(crate) fn parse_code_model(slot: &mut Option<CodeModel>, v: Option<&str>) -> bool {
1754 match v.and_then(|s| CodeModel::from_str(s).ok()) {
1755 Some(code_model) => *slot = Some(code_model),
1756 _ => return false,
1757 }
1758 true
1759 }
1760
1761 pub(crate) fn parse_tls_model(slot: &mut Option<TlsModel>, v: Option<&str>) -> bool {
1762 match v.and_then(|s| TlsModel::from_str(s).ok()) {
1763 Some(tls_model) => *slot = Some(tls_model),
1764 _ => return false,
1765 }
1766 true
1767 }
1768
1769 pub(crate) fn parse_terminal_url(slot: &mut TerminalUrl, v: Option<&str>) -> bool {
1770 *slot = match v {
1771 Some("on" | "" | "yes" | "y") | None => TerminalUrl::Yes,
1772 Some("off" | "no" | "n") => TerminalUrl::No,
1773 Some("auto") => TerminalUrl::Auto,
1774 _ => return false,
1775 };
1776 true
1777 }
1778
1779 pub(crate) fn parse_symbol_mangling_version(
1780 slot: &mut Option<SymbolManglingVersion>,
1781 v: Option<&str>,
1782 ) -> bool {
1783 *slot = match v {
1784 Some("legacy") => Some(SymbolManglingVersion::Legacy),
1785 Some("v0") => Some(SymbolManglingVersion::V0),
1786 Some("hashed") => Some(SymbolManglingVersion::Hashed),
1787 _ => return false,
1788 };
1789 true
1790 }
1791
1792 pub(crate) fn parse_src_file_hash(
1793 slot: &mut Option<SourceFileHashAlgorithm>,
1794 v: Option<&str>,
1795 ) -> bool {
1796 match v.and_then(|s| SourceFileHashAlgorithm::from_str(s).ok()) {
1797 Some(hash_kind) => *slot = Some(hash_kind),
1798 _ => return false,
1799 }
1800 true
1801 }
1802
1803 pub(crate) fn parse_cargo_src_file_hash(
1804 slot: &mut Option<SourceFileHashAlgorithm>,
1805 v: Option<&str>,
1806 ) -> bool {
1807 match v.and_then(|s| SourceFileHashAlgorithm::from_str(s).ok()) {
1808 Some(hash_kind) => {
1809 *slot = Some(hash_kind);
1810 }
1811 _ => return false,
1812 }
1813 true
1814 }
1815
1816 pub(crate) fn parse_target_feature(slot: &mut String, v: Option<&str>) -> bool {
1817 match v {
1818 Some(s) => {
1819 if !slot.is_empty() {
1820 slot.push(',');
1821 }
1822 slot.push_str(s);
1823 true
1824 }
1825 None => false,
1826 }
1827 }
1828
1829 pub(crate) fn parse_link_self_contained(slot: &mut LinkSelfContained, v: Option<&str>) -> bool {
1830 let s = v.unwrap_or("y");
1835 match s {
1836 "y" | "yes" | "on" => {
1837 slot.set_all_explicitly(true);
1838 return true;
1839 }
1840 "n" | "no" | "off" => {
1841 slot.set_all_explicitly(false);
1842 return true;
1843 }
1844 _ => {}
1845 }
1846
1847 for comp in s.split(',') {
1849 if slot.handle_cli_component(comp).is_none() {
1850 return false;
1851 }
1852 }
1853
1854 true
1855 }
1856
1857 pub(crate) fn parse_linker_features(slot: &mut LinkerFeaturesCli, v: Option<&str>) -> bool {
1859 match v {
1860 Some(s) => {
1861 for feature in s.split(',') {
1862 if slot.handle_cli_feature(feature).is_none() {
1863 return false;
1864 }
1865 }
1866
1867 true
1868 }
1869 None => false,
1870 }
1871 }
1872
1873 pub(crate) fn parse_wasi_exec_model(slot: &mut Option<WasiExecModel>, v: Option<&str>) -> bool {
1874 match v {
1875 Some("command") => *slot = Some(WasiExecModel::Command),
1876 Some("reactor") => *slot = Some(WasiExecModel::Reactor),
1877 _ => return false,
1878 }
1879 true
1880 }
1881
1882 pub(crate) fn parse_split_debuginfo(
1883 slot: &mut Option<SplitDebuginfo>,
1884 v: Option<&str>,
1885 ) -> bool {
1886 match v.and_then(|s| SplitDebuginfo::from_str(s).ok()) {
1887 Some(e) => *slot = Some(e),
1888 _ => return false,
1889 }
1890 true
1891 }
1892
1893 pub(crate) fn parse_split_dwarf_kind(slot: &mut SplitDwarfKind, v: Option<&str>) -> bool {
1894 match v.and_then(|s| SplitDwarfKind::from_str(s).ok()) {
1895 Some(e) => *slot = e,
1896 _ => return false,
1897 }
1898 true
1899 }
1900
1901 pub(crate) fn parse_stack_protector(slot: &mut StackProtector, v: Option<&str>) -> bool {
1902 match v.and_then(|s| StackProtector::from_str(s).ok()) {
1903 Some(ssp) => *slot = ssp,
1904 _ => return false,
1905 }
1906 true
1907 }
1908
1909 pub(crate) fn parse_branch_protection(
1910 slot: &mut Option<BranchProtection>,
1911 v: Option<&str>,
1912 ) -> bool {
1913 match v {
1914 Some(s) => {
1915 let slot = slot.get_or_insert_default();
1916 for opt in s.split(',') {
1917 match opt {
1918 "bti" => slot.bti = true,
1919 "pac-ret" if slot.pac_ret.is_none() => {
1920 slot.pac_ret = Some(PacRet { leaf: false, pc: false, key: PAuthKey::A })
1921 }
1922 "leaf" => match slot.pac_ret.as_mut() {
1923 Some(pac) => pac.leaf = true,
1924 _ => return false,
1925 },
1926 "b-key" => match slot.pac_ret.as_mut() {
1927 Some(pac) => pac.key = PAuthKey::B,
1928 _ => return false,
1929 },
1930 "pc" => match slot.pac_ret.as_mut() {
1931 Some(pac) => pac.pc = true,
1932 _ => return false,
1933 },
1934 "gcs" => slot.gcs = true,
1935 _ => return false,
1936 };
1937 }
1938 }
1939 _ => return false,
1940 }
1941 true
1942 }
1943
1944 pub(crate) fn parse_collapse_macro_debuginfo(
1945 slot: &mut CollapseMacroDebuginfo,
1946 v: Option<&str>,
1947 ) -> bool {
1948 if v.is_some() {
1949 let mut bool_arg = None;
1950 if parse_opt_bool(&mut bool_arg, v) {
1951 *slot = if bool_arg.unwrap() {
1952 CollapseMacroDebuginfo::Yes
1953 } else {
1954 CollapseMacroDebuginfo::No
1955 };
1956 return true;
1957 }
1958 }
1959
1960 *slot = match v {
1961 Some("external") => CollapseMacroDebuginfo::External,
1962 _ => return false,
1963 };
1964 true
1965 }
1966
1967 pub(crate) fn parse_proc_macro_execution_strategy(
1968 slot: &mut ProcMacroExecutionStrategy,
1969 v: Option<&str>,
1970 ) -> bool {
1971 *slot = match v {
1972 Some("same-thread") => ProcMacroExecutionStrategy::SameThread,
1973 Some("cross-thread") => ProcMacroExecutionStrategy::CrossThread,
1974 _ => return false,
1975 };
1976 true
1977 }
1978
1979 pub(crate) fn parse_inlining_threshold(slot: &mut InliningThreshold, v: Option<&str>) -> bool {
1980 match v {
1981 Some("always" | "yes") => {
1982 *slot = InliningThreshold::Always;
1983 }
1984 Some("never") => {
1985 *slot = InliningThreshold::Never;
1986 }
1987 Some(v) => {
1988 if let Ok(threshold) = v.parse() {
1989 *slot = InliningThreshold::Sometimes(threshold);
1990 } else {
1991 return false;
1992 }
1993 }
1994 None => return false,
1995 }
1996 true
1997 }
1998
1999 pub(crate) fn parse_llvm_module_flag(
2000 slot: &mut Vec<(String, u32, String)>,
2001 v: Option<&str>,
2002 ) -> bool {
2003 let elements = v.unwrap_or_default().split(':').collect::<Vec<_>>();
2004 let [key, md_type, value, behavior] = elements.as_slice() else {
2005 return false;
2006 };
2007 if *md_type != "u32" {
2008 return false;
2011 }
2012 let Ok(value) = value.parse::<u32>() else {
2013 return false;
2014 };
2015 let behavior = behavior.to_lowercase();
2016 let all_behaviors =
2017 ["error", "warning", "require", "override", "append", "appendunique", "max", "min"];
2018 if !all_behaviors.contains(&behavior.as_str()) {
2019 return false;
2020 }
2021
2022 slot.push((key.to_string(), value, behavior));
2023 true
2024 }
2025
2026 pub(crate) fn parse_function_return(slot: &mut FunctionReturn, v: Option<&str>) -> bool {
2027 match v {
2028 Some("keep") => *slot = FunctionReturn::Keep,
2029 Some("thunk-extern") => *slot = FunctionReturn::ThunkExtern,
2030 _ => return false,
2031 }
2032 true
2033 }
2034
2035 pub(crate) fn parse_wasm_c_abi(_slot: &mut (), v: Option<&str>) -> bool {
2036 v == Some("spec")
2037 }
2038
2039 pub(crate) fn parse_mir_include_spans(slot: &mut MirIncludeSpans, v: Option<&str>) -> bool {
2040 *slot = match v {
2041 Some("on" | "yes" | "y" | "true") | None => MirIncludeSpans::On,
2042 Some("off" | "no" | "n" | "false") => MirIncludeSpans::Off,
2043 Some("nll") => MirIncludeSpans::Nll,
2044 _ => return false,
2045 };
2046
2047 true
2048 }
2049
2050 pub(crate) fn parse_align(slot: &mut Option<Align>, v: Option<&str>) -> bool {
2051 let mut bytes = 0u64;
2052 if !parse_number(&mut bytes, v) {
2053 return false;
2054 }
2055
2056 let Ok(align) = Align::from_bytes(bytes) else {
2057 return false;
2058 };
2059
2060 *slot = Some(align);
2061
2062 true
2063 }
2064
2065 pub(crate) fn parse_assert_incr_state(
2066 slot: &mut Option<IncrementalStateAssertion>,
2067 v: Option<&str>,
2068 ) -> bool {
2069 *slot = match v {
2070 Some("loaded") => Some(IncrementalStateAssertion::Loaded),
2071 Some("not-loaded") => Some(IncrementalStateAssertion::NotLoaded),
2072 _ => return false,
2073 };
2074 true
2075 }
2076}
2077
2078#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialEq for CodegenOptionsTargetModifiers {
#[inline]
fn eq(&self, other: &CodegenOptionsTargetModifiers) -> bool {
match *self {}
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::Eq for CodegenOptionsTargetModifiers {
#[inline]
#[doc(hidden)]
#[coverage(off)]
fn assert_fields_are_eq(&self) {}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialOrd for CodegenOptionsTargetModifiers {
#[inline]
fn partial_cmp(&self, other: &CodegenOptionsTargetModifiers)
-> ::core::option::Option<::core::cmp::Ordering> {
match *self {}
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::Ord for CodegenOptionsTargetModifiers {
#[inline]
fn cmp(&self, other: &CodegenOptionsTargetModifiers)
-> ::core::cmp::Ordering {
match *self {}
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::fmt::Debug for CodegenOptionsTargetModifiers {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
match *self {}
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::marker::Copy for CodegenOptionsTargetModifiers { }
#[automatically_derived]
#[doc(hidden)]
#[allow(non_camel_case_types)]
unsafe impl ::core::clone::TrivialClone for CodegenOptionsTargetModifiers { }
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::clone::Clone for CodegenOptionsTargetModifiers {
#[inline]
fn clone(&self) -> CodegenOptionsTargetModifiers { *self }
}
const _: () =
{
impl<__E: ::rustc_span::SpanEncoder> ::rustc_serialize::Encodable<__E>
for CodegenOptionsTargetModifiers {
fn encode(&self, __encoder: &mut __E) { match *self {} }
}
};
const _: () =
{
impl<__D: ::rustc_span::BlobDecoder> ::rustc_serialize::Decodable<__D>
for CodegenOptionsTargetModifiers {
fn decode(__decoder: &mut __D) -> Self {
{
::core::panicking::panic_fmt(format_args!("`CodegenOptionsTargetModifiers` has no variants to decode"));
}
}
}
};
impl CodegenOptionsTargetModifiers {
#[allow(unused_variables)]
pub fn reparse(&self, user_value: &str) -> ExtendedTargetModifierInfo {
#[allow(unreachable_patterns)]
match self {
_ => {
::core::panicking::panic_fmt(format_args!("unknown target modifier option: {0:?}",
*self));
}
}
}
pub fn is_target_modifier(flag_name: &str) -> bool {
match flag_name.replace('-', "_").as_str() { _ => false, }
}
}
impl Default for CodegenOptions {
fn default() -> CodegenOptions {
CodegenOptions {
ar: String::new(),
code_model: None,
codegen_units: None,
collapse_macro_debuginfo: CollapseMacroDebuginfo::Unspecified,
control_flow_guard: CFGuard::Disabled,
debug_assertions: None,
debuginfo: DebugInfo::None,
default_linker_libraries: false,
dlltool: None,
dwarf_version: None,
embed_bitcode: true,
extra_filename: String::new(),
force_frame_pointers: FramePointer::MayOmit,
force_unwind_tables: None,
help: false,
incremental: None,
inline_threshold: None,
instrument_coverage: InstrumentCoverage::No,
jump_tables: true,
link_arg: (),
link_args: Vec::new(),
link_dead_code: None,
link_self_contained: LinkSelfContained::default(),
linker: None,
linker_features: LinkerFeaturesCli::default(),
linker_flavor: None,
linker_plugin_lto: LinkerPluginLto::Disabled,
llvm_args: Vec::new(),
lto: LtoCli::Unspecified,
metadata: Vec::new(),
no_prepopulate_passes: false,
no_redzone: None,
no_stack_check: false,
no_vectorize_loops: false,
no_vectorize_slp: false,
opt_level: "0".to_string(),
overflow_checks: None,
panic: None,
passes: Vec::new(),
prefer_dynamic: false,
profile_generate: SwitchWithOptPath::Disabled,
profile_use: None,
relocation_model: None,
relro_level: None,
remark: Passes::Some(Vec::new()),
rpath: false,
save_temps: false,
soft_float: (),
split_debuginfo: None,
strip: Strip::None,
symbol_mangling_version: None,
target_cpu: None,
target_feature: String::new(),
unsafe_allow_abi_mismatch: Vec::new(),
}
}
}
impl CodegenOptions {
pub fn build(early_dcx: &EarlyDiagCtxt, matches: &getopts::Matches,
target_modifiers: &mut BTreeMap<OptionsTargetModifiers, String>)
-> CodegenOptions {
build_options(early_dcx, matches, target_modifiers, CG_OPTIONS, "C",
"codegen")
}
fn dep_tracking_hash(&self, for_crate_hash: bool,
error_format: ErrorOutputType) -> Hash64 {
let mut sub_hashes = BTreeMap::new();
{ {}; }
{
{
if (&mut sub_hashes).insert("code_model",
&self.code_model as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"code_model"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("collapse_macro_debuginfo",
&self.collapse_macro_debuginfo as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"collapse_macro_debuginfo"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("control_flow_guard",
&self.control_flow_guard as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"control_flow_guard"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("debug_assertions",
&self.debug_assertions as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"debug_assertions"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("debuginfo",
&self.debuginfo as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"debuginfo"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("dwarf_version",
&self.dwarf_version as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"dwarf_version"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("embed_bitcode",
&self.embed_bitcode as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"embed_bitcode"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("force_frame_pointers",
&self.force_frame_pointers as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"force_frame_pointers"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("force_unwind_tables",
&self.force_unwind_tables as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"force_unwind_tables"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("instrument_coverage",
&self.instrument_coverage as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"instrument_coverage"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("jump_tables",
&self.jump_tables as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"jump_tables"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("link_dead_code",
&self.link_dead_code as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"link_dead_code"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("linker_plugin_lto",
&self.linker_plugin_lto as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"linker_plugin_lto"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("llvm_args",
&self.llvm_args as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"llvm_args"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("lto",
&self.lto as &dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"lto"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("metadata",
&self.metadata as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"metadata"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("no_prepopulate_passes",
&self.no_prepopulate_passes as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_prepopulate_passes"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("no_redzone",
&self.no_redzone as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_redzone"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("no_vectorize_loops",
&self.no_vectorize_loops as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_vectorize_loops"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("no_vectorize_slp",
&self.no_vectorize_slp as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_vectorize_slp"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("opt_level",
&self.opt_level as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"opt_level"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("overflow_checks",
&self.overflow_checks as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"overflow_checks"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("panic",
&self.panic as &dyn dep_tracking::DepTrackingHash).is_some()
{
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"panic"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("passes",
&self.passes as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"passes"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("prefer_dynamic",
&self.prefer_dynamic as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"prefer_dynamic"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("profile_generate",
&self.profile_generate as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"profile_generate"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("profile_use",
&self.profile_use as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"profile_use"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("relocation_model",
&self.relocation_model as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"relocation_model"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("relro_level",
&self.relro_level as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"relro_level"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("split_debuginfo",
&self.split_debuginfo as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"split_debuginfo"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("symbol_mangling_version",
&self.symbol_mangling_version as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"symbol_mangling_version"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("target_cpu",
&self.target_cpu as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"target_cpu"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("target_feature",
&self.target_feature as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"target_feature"));
}
}
};
}
{ {}; }
let mut hasher = StableHasher::new();
dep_tracking::stable_hash(sub_hashes, &mut hasher, error_format,
for_crate_hash);
hasher.finish()
}
pub fn gather_target_modifiers(&self, _mods: &mut Vec<TargetModifier>,
_tmod_vals: &BTreeMap<OptionsTargetModifiers, String>) {
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
}
}
pub const CG_OPTIONS: OptionDescrs<CodegenOptions> =
&[OptionDesc {
name: "ar",
setter: cgopts::ar,
type_desc: desc::parse_string,
desc: "this option is deprecated and does nothing",
removed: None.or(Some(RemovedOption::Warn)),
tmod: None,
},
OptionDesc {
name: "code_model",
setter: cgopts::code_model,
type_desc: desc::parse_code_model,
desc: "choose the code model to use (`rustc --print code-models` for details)",
removed: None,
tmod: None,
},
OptionDesc {
name: "codegen_units",
setter: cgopts::codegen_units,
type_desc: desc::parse_opt_number,
desc: "divide crate into N units to optimize in parallel",
removed: None,
tmod: None,
},
OptionDesc {
name: "collapse_macro_debuginfo",
setter: cgopts::collapse_macro_debuginfo,
type_desc: desc::parse_collapse_macro_debuginfo,
desc: "set option to collapse debuginfo for macros",
removed: None,
tmod: None,
},
OptionDesc {
name: "control_flow_guard",
setter: cgopts::control_flow_guard,
type_desc: desc::parse_cfguard,
desc: "use Windows Control Flow Guard (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "debug_assertions",
setter: cgopts::debug_assertions,
type_desc: desc::parse_opt_bool,
desc: "explicitly enable the `cfg(debug_assertions)` directive",
removed: None,
tmod: None,
},
OptionDesc {
name: "debuginfo",
setter: cgopts::debuginfo,
type_desc: desc::parse_debuginfo,
desc: "debug info emission level (0-2, none, line-directives-only, \
line-tables-only, limited, or full; default: 0)",
removed: None,
tmod: None,
},
OptionDesc {
name: "default_linker_libraries",
setter: cgopts::default_linker_libraries,
type_desc: desc::parse_bool,
desc: "allow the linker to link its default libraries (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dlltool",
setter: cgopts::dlltool,
type_desc: desc::parse_opt_pathbuf,
desc: "import library generation tool (ignored except when targeting windows-gnu)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dwarf_version",
setter: cgopts::dwarf_version,
type_desc: desc::parse_opt_number,
desc: "version of DWARF debug information to emit (default: 2 or 4, depending on platform)",
removed: None,
tmod: None,
},
OptionDesc {
name: "embed_bitcode",
setter: cgopts::embed_bitcode,
type_desc: desc::parse_bool,
desc: "emit bitcode in rlibs (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "extra_filename",
setter: cgopts::extra_filename,
type_desc: desc::parse_string,
desc: "extra data to put in each output filename",
removed: None,
tmod: None,
},
OptionDesc {
name: "force_frame_pointers",
setter: cgopts::force_frame_pointers,
type_desc: desc::parse_frame_pointer,
desc: "force use of the frame pointers",
removed: None,
tmod: None,
},
OptionDesc {
name: "force_unwind_tables",
setter: cgopts::force_unwind_tables,
type_desc: desc::parse_opt_bool,
desc: "force use of unwind tables",
removed: None,
tmod: None,
},
OptionDesc {
name: "help",
setter: cgopts::help,
type_desc: desc::parse_no_value,
desc: "Print codegen options",
removed: None,
tmod: None,
},
OptionDesc {
name: "incremental",
setter: cgopts::incremental,
type_desc: desc::parse_opt_string,
desc: "enable incremental compilation",
removed: None,
tmod: None,
},
OptionDesc {
name: "inline_threshold",
setter: cgopts::inline_threshold,
type_desc: desc::parse_opt_number,
desc: "this option is deprecated and does nothing \
(consider using `-Cllvm-args=--inline-threshold=...`)",
removed: None.or(Some(RemovedOption::Warn)),
tmod: None,
},
OptionDesc {
name: "instrument_coverage",
setter: cgopts::instrument_coverage,
type_desc: desc::parse_instrument_coverage,
desc: "instrument the generated code to support LLVM source-based code coverage reports \
(note, the compiler build config must include `profiler = true`); \
implies `-C symbol-mangling-version=v0`",
removed: None,
tmod: None,
},
OptionDesc {
name: "jump_tables",
setter: cgopts::jump_tables,
type_desc: desc::parse_bool,
desc: "allow jump table and lookup table generation from switch case lowering (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "link_arg",
setter: cgopts::link_arg,
type_desc: desc::parse_string_push,
desc: "a single extra argument to append to the linker invocation (can be used several times)",
removed: None,
tmod: None,
},
OptionDesc {
name: "link_args",
setter: cgopts::link_args,
type_desc: desc::parse_list,
desc: "extra arguments to append to the linker invocation (space separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "link_dead_code",
setter: cgopts::link_dead_code,
type_desc: desc::parse_opt_bool,
desc: "try to generate and link dead code (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "link_self_contained",
setter: cgopts::link_self_contained,
type_desc: desc::parse_link_self_contained,
desc: "control whether to link Rust provided C objects/libraries or rely \
on a C toolchain or linker installed in the system",
removed: None,
tmod: None,
},
OptionDesc {
name: "linker",
setter: cgopts::linker,
type_desc: desc::parse_opt_pathbuf,
desc: "system linker to link outputs with",
removed: None,
tmod: None,
},
OptionDesc {
name: "linker_features",
setter: cgopts::linker_features,
type_desc: desc::parse_linker_features,
desc: "a comma-separated list of linker features to enable (+) or disable (-): `lld`",
removed: None,
tmod: None,
},
OptionDesc {
name: "linker_flavor",
setter: cgopts::linker_flavor,
type_desc: desc::parse_linker_flavor,
desc: "linker flavor",
removed: None,
tmod: None,
},
OptionDesc {
name: "linker_plugin_lto",
setter: cgopts::linker_plugin_lto,
type_desc: desc::parse_linker_plugin_lto,
desc: "generate build artifacts that are compatible with linker-based LTO",
removed: None,
tmod: None,
},
OptionDesc {
name: "llvm_args",
setter: cgopts::llvm_args,
type_desc: desc::parse_list,
desc: "a list of arguments to pass to LLVM (space separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "lto",
setter: cgopts::lto,
type_desc: desc::parse_lto,
desc: "perform LLVM link-time optimizations",
removed: None,
tmod: None,
},
OptionDesc {
name: "metadata",
setter: cgopts::metadata,
type_desc: desc::parse_list,
desc: "metadata to mangle symbol names with",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_prepopulate_passes",
setter: cgopts::no_prepopulate_passes,
type_desc: desc::parse_no_value,
desc: "give an empty list of passes to the pass manager",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_redzone",
setter: cgopts::no_redzone,
type_desc: desc::parse_opt_bool,
desc: "disable the use of the redzone",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_stack_check",
setter: cgopts::no_stack_check,
type_desc: desc::parse_no_value,
desc: "this option is deprecated and does nothing",
removed: None.or(Some(RemovedOption::Warn)),
tmod: None,
},
OptionDesc {
name: "no_vectorize_loops",
setter: cgopts::no_vectorize_loops,
type_desc: desc::parse_no_value,
desc: "disable loop vectorization optimization passes",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_vectorize_slp",
setter: cgopts::no_vectorize_slp,
type_desc: desc::parse_no_value,
desc: "disable LLVM's SLP vectorization pass",
removed: None,
tmod: None,
},
OptionDesc {
name: "opt_level",
setter: cgopts::opt_level,
type_desc: desc::parse_string,
desc: "optimization level (0-3, s, or z; default: 0)",
removed: None,
tmod: None,
},
OptionDesc {
name: "overflow_checks",
setter: cgopts::overflow_checks,
type_desc: desc::parse_opt_bool,
desc: "use overflow checks for integer arithmetic",
removed: None,
tmod: None,
},
OptionDesc {
name: "panic",
setter: cgopts::panic,
type_desc: desc::parse_opt_panic_strategy,
desc: "panic strategy to compile crate with",
removed: None,
tmod: None,
},
OptionDesc {
name: "passes",
setter: cgopts::passes,
type_desc: desc::parse_list,
desc: "a list of extra LLVM passes to run (space separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "prefer_dynamic",
setter: cgopts::prefer_dynamic,
type_desc: desc::parse_bool,
desc: "prefer dynamic linking to static linking (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "profile_generate",
setter: cgopts::profile_generate,
type_desc: desc::parse_switch_with_opt_path,
desc: "compile the program with profiling instrumentation",
removed: None,
tmod: None,
},
OptionDesc {
name: "profile_use",
setter: cgopts::profile_use,
type_desc: desc::parse_opt_pathbuf,
desc: "use the given `.profdata` file for profile-guided optimization",
removed: None,
tmod: None,
},
OptionDesc {
name: "relocation_model",
setter: cgopts::relocation_model,
type_desc: desc::parse_relocation_model,
desc: "control generation of position-independent code (PIC) \
(`rustc --print relocation-models` for details)",
removed: None,
tmod: None,
},
OptionDesc {
name: "relro_level",
setter: cgopts::relro_level,
type_desc: desc::parse_relro_level,
desc: "choose which RELRO level to use",
removed: None,
tmod: None,
},
OptionDesc {
name: "remark",
setter: cgopts::remark,
type_desc: desc::parse_passes,
desc: "output remarks for these optimization passes (space separated, or \"all\")",
removed: None,
tmod: None,
},
OptionDesc {
name: "rpath",
setter: cgopts::rpath,
type_desc: desc::parse_bool,
desc: "set rpath values in libs/exes (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "save_temps",
setter: cgopts::save_temps,
type_desc: desc::parse_bool,
desc: "save all temporary output files during compilation (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "soft_float",
setter: cgopts::soft_float,
type_desc: desc::parse_ignore,
desc: "this option has been removed \
(use a corresponding *eabi target instead)",
removed: None.or(Some(RemovedOption::Err)),
tmod: None,
},
OptionDesc {
name: "split_debuginfo",
setter: cgopts::split_debuginfo,
type_desc: desc::parse_split_debuginfo,
desc: "how to handle split-debuginfo, a platform-specific option",
removed: None,
tmod: None,
},
OptionDesc {
name: "strip",
setter: cgopts::strip,
type_desc: desc::parse_strip,
desc: "tell the linker which information to strip (`none` (default), `debuginfo` or `symbols`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "symbol_mangling_version",
setter: cgopts::symbol_mangling_version,
type_desc: desc::parse_symbol_mangling_version,
desc: "which mangling version to use for symbol names ('legacy' (default), 'v0', or 'hashed')",
removed: None,
tmod: None,
},
OptionDesc {
name: "target_cpu",
setter: cgopts::target_cpu,
type_desc: desc::parse_opt_string,
desc: "select target processor (`rustc --print target-cpus` for details)",
removed: None,
tmod: None,
},
OptionDesc {
name: "target_feature",
setter: cgopts::target_feature,
type_desc: desc::parse_target_feature,
desc: "target specific attributes. (`rustc --print target-features` for details). \
This feature is unsafe.",
removed: None,
tmod: None,
},
OptionDesc {
name: "unsafe_allow_abi_mismatch",
setter: cgopts::unsafe_allow_abi_mismatch,
type_desc: desc::parse_comma_list,
desc: "Allow incompatible target modifiers in dependency crates (comma separated list)",
removed: None,
tmod: None,
}];
mod cgopts {
pub(super) fn ar(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_string(&mut cg.ar, v)
}
pub(super) fn code_model(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_code_model(&mut cg.code_model, v)
}
pub(super) fn codegen_units(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.codegen_units, v)
}
pub(super) fn collapse_macro_debuginfo(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_collapse_macro_debuginfo(&mut cg.collapse_macro_debuginfo,
v)
}
pub(super) fn control_flow_guard(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_cfguard(&mut cg.control_flow_guard, v)
}
pub(super) fn debug_assertions(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.debug_assertions, v)
}
pub(super) fn debuginfo(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_debuginfo(&mut cg.debuginfo, v)
}
pub(super) fn default_linker_libraries(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.default_linker_libraries, v)
}
pub(super) fn dlltool(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_pathbuf(&mut cg.dlltool, v)
}
pub(super) fn dwarf_version(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.dwarf_version, v)
}
pub(super) fn embed_bitcode(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.embed_bitcode, v)
}
pub(super) fn extra_filename(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_string(&mut cg.extra_filename, v)
}
pub(super) fn force_frame_pointers(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_frame_pointer(&mut cg.force_frame_pointers, v)
}
pub(super) fn force_unwind_tables(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.force_unwind_tables, v)
}
pub(super) fn help(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_no_value(&mut cg.help, v)
}
pub(super) fn incremental(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_string(&mut cg.incremental, v)
}
pub(super) fn inline_threshold(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.inline_threshold, v)
}
pub(super) fn instrument_coverage(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_instrument_coverage(&mut cg.instrument_coverage,
v)
}
pub(super) fn jump_tables(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.jump_tables, v)
}
pub(super) fn link_arg(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_string_push(&mut cg.link_args, v)
}
pub(super) fn link_args(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_list(&mut cg.link_args, v)
}
pub(super) fn link_dead_code(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.link_dead_code, v)
}
pub(super) fn link_self_contained(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_link_self_contained(&mut cg.link_self_contained,
v)
}
pub(super) fn linker(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_pathbuf(&mut cg.linker, v)
}
pub(super) fn linker_features(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_linker_features(&mut cg.linker_features, v)
}
pub(super) fn linker_flavor(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_linker_flavor(&mut cg.linker_flavor, v)
}
pub(super) fn linker_plugin_lto(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_linker_plugin_lto(&mut cg.linker_plugin_lto, v)
}
pub(super) fn llvm_args(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_list(&mut cg.llvm_args, v)
}
pub(super) fn lto(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_lto(&mut cg.lto, v)
}
pub(super) fn metadata(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_list(&mut cg.metadata, v)
}
pub(super) fn no_prepopulate_passes(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_prepopulate_passes, v)
}
pub(super) fn no_redzone(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_bool(&mut cg.no_redzone, v)
}
pub(super) fn no_stack_check(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_stack_check, v)
}
pub(super) fn no_vectorize_loops(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_vectorize_loops, v)
}
pub(super) fn no_vectorize_slp(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_vectorize_slp, v)
}
pub(super) fn opt_level(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_string(&mut cg.opt_level, v)
}
pub(super) fn overflow_checks(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.overflow_checks, v)
}
pub(super) fn panic(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_panic_strategy(&mut cg.panic, v)
}
pub(super) fn passes(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_list(&mut cg.passes, v)
}
pub(super) fn prefer_dynamic(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.prefer_dynamic, v)
}
pub(super) fn profile_generate(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_switch_with_opt_path(&mut cg.profile_generate, v)
}
pub(super) fn profile_use(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_pathbuf(&mut cg.profile_use, v)
}
pub(super) fn relocation_model(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_relocation_model(&mut cg.relocation_model, v)
}
pub(super) fn relro_level(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_relro_level(&mut cg.relro_level, v)
}
pub(super) fn remark(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_passes(&mut cg.remark, v)
}
pub(super) fn rpath(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.rpath, v)
}
pub(super) fn save_temps(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.save_temps, v)
}
pub(super) fn soft_float(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_ignore(&mut cg.soft_float, v)
}
pub(super) fn split_debuginfo(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_split_debuginfo(&mut cg.split_debuginfo, v)
}
pub(super) fn strip(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_strip(&mut cg.strip, v)
}
pub(super) fn symbol_mangling_version(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_symbol_mangling_version(&mut cg.symbol_mangling_version,
v)
}
pub(super) fn target_cpu(cg: &mut super::CodegenOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_string(&mut cg.target_cpu, v)
}
pub(super) fn target_feature(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_target_feature(&mut cg.target_feature, v)
}
pub(super) fn unsafe_allow_abi_mismatch(cg: &mut super::CodegenOptions,
v: Option<&str>) -> bool {
super::parse::parse_comma_list(&mut cg.unsafe_allow_abi_mismatch, v)
}
}options! {
2079 CodegenOptions, CodegenOptionsTargetModifiers, CG_OPTIONS, cgopts, "C", "codegen",
2080
2081 #[rustc_lint_opt_deny_field_access("documented to do nothing")]
2087 ar: String = (String::new(), parse_string, [UNTRACKED],
2088 "this option is deprecated and does nothing",
2089 removed: Warn),
2090 #[rustc_lint_opt_deny_field_access("use `Session::code_model` instead of this field")]
2091 code_model: Option<CodeModel> = (None, parse_code_model, [TRACKED],
2092 "choose the code model to use (`rustc --print code-models` for details)"),
2093 codegen_units: Option<usize> = (None, parse_opt_number, [UNTRACKED],
2094 "divide crate into N units to optimize in parallel"),
2095 collapse_macro_debuginfo: CollapseMacroDebuginfo = (CollapseMacroDebuginfo::Unspecified,
2096 parse_collapse_macro_debuginfo, [TRACKED],
2097 "set option to collapse debuginfo for macros"),
2098 control_flow_guard: CFGuard = (CFGuard::Disabled, parse_cfguard, [TRACKED],
2099 "use Windows Control Flow Guard (default: no)"),
2100 debug_assertions: Option<bool> = (None, parse_opt_bool, [TRACKED],
2101 "explicitly enable the `cfg(debug_assertions)` directive"),
2102 debuginfo: DebugInfo = (DebugInfo::None, parse_debuginfo, [TRACKED],
2103 "debug info emission level (0-2, none, line-directives-only, \
2104 line-tables-only, limited, or full; default: 0)"),
2105 default_linker_libraries: bool = (false, parse_bool, [UNTRACKED],
2106 "allow the linker to link its default libraries (default: no)"),
2107 dlltool: Option<PathBuf> = (None, parse_opt_pathbuf, [UNTRACKED],
2108 "import library generation tool (ignored except when targeting windows-gnu)"),
2109 #[rustc_lint_opt_deny_field_access("use `Session::dwarf_version` instead of this field")]
2110 dwarf_version: Option<u32> = (None, parse_opt_number, [TRACKED],
2111 "version of DWARF debug information to emit (default: 2 or 4, depending on platform)"),
2112 embed_bitcode: bool = (true, parse_bool, [TRACKED],
2113 "emit bitcode in rlibs (default: yes)"),
2114 extra_filename: String = (String::new(), parse_string, [UNTRACKED],
2115 "extra data to put in each output filename"),
2116 force_frame_pointers: FramePointer = (FramePointer::MayOmit, parse_frame_pointer, [TRACKED],
2117 "force use of the frame pointers"),
2118 #[rustc_lint_opt_deny_field_access("use `Session::must_emit_unwind_tables` instead of this field")]
2119 force_unwind_tables: Option<bool> = (None, parse_opt_bool, [TRACKED],
2120 "force use of unwind tables"),
2121 help: bool = (false, parse_no_value, [UNTRACKED], "Print codegen options"),
2122 incremental: Option<String> = (None, parse_opt_string, [UNTRACKED],
2123 "enable incremental compilation"),
2124 #[rustc_lint_opt_deny_field_access("documented to do nothing")]
2125 inline_threshold: Option<u32> = (None, parse_opt_number, [UNTRACKED],
2126 "this option is deprecated and does nothing \
2127 (consider using `-Cllvm-args=--inline-threshold=...`)",
2128 removed: Warn),
2129 #[rustc_lint_opt_deny_field_access("use `Session::instrument_coverage` instead of this field")]
2130 instrument_coverage: InstrumentCoverage = (InstrumentCoverage::No, parse_instrument_coverage, [TRACKED],
2131 "instrument the generated code to support LLVM source-based code coverage reports \
2132 (note, the compiler build config must include `profiler = true`); \
2133 implies `-C symbol-mangling-version=v0`"),
2134 jump_tables: bool = (true, parse_bool, [TRACKED],
2135 "allow jump table and lookup table generation from switch case lowering (default: yes)"),
2136 link_arg: () = ((), parse_string_push, [UNTRACKED],
2137 "a single extra argument to append to the linker invocation (can be used several times)"),
2138 link_args: Vec<String> = (Vec::new(), parse_list, [UNTRACKED],
2139 "extra arguments to append to the linker invocation (space separated)"),
2140 #[rustc_lint_opt_deny_field_access("use `Session::link_dead_code` instead of this field")]
2141 link_dead_code: Option<bool> = (None, parse_opt_bool, [TRACKED],
2142 "try to generate and link dead code (default: no)"),
2143 link_self_contained: LinkSelfContained = (LinkSelfContained::default(), parse_link_self_contained, [UNTRACKED],
2144 "control whether to link Rust provided C objects/libraries or rely \
2145 on a C toolchain or linker installed in the system"),
2146 linker: Option<PathBuf> = (None, parse_opt_pathbuf, [UNTRACKED],
2147 "system linker to link outputs with"),
2148 linker_features: LinkerFeaturesCli = (LinkerFeaturesCli::default(), parse_linker_features, [UNTRACKED],
2149 "a comma-separated list of linker features to enable (+) or disable (-): `lld`"),
2150 linker_flavor: Option<LinkerFlavorCli> = (None, parse_linker_flavor, [UNTRACKED],
2151 "linker flavor"),
2152 linker_plugin_lto: LinkerPluginLto = (LinkerPluginLto::Disabled,
2153 parse_linker_plugin_lto, [TRACKED],
2154 "generate build artifacts that are compatible with linker-based LTO"),
2155 llvm_args: Vec<String> = (Vec::new(), parse_list, [TRACKED],
2156 "a list of arguments to pass to LLVM (space separated)"),
2157 #[rustc_lint_opt_deny_field_access("use `Session::lto` instead of this field")]
2158 lto: LtoCli = (LtoCli::Unspecified, parse_lto, [TRACKED],
2159 "perform LLVM link-time optimizations"),
2160 metadata: Vec<String> = (Vec::new(), parse_list, [TRACKED],
2161 "metadata to mangle symbol names with"),
2162 no_prepopulate_passes: bool = (false, parse_no_value, [TRACKED],
2163 "give an empty list of passes to the pass manager"),
2164 no_redzone: Option<bool> = (None, parse_opt_bool, [TRACKED],
2165 "disable the use of the redzone"),
2166 #[rustc_lint_opt_deny_field_access("documented to do nothing")]
2167 no_stack_check: bool = (false, parse_no_value, [UNTRACKED],
2168 "this option is deprecated and does nothing",
2169 removed: Warn),
2170 no_vectorize_loops: bool = (false, parse_no_value, [TRACKED],
2171 "disable loop vectorization optimization passes"),
2172 no_vectorize_slp: bool = (false, parse_no_value, [TRACKED],
2173 "disable LLVM's SLP vectorization pass"),
2174 opt_level: String = ("0".to_string(), parse_string, [TRACKED],
2175 "optimization level (0-3, s, or z; default: 0)"),
2176 #[rustc_lint_opt_deny_field_access("use `Session::overflow_checks` instead of this field")]
2177 overflow_checks: Option<bool> = (None, parse_opt_bool, [TRACKED],
2178 "use overflow checks for integer arithmetic"),
2179 #[rustc_lint_opt_deny_field_access("use `Session::panic_strategy` instead of this field")]
2180 panic: Option<PanicStrategy> = (None, parse_opt_panic_strategy, [TRACKED],
2181 "panic strategy to compile crate with"),
2182 passes: Vec<String> = (Vec::new(), parse_list, [TRACKED],
2183 "a list of extra LLVM passes to run (space separated)"),
2184 prefer_dynamic: bool = (false, parse_bool, [TRACKED],
2185 "prefer dynamic linking to static linking (default: no)"),
2186 profile_generate: SwitchWithOptPath = (SwitchWithOptPath::Disabled,
2187 parse_switch_with_opt_path, [TRACKED],
2188 "compile the program with profiling instrumentation"),
2189 profile_use: Option<PathBuf> = (None, parse_opt_pathbuf, [TRACKED],
2190 "use the given `.profdata` file for profile-guided optimization"),
2191 #[rustc_lint_opt_deny_field_access("use `Session::relocation_model` instead of this field")]
2192 relocation_model: Option<RelocModel> = (None, parse_relocation_model, [TRACKED],
2193 "control generation of position-independent code (PIC) \
2194 (`rustc --print relocation-models` for details)"),
2195 relro_level: Option<RelroLevel> = (None, parse_relro_level, [TRACKED],
2196 "choose which RELRO level to use"),
2197 remark: Passes = (Passes::Some(Vec::new()), parse_passes, [UNTRACKED],
2198 "output remarks for these optimization passes (space separated, or \"all\")"),
2199 rpath: bool = (false, parse_bool, [UNTRACKED],
2200 "set rpath values in libs/exes (default: no)"),
2201 save_temps: bool = (false, parse_bool, [UNTRACKED],
2202 "save all temporary output files during compilation (default: no)"),
2203 #[rustc_lint_opt_deny_field_access("documented to do nothing")]
2204 soft_float: () = ((), parse_ignore, [UNTRACKED],
2205 "this option has been removed \
2206 (use a corresponding *eabi target instead)",
2207 removed: Err),
2208 #[rustc_lint_opt_deny_field_access("use `Session::split_debuginfo` instead of this field")]
2209 split_debuginfo: Option<SplitDebuginfo> = (None, parse_split_debuginfo, [TRACKED],
2210 "how to handle split-debuginfo, a platform-specific option"),
2211 strip: Strip = (Strip::None, parse_strip, [UNTRACKED],
2212 "tell the linker which information to strip (`none` (default), `debuginfo` or `symbols`)"),
2213 symbol_mangling_version: Option<SymbolManglingVersion> = (None,
2214 parse_symbol_mangling_version, [TRACKED],
2215 "which mangling version to use for symbol names ('legacy' (default), 'v0', or 'hashed')"),
2216 target_cpu: Option<String> = (None, parse_opt_string, [TRACKED],
2217 "select target processor (`rustc --print target-cpus` for details)"),
2218 target_feature: String = (String::new(), parse_target_feature, [TRACKED],
2219 "target specific attributes. (`rustc --print target-features` for details). \
2220 This feature is unsafe."),
2221 unsafe_allow_abi_mismatch: Vec<String> = (Vec::new(), parse_comma_list, [UNTRACKED],
2222 "Allow incompatible target modifiers in dependency crates (comma separated list)"),
2223 }
2229
2230#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialEq for UnstableOptionsTargetModifiers {
#[inline]
fn eq(&self, other: &UnstableOptionsTargetModifiers) -> bool {
let __self_discr = ::core::intrinsics::discriminant_value(self);
let __arg1_discr = ::core::intrinsics::discriminant_value(other);
__self_discr == __arg1_discr
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::Eq for UnstableOptionsTargetModifiers {
#[inline]
#[doc(hidden)]
#[coverage(off)]
fn assert_fields_are_eq(&self) {}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::PartialOrd for UnstableOptionsTargetModifiers {
#[inline]
fn partial_cmp(&self, other: &UnstableOptionsTargetModifiers)
-> ::core::option::Option<::core::cmp::Ordering> {
let __self_discr = ::core::intrinsics::discriminant_value(self);
let __arg1_discr = ::core::intrinsics::discriminant_value(other);
::core::cmp::PartialOrd::partial_cmp(&__self_discr, &__arg1_discr)
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::cmp::Ord for UnstableOptionsTargetModifiers {
#[inline]
fn cmp(&self, other: &UnstableOptionsTargetModifiers)
-> ::core::cmp::Ordering {
let __self_discr = ::core::intrinsics::discriminant_value(self);
let __arg1_discr = ::core::intrinsics::discriminant_value(other);
::core::cmp::Ord::cmp(&__self_discr, &__arg1_discr)
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::fmt::Debug for UnstableOptionsTargetModifiers {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
::core::fmt::Formatter::write_str(f,
match self {
UnstableOptionsTargetModifiers::branch_protection =>
"branch_protection",
UnstableOptionsTargetModifiers::fixed_x18 => "fixed_x18",
UnstableOptionsTargetModifiers::indirect_branch_cs_prefix =>
"indirect_branch_cs_prefix",
UnstableOptionsTargetModifiers::reg_struct_return =>
"reg_struct_return",
UnstableOptionsTargetModifiers::regparm => "regparm",
UnstableOptionsTargetModifiers::retpoline => "retpoline",
UnstableOptionsTargetModifiers::retpoline_external_thunk =>
"retpoline_external_thunk",
UnstableOptionsTargetModifiers::sanitizer => "sanitizer",
UnstableOptionsTargetModifiers::sanitizer_cfi_normalize_integers
=> "sanitizer_cfi_normalize_integers",
})
}
}
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::marker::Copy for UnstableOptionsTargetModifiers { }
#[automatically_derived]
#[doc(hidden)]
#[allow(non_camel_case_types)]
unsafe impl ::core::clone::TrivialClone for UnstableOptionsTargetModifiers { }
#[automatically_derived]
#[allow(non_camel_case_types)]
impl ::core::clone::Clone for UnstableOptionsTargetModifiers {
#[inline]
fn clone(&self) -> UnstableOptionsTargetModifiers { *self }
}
const _: () =
{
impl<__E: ::rustc_span::SpanEncoder> ::rustc_serialize::Encodable<__E>
for UnstableOptionsTargetModifiers {
fn encode(&self, __encoder: &mut __E) {
let disc =
match *self {
UnstableOptionsTargetModifiers::branch_protection => {
0usize
}
UnstableOptionsTargetModifiers::fixed_x18 => { 1usize }
UnstableOptionsTargetModifiers::indirect_branch_cs_prefix =>
{
2usize
}
UnstableOptionsTargetModifiers::reg_struct_return => {
3usize
}
UnstableOptionsTargetModifiers::regparm => { 4usize }
UnstableOptionsTargetModifiers::retpoline => { 5usize }
UnstableOptionsTargetModifiers::retpoline_external_thunk =>
{
6usize
}
UnstableOptionsTargetModifiers::sanitizer => { 7usize }
UnstableOptionsTargetModifiers::sanitizer_cfi_normalize_integers
=> {
8usize
}
};
::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
match *self {
UnstableOptionsTargetModifiers::branch_protection => {}
UnstableOptionsTargetModifiers::fixed_x18 => {}
UnstableOptionsTargetModifiers::indirect_branch_cs_prefix =>
{}
UnstableOptionsTargetModifiers::reg_struct_return => {}
UnstableOptionsTargetModifiers::regparm => {}
UnstableOptionsTargetModifiers::retpoline => {}
UnstableOptionsTargetModifiers::retpoline_external_thunk =>
{}
UnstableOptionsTargetModifiers::sanitizer => {}
UnstableOptionsTargetModifiers::sanitizer_cfi_normalize_integers
=> {}
}
}
}
};
const _: () =
{
impl<__D: ::rustc_span::BlobDecoder> ::rustc_serialize::Decodable<__D>
for UnstableOptionsTargetModifiers {
fn decode(__decoder: &mut __D) -> Self {
match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
{
0usize => {
UnstableOptionsTargetModifiers::branch_protection
}
1usize => { UnstableOptionsTargetModifiers::fixed_x18 }
2usize => {
UnstableOptionsTargetModifiers::indirect_branch_cs_prefix
}
3usize => {
UnstableOptionsTargetModifiers::reg_struct_return
}
4usize => { UnstableOptionsTargetModifiers::regparm }
5usize => { UnstableOptionsTargetModifiers::retpoline }
6usize => {
UnstableOptionsTargetModifiers::retpoline_external_thunk
}
7usize => { UnstableOptionsTargetModifiers::sanitizer }
8usize => {
UnstableOptionsTargetModifiers::sanitizer_cfi_normalize_integers
}
n => {
::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `UnstableOptionsTargetModifiers`, expected 0..9, actual {0}",
n));
}
}
}
}
};
impl UnstableOptionsTargetModifiers {
#[allow(unused_variables)]
pub fn reparse(&self, user_value: &str) -> ExtendedTargetModifierInfo {
#[allow(unreachable_patterns)]
match self {
Self::branch_protection => {
let mut parsed: Option<BranchProtection> = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_branch_protection(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "branch_protection".to_string().replace('_', "-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
Self::fixed_x18 => {
let mut parsed: bool = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_bool(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "fixed_x18".to_string().replace('_', "-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
Self::indirect_branch_cs_prefix => {
let mut parsed: bool = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_bool(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "indirect_branch_cs_prefix".to_string().replace('_',
"-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
Self::reg_struct_return => {
let mut parsed: bool = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_bool(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "reg_struct_return".to_string().replace('_', "-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
Self::regparm => {
let mut parsed: Option<u32> = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_opt_number(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "regparm".to_string().replace('_', "-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
Self::retpoline => {
let mut parsed: bool = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_bool(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "retpoline".to_string().replace('_', "-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
Self::retpoline_external_thunk => {
let mut parsed: bool = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_bool(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "retpoline_external_thunk".to_string().replace('_',
"-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
Self::sanitizer => {
let mut parsed: SanitizerSet = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_sanitizers(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "sanitizer".to_string().replace('_', "-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
Self::sanitizer_cfi_normalize_integers => {
let mut parsed: Option<bool> = Default::default();
let val =
if user_value.is_empty() { None } else { Some(user_value) };
parse::parse_opt_bool(&mut parsed, val);
ExtendedTargetModifierInfo {
prefix: "Z".to_string(),
name: "sanitizer_cfi_normalize_integers".to_string().replace('_',
"-"),
tech_value: ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0:?}", parsed))
}),
}
}
_ => {
::core::panicking::panic_fmt(format_args!("unknown target modifier option: {0:?}",
*self));
}
}
}
pub fn is_target_modifier(flag_name: &str) -> bool {
match flag_name.replace('-', "_").as_str() {
"branch_protection" => true,
"fixed_x18" => true,
"indirect_branch_cs_prefix" => true,
"reg_struct_return" => true,
"regparm" => true,
"retpoline" => true,
"retpoline_external_thunk" => true,
"sanitizer" => true,
"sanitizer_cfi_normalize_integers" => true,
_ => false,
}
}
}
impl Default for UnstableOptions {
fn default() -> UnstableOptions {
UnstableOptions {
allow_features: None,
always_encode_mir: false,
annotate_moves: AnnotateMoves::Disabled,
assert_incr_state: None,
assume_incomplete_release: false,
autodiff: Vec::new(),
binary_dep_depinfo: false,
box_noalias: true,
branch_protection: None,
build_sdylib_interface: false,
cache_proc_macros: false,
cf_protection: CFProtection::None,
check_cfg_all_expected: false,
checksum_hash_algorithm: None,
codegen_backend: None,
codegen_source_order: false,
contract_checks: None,
coverage_options: CoverageOptions::default(),
crate_attr: Vec::new(),
cross_crate_inline_threshold: InliningThreshold::Sometimes(100),
debug_info_for_profiling: false,
debug_info_type_line_numbers: false,
debuginfo_compression: DebugInfoCompression::None,
deduplicate_diagnostics: true,
default_visibility: None,
dep_info_omit_d_target: false,
direct_access_external_data: None,
dual_proc_macros: false,
dump_dep_graph: false,
dump_mir: None,
dump_mir_dataflow: false,
dump_mir_dir: "mir_dump".to_string(),
dump_mir_exclude_alloc_bytes: false,
dump_mir_exclude_pass_number: false,
dump_mir_graphviz: false,
dump_mono_stats: SwitchWithOptPath::Disabled,
dump_mono_stats_format: DumpMonoStatsFormat::Markdown,
dwarf_version: None,
dylib_lto: false,
eagerly_emit_delayed_bugs: false,
ehcont_guard: false,
embed_metadata: true,
embed_source: false,
emit_stack_sizes: false,
emscripten_wasm_eh: true,
enforce_type_length_limit: false,
experimental_default_bounds: false,
export_executable_symbols: false,
external_clangrt: false,
extra_const_ub_checks: false,
fewer_names: None,
fixed_x18: false,
flatten_format_args: true,
fmt_debug: FmtDebug::Full,
force_unstable_if_unmarked: false,
function_return: FunctionReturn::default(),
function_sections: None,
future_incompat_test: false,
graphviz_dark_mode: false,
graphviz_font: "Courier, monospace".to_string(),
has_thread_local: None,
help: false,
higher_ranked_assumptions: false,
hint_mostly_unused: false,
human_readable_cgu_names: false,
identify_regions: false,
ignore_directory_in_diagnostics_source_blocks: Vec::new(),
incremental_ignore_spans: false,
incremental_info: false,
incremental_verify_ich: false,
indirect_branch_cs_prefix: false,
inline_llvm: true,
inline_mir: None,
inline_mir_forwarder_threshold: None,
inline_mir_hint_threshold: None,
inline_mir_preserve_debug: None,
inline_mir_threshold: None,
input_stats: false,
instrument_mcount: false,
instrument_xray: None,
large_data_threshold: None,
layout_seed: None,
link_directives: true,
link_native_libraries: true,
link_only: false,
lint_llvm_ir: false,
lint_mir: false,
llvm_module_flag: Vec::new(),
llvm_plugins: Vec::new(),
llvm_time_trace: false,
location_detail: LocationDetail::all(),
ls: Vec::new(),
macro_backtrace: false,
macro_stats: false,
maximal_hir_to_mir_coverage: false,
merge_functions: None,
meta_stats: false,
metrics_dir: None,
min_function_alignment: None,
min_recursion_limit: None,
mir_emit_retag: false,
mir_enable_passes: Vec::new(),
mir_include_spans: MirIncludeSpans::default(),
mir_opt_bisect_limit: None,
mir_opt_level: None,
mir_preserve_ub: false,
mir_strip_debuginfo: MirStripDebugInfo::None,
move_size_limit: None,
mutable_noalias: true,
namespaced_crates: false,
next_solver: NextSolverConfig::default(),
nll_facts: false,
nll_facts_dir: "nll-facts".to_string(),
no_analysis: false,
no_codegen: false,
no_generate_arange_section: false,
no_implied_bounds_compat: false,
no_leak_check: false,
no_link: false,
no_parallel_backend: false,
no_profiler_runtime: false,
no_steal_thir: false,
no_trait_vptr: false,
no_unique_section_names: false,
normalize_docs: false,
offload: Vec::new(),
on_broken_pipe: OnBrokenPipe::Default,
osx_rpath_install_name: false,
packed_bundled_libs: false,
packed_stack: false,
panic_abort_tests: false,
panic_in_drop: PanicStrategy::Unwind,
parse_crate_root_only: false,
patchable_function_entry: PatchableFunctionEntry::default(),
plt: None,
polonius: Polonius::default(),
pre_link_arg: (),
pre_link_args: Vec::new(),
precise_enum_drop_elaboration: true,
print_codegen_stats: false,
print_llvm_passes: false,
print_mono_items: false,
print_type_sizes: false,
proc_macro_backtrace: false,
proc_macro_execution_strategy: ProcMacroExecutionStrategy::SameThread,
profile_closures: false,
profile_sample_use: None,
profiler_runtime: String::from("profiler_builtins"),
query_dep_graph: false,
randomize_layout: false,
reg_struct_return: false,
regparm: None,
relax_elf_relocations: None,
remap_cwd_prefix: None,
remark_dir: None,
retpoline: false,
retpoline_external_thunk: false,
sanitizer: SanitizerSet::empty(),
sanitizer_cfi_canonical_jump_tables: Some(true),
sanitizer_cfi_generalize_pointers: None,
sanitizer_cfi_normalize_integers: None,
sanitizer_dataflow_abilist: Vec::new(),
sanitizer_kcfi_arity: None,
sanitizer_memory_track_origins: 0,
sanitizer_recover: SanitizerSet::empty(),
saturating_float_casts: None,
self_profile: SwitchWithOptPath::Disabled,
self_profile_counter: "wall-time".to_string(),
self_profile_events: None,
share_generics: None,
shell_argfiles: false,
simulate_remapped_rust_src_base: None,
small_data_threshold: None,
span_debug: false,
span_free_formats: false,
split_dwarf_inlining: false,
split_dwarf_kind: SplitDwarfKind::Split,
split_dwarf_out_dir: None,
split_lto_unit: None,
src_hash_algorithm: None,
stack_protector: StackProtector::None,
staticlib_allow_rdylib_deps: false,
staticlib_prefer_dynamic: false,
strict_init_checks: false,
teach: false,
temps_dir: None,
terminal_urls: TerminalUrl::No,
thinlto: None,
threads: 1,
time_llvm_passes: false,
time_passes: false,
time_passes_format: TimePassesFormat::Text,
tiny_const_eval_limit: false,
tls_model: None,
trace_macros: false,
track_diagnostics: false,
translate_remapped_path_to_local_path: true,
trap_unreachable: None,
treat_err_as_bug: None,
trim_diagnostic_paths: true,
tune_cpu: None,
typing_mode_borrowck: false,
ub_checks: None,
ui_testing: false,
uninit_const_chunk_threshold: 16,
unleash_the_miri_inside_of_you: false,
unpretty: None,
unsound_mir_opts: false,
unstable_options: false,
use_ctors_section: None,
use_sync_unwind: None,
validate_mir: false,
verbose_asm: false,
verbose_internals: false,
verify_llvm_ir: false,
virtual_function_elimination: false,
wasi_exec_model: None,
wasm_c_abi: (),
write_long_types_to_disk: true,
}
}
}
impl UnstableOptions {
pub fn build(early_dcx: &EarlyDiagCtxt, matches: &getopts::Matches,
target_modifiers: &mut BTreeMap<OptionsTargetModifiers, String>)
-> UnstableOptions {
build_options(early_dcx, matches, target_modifiers, Z_OPTIONS, "Z",
"unstable")
}
fn dep_tracking_hash(&self, for_crate_hash: bool,
error_format: ErrorOutputType) -> Hash64 {
let mut sub_hashes = BTreeMap::new();
{
{
if (&mut sub_hashes).insert("allow_features",
&self.allow_features as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"allow_features"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("always_encode_mir",
&self.always_encode_mir as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"always_encode_mir"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("annotate_moves",
&self.annotate_moves as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"annotate_moves"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("assume_incomplete_release",
&self.assume_incomplete_release as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"assume_incomplete_release"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("autodiff",
&self.autodiff as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"autodiff"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("binary_dep_depinfo",
&self.binary_dep_depinfo as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"binary_dep_depinfo"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("box_noalias",
&self.box_noalias as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"box_noalias"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("branch_protection",
&self.branch_protection as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"branch_protection"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("cache_proc_macros",
&self.cache_proc_macros as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"cache_proc_macros"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("cf_protection",
&self.cf_protection as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"cf_protection"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("checksum_hash_algorithm",
&self.checksum_hash_algorithm as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"checksum_hash_algorithm"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("codegen_backend",
&self.codegen_backend as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"codegen_backend"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("contract_checks",
&self.contract_checks as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"contract_checks"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("coverage_options",
&self.coverage_options as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"coverage_options"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("crate_attr",
&self.crate_attr as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"crate_attr"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("cross_crate_inline_threshold",
&self.cross_crate_inline_threshold as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"cross_crate_inline_threshold"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("debug_info_for_profiling",
&self.debug_info_for_profiling as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"debug_info_for_profiling"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("debug_info_type_line_numbers",
&self.debug_info_type_line_numbers as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"debug_info_type_line_numbers"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("debuginfo_compression",
&self.debuginfo_compression as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"debuginfo_compression"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("default_visibility",
&self.default_visibility as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"default_visibility"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("dep_info_omit_d_target",
&self.dep_info_omit_d_target as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"dep_info_omit_d_target"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("direct_access_external_data",
&self.direct_access_external_data as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"direct_access_external_data"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("dual_proc_macros",
&self.dual_proc_macros as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"dual_proc_macros"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("dwarf_version",
&self.dwarf_version as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"dwarf_version"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("ehcont_guard",
&self.ehcont_guard as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"ehcont_guard"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("embed_metadata",
&self.embed_metadata as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"embed_metadata"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("embed_source",
&self.embed_source as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"embed_source"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("emscripten_wasm_eh",
&self.emscripten_wasm_eh as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"emscripten_wasm_eh"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("enforce_type_length_limit",
&self.enforce_type_length_limit as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"enforce_type_length_limit"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("experimental_default_bounds",
&self.experimental_default_bounds as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"experimental_default_bounds"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("export_executable_symbols",
&self.export_executable_symbols as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"export_executable_symbols"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("extra_const_ub_checks",
&self.extra_const_ub_checks as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"extra_const_ub_checks"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("fewer_names",
&self.fewer_names as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"fewer_names"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("fixed_x18",
&self.fixed_x18 as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"fixed_x18"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("flatten_format_args",
&self.flatten_format_args as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"flatten_format_args"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("fmt_debug",
&self.fmt_debug as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"fmt_debug"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("force_unstable_if_unmarked",
&self.force_unstable_if_unmarked as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"force_unstable_if_unmarked"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("function_return",
&self.function_return as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"function_return"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("function_sections",
&self.function_sections as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"function_sections"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("has_thread_local",
&self.has_thread_local as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"has_thread_local"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("higher_ranked_assumptions",
&self.higher_ranked_assumptions as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"higher_ranked_assumptions"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("hint_mostly_unused",
&self.hint_mostly_unused as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"hint_mostly_unused"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("human_readable_cgu_names",
&self.human_readable_cgu_names as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"human_readable_cgu_names"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("incremental_ignore_spans",
&self.incremental_ignore_spans as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"incremental_ignore_spans"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("indirect_branch_cs_prefix",
&self.indirect_branch_cs_prefix as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"indirect_branch_cs_prefix"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("inline_llvm",
&self.inline_llvm as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"inline_llvm"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("inline_mir",
&self.inline_mir as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"inline_mir"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("inline_mir_forwarder_threshold",
&self.inline_mir_forwarder_threshold as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"inline_mir_forwarder_threshold"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("inline_mir_hint_threshold",
&self.inline_mir_hint_threshold as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"inline_mir_hint_threshold"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("inline_mir_preserve_debug",
&self.inline_mir_preserve_debug as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"inline_mir_preserve_debug"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("inline_mir_threshold",
&self.inline_mir_threshold as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"inline_mir_threshold"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("instrument_mcount",
&self.instrument_mcount as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"instrument_mcount"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("instrument_xray",
&self.instrument_xray as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"instrument_xray"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("large_data_threshold",
&self.large_data_threshold as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"large_data_threshold"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("layout_seed",
&self.layout_seed as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"layout_seed"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("link_directives",
&self.link_directives as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"link_directives"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("link_only",
&self.link_only as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"link_only"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("lint_llvm_ir",
&self.lint_llvm_ir as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"lint_llvm_ir"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("llvm_module_flag",
&self.llvm_module_flag as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"llvm_module_flag"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("llvm_plugins",
&self.llvm_plugins as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"llvm_plugins"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("location_detail",
&self.location_detail as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"location_detail"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("maximal_hir_to_mir_coverage",
&self.maximal_hir_to_mir_coverage as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"maximal_hir_to_mir_coverage"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("merge_functions",
&self.merge_functions as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"merge_functions"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("min_function_alignment",
&self.min_function_alignment as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"min_function_alignment"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("min_recursion_limit",
&self.min_recursion_limit as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"min_recursion_limit"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("mir_emit_retag",
&self.mir_emit_retag as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"mir_emit_retag"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("mir_enable_passes",
&self.mir_enable_passes as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"mir_enable_passes"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("mir_opt_bisect_limit",
&self.mir_opt_bisect_limit as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"mir_opt_bisect_limit"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("mir_opt_level",
&self.mir_opt_level as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"mir_opt_level"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("mir_preserve_ub",
&self.mir_preserve_ub as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"mir_preserve_ub"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("mir_strip_debuginfo",
&self.mir_strip_debuginfo as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"mir_strip_debuginfo"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("move_size_limit",
&self.move_size_limit as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"move_size_limit"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("mutable_noalias",
&self.mutable_noalias as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"mutable_noalias"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("namespaced_crates",
&self.namespaced_crates as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"namespaced_crates"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("next_solver",
&self.next_solver as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"next_solver"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("no_codegen",
&self.no_codegen as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_codegen"));
}
}
}
};
}
{
{
if (&mut sub_hashes).insert("no_generate_arange_section",
&self.no_generate_arange_section as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_generate_arange_section"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("no_implied_bounds_compat",
&self.no_implied_bounds_compat as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_implied_bounds_compat"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("no_link",
&self.no_link as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_link"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("no_profiler_runtime",
&self.no_profiler_runtime as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_profiler_runtime"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("no_trait_vptr",
&self.no_trait_vptr as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_trait_vptr"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("no_unique_section_names",
&self.no_unique_section_names as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"no_unique_section_names"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("normalize_docs",
&self.normalize_docs as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"normalize_docs"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("offload",
&self.offload as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"offload"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("on_broken_pipe",
&self.on_broken_pipe as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"on_broken_pipe"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("osx_rpath_install_name",
&self.osx_rpath_install_name as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"osx_rpath_install_name"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("packed_bundled_libs",
&self.packed_bundled_libs as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"packed_bundled_libs"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("packed_stack",
&self.packed_stack as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"packed_stack"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("panic_abort_tests",
&self.panic_abort_tests as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"panic_abort_tests"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("panic_in_drop",
&self.panic_in_drop as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"panic_in_drop"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("patchable_function_entry",
&self.patchable_function_entry as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"patchable_function_entry"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("plt",
&self.plt as &dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"plt"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("polonius",
&self.polonius as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"polonius"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("precise_enum_drop_elaboration",
&self.precise_enum_drop_elaboration as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"precise_enum_drop_elaboration"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("profile_sample_use",
&self.profile_sample_use as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"profile_sample_use"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("profiler_runtime",
&self.profiler_runtime as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"profiler_runtime"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("randomize_layout",
&self.randomize_layout as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"randomize_layout"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("reg_struct_return",
&self.reg_struct_return as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"reg_struct_return"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("regparm",
&self.regparm as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"regparm"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("relax_elf_relocations",
&self.relax_elf_relocations as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"relax_elf_relocations"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("remap_cwd_prefix",
&self.remap_cwd_prefix as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"remap_cwd_prefix"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("retpoline",
&self.retpoline as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"retpoline"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("retpoline_external_thunk",
&self.retpoline_external_thunk as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"retpoline_external_thunk"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("sanitizer",
&self.sanitizer as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"sanitizer"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("sanitizer_cfi_canonical_jump_tables",
&self.sanitizer_cfi_canonical_jump_tables as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"sanitizer_cfi_canonical_jump_tables"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("sanitizer_cfi_generalize_pointers",
&self.sanitizer_cfi_generalize_pointers as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"sanitizer_cfi_generalize_pointers"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("sanitizer_cfi_normalize_integers",
&self.sanitizer_cfi_normalize_integers as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"sanitizer_cfi_normalize_integers"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("sanitizer_dataflow_abilist",
&self.sanitizer_dataflow_abilist as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"sanitizer_dataflow_abilist"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("sanitizer_kcfi_arity",
&self.sanitizer_kcfi_arity as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"sanitizer_kcfi_arity"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("sanitizer_memory_track_origins",
&self.sanitizer_memory_track_origins as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"sanitizer_memory_track_origins"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("sanitizer_recover",
&self.sanitizer_recover as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"sanitizer_recover"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("saturating_float_casts",
&self.saturating_float_casts as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"saturating_float_casts"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("share_generics",
&self.share_generics as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"share_generics"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("simulate_remapped_rust_src_base",
&self.simulate_remapped_rust_src_base as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"simulate_remapped_rust_src_base"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("small_data_threshold",
&self.small_data_threshold as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"small_data_threshold"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("split_dwarf_inlining",
&self.split_dwarf_inlining as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"split_dwarf_inlining"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("split_dwarf_kind",
&self.split_dwarf_kind as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"split_dwarf_kind"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("split_dwarf_out_dir",
&self.split_dwarf_out_dir as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"split_dwarf_out_dir"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("split_lto_unit",
&self.split_lto_unit as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"split_lto_unit"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("src_hash_algorithm",
&self.src_hash_algorithm as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"src_hash_algorithm"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("stack_protector",
&self.stack_protector as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"stack_protector"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("staticlib_allow_rdylib_deps",
&self.staticlib_allow_rdylib_deps as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"staticlib_allow_rdylib_deps"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("staticlib_prefer_dynamic",
&self.staticlib_prefer_dynamic as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"staticlib_prefer_dynamic"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("strict_init_checks",
&self.strict_init_checks as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"strict_init_checks"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("teach",
&self.teach as &dyn dep_tracking::DepTrackingHash).is_some()
{
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"teach"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("thinlto",
&self.thinlto as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"thinlto"));
}
}
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("tiny_const_eval_limit",
&self.tiny_const_eval_limit as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"tiny_const_eval_limit"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("tls_model",
&self.tls_model as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"tls_model"));
}
}
};
}
{ {}; }
{ {}; }
{
{
if (&mut sub_hashes).insert("translate_remapped_path_to_local_path",
&self.translate_remapped_path_to_local_path as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"translate_remapped_path_to_local_path"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("trap_unreachable",
&self.trap_unreachable as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"trap_unreachable"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("treat_err_as_bug",
&self.treat_err_as_bug as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"treat_err_as_bug"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("tune_cpu",
&self.tune_cpu as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"tune_cpu"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("typing_mode_borrowck",
&self.typing_mode_borrowck as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"typing_mode_borrowck"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("ub_checks",
&self.ub_checks as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"ub_checks"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("uninit_const_chunk_threshold",
&self.uninit_const_chunk_threshold as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"uninit_const_chunk_threshold"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("unleash_the_miri_inside_of_you",
&self.unleash_the_miri_inside_of_you as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"unleash_the_miri_inside_of_you"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("unsound_mir_opts",
&self.unsound_mir_opts as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"unsound_mir_opts"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("use_ctors_section",
&self.use_ctors_section as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"use_ctors_section"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("use_sync_unwind",
&self.use_sync_unwind as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"use_sync_unwind"));
}
}
};
}
{ {}; }
{
{
if (&mut sub_hashes).insert("verbose_asm",
&self.verbose_asm as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"verbose_asm"));
}
}
};
}
{
{
if !for_crate_hash {
if (&mut sub_hashes).insert("verbose_internals",
&self.verbose_internals as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"verbose_internals"));
}
}
}
};
}
{
{
if (&mut sub_hashes).insert("verify_llvm_ir",
&self.verify_llvm_ir as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"verify_llvm_ir"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("virtual_function_elimination",
&self.virtual_function_elimination as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"virtual_function_elimination"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("wasi_exec_model",
&self.wasi_exec_model as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"wasi_exec_model"));
}
}
};
}
{
{
if (&mut sub_hashes).insert("wasm_c_abi",
&self.wasm_c_abi as
&dyn dep_tracking::DepTrackingHash).is_some() {
{
::core::panicking::panic_fmt(format_args!("duplicate key in CLI DepTrackingHash: {0}",
"wasm_c_abi"));
}
}
};
}
{ {}; }
let mut hasher = StableHasher::new();
dep_tracking::stable_hash(sub_hashes, &mut hasher, error_format,
for_crate_hash);
hasher.finish()
}
pub fn gather_target_modifiers(&self, _mods: &mut Vec<TargetModifier>,
_tmod_vals: &BTreeMap<OptionsTargetModifiers, String>) {
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
if *&self.branch_protection != None {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::branch_protection),
_tmod_vals, _mods);
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
if *&self.fixed_x18 != false {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::fixed_x18),
_tmod_vals, _mods);
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
if *&self.indirect_branch_cs_prefix != false {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::indirect_branch_cs_prefix),
_tmod_vals, _mods);
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{
if *&self.reg_struct_return != false {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::reg_struct_return),
_tmod_vals, _mods);
};
}
{
if *&self.regparm != None {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::regparm),
_tmod_vals, _mods);
};
}
{ {}; }
{ {}; }
{ {}; }
{
if *&self.retpoline != false {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::retpoline),
_tmod_vals, _mods);
};
}
{
if *&self.retpoline_external_thunk != false {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::retpoline_external_thunk),
_tmod_vals, _mods);
};
}
{
if *&self.sanitizer != SanitizerSet::empty() {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::sanitizer),
_tmod_vals, _mods);
};
}
{ {}; }
{ {}; }
{
if *&self.sanitizer_cfi_normalize_integers != None {
tmod_push_impl(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::sanitizer_cfi_normalize_integers),
_tmod_vals, _mods);
};
}
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
{ {}; }
}
}
pub const Z_OPTIONS: OptionDescrs<UnstableOptions> =
&[OptionDesc {
name: "allow_features",
setter: dbopts::allow_features,
type_desc: desc::parse_opt_comma_list,
desc: "only allow the listed language features to be enabled in code (comma separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "always_encode_mir",
setter: dbopts::always_encode_mir,
type_desc: desc::parse_bool,
desc: "encode MIR of all functions into the crate metadata (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "annotate_moves",
setter: dbopts::annotate_moves,
type_desc: desc::parse_annotate_moves,
desc: "emit debug info for compiler-generated move and copy operations \
to make them visible in profilers. Can be a boolean or a size limit in bytes (default: disabled)",
removed: None,
tmod: None,
},
OptionDesc {
name: "assert_incr_state",
setter: dbopts::assert_incr_state,
type_desc: desc::parse_assert_incr_state,
desc: "assert that the incremental cache is in given state: \
either `loaded` or `not-loaded`.",
removed: None,
tmod: None,
},
OptionDesc {
name: "assume_incomplete_release",
setter: dbopts::assume_incomplete_release,
type_desc: desc::parse_bool,
desc: "make cfg(version) treat the current version as incomplete (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "autodiff",
setter: dbopts::autodiff,
type_desc: desc::parse_autodiff,
desc: "a list of autodiff flags to enable
Mandatory setting:
`=Enable`
Optional extra settings:
`=PrintTA`
`=PrintAA`
`=PrintPerf`
`=PrintSteps`
`=PrintModBefore`
`=PrintModAfter`
`=PrintModFinal`
`=PrintPasses`,
`=NoPostopt`
`=LooseTypes`
`=Inline`
Multiple options can be combined with commas.",
removed: None,
tmod: None,
},
OptionDesc {
name: "binary_dep_depinfo",
setter: dbopts::binary_dep_depinfo,
type_desc: desc::parse_bool,
desc: "include artifacts (sysroot, crate dependencies) used during compilation in dep-info \
(default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "box_noalias",
setter: dbopts::box_noalias,
type_desc: desc::parse_bool,
desc: "emit noalias metadata for box (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "branch_protection",
setter: dbopts::branch_protection,
type_desc: desc::parse_branch_protection,
desc: "set options for branch target identification and pointer authentication on AArch64",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::branch_protection)),
},
OptionDesc {
name: "build_sdylib_interface",
setter: dbopts::build_sdylib_interface,
type_desc: desc::parse_bool,
desc: "whether the stable interface is being built",
removed: None,
tmod: None,
},
OptionDesc {
name: "cache_proc_macros",
setter: dbopts::cache_proc_macros,
type_desc: desc::parse_bool,
desc: "cache the results of derive proc macro invocations (potentially unsound!) (default: no",
removed: None,
tmod: None,
},
OptionDesc {
name: "cf_protection",
setter: dbopts::cf_protection,
type_desc: desc::parse_cfprotection,
desc: "instrument control-flow architecture protection",
removed: None,
tmod: None,
},
OptionDesc {
name: "check_cfg_all_expected",
setter: dbopts::check_cfg_all_expected,
type_desc: desc::parse_bool,
desc: "show all expected values in check-cfg diagnostics (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "checksum_hash_algorithm",
setter: dbopts::checksum_hash_algorithm,
type_desc: desc::parse_cargo_src_file_hash,
desc: "hash algorithm of source files used to check freshness in cargo (`blake3` or `sha256`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "codegen_backend",
setter: dbopts::codegen_backend,
type_desc: desc::parse_opt_string,
desc: "the backend to use",
removed: None,
tmod: None,
},
OptionDesc {
name: "codegen_source_order",
setter: dbopts::codegen_source_order,
type_desc: desc::parse_bool,
desc: "emit mono items in the order of spans in source files (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "contract_checks",
setter: dbopts::contract_checks,
type_desc: desc::parse_opt_bool,
desc: "emit runtime checks for contract pre- and post-conditions (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "coverage_options",
setter: dbopts::coverage_options,
type_desc: desc::parse_coverage_options,
desc: "control details of coverage instrumentation",
removed: None,
tmod: None,
},
OptionDesc {
name: "crate_attr",
setter: dbopts::crate_attr,
type_desc: desc::parse_string_push,
desc: "inject the given attribute in the crate",
removed: None,
tmod: None,
},
OptionDesc {
name: "cross_crate_inline_threshold",
setter: dbopts::cross_crate_inline_threshold,
type_desc: desc::parse_inlining_threshold,
desc: "threshold to allow cross crate inlining of functions",
removed: None,
tmod: None,
},
OptionDesc {
name: "debug_info_for_profiling",
setter: dbopts::debug_info_for_profiling,
type_desc: desc::parse_bool,
desc: "emit discriminators and other data necessary for AutoFDO",
removed: None,
tmod: None,
},
OptionDesc {
name: "debug_info_type_line_numbers",
setter: dbopts::debug_info_type_line_numbers,
type_desc: desc::parse_bool,
desc: "emit type and line information for additional data types (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "debuginfo_compression",
setter: dbopts::debuginfo_compression,
type_desc: desc::parse_debuginfo_compression,
desc: "compress debug info sections (none, zlib, zstd, default: none)",
removed: None,
tmod: None,
},
OptionDesc {
name: "deduplicate_diagnostics",
setter: dbopts::deduplicate_diagnostics,
type_desc: desc::parse_bool,
desc: "deduplicate identical diagnostics (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "default_visibility",
setter: dbopts::default_visibility,
type_desc: desc::parse_opt_symbol_visibility,
desc: "overrides the `default_visibility` setting of the target",
removed: None,
tmod: None,
},
OptionDesc {
name: "dep_info_omit_d_target",
setter: dbopts::dep_info_omit_d_target,
type_desc: desc::parse_bool,
desc: "in dep-info output, omit targets for tracking dependencies of the dep-info files \
themselves (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "direct_access_external_data",
setter: dbopts::direct_access_external_data,
type_desc: desc::parse_opt_bool,
desc: "Direct or use GOT indirect to reference external data symbols",
removed: None,
tmod: None,
},
OptionDesc {
name: "dual_proc_macros",
setter: dbopts::dual_proc_macros,
type_desc: desc::parse_bool,
desc: "load proc macros for both target and host, but only link to the target (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_dep_graph",
setter: dbopts::dump_dep_graph,
type_desc: desc::parse_bool,
desc: "dump the dependency graph to $RUST_DEP_GRAPH (default: /tmp/dep_graph.gv) \
(default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_mir",
setter: dbopts::dump_mir,
type_desc: desc::parse_opt_string,
desc: "dump MIR state to file.
`val` is used to select which passes and functions to dump. For example:
`all` matches all passes and functions,
`foo` matches all passes for functions whose name contains 'foo',
`foo & ConstProp` only the 'ConstProp' pass for function names containing 'foo',
`foo | bar` all passes for function names containing 'foo' or 'bar'.",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_mir_dataflow",
setter: dbopts::dump_mir_dataflow,
type_desc: desc::parse_bool,
desc: "in addition to `.mir` files, create graphviz `.dot` files with dataflow results \
(default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_mir_dir",
setter: dbopts::dump_mir_dir,
type_desc: desc::parse_string,
desc: "the directory the MIR is dumped into (default: `mir_dump`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_mir_exclude_alloc_bytes",
setter: dbopts::dump_mir_exclude_alloc_bytes,
type_desc: desc::parse_bool,
desc: "exclude the raw bytes of allocations when dumping MIR (used in tests) (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_mir_exclude_pass_number",
setter: dbopts::dump_mir_exclude_pass_number,
type_desc: desc::parse_bool,
desc: "exclude the pass number when dumping MIR (used in tests) (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_mir_graphviz",
setter: dbopts::dump_mir_graphviz,
type_desc: desc::parse_bool,
desc: "in addition to `.mir` files, create graphviz `.dot` files (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_mono_stats",
setter: dbopts::dump_mono_stats,
type_desc: desc::parse_switch_with_opt_path,
desc: "output statistics about monomorphization collection",
removed: None,
tmod: None,
},
OptionDesc {
name: "dump_mono_stats_format",
setter: dbopts::dump_mono_stats_format,
type_desc: desc::parse_dump_mono_stats,
desc: "the format to use for -Z dump-mono-stats (`markdown` (default) or `json`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dwarf_version",
setter: dbopts::dwarf_version,
type_desc: desc::parse_opt_number,
desc: "version of DWARF debug information to emit (default: 2 or 4, depending on platform)",
removed: None,
tmod: None,
},
OptionDesc {
name: "dylib_lto",
setter: dbopts::dylib_lto,
type_desc: desc::parse_bool,
desc: "enables LTO for dylib crate type",
removed: None,
tmod: None,
},
OptionDesc {
name: "eagerly_emit_delayed_bugs",
setter: dbopts::eagerly_emit_delayed_bugs,
type_desc: desc::parse_bool,
desc: "emit delayed bugs eagerly as errors instead of stashing them and emitting \
them only if an error has not been emitted",
removed: None,
tmod: None,
},
OptionDesc {
name: "ehcont_guard",
setter: dbopts::ehcont_guard,
type_desc: desc::parse_bool,
desc: "generate Windows EHCont Guard tables",
removed: None,
tmod: None,
},
OptionDesc {
name: "embed_metadata",
setter: dbopts::embed_metadata,
type_desc: desc::parse_bool,
desc: "embed metadata in rlibs and dylibs (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "embed_source",
setter: dbopts::embed_source,
type_desc: desc::parse_bool,
desc: "embed source text in DWARF debug sections (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "emit_stack_sizes",
setter: dbopts::emit_stack_sizes,
type_desc: desc::parse_bool,
desc: "emit a section containing stack size metadata (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "emscripten_wasm_eh",
setter: dbopts::emscripten_wasm_eh,
type_desc: desc::parse_bool,
desc: "Use WebAssembly error handling for wasm32-unknown-emscripten",
removed: None,
tmod: None,
},
OptionDesc {
name: "enforce_type_length_limit",
setter: dbopts::enforce_type_length_limit,
type_desc: desc::parse_bool,
desc: "enforce the type length limit when monomorphizing instances in codegen",
removed: None,
tmod: None,
},
OptionDesc {
name: "experimental_default_bounds",
setter: dbopts::experimental_default_bounds,
type_desc: desc::parse_bool,
desc: "enable default bounds for experimental group of auto traits",
removed: None,
tmod: None,
},
OptionDesc {
name: "export_executable_symbols",
setter: dbopts::export_executable_symbols,
type_desc: desc::parse_bool,
desc: "export symbols from executables, as if they were dynamic libraries",
removed: None,
tmod: None,
},
OptionDesc {
name: "external_clangrt",
setter: dbopts::external_clangrt,
type_desc: desc::parse_bool,
desc: "rely on user specified linker commands to find clangrt",
removed: None,
tmod: None,
},
OptionDesc {
name: "extra_const_ub_checks",
setter: dbopts::extra_const_ub_checks,
type_desc: desc::parse_bool,
desc: "turns on more checks to detect const UB, which can be slow (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "fewer_names",
setter: dbopts::fewer_names,
type_desc: desc::parse_opt_bool,
desc: "reduce memory use by retaining fewer names within compilation artifacts (LLVM-IR) \
(default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "fixed_x18",
setter: dbopts::fixed_x18,
type_desc: desc::parse_bool,
desc: "make the x18 register reserved on AArch64 (default: no)",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::fixed_x18)),
},
OptionDesc {
name: "flatten_format_args",
setter: dbopts::flatten_format_args,
type_desc: desc::parse_bool,
desc: "flatten nested format_args!() and literals into a simplified format_args!() call \
(default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "fmt_debug",
setter: dbopts::fmt_debug,
type_desc: desc::parse_fmt_debug,
desc: "how detailed `#[derive(Debug)]` should be. `full` prints types recursively, \
`shallow` prints only type names, `none` prints nothing and disables `{:?}`. (default: `full`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "force_unstable_if_unmarked",
setter: dbopts::force_unstable_if_unmarked,
type_desc: desc::parse_bool,
desc: "force all crates to be `rustc_private` unstable (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "function_return",
setter: dbopts::function_return,
type_desc: desc::parse_function_return,
desc: "replace returns with jumps to `__x86_return_thunk` (default: `keep`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "function_sections",
setter: dbopts::function_sections,
type_desc: desc::parse_opt_bool,
desc: "whether each function should go in its own section",
removed: None,
tmod: None,
},
OptionDesc {
name: "future_incompat_test",
setter: dbopts::future_incompat_test,
type_desc: desc::parse_bool,
desc: "forces all lints to be future incompatible, used for internal testing (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "graphviz_dark_mode",
setter: dbopts::graphviz_dark_mode,
type_desc: desc::parse_bool,
desc: "use dark-themed colors in graphviz output (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "graphviz_font",
setter: dbopts::graphviz_font,
type_desc: desc::parse_string,
desc: "use the given `fontname` in graphviz output; can be overridden by setting \
environment variable `RUSTC_GRAPHVIZ_FONT` (default: `Courier, monospace`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "has_thread_local",
setter: dbopts::has_thread_local,
type_desc: desc::parse_opt_bool,
desc: "explicitly enable the `cfg(target_thread_local)` directive",
removed: None,
tmod: None,
},
OptionDesc {
name: "help",
setter: dbopts::help,
type_desc: desc::parse_no_value,
desc: "Print unstable compiler options",
removed: None,
tmod: None,
},
OptionDesc {
name: "higher_ranked_assumptions",
setter: dbopts::higher_ranked_assumptions,
type_desc: desc::parse_bool,
desc: "allow deducing higher-ranked outlives assumptions from coroutines when proving auto traits",
removed: None,
tmod: None,
},
OptionDesc {
name: "hint_mostly_unused",
setter: dbopts::hint_mostly_unused,
type_desc: desc::parse_bool,
desc: "hint that most of this crate will go unused, to minimize work for uncalled functions",
removed: None,
tmod: None,
},
OptionDesc {
name: "human_readable_cgu_names",
setter: dbopts::human_readable_cgu_names,
type_desc: desc::parse_bool,
desc: "generate human-readable, predictable names for codegen units (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "identify_regions",
setter: dbopts::identify_regions,
type_desc: desc::parse_bool,
desc: "display unnamed regions as `'<id>`, using a non-ident unique id (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "ignore_directory_in_diagnostics_source_blocks",
setter: dbopts::ignore_directory_in_diagnostics_source_blocks,
type_desc: desc::parse_string_push,
desc: "do not display the source code block in diagnostics for files in the directory",
removed: None,
tmod: None,
},
OptionDesc {
name: "incremental_ignore_spans",
setter: dbopts::incremental_ignore_spans,
type_desc: desc::parse_bool,
desc: "ignore spans during ICH computation -- used for testing (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "incremental_info",
setter: dbopts::incremental_info,
type_desc: desc::parse_bool,
desc: "print high-level information about incremental reuse (or the lack thereof) \
(default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "incremental_verify_ich",
setter: dbopts::incremental_verify_ich,
type_desc: desc::parse_bool,
desc: "verify extended properties for incr. comp. (default: no):
- hashes of green query instances
- hash collisions of query keys
- hash collisions when creating dep-nodes",
removed: None,
tmod: None,
},
OptionDesc {
name: "indirect_branch_cs_prefix",
setter: dbopts::indirect_branch_cs_prefix,
type_desc: desc::parse_bool,
desc: "add `cs` prefix to `call` and `jmp` to indirect thunks (default: no)",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::indirect_branch_cs_prefix)),
},
OptionDesc {
name: "inline_llvm",
setter: dbopts::inline_llvm,
type_desc: desc::parse_bool,
desc: "enable LLVM inlining (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "inline_mir",
setter: dbopts::inline_mir,
type_desc: desc::parse_opt_bool,
desc: "enable MIR inlining (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "inline_mir_forwarder_threshold",
setter: dbopts::inline_mir_forwarder_threshold,
type_desc: desc::parse_opt_number,
desc: "inlining threshold when the caller is a simple forwarding function (default: 30)",
removed: None,
tmod: None,
},
OptionDesc {
name: "inline_mir_hint_threshold",
setter: dbopts::inline_mir_hint_threshold,
type_desc: desc::parse_opt_number,
desc: "inlining threshold for functions with inline hint (default: 100)",
removed: None,
tmod: None,
},
OptionDesc {
name: "inline_mir_preserve_debug",
setter: dbopts::inline_mir_preserve_debug,
type_desc: desc::parse_opt_bool,
desc: "when MIR inlining, whether to preserve debug info for callee variables \
(default: preserve for debuginfo != None, otherwise remove)",
removed: None,
tmod: None,
},
OptionDesc {
name: "inline_mir_threshold",
setter: dbopts::inline_mir_threshold,
type_desc: desc::parse_opt_number,
desc: "a default MIR inlining threshold (default: 50)",
removed: None,
tmod: None,
},
OptionDesc {
name: "input_stats",
setter: dbopts::input_stats,
type_desc: desc::parse_bool,
desc: "print some statistics about AST and HIR (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "instrument_mcount",
setter: dbopts::instrument_mcount,
type_desc: desc::parse_bool,
desc: "insert function instrument code for mcount-based tracing (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "instrument_xray",
setter: dbopts::instrument_xray,
type_desc: desc::parse_instrument_xray,
desc: "insert function instrument code for XRay-based tracing (default: no)
Optional extra settings:
`=always`
`=never`
`=ignore-loops`
`=instruction-threshold=N`
`=skip-entry`
`=skip-exit`
Multiple options can be combined with commas.",
removed: None,
tmod: None,
},
OptionDesc {
name: "large_data_threshold",
setter: dbopts::large_data_threshold,
type_desc: desc::parse_opt_number,
desc: "set the threshold for objects to be stored in a \"large data\" section \
(only effective with -Ccode-model=medium, default: 65536)",
removed: None,
tmod: None,
},
OptionDesc {
name: "layout_seed",
setter: dbopts::layout_seed,
type_desc: desc::parse_opt_number,
desc: "seed layout randomization",
removed: None,
tmod: None,
},
OptionDesc {
name: "link_directives",
setter: dbopts::link_directives,
type_desc: desc::parse_bool,
desc: "honor #[link] directives in the compiled crate (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "link_native_libraries",
setter: dbopts::link_native_libraries,
type_desc: desc::parse_bool,
desc: "link native libraries in the linker invocation (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "link_only",
setter: dbopts::link_only,
type_desc: desc::parse_bool,
desc: "link the `.rlink` file generated by `-Z no-link` (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "lint_llvm_ir",
setter: dbopts::lint_llvm_ir,
type_desc: desc::parse_bool,
desc: "lint LLVM IR (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "lint_mir",
setter: dbopts::lint_mir,
type_desc: desc::parse_bool,
desc: "lint MIR before and after each transformation",
removed: None,
tmod: None,
},
OptionDesc {
name: "llvm_module_flag",
setter: dbopts::llvm_module_flag,
type_desc: desc::parse_llvm_module_flag,
desc: "a list of module flags to pass to LLVM (space separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "llvm_plugins",
setter: dbopts::llvm_plugins,
type_desc: desc::parse_list,
desc: "a list LLVM plugins to enable (space separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "llvm_time_trace",
setter: dbopts::llvm_time_trace,
type_desc: desc::parse_bool,
desc: "generate JSON tracing data file from LLVM data (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "location_detail",
setter: dbopts::location_detail,
type_desc: desc::parse_location_detail,
desc: "what location details should be tracked when using caller_location, either \
`none`, or a comma separated list of location details, for which \
valid options are `file`, `line`, and `column` (default: `file,line,column`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "ls",
setter: dbopts::ls,
type_desc: desc::parse_list,
desc: "decode and print various parts of the crate metadata for a library crate \
(space separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "macro_backtrace",
setter: dbopts::macro_backtrace,
type_desc: desc::parse_bool,
desc: "show macro backtraces (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "macro_stats",
setter: dbopts::macro_stats,
type_desc: desc::parse_bool,
desc: "print some statistics about macro expansions (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "maximal_hir_to_mir_coverage",
setter: dbopts::maximal_hir_to_mir_coverage,
type_desc: desc::parse_bool,
desc: "save as much information as possible about the correspondence between MIR and HIR \
as source scopes (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "merge_functions",
setter: dbopts::merge_functions,
type_desc: desc::parse_merge_functions,
desc: "control the operation of the MergeFunctions LLVM pass, taking \
the same values as the target option of the same name",
removed: None,
tmod: None,
},
OptionDesc {
name: "meta_stats",
setter: dbopts::meta_stats,
type_desc: desc::parse_bool,
desc: "gather metadata statistics (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "metrics_dir",
setter: dbopts::metrics_dir,
type_desc: desc::parse_opt_pathbuf,
desc: "the directory metrics emitted by rustc are dumped into (implicitly enables default set of metrics)",
removed: None,
tmod: None,
},
OptionDesc {
name: "min_function_alignment",
setter: dbopts::min_function_alignment,
type_desc: desc::parse_align,
desc: "align all functions to at least this many bytes. Must be a power of 2",
removed: None,
tmod: None,
},
OptionDesc {
name: "min_recursion_limit",
setter: dbopts::min_recursion_limit,
type_desc: desc::parse_opt_number,
desc: "set a minimum recursion limit (final limit = max(this, recursion_limit_from_crate))",
removed: None,
tmod: None,
},
OptionDesc {
name: "mir_emit_retag",
setter: dbopts::mir_emit_retag,
type_desc: desc::parse_bool,
desc: "emit Retagging MIR statements, interpreted e.g., by miri; implies -Zmir-opt-level=0 \
(default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "mir_enable_passes",
setter: dbopts::mir_enable_passes,
type_desc: desc::parse_list_with_polarity,
desc: "use like `-Zmir-enable-passes=+DestinationPropagation,-InstSimplify`. Forces the \
specified passes to be enabled, overriding all other checks. In particular, this will \
enable unsound (known-buggy and hence usually disabled) passes without further warning! \
Passes that are not specified are enabled or disabled by other flags as usual.",
removed: None,
tmod: None,
},
OptionDesc {
name: "mir_include_spans",
setter: dbopts::mir_include_spans,
type_desc: desc::parse_mir_include_spans,
desc: "include extra comments in mir pretty printing, like line numbers and statement indices, \
details about types, etc. (boolean for all passes, 'nll' to enable in NLL MIR only, default: 'nll')",
removed: None,
tmod: None,
},
OptionDesc {
name: "mir_opt_bisect_limit",
setter: dbopts::mir_opt_bisect_limit,
type_desc: desc::parse_opt_number,
desc: "limit the number of MIR optimization pass executions (global across all bodies). \
Pass executions after this limit are skipped and reported. (default: no limit)",
removed: None,
tmod: None,
},
OptionDesc {
name: "mir_opt_level",
setter: dbopts::mir_opt_level,
type_desc: desc::parse_opt_number,
desc: "MIR optimization level (0-4; default: 1 in non optimized builds and 2 in optimized builds)",
removed: None,
tmod: None,
},
OptionDesc {
name: "mir_preserve_ub",
setter: dbopts::mir_preserve_ub,
type_desc: desc::parse_bool,
desc: "keep place mention statements and reads in trivial SwitchInt terminators, which are interpreted \
e.g., by miri; implies -Zmir-opt-level=0 (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "mir_strip_debuginfo",
setter: dbopts::mir_strip_debuginfo,
type_desc: desc::parse_mir_strip_debuginfo,
desc: "Whether to remove some of the MIR debug info from methods. Default: None",
removed: None,
tmod: None,
},
OptionDesc {
name: "move_size_limit",
setter: dbopts::move_size_limit,
type_desc: desc::parse_opt_number,
desc: "the size at which the `large_assignments` lint starts to be emitted",
removed: None,
tmod: None,
},
OptionDesc {
name: "mutable_noalias",
setter: dbopts::mutable_noalias,
type_desc: desc::parse_bool,
desc: "emit noalias metadata for mutable references (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "namespaced_crates",
setter: dbopts::namespaced_crates,
type_desc: desc::parse_bool,
desc: "allow crates to be namespaced by other crates (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "next_solver",
setter: dbopts::next_solver,
type_desc: desc::parse_next_solver_config,
desc: "enable and configure the next generation trait solver used by rustc",
removed: None,
tmod: None,
},
OptionDesc {
name: "nll_facts",
setter: dbopts::nll_facts,
type_desc: desc::parse_bool,
desc: "dump facts from NLL analysis into side files (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "nll_facts_dir",
setter: dbopts::nll_facts_dir,
type_desc: desc::parse_string,
desc: "the directory the NLL facts are dumped into (default: `nll-facts`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_analysis",
setter: dbopts::no_analysis,
type_desc: desc::parse_no_value,
desc: "parse and expand the source, but run no analysis",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_codegen",
setter: dbopts::no_codegen,
type_desc: desc::parse_no_value,
desc: "run all passes except codegen; no output",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_generate_arange_section",
setter: dbopts::no_generate_arange_section,
type_desc: desc::parse_no_value,
desc: "omit DWARF address ranges that give faster lookups",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_implied_bounds_compat",
setter: dbopts::no_implied_bounds_compat,
type_desc: desc::parse_bool,
desc: "disable the compatibility version of the `implied_bounds_ty` query",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_leak_check",
setter: dbopts::no_leak_check,
type_desc: desc::parse_no_value,
desc: "disable the 'leak check' for subtyping; unsound, but useful for tests",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_link",
setter: dbopts::no_link,
type_desc: desc::parse_no_value,
desc: "compile without linking",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_parallel_backend",
setter: dbopts::no_parallel_backend,
type_desc: desc::parse_no_value,
desc: "run LLVM in non-parallel mode (while keeping codegen-units and ThinLTO)",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_profiler_runtime",
setter: dbopts::no_profiler_runtime,
type_desc: desc::parse_no_value,
desc: "prevent automatic injection of the profiler_builtins crate",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_steal_thir",
setter: dbopts::no_steal_thir,
type_desc: desc::parse_bool,
desc: "don't steal the THIR when we're done with it; useful for rustc drivers (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_trait_vptr",
setter: dbopts::no_trait_vptr,
type_desc: desc::parse_no_value,
desc: "disable generation of trait vptr in vtable for upcasting",
removed: None,
tmod: None,
},
OptionDesc {
name: "no_unique_section_names",
setter: dbopts::no_unique_section_names,
type_desc: desc::parse_bool,
desc: "do not use unique names for text and data sections when -Z function-sections is used",
removed: None,
tmod: None,
},
OptionDesc {
name: "normalize_docs",
setter: dbopts::normalize_docs,
type_desc: desc::parse_bool,
desc: "normalize associated items in rustdoc when generating documentation",
removed: None,
tmod: None,
},
OptionDesc {
name: "offload",
setter: dbopts::offload,
type_desc: desc::parse_offload,
desc: "a list of offload flags to enable
Mandatory setting:
`=Enable`
Currently the only option available",
removed: None,
tmod: None,
},
OptionDesc {
name: "on_broken_pipe",
setter: dbopts::on_broken_pipe,
type_desc: desc::parse_on_broken_pipe,
desc: "behavior of std::io::ErrorKind::BrokenPipe (SIGPIPE)",
removed: None,
tmod: None,
},
OptionDesc {
name: "osx_rpath_install_name",
setter: dbopts::osx_rpath_install_name,
type_desc: desc::parse_bool,
desc: "pass `-install_name @rpath/...` to the macOS linker (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "packed_bundled_libs",
setter: dbopts::packed_bundled_libs,
type_desc: desc::parse_bool,
desc: "change rlib format to store native libraries as archives",
removed: None,
tmod: None,
},
OptionDesc {
name: "packed_stack",
setter: dbopts::packed_stack,
type_desc: desc::parse_bool,
desc: "use packed stack frames (s390x only) (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "panic_abort_tests",
setter: dbopts::panic_abort_tests,
type_desc: desc::parse_bool,
desc: "support compiling tests with panic=abort (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "panic_in_drop",
setter: dbopts::panic_in_drop,
type_desc: desc::parse_panic_strategy,
desc: "panic strategy for panics in drops",
removed: None,
tmod: None,
},
OptionDesc {
name: "parse_crate_root_only",
setter: dbopts::parse_crate_root_only,
type_desc: desc::parse_bool,
desc: "parse the crate root file only; do not parse other files, compile, assemble, or link \
(default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "patchable_function_entry",
setter: dbopts::patchable_function_entry,
type_desc: desc::parse_patchable_function_entry,
desc: "nop padding at function entry",
removed: None,
tmod: None,
},
OptionDesc {
name: "plt",
setter: dbopts::plt,
type_desc: desc::parse_opt_bool,
desc: "whether to use the PLT when calling into shared libraries;
only has effect for PIC code on systems with ELF binaries
(default: PLT is disabled if full relro is enabled on x86_64)",
removed: None,
tmod: None,
},
OptionDesc {
name: "polonius",
setter: dbopts::polonius,
type_desc: desc::parse_polonius,
desc: "enable polonius-based borrow-checker (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "pre_link_arg",
setter: dbopts::pre_link_arg,
type_desc: desc::parse_string_push,
desc: "a single extra argument to prepend the linker invocation (can be used several times)",
removed: None,
tmod: None,
},
OptionDesc {
name: "pre_link_args",
setter: dbopts::pre_link_args,
type_desc: desc::parse_list,
desc: "extra arguments to prepend to the linker invocation (space separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "precise_enum_drop_elaboration",
setter: dbopts::precise_enum_drop_elaboration,
type_desc: desc::parse_bool,
desc: "use a more precise version of drop elaboration for matches on enums (default: yes). \
This results in better codegen, but has caused miscompilations on some tier 2 platforms. \
See #77382 and #74551.",
removed: None,
tmod: None,
},
OptionDesc {
name: "print_codegen_stats",
setter: dbopts::print_codegen_stats,
type_desc: desc::parse_bool,
desc: "print codegen statistics (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "print_llvm_passes",
setter: dbopts::print_llvm_passes,
type_desc: desc::parse_bool,
desc: "print the LLVM optimization passes being run (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "print_mono_items",
setter: dbopts::print_mono_items,
type_desc: desc::parse_bool,
desc: "print the result of the monomorphization collection pass (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "print_type_sizes",
setter: dbopts::print_type_sizes,
type_desc: desc::parse_bool,
desc: "print layout information for each type encountered (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "proc_macro_backtrace",
setter: dbopts::proc_macro_backtrace,
type_desc: desc::parse_bool,
desc: "show backtraces for panics during proc-macro execution (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "proc_macro_execution_strategy",
setter: dbopts::proc_macro_execution_strategy,
type_desc: desc::parse_proc_macro_execution_strategy,
desc: "how to run proc-macro code (default: same-thread)",
removed: None,
tmod: None,
},
OptionDesc {
name: "profile_closures",
setter: dbopts::profile_closures,
type_desc: desc::parse_no_value,
desc: "profile size of closures",
removed: None,
tmod: None,
},
OptionDesc {
name: "profile_sample_use",
setter: dbopts::profile_sample_use,
type_desc: desc::parse_opt_pathbuf,
desc: "use the given `.prof` file for sampled profile-guided optimization (also known as AutoFDO)",
removed: None,
tmod: None,
},
OptionDesc {
name: "profiler_runtime",
setter: dbopts::profiler_runtime,
type_desc: desc::parse_string,
desc: "name of the profiler runtime crate to automatically inject (default: `profiler_builtins`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "query_dep_graph",
setter: dbopts::query_dep_graph,
type_desc: desc::parse_bool,
desc: "enable queries of the dependency graph for regression testing (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "randomize_layout",
setter: dbopts::randomize_layout,
type_desc: desc::parse_bool,
desc: "randomize the layout of types (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "reg_struct_return",
setter: dbopts::reg_struct_return,
type_desc: desc::parse_bool,
desc: "On x86-32 targets, it overrides the default ABI to return small structs in registers.
It is UNSOUND to link together crates that use different values for this flag!",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::reg_struct_return)),
},
OptionDesc {
name: "regparm",
setter: dbopts::regparm,
type_desc: desc::parse_opt_number,
desc: "On x86-32 targets, setting this to N causes the compiler to pass N arguments \
in registers EAX, EDX, and ECX instead of on the stack for\
\"C\", \"cdecl\", and \"stdcall\" fn.\
It is UNSOUND to link together crates that use different values for this flag!",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::regparm)),
},
OptionDesc {
name: "relax_elf_relocations",
setter: dbopts::relax_elf_relocations,
type_desc: desc::parse_opt_bool,
desc: "whether ELF relocations can be relaxed",
removed: None,
tmod: None,
},
OptionDesc {
name: "remap_cwd_prefix",
setter: dbopts::remap_cwd_prefix,
type_desc: desc::parse_opt_pathbuf,
desc: "remap paths under the current working directory to this path prefix",
removed: None,
tmod: None,
},
OptionDesc {
name: "remark_dir",
setter: dbopts::remark_dir,
type_desc: desc::parse_opt_pathbuf,
desc: "directory into which to write optimization remarks (if not specified, they will be \
written to standard error output)",
removed: None,
tmod: None,
},
OptionDesc {
name: "retpoline",
setter: dbopts::retpoline,
type_desc: desc::parse_bool,
desc: "enables retpoline-indirect-branches and retpoline-indirect-calls target features (default: no)",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::retpoline)),
},
OptionDesc {
name: "retpoline_external_thunk",
setter: dbopts::retpoline_external_thunk,
type_desc: desc::parse_bool,
desc: "enables retpoline-external-thunk, retpoline-indirect-branches and retpoline-indirect-calls \
target features (default: no)",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::retpoline_external_thunk)),
},
OptionDesc {
name: "sanitizer",
setter: dbopts::sanitizer,
type_desc: desc::parse_sanitizers,
desc: "use a sanitizer",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::sanitizer)),
},
OptionDesc {
name: "sanitizer_cfi_canonical_jump_tables",
setter: dbopts::sanitizer_cfi_canonical_jump_tables,
type_desc: desc::parse_opt_bool,
desc: "enable canonical jump tables (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "sanitizer_cfi_generalize_pointers",
setter: dbopts::sanitizer_cfi_generalize_pointers,
type_desc: desc::parse_opt_bool,
desc: "enable generalizing pointer types (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "sanitizer_cfi_normalize_integers",
setter: dbopts::sanitizer_cfi_normalize_integers,
type_desc: desc::parse_opt_bool,
desc: "enable normalizing integer types (default: no)",
removed: None,
tmod: Some(OptionsTargetModifiers::UnstableOptions(UnstableOptionsTargetModifiers::sanitizer_cfi_normalize_integers)),
},
OptionDesc {
name: "sanitizer_dataflow_abilist",
setter: dbopts::sanitizer_dataflow_abilist,
type_desc: desc::parse_comma_list,
desc: "additional ABI list files that control how shadow parameters are passed (comma separated)",
removed: None,
tmod: None,
},
OptionDesc {
name: "sanitizer_kcfi_arity",
setter: dbopts::sanitizer_kcfi_arity,
type_desc: desc::parse_opt_bool,
desc: "enable KCFI arity indicator (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "sanitizer_memory_track_origins",
setter: dbopts::sanitizer_memory_track_origins,
type_desc: desc::parse_sanitizer_memory_track_origins,
desc: "enable origins tracking in MemorySanitizer",
removed: None,
tmod: None,
},
OptionDesc {
name: "sanitizer_recover",
setter: dbopts::sanitizer_recover,
type_desc: desc::parse_sanitizers,
desc: "enable recovery for selected sanitizers",
removed: None,
tmod: None,
},
OptionDesc {
name: "saturating_float_casts",
setter: dbopts::saturating_float_casts,
type_desc: desc::parse_opt_bool,
desc: "make float->int casts UB-free: numbers outside the integer type's range are clipped to \
the max/min integer respectively, and NaN is mapped to 0 (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "self_profile",
setter: dbopts::self_profile,
type_desc: desc::parse_switch_with_opt_path,
desc: "run the self profiler and output the raw event data",
removed: None,
tmod: None,
},
OptionDesc {
name: "self_profile_counter",
setter: dbopts::self_profile_counter,
type_desc: desc::parse_string,
desc: "counter used by the self profiler (default: `wall-time`), one of:
`wall-time` (monotonic clock, i.e. `std::time::Instant`)
`instructions:u` (retired instructions, userspace-only)
`instructions-minus-irqs:u` (subtracting hardware interrupt counts for extra accuracy)",
removed: None,
tmod: None,
},
OptionDesc {
name: "self_profile_events",
setter: dbopts::self_profile_events,
type_desc: desc::parse_opt_comma_list,
desc: "specify the events recorded by the self profiler;
for example: `-Z self-profile-events=default,query-keys`
all options: none, all, default, generic-activity, query-provider, query-cache-hit
query-blocked, incr-cache-load, incr-result-hashing, query-keys, function-args, args, llvm, artifact-sizes",
removed: None,
tmod: None,
},
OptionDesc {
name: "share_generics",
setter: dbopts::share_generics,
type_desc: desc::parse_opt_bool,
desc: "make the current crate share its generic instantiations",
removed: None,
tmod: None,
},
OptionDesc {
name: "shell_argfiles",
setter: dbopts::shell_argfiles,
type_desc: desc::parse_bool,
desc: "allow argument files to be specified with POSIX \"shell-style\" argument quoting",
removed: None,
tmod: None,
},
OptionDesc {
name: "simulate_remapped_rust_src_base",
setter: dbopts::simulate_remapped_rust_src_base,
type_desc: desc::parse_opt_pathbuf,
desc: "simulate the effect of remap-debuginfo = true at bootstrapping by remapping path \
to rust's source base directory. only meant for testing purposes",
removed: None,
tmod: None,
},
OptionDesc {
name: "small_data_threshold",
setter: dbopts::small_data_threshold,
type_desc: desc::parse_opt_number,
desc: "Set the threshold for objects to be stored in a \"small data\" section",
removed: None,
tmod: None,
},
OptionDesc {
name: "span_debug",
setter: dbopts::span_debug,
type_desc: desc::parse_bool,
desc: "forward proc_macro::Span's `Debug` impl to `Span`",
removed: None,
tmod: None,
},
OptionDesc {
name: "span_free_formats",
setter: dbopts::span_free_formats,
type_desc: desc::parse_bool,
desc: "exclude spans when debug-printing compiler state (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "split_dwarf_inlining",
setter: dbopts::split_dwarf_inlining,
type_desc: desc::parse_bool,
desc: "provide minimal debug info in the object/executable to facilitate online \
symbolication/stack traces in the absence of .dwo/.dwp files when using Split DWARF",
removed: None,
tmod: None,
},
OptionDesc {
name: "split_dwarf_kind",
setter: dbopts::split_dwarf_kind,
type_desc: desc::parse_split_dwarf_kind,
desc: "split dwarf variant (only if -Csplit-debuginfo is enabled and on relevant platform)
(default: `split`)
`split`: sections which do not require relocation are written into a DWARF object (`.dwo`)
file which is ignored by the linker
`single`: sections which do not require relocation are written into object file but ignored
by the linker",
removed: None,
tmod: None,
},
OptionDesc {
name: "split_dwarf_out_dir",
setter: dbopts::split_dwarf_out_dir,
type_desc: desc::parse_opt_pathbuf,
desc: "location for writing split DWARF objects (`.dwo`) if enabled",
removed: None,
tmod: None,
},
OptionDesc {
name: "split_lto_unit",
setter: dbopts::split_lto_unit,
type_desc: desc::parse_opt_bool,
desc: "enable LTO unit splitting (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "src_hash_algorithm",
setter: dbopts::src_hash_algorithm,
type_desc: desc::parse_src_file_hash,
desc: "hash algorithm of source files in debug info (`md5`, `sha1`, or `sha256`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "stack_protector",
setter: dbopts::stack_protector,
type_desc: desc::parse_stack_protector,
desc: "control stack smash protection strategy (`rustc --print stack-protector-strategies` for details)",
removed: None,
tmod: None,
},
OptionDesc {
name: "staticlib_allow_rdylib_deps",
setter: dbopts::staticlib_allow_rdylib_deps,
type_desc: desc::parse_bool,
desc: "allow staticlibs to have rust dylib dependencies",
removed: None,
tmod: None,
},
OptionDesc {
name: "staticlib_prefer_dynamic",
setter: dbopts::staticlib_prefer_dynamic,
type_desc: desc::parse_bool,
desc: "prefer dynamic linking to static linking for staticlibs (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "strict_init_checks",
setter: dbopts::strict_init_checks,
type_desc: desc::parse_bool,
desc: "control if mem::uninitialized and mem::zeroed panic on more UB",
removed: None,
tmod: None,
},
OptionDesc {
name: "teach",
setter: dbopts::teach,
type_desc: desc::parse_bool,
desc: "show extended diagnostic help (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "temps_dir",
setter: dbopts::temps_dir,
type_desc: desc::parse_opt_string,
desc: "the directory the intermediate files are written to",
removed: None,
tmod: None,
},
OptionDesc {
name: "terminal_urls",
setter: dbopts::terminal_urls,
type_desc: desc::parse_terminal_url,
desc: "use the OSC 8 hyperlink terminal specification to print hyperlinks in the compiler output",
removed: None,
tmod: None,
},
OptionDesc {
name: "thinlto",
setter: dbopts::thinlto,
type_desc: desc::parse_opt_bool,
desc: "enable ThinLTO when possible",
removed: None,
tmod: None,
},
OptionDesc {
name: "threads",
setter: dbopts::threads,
type_desc: desc::parse_threads,
desc: "use a thread pool with N threads",
removed: None,
tmod: None,
},
OptionDesc {
name: "time_llvm_passes",
setter: dbopts::time_llvm_passes,
type_desc: desc::parse_bool,
desc: "measure time of each LLVM pass (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "time_passes",
setter: dbopts::time_passes,
type_desc: desc::parse_bool,
desc: "measure time of each rustc pass (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "time_passes_format",
setter: dbopts::time_passes_format,
type_desc: desc::parse_time_passes_format,
desc: "the format to use for -Z time-passes (`text` (default) or `json`)",
removed: None,
tmod: None,
},
OptionDesc {
name: "tiny_const_eval_limit",
setter: dbopts::tiny_const_eval_limit,
type_desc: desc::parse_bool,
desc: "sets a tiny, non-configurable limit for const eval; useful for compiler tests",
removed: None,
tmod: None,
},
OptionDesc {
name: "tls_model",
setter: dbopts::tls_model,
type_desc: desc::parse_tls_model,
desc: "choose the TLS model to use (`rustc --print tls-models` for details)",
removed: None,
tmod: None,
},
OptionDesc {
name: "trace_macros",
setter: dbopts::trace_macros,
type_desc: desc::parse_bool,
desc: "for every macro invocation, print its name and arguments (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "track_diagnostics",
setter: dbopts::track_diagnostics,
type_desc: desc::parse_bool,
desc: "tracks where in rustc a diagnostic was emitted",
removed: None,
tmod: None,
},
OptionDesc {
name: "translate_remapped_path_to_local_path",
setter: dbopts::translate_remapped_path_to_local_path,
type_desc: desc::parse_bool,
desc: "translate remapped paths into local paths when possible (default: yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "trap_unreachable",
setter: dbopts::trap_unreachable,
type_desc: desc::parse_opt_bool,
desc: "generate trap instructions for unreachable intrinsics (default: use target setting, usually yes)",
removed: None,
tmod: None,
},
OptionDesc {
name: "treat_err_as_bug",
setter: dbopts::treat_err_as_bug,
type_desc: desc::parse_treat_err_as_bug,
desc: "treat the `val`th error that occurs as bug (default if not specified: 0 - don't treat errors as bugs. \
default if specified without a value: 1 - treat the first error as bug)",
removed: None,
tmod: None,
},
OptionDesc {
name: "trim_diagnostic_paths",
setter: dbopts::trim_diagnostic_paths,
type_desc: desc::parse_bool,
desc: "in diagnostics, use heuristics to shorten paths referring to items",
removed: None,
tmod: None,
},
OptionDesc {
name: "tune_cpu",
setter: dbopts::tune_cpu,
type_desc: desc::parse_opt_string,
desc: "select processor to schedule for (`rustc --print target-cpus` for details)",
removed: None,
tmod: None,
},
OptionDesc {
name: "typing_mode_borrowck",
setter: dbopts::typing_mode_borrowck,
type_desc: desc::parse_bool,
desc: "enable `TypingMode::Borrowck`, changing the way opaque types are handled during MIR borrowck",
removed: None,
tmod: None,
},
OptionDesc {
name: "ub_checks",
setter: dbopts::ub_checks,
type_desc: desc::parse_opt_bool,
desc: "emit runtime checks for Undefined Behavior (default: -Cdebug-assertions)",
removed: None,
tmod: None,
},
OptionDesc {
name: "ui_testing",
setter: dbopts::ui_testing,
type_desc: desc::parse_bool,
desc: "emit compiler diagnostics in a form suitable for UI testing (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "uninit_const_chunk_threshold",
setter: dbopts::uninit_const_chunk_threshold,
type_desc: desc::parse_number,
desc: "allow generating const initializers with mixed init/uninit chunks, \
and set the maximum number of chunks for which this is allowed (default: 16)",
removed: None,
tmod: None,
},
OptionDesc {
name: "unleash_the_miri_inside_of_you",
setter: dbopts::unleash_the_miri_inside_of_you,
type_desc: desc::parse_bool,
desc: "take the brakes off const evaluation. NOTE: this is unsound (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "unpretty",
setter: dbopts::unpretty,
type_desc: desc::parse_unpretty,
desc: "present the input source, unstable (and less-pretty) variants;
`normal`, `identified`,
`expanded`, `expanded,identified`,
`expanded,hygiene` (with internal representations),
`ast-tree` (raw AST before expansion),
`ast-tree,expanded` (raw AST after expansion),
`hir` (the HIR), `hir,identified`,
`hir,typed` (HIR with types for each node),
`hir-tree` (dump the raw HIR),
`thir-tree`, `thir-flat`,
`mir` (the MIR), or `mir-cfg` (graphviz formatted MIR)",
removed: None,
tmod: None,
},
OptionDesc {
name: "unsound_mir_opts",
setter: dbopts::unsound_mir_opts,
type_desc: desc::parse_bool,
desc: "enable unsound and buggy MIR optimizations (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "unstable_options",
setter: dbopts::unstable_options,
type_desc: desc::parse_no_value,
desc: "adds unstable command line options to rustc interface (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "use_ctors_section",
setter: dbopts::use_ctors_section,
type_desc: desc::parse_opt_bool,
desc: "use legacy .ctors section for initializers rather than .init_array",
removed: None,
tmod: None,
},
OptionDesc {
name: "use_sync_unwind",
setter: dbopts::use_sync_unwind,
type_desc: desc::parse_opt_bool,
desc: "Generate sync unwind tables instead of async unwind tables (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "validate_mir",
setter: dbopts::validate_mir,
type_desc: desc::parse_bool,
desc: "validate MIR after each transformation",
removed: None,
tmod: None,
},
OptionDesc {
name: "verbose_asm",
setter: dbopts::verbose_asm,
type_desc: desc::parse_bool,
desc: "add descriptive comments from LLVM to the assembly (may change behavior) (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "verbose_internals",
setter: dbopts::verbose_internals,
type_desc: desc::parse_bool,
desc: "in general, enable more debug printouts (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "verify_llvm_ir",
setter: dbopts::verify_llvm_ir,
type_desc: desc::parse_bool,
desc: "verify LLVM IR (default: no)",
removed: None,
tmod: None,
},
OptionDesc {
name: "virtual_function_elimination",
setter: dbopts::virtual_function_elimination,
type_desc: desc::parse_bool,
desc: "enables dead virtual function elimination optimization. \
Requires `-Clto[=[fat,yes]]`",
removed: None,
tmod: None,
},
OptionDesc {
name: "wasi_exec_model",
setter: dbopts::wasi_exec_model,
type_desc: desc::parse_wasi_exec_model,
desc: "whether to build a wasi command or reactor",
removed: None,
tmod: None,
},
OptionDesc {
name: "wasm_c_abi",
setter: dbopts::wasm_c_abi,
type_desc: desc::parse_wasm_c_abi,
desc: "use spec-compliant C ABI for `wasm32-unknown-unknown` (deprecated, always enabled)",
removed: None,
tmod: None,
},
OptionDesc {
name: "write_long_types_to_disk",
setter: dbopts::write_long_types_to_disk,
type_desc: desc::parse_bool,
desc: "whether long type names should be written to files instead of being printed in errors",
removed: None,
tmod: None,
}];
mod dbopts {
pub(super) fn allow_features(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_comma_list(&mut cg.allow_features, v)
}
pub(super) fn always_encode_mir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.always_encode_mir, v)
}
pub(super) fn annotate_moves(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_annotate_moves(&mut cg.annotate_moves, v)
}
pub(super) fn assert_incr_state(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_assert_incr_state(&mut cg.assert_incr_state, v)
}
pub(super) fn assume_incomplete_release(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.assume_incomplete_release, v)
}
pub(super) fn autodiff(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_autodiff(&mut cg.autodiff, v)
}
pub(super) fn binary_dep_depinfo(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.binary_dep_depinfo, v)
}
pub(super) fn box_noalias(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.box_noalias, v)
}
pub(super) fn branch_protection(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_branch_protection(&mut cg.branch_protection, v)
}
pub(super) fn build_sdylib_interface(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.build_sdylib_interface, v)
}
pub(super) fn cache_proc_macros(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.cache_proc_macros, v)
}
pub(super) fn cf_protection(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_cfprotection(&mut cg.cf_protection, v)
}
pub(super) fn check_cfg_all_expected(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.check_cfg_all_expected, v)
}
pub(super) fn checksum_hash_algorithm(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_cargo_src_file_hash(&mut cg.checksum_hash_algorithm,
v)
}
pub(super) fn codegen_backend(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_string(&mut cg.codegen_backend, v)
}
pub(super) fn codegen_source_order(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.codegen_source_order, v)
}
pub(super) fn contract_checks(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.contract_checks, v)
}
pub(super) fn coverage_options(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_coverage_options(&mut cg.coverage_options, v)
}
pub(super) fn crate_attr(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_string_push(&mut cg.crate_attr, v)
}
pub(super) fn cross_crate_inline_threshold(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_inlining_threshold(&mut cg.cross_crate_inline_threshold,
v)
}
pub(super) fn debug_info_for_profiling(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.debug_info_for_profiling, v)
}
pub(super) fn debug_info_type_line_numbers(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.debug_info_type_line_numbers, v)
}
pub(super) fn debuginfo_compression(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_debuginfo_compression(&mut cg.debuginfo_compression,
v)
}
pub(super) fn deduplicate_diagnostics(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.deduplicate_diagnostics, v)
}
pub(super) fn default_visibility(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_symbol_visibility(&mut cg.default_visibility,
v)
}
pub(super) fn dep_info_omit_d_target(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.dep_info_omit_d_target, v)
}
pub(super) fn direct_access_external_data(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.direct_access_external_data, v)
}
pub(super) fn dual_proc_macros(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.dual_proc_macros, v)
}
pub(super) fn dump_dep_graph(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.dump_dep_graph, v)
}
pub(super) fn dump_mir(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_string(&mut cg.dump_mir, v)
}
pub(super) fn dump_mir_dataflow(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.dump_mir_dataflow, v)
}
pub(super) fn dump_mir_dir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_string(&mut cg.dump_mir_dir, v)
}
pub(super) fn dump_mir_exclude_alloc_bytes(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.dump_mir_exclude_alloc_bytes, v)
}
pub(super) fn dump_mir_exclude_pass_number(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.dump_mir_exclude_pass_number, v)
}
pub(super) fn dump_mir_graphviz(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.dump_mir_graphviz, v)
}
pub(super) fn dump_mono_stats(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_switch_with_opt_path(&mut cg.dump_mono_stats, v)
}
pub(super) fn dump_mono_stats_format(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_dump_mono_stats(&mut cg.dump_mono_stats_format, v)
}
pub(super) fn dwarf_version(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.dwarf_version, v)
}
pub(super) fn dylib_lto(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.dylib_lto, v)
}
pub(super) fn eagerly_emit_delayed_bugs(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.eagerly_emit_delayed_bugs, v)
}
pub(super) fn ehcont_guard(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.ehcont_guard, v)
}
pub(super) fn embed_metadata(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.embed_metadata, v)
}
pub(super) fn embed_source(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.embed_source, v)
}
pub(super) fn emit_stack_sizes(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.emit_stack_sizes, v)
}
pub(super) fn emscripten_wasm_eh(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.emscripten_wasm_eh, v)
}
pub(super) fn enforce_type_length_limit(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.enforce_type_length_limit, v)
}
pub(super) fn experimental_default_bounds(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.experimental_default_bounds, v)
}
pub(super) fn export_executable_symbols(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.export_executable_symbols, v)
}
pub(super) fn external_clangrt(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.external_clangrt, v)
}
pub(super) fn extra_const_ub_checks(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.extra_const_ub_checks, v)
}
pub(super) fn fewer_names(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.fewer_names, v)
}
pub(super) fn fixed_x18(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.fixed_x18, v)
}
pub(super) fn flatten_format_args(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.flatten_format_args, v)
}
pub(super) fn fmt_debug(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_fmt_debug(&mut cg.fmt_debug, v)
}
pub(super) fn force_unstable_if_unmarked(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.force_unstable_if_unmarked, v)
}
pub(super) fn function_return(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_function_return(&mut cg.function_return, v)
}
pub(super) fn function_sections(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.function_sections, v)
}
pub(super) fn future_incompat_test(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.future_incompat_test, v)
}
pub(super) fn graphviz_dark_mode(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.graphviz_dark_mode, v)
}
pub(super) fn graphviz_font(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_string(&mut cg.graphviz_font, v)
}
pub(super) fn has_thread_local(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.has_thread_local, v)
}
pub(super) fn help(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_no_value(&mut cg.help, v)
}
pub(super) fn higher_ranked_assumptions(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.higher_ranked_assumptions, v)
}
pub(super) fn hint_mostly_unused(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.hint_mostly_unused, v)
}
pub(super) fn human_readable_cgu_names(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.human_readable_cgu_names, v)
}
pub(super) fn identify_regions(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.identify_regions, v)
}
pub(super) fn ignore_directory_in_diagnostics_source_blocks(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_string_push(&mut cg.ignore_directory_in_diagnostics_source_blocks,
v)
}
pub(super) fn incremental_ignore_spans(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.incremental_ignore_spans, v)
}
pub(super) fn incremental_info(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.incremental_info, v)
}
pub(super) fn incremental_verify_ich(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.incremental_verify_ich, v)
}
pub(super) fn indirect_branch_cs_prefix(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.indirect_branch_cs_prefix, v)
}
pub(super) fn inline_llvm(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.inline_llvm, v)
}
pub(super) fn inline_mir(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_bool(&mut cg.inline_mir, v)
}
pub(super) fn inline_mir_forwarder_threshold(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.inline_mir_forwarder_threshold,
v)
}
pub(super) fn inline_mir_hint_threshold(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.inline_mir_hint_threshold, v)
}
pub(super) fn inline_mir_preserve_debug(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.inline_mir_preserve_debug, v)
}
pub(super) fn inline_mir_threshold(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.inline_mir_threshold, v)
}
pub(super) fn input_stats(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.input_stats, v)
}
pub(super) fn instrument_mcount(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.instrument_mcount, v)
}
pub(super) fn instrument_xray(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_instrument_xray(&mut cg.instrument_xray, v)
}
pub(super) fn large_data_threshold(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.large_data_threshold, v)
}
pub(super) fn layout_seed(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.layout_seed, v)
}
pub(super) fn link_directives(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.link_directives, v)
}
pub(super) fn link_native_libraries(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.link_native_libraries, v)
}
pub(super) fn link_only(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.link_only, v)
}
pub(super) fn lint_llvm_ir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.lint_llvm_ir, v)
}
pub(super) fn lint_mir(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.lint_mir, v)
}
pub(super) fn llvm_module_flag(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_llvm_module_flag(&mut cg.llvm_module_flag, v)
}
pub(super) fn llvm_plugins(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_list(&mut cg.llvm_plugins, v)
}
pub(super) fn llvm_time_trace(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.llvm_time_trace, v)
}
pub(super) fn location_detail(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_location_detail(&mut cg.location_detail, v)
}
pub(super) fn ls(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_list(&mut cg.ls, v)
}
pub(super) fn macro_backtrace(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.macro_backtrace, v)
}
pub(super) fn macro_stats(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.macro_stats, v)
}
pub(super) fn maximal_hir_to_mir_coverage(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.maximal_hir_to_mir_coverage, v)
}
pub(super) fn merge_functions(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_merge_functions(&mut cg.merge_functions, v)
}
pub(super) fn meta_stats(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.meta_stats, v)
}
pub(super) fn metrics_dir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_pathbuf(&mut cg.metrics_dir, v)
}
pub(super) fn min_function_alignment(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_align(&mut cg.min_function_alignment, v)
}
pub(super) fn min_recursion_limit(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.min_recursion_limit, v)
}
pub(super) fn mir_emit_retag(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.mir_emit_retag, v)
}
pub(super) fn mir_enable_passes(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_list_with_polarity(&mut cg.mir_enable_passes, v)
}
pub(super) fn mir_include_spans(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_mir_include_spans(&mut cg.mir_include_spans, v)
}
pub(super) fn mir_opt_bisect_limit(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.mir_opt_bisect_limit, v)
}
pub(super) fn mir_opt_level(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.mir_opt_level, v)
}
pub(super) fn mir_preserve_ub(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.mir_preserve_ub, v)
}
pub(super) fn mir_strip_debuginfo(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_mir_strip_debuginfo(&mut cg.mir_strip_debuginfo,
v)
}
pub(super) fn move_size_limit(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.move_size_limit, v)
}
pub(super) fn mutable_noalias(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.mutable_noalias, v)
}
pub(super) fn namespaced_crates(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.namespaced_crates, v)
}
pub(super) fn next_solver(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_next_solver_config(&mut cg.next_solver, v)
}
pub(super) fn nll_facts(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.nll_facts, v)
}
pub(super) fn nll_facts_dir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_string(&mut cg.nll_facts_dir, v)
}
pub(super) fn no_analysis(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_analysis, v)
}
pub(super) fn no_codegen(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_no_value(&mut cg.no_codegen, v)
}
pub(super) fn no_generate_arange_section(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_generate_arange_section, v)
}
pub(super) fn no_implied_bounds_compat(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.no_implied_bounds_compat, v)
}
pub(super) fn no_leak_check(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_leak_check, v)
}
pub(super) fn no_link(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_no_value(&mut cg.no_link, v)
}
pub(super) fn no_parallel_backend(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_parallel_backend, v)
}
pub(super) fn no_profiler_runtime(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_profiler_runtime, v)
}
pub(super) fn no_steal_thir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.no_steal_thir, v)
}
pub(super) fn no_trait_vptr(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.no_trait_vptr, v)
}
pub(super) fn no_unique_section_names(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.no_unique_section_names, v)
}
pub(super) fn normalize_docs(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.normalize_docs, v)
}
pub(super) fn offload(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_offload(&mut cg.offload, v)
}
pub(super) fn on_broken_pipe(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_on_broken_pipe(&mut cg.on_broken_pipe, v)
}
pub(super) fn osx_rpath_install_name(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.osx_rpath_install_name, v)
}
pub(super) fn packed_bundled_libs(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.packed_bundled_libs, v)
}
pub(super) fn packed_stack(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.packed_stack, v)
}
pub(super) fn panic_abort_tests(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.panic_abort_tests, v)
}
pub(super) fn panic_in_drop(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_panic_strategy(&mut cg.panic_in_drop, v)
}
pub(super) fn parse_crate_root_only(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.parse_crate_root_only, v)
}
pub(super) fn patchable_function_entry(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_patchable_function_entry(&mut cg.patchable_function_entry,
v)
}
pub(super) fn plt(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_bool(&mut cg.plt, v)
}
pub(super) fn polonius(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_polonius(&mut cg.polonius, v)
}
pub(super) fn pre_link_arg(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_string_push(&mut cg.pre_link_args, v)
}
pub(super) fn pre_link_args(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_list(&mut cg.pre_link_args, v)
}
pub(super) fn precise_enum_drop_elaboration(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.precise_enum_drop_elaboration, v)
}
pub(super) fn print_codegen_stats(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.print_codegen_stats, v)
}
pub(super) fn print_llvm_passes(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.print_llvm_passes, v)
}
pub(super) fn print_mono_items(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.print_mono_items, v)
}
pub(super) fn print_type_sizes(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.print_type_sizes, v)
}
pub(super) fn proc_macro_backtrace(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.proc_macro_backtrace, v)
}
pub(super) fn proc_macro_execution_strategy(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_proc_macro_execution_strategy(&mut cg.proc_macro_execution_strategy,
v)
}
pub(super) fn profile_closures(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.profile_closures, v)
}
pub(super) fn profile_sample_use(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_pathbuf(&mut cg.profile_sample_use, v)
}
pub(super) fn profiler_runtime(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_string(&mut cg.profiler_runtime, v)
}
pub(super) fn query_dep_graph(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.query_dep_graph, v)
}
pub(super) fn randomize_layout(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.randomize_layout, v)
}
pub(super) fn reg_struct_return(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.reg_struct_return, v)
}
pub(super) fn regparm(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_number(&mut cg.regparm, v)
}
pub(super) fn relax_elf_relocations(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.relax_elf_relocations, v)
}
pub(super) fn remap_cwd_prefix(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_pathbuf(&mut cg.remap_cwd_prefix, v)
}
pub(super) fn remark_dir(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_pathbuf(&mut cg.remark_dir, v)
}
pub(super) fn retpoline(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.retpoline, v)
}
pub(super) fn retpoline_external_thunk(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.retpoline_external_thunk, v)
}
pub(super) fn sanitizer(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_sanitizers(&mut cg.sanitizer, v)
}
pub(super) fn sanitizer_cfi_canonical_jump_tables(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.sanitizer_cfi_canonical_jump_tables,
v)
}
pub(super) fn sanitizer_cfi_generalize_pointers(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.sanitizer_cfi_generalize_pointers,
v)
}
pub(super) fn sanitizer_cfi_normalize_integers(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.sanitizer_cfi_normalize_integers,
v)
}
pub(super) fn sanitizer_dataflow_abilist(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_comma_list(&mut cg.sanitizer_dataflow_abilist, v)
}
pub(super) fn sanitizer_kcfi_arity(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.sanitizer_kcfi_arity, v)
}
pub(super) fn sanitizer_memory_track_origins(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_sanitizer_memory_track_origins(&mut cg.sanitizer_memory_track_origins,
v)
}
pub(super) fn sanitizer_recover(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_sanitizers(&mut cg.sanitizer_recover, v)
}
pub(super) fn saturating_float_casts(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.saturating_float_casts, v)
}
pub(super) fn self_profile(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_switch_with_opt_path(&mut cg.self_profile, v)
}
pub(super) fn self_profile_counter(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_string(&mut cg.self_profile_counter, v)
}
pub(super) fn self_profile_events(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_comma_list(&mut cg.self_profile_events, v)
}
pub(super) fn share_generics(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.share_generics, v)
}
pub(super) fn shell_argfiles(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.shell_argfiles, v)
}
pub(super) fn simulate_remapped_rust_src_base(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_opt_pathbuf(&mut cg.simulate_remapped_rust_src_base,
v)
}
pub(super) fn small_data_threshold(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_number(&mut cg.small_data_threshold, v)
}
pub(super) fn span_debug(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.span_debug, v)
}
pub(super) fn span_free_formats(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.span_free_formats, v)
}
pub(super) fn split_dwarf_inlining(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.split_dwarf_inlining, v)
}
pub(super) fn split_dwarf_kind(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_split_dwarf_kind(&mut cg.split_dwarf_kind, v)
}
pub(super) fn split_dwarf_out_dir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_pathbuf(&mut cg.split_dwarf_out_dir, v)
}
pub(super) fn split_lto_unit(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.split_lto_unit, v)
}
pub(super) fn src_hash_algorithm(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_src_file_hash(&mut cg.src_hash_algorithm, v)
}
pub(super) fn stack_protector(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_stack_protector(&mut cg.stack_protector, v)
}
pub(super) fn staticlib_allow_rdylib_deps(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.staticlib_allow_rdylib_deps, v)
}
pub(super) fn staticlib_prefer_dynamic(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.staticlib_prefer_dynamic, v)
}
pub(super) fn strict_init_checks(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.strict_init_checks, v)
}
pub(super) fn teach(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.teach, v)
}
pub(super) fn temps_dir(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_string(&mut cg.temps_dir, v)
}
pub(super) fn terminal_urls(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_terminal_url(&mut cg.terminal_urls, v)
}
pub(super) fn thinlto(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_bool(&mut cg.thinlto, v)
}
pub(super) fn threads(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_threads(&mut cg.threads, v)
}
pub(super) fn time_llvm_passes(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.time_llvm_passes, v)
}
pub(super) fn time_passes(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.time_passes, v)
}
pub(super) fn time_passes_format(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_time_passes_format(&mut cg.time_passes_format, v)
}
pub(super) fn tiny_const_eval_limit(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.tiny_const_eval_limit, v)
}
pub(super) fn tls_model(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_tls_model(&mut cg.tls_model, v)
}
pub(super) fn trace_macros(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.trace_macros, v)
}
pub(super) fn track_diagnostics(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.track_diagnostics, v)
}
pub(super) fn translate_remapped_path_to_local_path(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.translate_remapped_path_to_local_path,
v)
}
pub(super) fn trap_unreachable(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.trap_unreachable, v)
}
pub(super) fn treat_err_as_bug(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_treat_err_as_bug(&mut cg.treat_err_as_bug, v)
}
pub(super) fn trim_diagnostic_paths(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.trim_diagnostic_paths, v)
}
pub(super) fn tune_cpu(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_string(&mut cg.tune_cpu, v)
}
pub(super) fn typing_mode_borrowck(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.typing_mode_borrowck, v)
}
pub(super) fn ub_checks(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_opt_bool(&mut cg.ub_checks, v)
}
pub(super) fn ui_testing(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_bool(&mut cg.ui_testing, v)
}
pub(super) fn uninit_const_chunk_threshold(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_number(&mut cg.uninit_const_chunk_threshold, v)
}
pub(super) fn unleash_the_miri_inside_of_you(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.unleash_the_miri_inside_of_you, v)
}
pub(super) fn unpretty(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_unpretty(&mut cg.unpretty, v)
}
pub(super) fn unsound_mir_opts(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.unsound_mir_opts, v)
}
pub(super) fn unstable_options(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_no_value(&mut cg.unstable_options, v)
}
pub(super) fn use_ctors_section(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.use_ctors_section, v)
}
pub(super) fn use_sync_unwind(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_opt_bool(&mut cg.use_sync_unwind, v)
}
pub(super) fn validate_mir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.validate_mir, v)
}
pub(super) fn verbose_asm(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.verbose_asm, v)
}
pub(super) fn verbose_internals(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.verbose_internals, v)
}
pub(super) fn verify_llvm_ir(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.verify_llvm_ir, v)
}
pub(super) fn virtual_function_elimination(cg:
&mut super::UnstableOptions, v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.virtual_function_elimination, v)
}
pub(super) fn wasi_exec_model(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_wasi_exec_model(&mut cg.wasi_exec_model, v)
}
pub(super) fn wasm_c_abi(cg: &mut super::UnstableOptions, v: Option<&str>)
-> bool {
super::parse::parse_wasm_c_abi(&mut cg.wasm_c_abi, v)
}
pub(super) fn write_long_types_to_disk(cg: &mut super::UnstableOptions,
v: Option<&str>) -> bool {
super::parse::parse_bool(&mut cg.write_long_types_to_disk, v)
}
}options! {
2231 UnstableOptions, UnstableOptionsTargetModifiers, Z_OPTIONS, dbopts, "Z", "unstable",
2232
2233 allow_features: Option<Vec<String>> = (None, parse_opt_comma_list, [TRACKED],
2239 "only allow the listed language features to be enabled in code (comma separated)"),
2240 always_encode_mir: bool = (false, parse_bool, [TRACKED],
2241 "encode MIR of all functions into the crate metadata (default: no)"),
2242 annotate_moves: AnnotateMoves = (AnnotateMoves::Disabled, parse_annotate_moves, [TRACKED],
2243 "emit debug info for compiler-generated move and copy operations \
2244 to make them visible in profilers. Can be a boolean or a size limit in bytes (default: disabled)"),
2245 assert_incr_state: Option<IncrementalStateAssertion> = (None, parse_assert_incr_state, [UNTRACKED],
2246 "assert that the incremental cache is in given state: \
2247 either `loaded` or `not-loaded`."),
2248 assume_incomplete_release: bool = (false, parse_bool, [TRACKED],
2249 "make cfg(version) treat the current version as incomplete (default: no)"),
2250 autodiff: Vec<crate::config::AutoDiff> = (Vec::new(), parse_autodiff, [TRACKED],
2251 "a list of autodiff flags to enable
2252 Mandatory setting:
2253 `=Enable`
2254 Optional extra settings:
2255 `=PrintTA`
2256 `=PrintAA`
2257 `=PrintPerf`
2258 `=PrintSteps`
2259 `=PrintModBefore`
2260 `=PrintModAfter`
2261 `=PrintModFinal`
2262 `=PrintPasses`,
2263 `=NoPostopt`
2264 `=LooseTypes`
2265 `=Inline`
2266 Multiple options can be combined with commas."),
2267 #[rustc_lint_opt_deny_field_access("use `Session::binary_dep_depinfo` instead of this field")]
2268 binary_dep_depinfo: bool = (false, parse_bool, [TRACKED],
2269 "include artifacts (sysroot, crate dependencies) used during compilation in dep-info \
2270 (default: no)"),
2271 box_noalias: bool = (true, parse_bool, [TRACKED],
2272 "emit noalias metadata for box (default: yes)"),
2273 branch_protection: Option<BranchProtection> = (None, parse_branch_protection, [TRACKED TARGET_MODIFIER],
2274 "set options for branch target identification and pointer authentication on AArch64"),
2275 build_sdylib_interface: bool = (false, parse_bool, [UNTRACKED],
2276 "whether the stable interface is being built"),
2277 cache_proc_macros: bool = (false, parse_bool, [TRACKED],
2278 "cache the results of derive proc macro invocations (potentially unsound!) (default: no"),
2279 cf_protection: CFProtection = (CFProtection::None, parse_cfprotection, [TRACKED],
2280 "instrument control-flow architecture protection"),
2281 check_cfg_all_expected: bool = (false, parse_bool, [UNTRACKED],
2282 "show all expected values in check-cfg diagnostics (default: no)"),
2283 checksum_hash_algorithm: Option<SourceFileHashAlgorithm> = (None, parse_cargo_src_file_hash, [TRACKED],
2284 "hash algorithm of source files used to check freshness in cargo (`blake3` or `sha256`)"),
2285 codegen_backend: Option<String> = (None, parse_opt_string, [TRACKED],
2286 "the backend to use"),
2287 codegen_source_order: bool = (false, parse_bool, [UNTRACKED],
2288 "emit mono items in the order of spans in source files (default: no)"),
2289 contract_checks: Option<bool> = (None, parse_opt_bool, [TRACKED],
2290 "emit runtime checks for contract pre- and post-conditions (default: no)"),
2291 coverage_options: CoverageOptions = (CoverageOptions::default(), parse_coverage_options, [TRACKED],
2292 "control details of coverage instrumentation"),
2293 crate_attr: Vec<String> = (Vec::new(), parse_string_push, [TRACKED],
2294 "inject the given attribute in the crate"),
2295 cross_crate_inline_threshold: InliningThreshold = (InliningThreshold::Sometimes(100), parse_inlining_threshold, [TRACKED],
2296 "threshold to allow cross crate inlining of functions"),
2297 debug_info_for_profiling: bool = (false, parse_bool, [TRACKED],
2298 "emit discriminators and other data necessary for AutoFDO"),
2299 debug_info_type_line_numbers: bool = (false, parse_bool, [TRACKED],
2300 "emit type and line information for additional data types (default: no)"),
2301 debuginfo_compression: DebugInfoCompression = (DebugInfoCompression::None, parse_debuginfo_compression, [TRACKED],
2302 "compress debug info sections (none, zlib, zstd, default: none)"),
2303 deduplicate_diagnostics: bool = (true, parse_bool, [UNTRACKED],
2304 "deduplicate identical diagnostics (default: yes)"),
2305 default_visibility: Option<SymbolVisibility> = (None, parse_opt_symbol_visibility, [TRACKED],
2306 "overrides the `default_visibility` setting of the target"),
2307 dep_info_omit_d_target: bool = (false, parse_bool, [TRACKED],
2308 "in dep-info output, omit targets for tracking dependencies of the dep-info files \
2309 themselves (default: no)"),
2310 direct_access_external_data: Option<bool> = (None, parse_opt_bool, [TRACKED],
2311 "Direct or use GOT indirect to reference external data symbols"),
2312 dual_proc_macros: bool = (false, parse_bool, [TRACKED],
2313 "load proc macros for both target and host, but only link to the target (default: no)"),
2314 dump_dep_graph: bool = (false, parse_bool, [UNTRACKED],
2315 "dump the dependency graph to $RUST_DEP_GRAPH (default: /tmp/dep_graph.gv) \
2316 (default: no)"),
2317 dump_mir: Option<String> = (None, parse_opt_string, [UNTRACKED],
2318 "dump MIR state to file.
2319 `val` is used to select which passes and functions to dump. For example:
2320 `all` matches all passes and functions,
2321 `foo` matches all passes for functions whose name contains 'foo',
2322 `foo & ConstProp` only the 'ConstProp' pass for function names containing 'foo',
2323 `foo | bar` all passes for function names containing 'foo' or 'bar'."),
2324 dump_mir_dataflow: bool = (false, parse_bool, [UNTRACKED],
2325 "in addition to `.mir` files, create graphviz `.dot` files with dataflow results \
2326 (default: no)"),
2327 dump_mir_dir: String = ("mir_dump".to_string(), parse_string, [UNTRACKED],
2328 "the directory the MIR is dumped into (default: `mir_dump`)"),
2329 dump_mir_exclude_alloc_bytes: bool = (false, parse_bool, [UNTRACKED],
2330 "exclude the raw bytes of allocations when dumping MIR (used in tests) (default: no)"),
2331 dump_mir_exclude_pass_number: bool = (false, parse_bool, [UNTRACKED],
2332 "exclude the pass number when dumping MIR (used in tests) (default: no)"),
2333 dump_mir_graphviz: bool = (false, parse_bool, [UNTRACKED],
2334 "in addition to `.mir` files, create graphviz `.dot` files (default: no)"),
2335 dump_mono_stats: SwitchWithOptPath = (SwitchWithOptPath::Disabled,
2336 parse_switch_with_opt_path, [UNTRACKED],
2337 "output statistics about monomorphization collection"),
2338 dump_mono_stats_format: DumpMonoStatsFormat = (DumpMonoStatsFormat::Markdown, parse_dump_mono_stats, [UNTRACKED],
2339 "the format to use for -Z dump-mono-stats (`markdown` (default) or `json`)"),
2340 #[rustc_lint_opt_deny_field_access("use `Session::dwarf_version` instead of this field")]
2341 dwarf_version: Option<u32> = (None, parse_opt_number, [TRACKED],
2342 "version of DWARF debug information to emit (default: 2 or 4, depending on platform)"),
2343 dylib_lto: bool = (false, parse_bool, [UNTRACKED],
2344 "enables LTO for dylib crate type"),
2345 eagerly_emit_delayed_bugs: bool = (false, parse_bool, [UNTRACKED],
2346 "emit delayed bugs eagerly as errors instead of stashing them and emitting \
2347 them only if an error has not been emitted"),
2348 ehcont_guard: bool = (false, parse_bool, [TRACKED],
2349 "generate Windows EHCont Guard tables"),
2350 embed_metadata: bool = (true, parse_bool, [TRACKED],
2351 "embed metadata in rlibs and dylibs (default: yes)"),
2352 embed_source: bool = (false, parse_bool, [TRACKED],
2353 "embed source text in DWARF debug sections (default: no)"),
2354 emit_stack_sizes: bool = (false, parse_bool, [UNTRACKED],
2355 "emit a section containing stack size metadata (default: no)"),
2356 emscripten_wasm_eh: bool = (true, parse_bool, [TRACKED],
2357 "Use WebAssembly error handling for wasm32-unknown-emscripten"),
2358 enforce_type_length_limit: bool = (false, parse_bool, [TRACKED],
2359 "enforce the type length limit when monomorphizing instances in codegen"),
2360 experimental_default_bounds: bool = (false, parse_bool, [TRACKED],
2361 "enable default bounds for experimental group of auto traits"),
2362 export_executable_symbols: bool = (false, parse_bool, [TRACKED],
2363 "export symbols from executables, as if they were dynamic libraries"),
2364 external_clangrt: bool = (false, parse_bool, [UNTRACKED],
2365 "rely on user specified linker commands to find clangrt"),
2366 extra_const_ub_checks: bool = (false, parse_bool, [TRACKED],
2367 "turns on more checks to detect const UB, which can be slow (default: no)"),
2368 #[rustc_lint_opt_deny_field_access("use `Session::fewer_names` instead of this field")]
2369 fewer_names: Option<bool> = (None, parse_opt_bool, [TRACKED],
2370 "reduce memory use by retaining fewer names within compilation artifacts (LLVM-IR) \
2371 (default: no)"),
2372 fixed_x18: bool = (false, parse_bool, [TRACKED TARGET_MODIFIER],
2373 "make the x18 register reserved on AArch64 (default: no)"),
2374 flatten_format_args: bool = (true, parse_bool, [TRACKED],
2375 "flatten nested format_args!() and literals into a simplified format_args!() call \
2376 (default: yes)"),
2377 fmt_debug: FmtDebug = (FmtDebug::Full, parse_fmt_debug, [TRACKED],
2378 "how detailed `#[derive(Debug)]` should be. `full` prints types recursively, \
2379 `shallow` prints only type names, `none` prints nothing and disables `{:?}`. (default: `full`)"),
2380 force_unstable_if_unmarked: bool = (false, parse_bool, [TRACKED],
2381 "force all crates to be `rustc_private` unstable (default: no)"),
2382 function_return: FunctionReturn = (FunctionReturn::default(), parse_function_return, [TRACKED],
2383 "replace returns with jumps to `__x86_return_thunk` (default: `keep`)"),
2384 function_sections: Option<bool> = (None, parse_opt_bool, [TRACKED],
2385 "whether each function should go in its own section"),
2386 future_incompat_test: bool = (false, parse_bool, [UNTRACKED],
2387 "forces all lints to be future incompatible, used for internal testing (default: no)"),
2388 graphviz_dark_mode: bool = (false, parse_bool, [UNTRACKED],
2389 "use dark-themed colors in graphviz output (default: no)"),
2390 graphviz_font: String = ("Courier, monospace".to_string(), parse_string, [UNTRACKED],
2391 "use the given `fontname` in graphviz output; can be overridden by setting \
2392 environment variable `RUSTC_GRAPHVIZ_FONT` (default: `Courier, monospace`)"),
2393 has_thread_local: Option<bool> = (None, parse_opt_bool, [TRACKED],
2394 "explicitly enable the `cfg(target_thread_local)` directive"),
2395 help: bool = (false, parse_no_value, [UNTRACKED], "Print unstable compiler options"),
2396 higher_ranked_assumptions: bool = (false, parse_bool, [TRACKED],
2397 "allow deducing higher-ranked outlives assumptions from coroutines when proving auto traits"),
2398 hint_mostly_unused: bool = (false, parse_bool, [TRACKED],
2399 "hint that most of this crate will go unused, to minimize work for uncalled functions"),
2400 human_readable_cgu_names: bool = (false, parse_bool, [TRACKED],
2401 "generate human-readable, predictable names for codegen units (default: no)"),
2402 identify_regions: bool = (false, parse_bool, [UNTRACKED],
2403 "display unnamed regions as `'<id>`, using a non-ident unique id (default: no)"),
2404 ignore_directory_in_diagnostics_source_blocks: Vec<String> = (Vec::new(), parse_string_push, [UNTRACKED],
2405 "do not display the source code block in diagnostics for files in the directory"),
2406 incremental_ignore_spans: bool = (false, parse_bool, [TRACKED],
2407 "ignore spans during ICH computation -- used for testing (default: no)"),
2408 incremental_info: bool = (false, parse_bool, [UNTRACKED],
2409 "print high-level information about incremental reuse (or the lack thereof) \
2410 (default: no)"),
2411 incremental_verify_ich: bool = (false, parse_bool, [UNTRACKED],
2412 "verify extended properties for incr. comp. (default: no):
2413 - hashes of green query instances
2414 - hash collisions of query keys
2415 - hash collisions when creating dep-nodes"),
2416 indirect_branch_cs_prefix: bool = (false, parse_bool, [TRACKED TARGET_MODIFIER],
2417 "add `cs` prefix to `call` and `jmp` to indirect thunks (default: no)"),
2418 inline_llvm: bool = (true, parse_bool, [TRACKED],
2419 "enable LLVM inlining (default: yes)"),
2420 inline_mir: Option<bool> = (None, parse_opt_bool, [TRACKED],
2421 "enable MIR inlining (default: no)"),
2422 inline_mir_forwarder_threshold: Option<usize> = (None, parse_opt_number, [TRACKED],
2423 "inlining threshold when the caller is a simple forwarding function (default: 30)"),
2424 inline_mir_hint_threshold: Option<usize> = (None, parse_opt_number, [TRACKED],
2425 "inlining threshold for functions with inline hint (default: 100)"),
2426 inline_mir_preserve_debug: Option<bool> = (None, parse_opt_bool, [TRACKED],
2427 "when MIR inlining, whether to preserve debug info for callee variables \
2428 (default: preserve for debuginfo != None, otherwise remove)"),
2429 inline_mir_threshold: Option<usize> = (None, parse_opt_number, [TRACKED],
2430 "a default MIR inlining threshold (default: 50)"),
2431 input_stats: bool = (false, parse_bool, [UNTRACKED],
2432 "print some statistics about AST and HIR (default: no)"),
2433 instrument_mcount: bool = (false, parse_bool, [TRACKED],
2434 "insert function instrument code for mcount-based tracing (default: no)"),
2435 instrument_xray: Option<InstrumentXRay> = (None, parse_instrument_xray, [TRACKED],
2436 "insert function instrument code for XRay-based tracing (default: no)
2437 Optional extra settings:
2438 `=always`
2439 `=never`
2440 `=ignore-loops`
2441 `=instruction-threshold=N`
2442 `=skip-entry`
2443 `=skip-exit`
2444 Multiple options can be combined with commas."),
2445 large_data_threshold: Option<u64> = (None, parse_opt_number, [TRACKED],
2446 "set the threshold for objects to be stored in a \"large data\" section \
2447 (only effective with -Ccode-model=medium, default: 65536)"),
2448 layout_seed: Option<u64> = (None, parse_opt_number, [TRACKED],
2449 "seed layout randomization"),
2450 link_directives: bool = (true, parse_bool, [TRACKED],
2451 "honor #[link] directives in the compiled crate (default: yes)"),
2452 link_native_libraries: bool = (true, parse_bool, [UNTRACKED],
2453 "link native libraries in the linker invocation (default: yes)"),
2454 link_only: bool = (false, parse_bool, [TRACKED],
2455 "link the `.rlink` file generated by `-Z no-link` (default: no)"),
2456 lint_llvm_ir: bool = (false, parse_bool, [TRACKED],
2457 "lint LLVM IR (default: no)"),
2458 lint_mir: bool = (false, parse_bool, [UNTRACKED],
2459 "lint MIR before and after each transformation"),
2460 llvm_module_flag: Vec<(String, u32, String)> = (Vec::new(), parse_llvm_module_flag, [TRACKED],
2461 "a list of module flags to pass to LLVM (space separated)"),
2462 llvm_plugins: Vec<String> = (Vec::new(), parse_list, [TRACKED],
2463 "a list LLVM plugins to enable (space separated)"),
2464 llvm_time_trace: bool = (false, parse_bool, [UNTRACKED],
2465 "generate JSON tracing data file from LLVM data (default: no)"),
2466 location_detail: LocationDetail = (LocationDetail::all(), parse_location_detail, [TRACKED],
2467 "what location details should be tracked when using caller_location, either \
2468 `none`, or a comma separated list of location details, for which \
2469 valid options are `file`, `line`, and `column` (default: `file,line,column`)"),
2470 ls: Vec<String> = (Vec::new(), parse_list, [UNTRACKED],
2471 "decode and print various parts of the crate metadata for a library crate \
2472 (space separated)"),
2473 macro_backtrace: bool = (false, parse_bool, [UNTRACKED],
2474 "show macro backtraces (default: no)"),
2475 macro_stats: bool = (false, parse_bool, [UNTRACKED],
2476 "print some statistics about macro expansions (default: no)"),
2477 maximal_hir_to_mir_coverage: bool = (false, parse_bool, [TRACKED],
2478 "save as much information as possible about the correspondence between MIR and HIR \
2479 as source scopes (default: no)"),
2480 merge_functions: Option<MergeFunctions> = (None, parse_merge_functions, [TRACKED],
2481 "control the operation of the MergeFunctions LLVM pass, taking \
2482 the same values as the target option of the same name"),
2483 meta_stats: bool = (false, parse_bool, [UNTRACKED],
2484 "gather metadata statistics (default: no)"),
2485 metrics_dir: Option<PathBuf> = (None, parse_opt_pathbuf, [UNTRACKED],
2486 "the directory metrics emitted by rustc are dumped into (implicitly enables default set of metrics)"),
2487 min_function_alignment: Option<Align> = (None, parse_align, [TRACKED],
2488 "align all functions to at least this many bytes. Must be a power of 2"),
2489 min_recursion_limit: Option<usize> = (None, parse_opt_number, [TRACKED],
2490 "set a minimum recursion limit (final limit = max(this, recursion_limit_from_crate))"),
2491 mir_emit_retag: bool = (false, parse_bool, [TRACKED],
2492 "emit Retagging MIR statements, interpreted e.g., by miri; implies -Zmir-opt-level=0 \
2493 (default: no)"),
2494 mir_enable_passes: Vec<(String, bool)> = (Vec::new(), parse_list_with_polarity, [TRACKED],
2495 "use like `-Zmir-enable-passes=+DestinationPropagation,-InstSimplify`. Forces the \
2496 specified passes to be enabled, overriding all other checks. In particular, this will \
2497 enable unsound (known-buggy and hence usually disabled) passes without further warning! \
2498 Passes that are not specified are enabled or disabled by other flags as usual."),
2499 mir_include_spans: MirIncludeSpans = (MirIncludeSpans::default(), parse_mir_include_spans, [UNTRACKED],
2500 "include extra comments in mir pretty printing, like line numbers and statement indices, \
2501 details about types, etc. (boolean for all passes, 'nll' to enable in NLL MIR only, default: 'nll')"),
2502 mir_opt_bisect_limit: Option<usize> = (None, parse_opt_number, [TRACKED],
2503 "limit the number of MIR optimization pass executions (global across all bodies). \
2504 Pass executions after this limit are skipped and reported. (default: no limit)"),
2505 #[rustc_lint_opt_deny_field_access("use `Session::mir_opt_level` instead of this field")]
2506 mir_opt_level: Option<usize> = (None, parse_opt_number, [TRACKED],
2507 "MIR optimization level (0-4; default: 1 in non optimized builds and 2 in optimized builds)"),
2508 mir_preserve_ub: bool = (false, parse_bool, [TRACKED],
2509 "keep place mention statements and reads in trivial SwitchInt terminators, which are interpreted \
2510 e.g., by miri; implies -Zmir-opt-level=0 (default: no)"),
2511 mir_strip_debuginfo: MirStripDebugInfo = (MirStripDebugInfo::None, parse_mir_strip_debuginfo, [TRACKED],
2512 "Whether to remove some of the MIR debug info from methods. Default: None"),
2513 move_size_limit: Option<usize> = (None, parse_opt_number, [TRACKED],
2514 "the size at which the `large_assignments` lint starts to be emitted"),
2515 mutable_noalias: bool = (true, parse_bool, [TRACKED],
2516 "emit noalias metadata for mutable references (default: yes)"),
2517 namespaced_crates: bool = (false, parse_bool, [TRACKED],
2518 "allow crates to be namespaced by other crates (default: no)"),
2519 next_solver: NextSolverConfig = (NextSolverConfig::default(), parse_next_solver_config, [TRACKED],
2520 "enable and configure the next generation trait solver used by rustc"),
2521 nll_facts: bool = (false, parse_bool, [UNTRACKED],
2522 "dump facts from NLL analysis into side files (default: no)"),
2523 nll_facts_dir: String = ("nll-facts".to_string(), parse_string, [UNTRACKED],
2524 "the directory the NLL facts are dumped into (default: `nll-facts`)"),
2525 no_analysis: bool = (false, parse_no_value, [UNTRACKED],
2526 "parse and expand the source, but run no analysis"),
2527 no_codegen: bool = (false, parse_no_value, [TRACKED_NO_CRATE_HASH],
2528 "run all passes except codegen; no output"),
2529 no_generate_arange_section: bool = (false, parse_no_value, [TRACKED],
2530 "omit DWARF address ranges that give faster lookups"),
2531 no_implied_bounds_compat: bool = (false, parse_bool, [TRACKED],
2532 "disable the compatibility version of the `implied_bounds_ty` query"),
2533 no_leak_check: bool = (false, parse_no_value, [UNTRACKED],
2534 "disable the 'leak check' for subtyping; unsound, but useful for tests"),
2535 no_link: bool = (false, parse_no_value, [TRACKED],
2536 "compile without linking"),
2537 no_parallel_backend: bool = (false, parse_no_value, [UNTRACKED],
2538 "run LLVM in non-parallel mode (while keeping codegen-units and ThinLTO)"),
2539 no_profiler_runtime: bool = (false, parse_no_value, [TRACKED],
2540 "prevent automatic injection of the profiler_builtins crate"),
2541 no_steal_thir: bool = (false, parse_bool, [UNTRACKED],
2542 "don't steal the THIR when we're done with it; useful for rustc drivers (default: no)"),
2543 no_trait_vptr: bool = (false, parse_no_value, [TRACKED],
2544 "disable generation of trait vptr in vtable for upcasting"),
2545 no_unique_section_names: bool = (false, parse_bool, [TRACKED],
2546 "do not use unique names for text and data sections when -Z function-sections is used"),
2547 normalize_docs: bool = (false, parse_bool, [TRACKED],
2548 "normalize associated items in rustdoc when generating documentation"),
2549 offload: Vec<crate::config::Offload> = (Vec::new(), parse_offload, [TRACKED],
2550 "a list of offload flags to enable
2551 Mandatory setting:
2552 `=Enable`
2553 Currently the only option available"),
2554 on_broken_pipe: OnBrokenPipe = (OnBrokenPipe::Default, parse_on_broken_pipe, [TRACKED],
2555 "behavior of std::io::ErrorKind::BrokenPipe (SIGPIPE)"),
2556 osx_rpath_install_name: bool = (false, parse_bool, [TRACKED],
2557 "pass `-install_name @rpath/...` to the macOS linker (default: no)"),
2558 packed_bundled_libs: bool = (false, parse_bool, [TRACKED],
2559 "change rlib format to store native libraries as archives"),
2560 packed_stack: bool = (false, parse_bool, [TRACKED],
2561 "use packed stack frames (s390x only) (default: no)"),
2562 panic_abort_tests: bool = (false, parse_bool, [TRACKED],
2563 "support compiling tests with panic=abort (default: no)"),
2564 panic_in_drop: PanicStrategy = (PanicStrategy::Unwind, parse_panic_strategy, [TRACKED],
2565 "panic strategy for panics in drops"),
2566 parse_crate_root_only: bool = (false, parse_bool, [UNTRACKED],
2567 "parse the crate root file only; do not parse other files, compile, assemble, or link \
2568 (default: no)"),
2569 patchable_function_entry: PatchableFunctionEntry = (PatchableFunctionEntry::default(), parse_patchable_function_entry, [TRACKED],
2570 "nop padding at function entry"),
2571 plt: Option<bool> = (None, parse_opt_bool, [TRACKED],
2572 "whether to use the PLT when calling into shared libraries;
2573 only has effect for PIC code on systems with ELF binaries
2574 (default: PLT is disabled if full relro is enabled on x86_64)"),
2575 polonius: Polonius = (Polonius::default(), parse_polonius, [TRACKED],
2576 "enable polonius-based borrow-checker (default: no)"),
2577 pre_link_arg: () = ((), parse_string_push, [UNTRACKED],
2578 "a single extra argument to prepend the linker invocation (can be used several times)"),
2579 pre_link_args: Vec<String> = (Vec::new(), parse_list, [UNTRACKED],
2580 "extra arguments to prepend to the linker invocation (space separated)"),
2581 precise_enum_drop_elaboration: bool = (true, parse_bool, [TRACKED],
2582 "use a more precise version of drop elaboration for matches on enums (default: yes). \
2583 This results in better codegen, but has caused miscompilations on some tier 2 platforms. \
2584 See #77382 and #74551."),
2585 #[rustc_lint_opt_deny_field_access("use `Session::print_codegen_stats` instead of this field")]
2586 print_codegen_stats: bool = (false, parse_bool, [UNTRACKED],
2587 "print codegen statistics (default: no)"),
2588 print_llvm_passes: bool = (false, parse_bool, [UNTRACKED],
2589 "print the LLVM optimization passes being run (default: no)"),
2590 print_mono_items: bool = (false, parse_bool, [UNTRACKED],
2591 "print the result of the monomorphization collection pass (default: no)"),
2592 print_type_sizes: bool = (false, parse_bool, [UNTRACKED],
2593 "print layout information for each type encountered (default: no)"),
2594 proc_macro_backtrace: bool = (false, parse_bool, [UNTRACKED],
2595 "show backtraces for panics during proc-macro execution (default: no)"),
2596 proc_macro_execution_strategy: ProcMacroExecutionStrategy = (ProcMacroExecutionStrategy::SameThread,
2597 parse_proc_macro_execution_strategy, [UNTRACKED],
2598 "how to run proc-macro code (default: same-thread)"),
2599 profile_closures: bool = (false, parse_no_value, [UNTRACKED],
2600 "profile size of closures"),
2601 profile_sample_use: Option<PathBuf> = (None, parse_opt_pathbuf, [TRACKED],
2602 "use the given `.prof` file for sampled profile-guided optimization (also known as AutoFDO)"),
2603 profiler_runtime: String = (String::from("profiler_builtins"), parse_string, [TRACKED],
2604 "name of the profiler runtime crate to automatically inject (default: `profiler_builtins`)"),
2605 query_dep_graph: bool = (false, parse_bool, [UNTRACKED],
2606 "enable queries of the dependency graph for regression testing (default: no)"),
2607 randomize_layout: bool = (false, parse_bool, [TRACKED],
2608 "randomize the layout of types (default: no)"),
2609 reg_struct_return: bool = (false, parse_bool, [TRACKED TARGET_MODIFIER],
2610 "On x86-32 targets, it overrides the default ABI to return small structs in registers.
2611 It is UNSOUND to link together crates that use different values for this flag!"),
2612 regparm: Option<u32> = (None, parse_opt_number, [TRACKED TARGET_MODIFIER],
2613 "On x86-32 targets, setting this to N causes the compiler to pass N arguments \
2614 in registers EAX, EDX, and ECX instead of on the stack for\
2615 \"C\", \"cdecl\", and \"stdcall\" fn.\
2616 It is UNSOUND to link together crates that use different values for this flag!"),
2617 relax_elf_relocations: Option<bool> = (None, parse_opt_bool, [TRACKED],
2618 "whether ELF relocations can be relaxed"),
2619 remap_cwd_prefix: Option<PathBuf> = (None, parse_opt_pathbuf, [TRACKED],
2620 "remap paths under the current working directory to this path prefix"),
2621 remark_dir: Option<PathBuf> = (None, parse_opt_pathbuf, [UNTRACKED],
2622 "directory into which to write optimization remarks (if not specified, they will be \
2623written to standard error output)"),
2624 retpoline: bool = (false, parse_bool, [TRACKED TARGET_MODIFIER],
2625 "enables retpoline-indirect-branches and retpoline-indirect-calls target features (default: no)"),
2626 retpoline_external_thunk: bool = (false, parse_bool, [TRACKED TARGET_MODIFIER],
2627 "enables retpoline-external-thunk, retpoline-indirect-branches and retpoline-indirect-calls \
2628 target features (default: no)"),
2629 #[rustc_lint_opt_deny_field_access("use `Session::sanitizers()` instead of this field")]
2630 sanitizer: SanitizerSet = (SanitizerSet::empty(), parse_sanitizers, [TRACKED TARGET_MODIFIER],
2631 "use a sanitizer"),
2632 sanitizer_cfi_canonical_jump_tables: Option<bool> = (Some(true), parse_opt_bool, [TRACKED],
2633 "enable canonical jump tables (default: yes)"),
2634 sanitizer_cfi_generalize_pointers: Option<bool> = (None, parse_opt_bool, [TRACKED],
2635 "enable generalizing pointer types (default: no)"),
2636 sanitizer_cfi_normalize_integers: Option<bool> = (None, parse_opt_bool, [TRACKED TARGET_MODIFIER],
2637 "enable normalizing integer types (default: no)"),
2638 sanitizer_dataflow_abilist: Vec<String> = (Vec::new(), parse_comma_list, [TRACKED],
2639 "additional ABI list files that control how shadow parameters are passed (comma separated)"),
2640 sanitizer_kcfi_arity: Option<bool> = (None, parse_opt_bool, [TRACKED],
2641 "enable KCFI arity indicator (default: no)"),
2642 sanitizer_memory_track_origins: usize = (0, parse_sanitizer_memory_track_origins, [TRACKED],
2643 "enable origins tracking in MemorySanitizer"),
2644 sanitizer_recover: SanitizerSet = (SanitizerSet::empty(), parse_sanitizers, [TRACKED],
2645 "enable recovery for selected sanitizers"),
2646 saturating_float_casts: Option<bool> = (None, parse_opt_bool, [TRACKED],
2647 "make float->int casts UB-free: numbers outside the integer type's range are clipped to \
2648 the max/min integer respectively, and NaN is mapped to 0 (default: yes)"),
2649 self_profile: SwitchWithOptPath = (SwitchWithOptPath::Disabled,
2650 parse_switch_with_opt_path, [UNTRACKED],
2651 "run the self profiler and output the raw event data"),
2652 self_profile_counter: String = ("wall-time".to_string(), parse_string, [UNTRACKED],
2653 "counter used by the self profiler (default: `wall-time`), one of:
2654 `wall-time` (monotonic clock, i.e. `std::time::Instant`)
2655 `instructions:u` (retired instructions, userspace-only)
2656 `instructions-minus-irqs:u` (subtracting hardware interrupt counts for extra accuracy)"
2657 ),
2658 self_profile_events: Option<Vec<String>> = (None, parse_opt_comma_list, [UNTRACKED],
2660 "specify the events recorded by the self profiler;
2661 for example: `-Z self-profile-events=default,query-keys`
2662 all options: none, all, default, generic-activity, query-provider, query-cache-hit
2663 query-blocked, incr-cache-load, incr-result-hashing, query-keys, function-args, args, llvm, artifact-sizes"),
2664 share_generics: Option<bool> = (None, parse_opt_bool, [TRACKED],
2665 "make the current crate share its generic instantiations"),
2666 shell_argfiles: bool = (false, parse_bool, [UNTRACKED],
2667 "allow argument files to be specified with POSIX \"shell-style\" argument quoting"),
2668 simulate_remapped_rust_src_base: Option<PathBuf> = (None, parse_opt_pathbuf, [TRACKED],
2669 "simulate the effect of remap-debuginfo = true at bootstrapping by remapping path \
2670 to rust's source base directory. only meant for testing purposes"),
2671 small_data_threshold: Option<usize> = (None, parse_opt_number, [TRACKED],
2672 "Set the threshold for objects to be stored in a \"small data\" section"),
2673 span_debug: bool = (false, parse_bool, [UNTRACKED],
2674 "forward proc_macro::Span's `Debug` impl to `Span`"),
2675 span_free_formats: bool = (false, parse_bool, [UNTRACKED],
2677 "exclude spans when debug-printing compiler state (default: no)"),
2678 split_dwarf_inlining: bool = (false, parse_bool, [TRACKED],
2679 "provide minimal debug info in the object/executable to facilitate online \
2680 symbolication/stack traces in the absence of .dwo/.dwp files when using Split DWARF"),
2681 split_dwarf_kind: SplitDwarfKind = (SplitDwarfKind::Split, parse_split_dwarf_kind, [TRACKED],
2682 "split dwarf variant (only if -Csplit-debuginfo is enabled and on relevant platform)
2683 (default: `split`)
2684
2685 `split`: sections which do not require relocation are written into a DWARF object (`.dwo`)
2686 file which is ignored by the linker
2687 `single`: sections which do not require relocation are written into object file but ignored
2688 by the linker"),
2689 split_dwarf_out_dir : Option<PathBuf> = (None, parse_opt_pathbuf, [TRACKED],
2690 "location for writing split DWARF objects (`.dwo`) if enabled"),
2691 split_lto_unit: Option<bool> = (None, parse_opt_bool, [TRACKED],
2692 "enable LTO unit splitting (default: no)"),
2693 src_hash_algorithm: Option<SourceFileHashAlgorithm> = (None, parse_src_file_hash, [TRACKED],
2694 "hash algorithm of source files in debug info (`md5`, `sha1`, or `sha256`)"),
2695 #[rustc_lint_opt_deny_field_access("use `Session::stack_protector` instead of this field")]
2696 stack_protector: StackProtector = (StackProtector::None, parse_stack_protector, [TRACKED],
2697 "control stack smash protection strategy (`rustc --print stack-protector-strategies` for details)"),
2698 staticlib_allow_rdylib_deps: bool = (false, parse_bool, [TRACKED],
2699 "allow staticlibs to have rust dylib dependencies"),
2700 staticlib_prefer_dynamic: bool = (false, parse_bool, [TRACKED],
2701 "prefer dynamic linking to static linking for staticlibs (default: no)"),
2702 strict_init_checks: bool = (false, parse_bool, [TRACKED],
2703 "control if mem::uninitialized and mem::zeroed panic on more UB"),
2704 #[rustc_lint_opt_deny_field_access("use `Session::teach` instead of this field")]
2705 teach: bool = (false, parse_bool, [TRACKED],
2706 "show extended diagnostic help (default: no)"),
2707 temps_dir: Option<String> = (None, parse_opt_string, [UNTRACKED],
2708 "the directory the intermediate files are written to"),
2709 terminal_urls: TerminalUrl = (TerminalUrl::No, parse_terminal_url, [UNTRACKED],
2710 "use the OSC 8 hyperlink terminal specification to print hyperlinks in the compiler output"),
2711 #[rustc_lint_opt_deny_field_access("use `Session::lto` instead of this field")]
2712 thinlto: Option<bool> = (None, parse_opt_bool, [TRACKED],
2713 "enable ThinLTO when possible"),
2714 #[rustc_lint_opt_deny_field_access("use `Session::threads` instead of this field")]
2719 threads: usize = (1, parse_threads, [UNTRACKED],
2720 "use a thread pool with N threads"),
2721 time_llvm_passes: bool = (false, parse_bool, [UNTRACKED],
2722 "measure time of each LLVM pass (default: no)"),
2723 time_passes: bool = (false, parse_bool, [UNTRACKED],
2724 "measure time of each rustc pass (default: no)"),
2725 time_passes_format: TimePassesFormat = (TimePassesFormat::Text, parse_time_passes_format, [UNTRACKED],
2726 "the format to use for -Z time-passes (`text` (default) or `json`)"),
2727 tiny_const_eval_limit: bool = (false, parse_bool, [TRACKED],
2728 "sets a tiny, non-configurable limit for const eval; useful for compiler tests"),
2729 #[rustc_lint_opt_deny_field_access("use `Session::tls_model` instead of this field")]
2730 tls_model: Option<TlsModel> = (None, parse_tls_model, [TRACKED],
2731 "choose the TLS model to use (`rustc --print tls-models` for details)"),
2732 trace_macros: bool = (false, parse_bool, [UNTRACKED],
2733 "for every macro invocation, print its name and arguments (default: no)"),
2734 track_diagnostics: bool = (false, parse_bool, [UNTRACKED],
2735 "tracks where in rustc a diagnostic was emitted"),
2736 translate_remapped_path_to_local_path: bool = (true, parse_bool, [TRACKED],
2737 "translate remapped paths into local paths when possible (default: yes)"),
2738 trap_unreachable: Option<bool> = (None, parse_opt_bool, [TRACKED],
2739 "generate trap instructions for unreachable intrinsics (default: use target setting, usually yes)"),
2740 treat_err_as_bug: Option<NonZero<usize>> = (None, parse_treat_err_as_bug, [TRACKED],
2741 "treat the `val`th error that occurs as bug (default if not specified: 0 - don't treat errors as bugs. \
2742 default if specified without a value: 1 - treat the first error as bug)"),
2743 trim_diagnostic_paths: bool = (true, parse_bool, [UNTRACKED],
2744 "in diagnostics, use heuristics to shorten paths referring to items"),
2745 tune_cpu: Option<String> = (None, parse_opt_string, [TRACKED],
2746 "select processor to schedule for (`rustc --print target-cpus` for details)"),
2747 #[rustc_lint_opt_deny_field_access("use `TyCtxt::use_typing_mode_borrowck` instead of this field")]
2748 typing_mode_borrowck: bool = (false, parse_bool, [TRACKED],
2749 "enable `TypingMode::Borrowck`, changing the way opaque types are handled during MIR borrowck"),
2750 #[rustc_lint_opt_deny_field_access("use `Session::ub_checks` instead of this field")]
2751 ub_checks: Option<bool> = (None, parse_opt_bool, [TRACKED],
2752 "emit runtime checks for Undefined Behavior (default: -Cdebug-assertions)"),
2753 ui_testing: bool = (false, parse_bool, [UNTRACKED],
2754 "emit compiler diagnostics in a form suitable for UI testing (default: no)"),
2755 uninit_const_chunk_threshold: usize = (16, parse_number, [TRACKED],
2756 "allow generating const initializers with mixed init/uninit chunks, \
2757 and set the maximum number of chunks for which this is allowed (default: 16)"),
2758 unleash_the_miri_inside_of_you: bool = (false, parse_bool, [TRACKED],
2759 "take the brakes off const evaluation. NOTE: this is unsound (default: no)"),
2760 unpretty: Option<String> = (None, parse_unpretty, [UNTRACKED],
2761 "present the input source, unstable (and less-pretty) variants;
2762 `normal`, `identified`,
2763 `expanded`, `expanded,identified`,
2764 `expanded,hygiene` (with internal representations),
2765 `ast-tree` (raw AST before expansion),
2766 `ast-tree,expanded` (raw AST after expansion),
2767 `hir` (the HIR), `hir,identified`,
2768 `hir,typed` (HIR with types for each node),
2769 `hir-tree` (dump the raw HIR),
2770 `thir-tree`, `thir-flat`,
2771 `mir` (the MIR), or `mir-cfg` (graphviz formatted MIR)"),
2772 unsound_mir_opts: bool = (false, parse_bool, [TRACKED],
2773 "enable unsound and buggy MIR optimizations (default: no)"),
2774 #[rustc_lint_opt_deny_field_access("use `Session::unstable_options` instead of this field")]
2783 unstable_options: bool = (false, parse_no_value, [UNTRACKED],
2784 "adds unstable command line options to rustc interface (default: no)"),
2785 use_ctors_section: Option<bool> = (None, parse_opt_bool, [TRACKED],
2786 "use legacy .ctors section for initializers rather than .init_array"),
2787 use_sync_unwind: Option<bool> = (None, parse_opt_bool, [TRACKED],
2788 "Generate sync unwind tables instead of async unwind tables (default: no)"),
2789 validate_mir: bool = (false, parse_bool, [UNTRACKED],
2790 "validate MIR after each transformation"),
2791 verbose_asm: bool = (false, parse_bool, [TRACKED],
2792 "add descriptive comments from LLVM to the assembly (may change behavior) (default: no)"),
2793 #[rustc_lint_opt_deny_field_access("use `Session::verbose_internals` instead of this field")]
2794 verbose_internals: bool = (false, parse_bool, [TRACKED_NO_CRATE_HASH],
2795 "in general, enable more debug printouts (default: no)"),
2796 #[rustc_lint_opt_deny_field_access("use `Session::verify_llvm_ir` instead of this field")]
2797 verify_llvm_ir: bool = (false, parse_bool, [TRACKED],
2798 "verify LLVM IR (default: no)"),
2799 virtual_function_elimination: bool = (false, parse_bool, [TRACKED],
2800 "enables dead virtual function elimination optimization. \
2801 Requires `-Clto[=[fat,yes]]`"),
2802 wasi_exec_model: Option<WasiExecModel> = (None, parse_wasi_exec_model, [TRACKED],
2803 "whether to build a wasi command or reactor"),
2804 wasm_c_abi: () = ((), parse_wasm_c_abi, [TRACKED],
2808 "use spec-compliant C ABI for `wasm32-unknown-unknown` (deprecated, always enabled)"),
2809 write_long_types_to_disk: bool = (true, parse_bool, [UNTRACKED],
2810 "whether long type names should be written to files instead of being printed in errors"),
2811 }