//@ min-lldb-version: 1800 //@ min-gdb-version: 13.0 //@ compile-flags:-g // === GDB TESTS =================================================================================== // gdb-command:run // gdb-command:print some // gdb-check:$1 = core::option::Option<&u32>::Some(0x[...]) // gdb-command:print none // gdb-check:$2 = core::option::Option<&u32>::None // gdb-command:print full // gdb-check:$3 = option_like_enum::MoreFields::Full(454545, 0x[...], 9988) // gdb-command:print empty // gdb-check:$4 = option_like_enum::MoreFields::Empty // gdb-command:print droid // gdb-check:$5 = option_like_enum::NamedFields::Droid{id: 675675, range: 10000001, internals: 0x[...]} // gdb-command:print void_droid // gdb-check:$6 = option_like_enum::NamedFields::Void // gdb-command:print nested_non_zero_yep // gdb-check:$7 = option_like_enum::NestedNonZero::Yep(10.5, option_like_enum::NestedNonZeroField {a: 10, b: 20, c: 0x[...]}) // gdb-command:print nested_non_zero_nope // gdb-check:$8 = option_like_enum::NestedNonZero::Nope // gdb-command:continue // === LLDB TESTS ================================================================================== // lldb-command:run // lldb-command:v some // lldb-check:[...] Some(&0x[...]) // lldb-command:v none // lldb-check:[...] None // lldb-command:v full // lldb-check:[...] Full(454545, &0x[...], 9988) // lldb-command:v empty // lldb-check:[...] Empty // lldb-command:v droid // lldb-check:[...] Droid { id: 675675, range: 10000001, internals: &0x[...] } // lldb-command:v void_droid // lldb-check:[...] Void // lldb-command:v some_str // lldb-check:[...] Some("abc") // lldb-command:v none_str // lldb-check:[...] None // lldb-command:v nested_non_zero_yep // lldb-check:[...] Yep(10.5, NestedNonZeroField { a: 10, b: 20, c: &[...] }) // lldb-command:v nested_non_zero_nope // lldb-check:[...] Nope #![feature(omit_gdb_pretty_printer_section)] #![omit_gdb_pretty_printer_section] // If a struct has exactly two variants, one of them is empty, and the other one // contains a non-nullable pointer, then this value is used as the discriminator. // The test cases in this file make sure that something readable is generated for // this kind of types. enum MoreFields<'a> { Full(u32, &'a isize, i16), Empty } struct MoreFieldsRepr<'a> { a: u32, discr: &'a isize, b: i16 } enum NamedFields<'a> { Droid { id: i32, range: i64, internals: &'a isize }, Void } struct NamedFieldsRepr<'a> { id: i32, range: i64, internals: &'a isize } struct NestedNonZeroField<'a> { a: u16, b: u32, c: &'a char, } enum NestedNonZero<'a> { Yep(f64, NestedNonZeroField<'a>), Nope } fn main() { let some_str: Option<&'static str> = Some("abc"); let none_str: Option<&'static str> = None; let some: Option<&u32> = Some(&1234); let none: Option<&u32> = None; let full = MoreFields::Full(454545, &1234, 9988); let empty = MoreFields::Empty; let droid = NamedFields::Droid { id: 675675, range: 10000001, internals: &1234, }; let void_droid = NamedFields::Void; let nested_non_zero_yep = NestedNonZero::Yep( 10.5, NestedNonZeroField { a: 10, b: 20, c: &'x', }); let nested_non_zero_nope = NestedNonZero::Nope; zzz(); // #break } fn zzz() {()}