2014-10-09 16:31:03 +02:00
|
|
|
// min-lldb-version: 310
|
2018-09-26 12:58:10 -06:00
|
|
|
|
2020-04-14 12:10:58 -07:00
|
|
|
// Require a gdb that can read DW_TAG_variant_part.
|
2018-09-26 12:58:10 -06:00
|
|
|
// min-gdb-version: 8.2
|
2013-11-04 15:53:01 +09:00
|
|
|
|
2014-02-06 19:57:09 -08:00
|
|
|
// compile-flags:-g
|
2014-10-09 16:31:03 +02:00
|
|
|
|
2014-04-24 11:35:48 +02:00
|
|
|
// gdb-command:set print union on
|
|
|
|
// gdb-command:run
|
2013-08-13 16:31:42 +02:00
|
|
|
|
2014-04-24 11:35:48 +02:00
|
|
|
// gdb-command:print case1
|
2018-09-26 12:58:10 -06:00
|
|
|
// gdbr-check:$1 = generic_struct_style_enum::Regular<u16, u32, i64>::Case1{a: 0, b: 31868, c: 31868, d: 31868, e: 31868}
|
2013-08-13 16:31:42 +02:00
|
|
|
|
2014-04-24 11:35:48 +02:00
|
|
|
// gdb-command:print case2
|
2018-09-26 12:58:10 -06:00
|
|
|
// gdbr-check:$2 = generic_struct_style_enum::Regular<i16, u32, i64>::Case2{a: 0, b: 286331153, c: 286331153}
|
2013-08-13 16:31:42 +02:00
|
|
|
|
2014-04-24 11:35:48 +02:00
|
|
|
// gdb-command:print case3
|
2018-09-26 12:58:10 -06:00
|
|
|
// gdbr-check:$3 = generic_struct_style_enum::Regular<u16, i32, u64>::Case3{a: 0, b: 6438275382588823897}
|
2013-08-13 16:31:42 +02:00
|
|
|
|
2014-04-24 11:35:48 +02:00
|
|
|
// gdb-command:print univariant
|
2016-10-25 23:32:04 +02:00
|
|
|
// gdbr-check:$4 = generic_struct_style_enum::Univariant<i32>::TheOnlyCase{a: -1}
|
2013-08-13 16:31:42 +02:00
|
|
|
|
2014-12-03 14:48:18 -08:00
|
|
|
|
2015-09-19 16:33:47 -04:00
|
|
|
#![feature(omit_gdb_pretty_printer_section)]
|
2014-12-03 14:48:18 -08:00
|
|
|
#![omit_gdb_pretty_printer_section]
|
|
|
|
|
2014-11-06 00:05:53 -08:00
|
|
|
use self::Regular::{Case1, Case2, Case3};
|
|
|
|
use self::Univariant::TheOnlyCase;
|
|
|
|
|
2013-08-13 16:31:42 +02:00
|
|
|
// NOTE: This is a copy of the non-generic test case. The `Txx` type parameters have to be
|
|
|
|
// substituted with something of size `xx` bits and the same alignment as an integer type of the
|
|
|
|
// same size.
|
|
|
|
|
|
|
|
// The first element is to ensure proper alignment, irrespective of the machines word size. Since
|
|
|
|
// the size of the discriminant value is machine dependent, this has be taken into account when
|
|
|
|
// datatype layout should be predictable as in this case.
|
|
|
|
enum Regular<T16, T32, T64> {
|
|
|
|
Case1 { a: T64, b: T16, c: T16, d: T16, e: T16},
|
|
|
|
Case2 { a: T64, b: T32, c: T32},
|
|
|
|
Case3 { a: T64, b: T64 }
|
|
|
|
}
|
|
|
|
|
|
|
|
enum Univariant<T> {
|
|
|
|
TheOnlyCase { a: T }
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
|
2015-03-28 18:09:51 +03:00
|
|
|
// In order to avoid endianness trouble all of the following test values consist of a single
|
2013-08-13 16:31:42 +02:00
|
|
|
// repeated byte. This way each interpretation of the union should look the same, no matter if
|
|
|
|
// this is a big or little endian machine.
|
|
|
|
|
|
|
|
// 0b0111110001111100011111000111110001111100011111000111110001111100 = 8970181431921507452
|
|
|
|
// 0b01111100011111000111110001111100 = 2088533116
|
|
|
|
// 0b0111110001111100 = 31868
|
|
|
|
// 0b01111100 = 124
|
|
|
|
let case1: Regular<u16, u32, i64> = Case1 { a: 0, b: 31868, c: 31868, d: 31868, e: 31868 };
|
|
|
|
|
|
|
|
// 0b0001000100010001000100010001000100010001000100010001000100010001 = 1229782938247303441
|
|
|
|
// 0b00010001000100010001000100010001 = 286331153
|
|
|
|
// 0b0001000100010001 = 4369
|
|
|
|
// 0b00010001 = 17
|
|
|
|
let case2: Regular<i16, u32, i64> = Case2 { a: 0, b: 286331153, c: 286331153 };
|
|
|
|
|
|
|
|
// 0b0101100101011001010110010101100101011001010110010101100101011001 = 6438275382588823897
|
|
|
|
// 0b01011001010110010101100101011001 = 1499027801
|
|
|
|
// 0b0101100101011001 = 22873
|
|
|
|
// 0b01011001 = 89
|
|
|
|
let case3: Regular<u16, i32, u64> = Case3 { a: 0, b: 6438275382588823897 };
|
|
|
|
|
2015-01-25 22:05:03 +01:00
|
|
|
let univariant = TheOnlyCase { a: -1 };
|
2013-08-13 16:31:42 +02:00
|
|
|
|
2014-10-29 10:13:29 +04:00
|
|
|
zzz(); // #break
|
2013-08-13 16:31:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn zzz() {()}
|