Skip to content

Commit

Permalink
debuginfo: Fix issue with associated types and struct fields
Browse files Browse the repository at this point in the history
  • Loading branch information
michaelwoerister committed Jan 21, 2015
1 parent 6869645 commit 3a44107
Show file tree
Hide file tree
Showing 2 changed files with 159 additions and 1 deletion.
8 changes: 7 additions & 1 deletion src/librustc_trans/trans/debuginfo.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down
152 changes: 152 additions & 0 deletions src/test/debuginfo/associated-types.rs
Original file line number Diff line number Diff line change
@@ -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() { () }

0 comments on commit 3a44107

Please sign in to comment.