mirror of https://github.com/rust-lang/rust.git
141 lines
4.0 KiB
Rust
141 lines
4.0 KiB
Rust
//@ compile-flags:-g
|
|
|
|
// === GDB TESTS ===================================================================================
|
|
|
|
// gdb-command:run
|
|
|
|
// gdb-command:print tuple_interior_padding
|
|
// gdb-check:$1 = (0, c_style_enum_in_composite::AnEnum::OneHundred)
|
|
|
|
// gdb-command:print tuple_padding_at_end
|
|
// gdb-check:$2 = ((1, c_style_enum_in_composite::AnEnum::OneThousand), 2)
|
|
|
|
// gdb-command:print tuple_different_enums
|
|
// gdb-check:$3 = (c_style_enum_in_composite::AnEnum::OneThousand, c_style_enum_in_composite::AnotherEnum::MountainView, c_style_enum_in_composite::AnEnum::OneMillion, c_style_enum_in_composite::AnotherEnum::Vienna)
|
|
|
|
// gdb-command:print padded_struct
|
|
// gdb-check:$4 = c_style_enum_in_composite::PaddedStruct {a: 3, b: c_style_enum_in_composite::AnEnum::OneMillion, c: 4, d: c_style_enum_in_composite::AnotherEnum::Toronto, e: 5}
|
|
|
|
// gdb-command:print packed_struct
|
|
// gdb-check:$5 = c_style_enum_in_composite::PackedStruct {a: 6, b: c_style_enum_in_composite::AnEnum::OneHundred, c: 7, d: c_style_enum_in_composite::AnotherEnum::Vienna, e: 8}
|
|
|
|
// gdb-command:print non_padded_struct
|
|
// gdb-check:$6 = c_style_enum_in_composite::NonPaddedStruct {a: c_style_enum_in_composite::AnEnum::OneMillion, b: c_style_enum_in_composite::AnotherEnum::MountainView, c: c_style_enum_in_composite::AnEnum::OneThousand, d: c_style_enum_in_composite::AnotherEnum::Toronto}
|
|
|
|
// gdb-command:print struct_with_drop
|
|
// gdb-check:$7 = (c_style_enum_in_composite::StructWithDrop {a: c_style_enum_in_composite::AnEnum::OneHundred, b: c_style_enum_in_composite::AnotherEnum::Vienna}, 9)
|
|
|
|
// === LLDB TESTS ==================================================================================
|
|
|
|
// lldb-command:run
|
|
|
|
// lldb-command:v tuple_interior_padding
|
|
// lldb-check:[...] { 0 = 0 1 = OneHundred }
|
|
|
|
// lldb-command:v tuple_padding_at_end
|
|
// lldb-check:[...] { 0 = { 0 = 1 1 = OneThousand } 1 = 2 }
|
|
|
|
// lldb-command:v tuple_different_enums
|
|
// lldb-check:[...] { 0 = OneThousand 1 = MountainView 2 = OneMillion 3 = Vienna }
|
|
|
|
// lldb-command:v padded_struct
|
|
// lldb-check:[...] { a = 3 b = OneMillion c = 4 d = Toronto e = 5 }
|
|
|
|
// lldb-command:v packed_struct
|
|
// lldb-check:[...] { a = 6 b = OneHundred c = 7 d = Vienna e = 8 }
|
|
|
|
// lldb-command:v non_padded_struct
|
|
// lldb-check:[...] { a = OneMillion b = MountainView c = OneThousand d = Toronto }
|
|
|
|
// lldb-command:v struct_with_drop
|
|
// lldb-check:[...] { 0 = { a = OneHundred b = Vienna } 1 = 9 }
|
|
|
|
#![allow(unused_variables)]
|
|
#![feature(omit_gdb_pretty_printer_section)]
|
|
#![omit_gdb_pretty_printer_section]
|
|
|
|
use self::AnEnum::{OneHundred, OneThousand, OneMillion};
|
|
use self::AnotherEnum::{MountainView, Toronto, Vienna};
|
|
|
|
enum AnEnum {
|
|
OneHundred = 100,
|
|
OneThousand = 1000,
|
|
OneMillion = 1000000
|
|
}
|
|
|
|
enum AnotherEnum {
|
|
MountainView,
|
|
Toronto,
|
|
Vienna
|
|
}
|
|
|
|
struct PaddedStruct {
|
|
a: i16,
|
|
b: AnEnum,
|
|
c: i16,
|
|
d: AnotherEnum,
|
|
e: i16
|
|
}
|
|
|
|
#[repr(packed)]
|
|
struct PackedStruct {
|
|
a: i16,
|
|
b: AnEnum,
|
|
c: i16,
|
|
d: AnotherEnum,
|
|
e: i16
|
|
}
|
|
|
|
struct NonPaddedStruct {
|
|
a: AnEnum,
|
|
b: AnotherEnum,
|
|
c: AnEnum,
|
|
d: AnotherEnum
|
|
}
|
|
|
|
struct StructWithDrop {
|
|
a: AnEnum,
|
|
b: AnotherEnum
|
|
}
|
|
|
|
impl Drop for StructWithDrop {
|
|
fn drop(&mut self) {()}
|
|
}
|
|
|
|
fn main() {
|
|
|
|
let tuple_interior_padding = (0_i16, OneHundred);
|
|
// It will depend on the machine architecture if any padding is actually involved here
|
|
let tuple_padding_at_end = ((1_u64, OneThousand), 2_u64);
|
|
let tuple_different_enums = (OneThousand, MountainView, OneMillion, Vienna);
|
|
|
|
let padded_struct = PaddedStruct {
|
|
a: 3,
|
|
b: OneMillion,
|
|
c: 4,
|
|
d: Toronto,
|
|
e: 5
|
|
};
|
|
|
|
let packed_struct = PackedStruct {
|
|
a: 6,
|
|
b: OneHundred,
|
|
c: 7,
|
|
d: Vienna,
|
|
e: 8
|
|
};
|
|
|
|
let non_padded_struct = NonPaddedStruct {
|
|
a: OneMillion,
|
|
b: MountainView,
|
|
c: OneThousand,
|
|
d: Toronto
|
|
};
|
|
|
|
let struct_with_drop = (StructWithDrop { a: OneHundred, b: Vienna }, 9_i64);
|
|
|
|
zzz(); // #break
|
|
}
|
|
|
|
fn zzz() { () }
|