ac33b2e578
If the rust-enabled lldb was built, then use it when running the debuginfo tests. Updating the lldb submodule was necessary as this needed a way to differentiate the rust-enabled lldb, so I added a line to the --version output. This adds compiletest commands to differentiate between the rust-enabled and non-rust-enabled lldb, as is already done for gdb. A new "rust-lldb" header directive is also added, but not used in this patch; I plan to use it in #54004. This updates all the tests.
174 lines
5.0 KiB
Rust
174 lines
5.0 KiB
Rust
// Copyright 2013-2014 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
// ignore-tidy-linelength
|
|
|
|
// compile-flags:-g
|
|
// min-lldb-version: 310
|
|
|
|
// === GDB TESTS ===================================================================================
|
|
|
|
// gdb-command:run
|
|
|
|
// STACK BY REF
|
|
// gdb-command:print *self
|
|
// gdbg-check:$1 = {x = {__0 = 8888, __1 = -8888}}
|
|
// gdbr-check:$1 = generic_method_on_generic_struct::Struct<(u32, i32)> {x: (8888, -8888)}
|
|
// gdb-command:print arg1
|
|
// gdb-check:$2 = -1
|
|
// gdb-command:print arg2
|
|
// gdb-check:$3 = 2
|
|
// gdb-command:continue
|
|
|
|
// STACK BY VAL
|
|
// gdb-command:print self
|
|
// gdbg-check:$4 = {x = {__0 = 8888, __1 = -8888}}
|
|
// gdbr-check:$4 = generic_method_on_generic_struct::Struct<(u32, i32)> {x: (8888, -8888)}
|
|
// gdb-command:print arg1
|
|
// gdb-check:$5 = -3
|
|
// gdb-command:print arg2
|
|
// gdb-check:$6 = -4
|
|
// gdb-command:continue
|
|
|
|
// OWNED BY REF
|
|
// gdb-command:print *self
|
|
// gdbg-check:$7 = {x = 1234.5}
|
|
// gdbr-check:$7 = generic_method_on_generic_struct::Struct<f64> {x: 1234.5}
|
|
// gdb-command:print arg1
|
|
// gdb-check:$8 = -5
|
|
// gdb-command:print arg2
|
|
// gdb-check:$9 = -6
|
|
// gdb-command:continue
|
|
|
|
// OWNED BY VAL
|
|
// gdb-command:print self
|
|
// gdbg-check:$10 = {x = 1234.5}
|
|
// gdbr-check:$10 = generic_method_on_generic_struct::Struct<f64> {x: 1234.5}
|
|
// gdb-command:print arg1
|
|
// gdb-check:$11 = -7
|
|
// gdb-command:print arg2
|
|
// gdb-check:$12 = -8
|
|
// gdb-command:continue
|
|
|
|
// OWNED MOVED
|
|
// gdb-command:print *self
|
|
// gdbg-check:$13 = {x = 1234.5}
|
|
// gdbr-check:$13 = generic_method_on_generic_struct::Struct<f64> {x: 1234.5}
|
|
// gdb-command:print arg1
|
|
// gdb-check:$14 = -9
|
|
// gdb-command:print arg2
|
|
// gdb-check:$15 = -10.5
|
|
// gdb-command:continue
|
|
|
|
|
|
// === LLDB TESTS ==================================================================================
|
|
|
|
// lldb-command:run
|
|
|
|
// STACK BY REF
|
|
// lldb-command:print *self
|
|
// lldbg-check:[...]$0 = Struct<(u32, i32)> { x: (8888, -8888) }
|
|
// lldbr-check:(generic_method_on_generic_struct::Struct<(u32, i32)>) *self = { x = { = 8888 = -8888 } }
|
|
// lldb-command:print arg1
|
|
// lldbg-check:[...]$1 = -1
|
|
// lldbr-check:(isize) arg1 = -1
|
|
// lldb-command:print arg2
|
|
// lldbg-check:[...]$2 = 2
|
|
// lldbr-check:(u16) arg2 = 2
|
|
// lldb-command:continue
|
|
|
|
// STACK BY VAL
|
|
// lldb-command:print self
|
|
// lldbg-check:[...]$3 = Struct<(u32, i32)> { x: (8888, -8888) }
|
|
// lldbr-check:(generic_method_on_generic_struct::Struct<(u32, i32)>) self = { x = { = 8888 = -8888 } }
|
|
// lldb-command:print arg1
|
|
// lldbg-check:[...]$4 = -3
|
|
// lldbr-check:(isize) arg1 = -3
|
|
// lldb-command:print arg2
|
|
// lldbg-check:[...]$5 = -4
|
|
// lldbr-check:(i16) arg2 = -4
|
|
// lldb-command:continue
|
|
|
|
// OWNED BY REF
|
|
// lldb-command:print *self
|
|
// lldbg-check:[...]$6 = Struct<f64> { x: 1234.5 }
|
|
// lldbr-check:(generic_method_on_generic_struct::Struct<f64>) *self = Struct<f64> { x: 1234.5 }
|
|
// lldb-command:print arg1
|
|
// lldbg-check:[...]$7 = -5
|
|
// lldbr-check:(isize) arg1 = -5
|
|
// lldb-command:print arg2
|
|
// lldbg-check:[...]$8 = -6
|
|
// lldbr-check:(i32) arg2 = -6
|
|
// lldb-command:continue
|
|
|
|
// OWNED BY VAL
|
|
// lldb-command:print self
|
|
// lldbg-check:[...]$9 = Struct<f64> { x: 1234.5 }
|
|
// lldbr-check:(generic_method_on_generic_struct::Struct<f64>) self = Struct<f64> { x: 1234.5 }
|
|
// lldb-command:print arg1
|
|
// lldbg-check:[...]$10 = -7
|
|
// lldbr-check:(isize) arg1 = -7
|
|
// lldb-command:print arg2
|
|
// lldbg-check:[...]$11 = -8
|
|
// lldbr-check:(i64) arg2 = -8
|
|
// lldb-command:continue
|
|
|
|
// OWNED MOVED
|
|
// lldb-command:print *self
|
|
// lldbg-check:[...]$12 = Struct<f64> { x: 1234.5 }
|
|
// lldbr-check:(generic_method_on_generic_struct::Struct<f64>) *self = Struct<f64> { x: 1234.5 }
|
|
// lldb-command:print arg1
|
|
// lldbg-check:[...]$13 = -9
|
|
// lldbr-check:(isize) arg1 = -9
|
|
// lldb-command:print arg2
|
|
// lldbg-check:[...]$14 = -10.5
|
|
// lldbr-check:(f32) arg2 = -10.5
|
|
// lldb-command:continue
|
|
|
|
#![feature(box_syntax)]
|
|
#![feature(omit_gdb_pretty_printer_section)]
|
|
#![omit_gdb_pretty_printer_section]
|
|
|
|
#[derive(Copy, Clone)]
|
|
struct Struct<T> {
|
|
x: T
|
|
}
|
|
|
|
impl<T1> Struct<T1> {
|
|
|
|
fn self_by_ref<T2>(&self, arg1: isize, arg2: T2) -> isize {
|
|
zzz(); // #break
|
|
arg1
|
|
}
|
|
|
|
fn self_by_val<T2>(self, arg1: isize, arg2: T2) -> isize {
|
|
zzz(); // #break
|
|
arg1
|
|
}
|
|
|
|
fn self_owned<T2>(self: Box<Struct<T1>>, arg1: isize, arg2: T2) -> isize {
|
|
zzz(); // #break
|
|
arg1
|
|
}
|
|
}
|
|
|
|
fn main() {
|
|
let stack = Struct { x: (8888_u32, -8888_i32) };
|
|
let _ = stack.self_by_ref(-1, 2_u16);
|
|
let _ = stack.self_by_val(-3, -4_i16);
|
|
|
|
let owned: Box<_> = box Struct { x: 1234.5f64 };
|
|
let _ = owned.self_by_ref(-5, -6_i32);
|
|
let _ = owned.self_by_val(-7, -8_i64);
|
|
let _ = owned.self_owned(-9, -10.5_f32);
|
|
}
|
|
|
|
fn zzz() {()}
|