debuginfo: Fix issue with associated types and struct fields

This commit is contained in:
Michael Woerister 2015-01-21 17:10:02 +01:00
parent 6869645e86
commit 3a44107f9e
2 changed files with 159 additions and 1 deletions

View file

@ -2068,7 +2068,13 @@ fn prepare_struct_metadata<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
unique_type_id,
containing_scope);
let fields = ty::struct_fields(cx.tcx(), def_id, substs);
let mut fields = ty::struct_fields(cx.tcx(), def_id, substs);
// The `Ty` values returned by `ty::struct_fields` can still contain
// `ty_projection` variants, so normalize those away.
for field in fields.iter_mut() {
field.mt.ty = monomorphize::normalize_associated_type(cx.tcx(), &field.mt.ty);
}
create_and_register_recursive_type_forward_declaration(
cx,

View file

@ -0,0 +1,152 @@
// 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-android: FIXME(#10381)
// min-lldb-version: 310
// compile-flags:-g
// === GDB TESTS ===================================================================================
// gdb-command:run
// gdb-command:print arg
// gdb-check:$1 = {b = -1, b1 = 0}
// gdb-command:continue
// gdb-command:print inferred
// gdb-check:$2 = 1
// gdb-command:print explicitly
// gdb-check:$3 = 1
// gdb-command:continue
// gdb-command:print arg
// gdb-check:$4 = 2
// gdb-command:continue
// gdb-command:print arg
// gdb-check:$5 = {4, 5}
// gdb-command:continue
// gdb-command:print a
// gdb-check:$6 = 6
// gdb-command:print b
// gdb-check:$7 = 7
// gdb-command:continue
// gdb-command:print a
// gdb-check:$8 = 8
// gdb-command:print b
// gdb-check:$9 = 9
// gdb-command:continue
// === LLDB TESTS ==================================================================================
// lldb-command:run
// lldb-command:print arg
// lldb-check:[...]$0 = Struct<i32> { b: -1, b1: 0 }
// lldb-command:continue
// lldb-command:print inferred
// lldb-check:[...]$1 = 1
// lldb-command:print explicitly
// lldb-check:[...]$2 = 1
// lldb-command:continue
// lldb-command:print arg
// lldb-check:[...]$3 = 2
// lldb-command:continue
// lldb-command:print arg
// lldb-check:[...]$4 = (4, 5)
// lldb-command:continue
// lldb-command:print a
// lldb-check:[...]$5 = 6
// lldb-command:print b
// lldb-check:[...]$6 = 7
// lldb-command:continue
// lldb-command:print a
// lldb-check:[...]$7 = 8
// lldb-command:print b
// lldb-check:[...]$8 = 9
// lldb-command:continue
#![allow(unused_variables)]
#![allow(dead_code)]
#![omit_gdb_pretty_printer_section]
trait TraitWithAssocType {
type Type;
fn get_value(&self) -> Self::Type;
}
impl TraitWithAssocType for i32 {
type Type = i64;
fn get_value(&self) -> i64 { *self as i64 }
}
struct Struct<T: TraitWithAssocType> {
b: T,
b1: T::Type,
}
enum Enum<T: TraitWithAssocType> {
Variant1(T, T::Type),
Variant2(T::Type, T)
}
fn assoc_struct<T: TraitWithAssocType>(arg: Struct<T>) {
zzz(); // #break
}
fn assoc_local<T: TraitWithAssocType>(x: T) {
let inferred = x.get_value();
let explicitly: T::Type = x.get_value();
zzz(); // #break
}
fn assoc_arg<T: TraitWithAssocType>(arg: T::Type) {
zzz(); // #break
}
fn assoc_return_value<T: TraitWithAssocType>(arg: T) -> T::Type {
return arg.get_value();
}
fn assoc_tuple<T: TraitWithAssocType>(arg: (T, T::Type)) {
zzz(); // #break
}
fn assoc_enum<T: TraitWithAssocType>(arg: Enum<T>) {
match arg {
Enum::Variant1(a, b) => {
zzz(); // #break
}
Enum::Variant2(a, b) => {
zzz(); // #break
}
}
}
fn main() {
assoc_struct(Struct { b: -1i32, b1: 0i64 });
assoc_local(1i32);
assoc_arg::<i32>(2i64);
assoc_return_value(3i32);
assoc_tuple((4i32, 5i64));
assoc_enum(Enum::Variant1(6i32, 7i64));
assoc_enum(Enum::Variant2(8i64, 9i32));
}
fn zzz() { () }