163 lines
4.7 KiB
Rust
163 lines
4.7 KiB
Rust
//@ ignore-test // Test temporarily ignored due to debuginfo tests being disabled, see PR 47155
|
|
|
|
//@ min-lldb-version: 310
|
|
|
|
//@ compile-flags:-g
|
|
|
|
// === GDB TESTS ===================================================================================
|
|
|
|
// gdb-command:run
|
|
|
|
// gdb-command:print some
|
|
// gdbg-check:$1 = {RUST$ENCODED$ENUM$0$None = {__0 = 0x12345678}}
|
|
// gdbr-check:$1 = core::option::Option<&u32>::Some(0x12345678)
|
|
|
|
// gdb-command:print none
|
|
// gdbg-check:$2 = {RUST$ENCODED$ENUM$0$None = {__0 = 0x0}}
|
|
// gdbr-check:$2 = core::option::Option<&u32>::None
|
|
|
|
// gdb-command:print full
|
|
// gdbg-check:$3 = {RUST$ENCODED$ENUM$1$Empty = {__0 = 454545, __1 = 0x87654321, __2 = 9988}}
|
|
// gdbr-check:$3 = option_like_enum::MoreFields::Full(454545, 0x87654321, 9988)
|
|
|
|
// gdbg-command:print empty_gdb->discr
|
|
// gdbr-command:print empty_gdb.discr
|
|
// gdb-check:$4 = (isize *) 0x0
|
|
|
|
// gdb-command:print droid
|
|
// gdbg-check:$5 = {RUST$ENCODED$ENUM$2$Void = {id = 675675, range = 10000001, internals = 0x43218765}}
|
|
// gdbr-check:$5 = option_like_enum::NamedFields::Droid{id: 675675, range: 10000001, internals: 0x43218765}
|
|
|
|
// gdbg-command:print void_droid_gdb->internals
|
|
// gdbr-command:print void_droid_gdb.internals
|
|
// gdb-check:$6 = (isize *) 0x0
|
|
|
|
// gdb-command:print nested_non_zero_yep
|
|
// gdbg-check:$7 = {RUST$ENCODED$ENUM$1$2$Nope = {__0 = 10.5, __1 = {a = 10, b = 20, c = [...]}}}
|
|
// gdbr-check:$7 = option_like_enum::NestedNonZero::Yep(10.5, option_like_enum::NestedNonZeroField {a: 10, b: 20, c: 0x[...] "x[...]"})
|
|
|
|
// gdb-command:print nested_non_zero_nope
|
|
// gdbg-check:$8 = {RUST$ENCODED$ENUM$1$2$Nope = {__0 = [...], __1 = {a = [...], b = [...], c = 0x0}}}
|
|
// gdbr-check:$8 = option_like_enum::NestedNonZero::Nope
|
|
|
|
// gdb-command:continue
|
|
|
|
|
|
// === LLDB TESTS ==================================================================================
|
|
|
|
// lldb-command:run
|
|
|
|
// lldb-command:v some
|
|
// lldb-check:[...] Some(&0x12345678)
|
|
|
|
// lldb-command:v none
|
|
// lldb-check:[...] None
|
|
|
|
// lldb-command:v full
|
|
// lldb-check:[...] Full(454545, &0x87654321, 9988)
|
|
|
|
// lldb-command:v empty
|
|
// lldb-check:[...] Empty
|
|
|
|
// lldb-command:v droid
|
|
// lldb-check:[...] Droid { id: 675675, range: 10000001, internals: &0x43218765 }
|
|
|
|
// 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.
|
|
// If the non-empty variant contains a single non-nullable pointer than the whole
|
|
// item is represented as just a pointer and not wrapped in a struct.
|
|
// Unfortunately (for these test cases) the content of the non-discriminant fields
|
|
// in the null-case is not defined. So we just read the discriminator field in
|
|
// this case (by casting the value to a memory-equivalent struct).
|
|
|
|
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(unsafe { std::mem::transmute(0x12345678_usize) });
|
|
let none: Option<&u32> = None;
|
|
|
|
let full = MoreFields::Full(454545, unsafe { std::mem::transmute(0x87654321_usize) }, 9988);
|
|
|
|
let empty = MoreFields::Empty;
|
|
let empty_gdb: &MoreFieldsRepr = unsafe { std::mem::transmute(&MoreFields::Empty) };
|
|
|
|
let droid = NamedFields::Droid {
|
|
id: 675675,
|
|
range: 10000001,
|
|
internals: unsafe { std::mem::transmute(0x43218765_usize) }
|
|
};
|
|
|
|
let void_droid = NamedFields::Void;
|
|
let void_droid_gdb: &NamedFieldsRepr = unsafe { std::mem::transmute(&NamedFields::Void) };
|
|
|
|
let x = 'x';
|
|
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() {()}
|