debuginfo: Fix type description generic enum discriminants.

This commit is contained in:
Michael Woerister 2015-07-16 01:34:13 -07:00
parent e4e93196e1
commit f9a20bb206
3 changed files with 98 additions and 9 deletions

View file

@ -1606,13 +1606,10 @@ fn prepare_enum_metadata<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
.collect(); .collect();
let discriminant_type_metadata = |inttype| { let discriminant_type_metadata = |inttype| {
// We can reuse the type of the discriminant for all monomorphized let disr_type_key = (enum_def_id, inttype);
// instances of an enum because it doesn't depend on any type
// parameters. The def_id, uniquely identifying the enum's polytype acts
// as key in this cache.
let cached_discriminant_type_metadata = debug_context(cx).created_enum_disr_types let cached_discriminant_type_metadata = debug_context(cx).created_enum_disr_types
.borrow() .borrow()
.get(&enum_def_id).cloned(); .get(&disr_type_key).cloned();
match cached_discriminant_type_metadata { match cached_discriminant_type_metadata {
Some(discriminant_type_metadata) => discriminant_type_metadata, Some(discriminant_type_metadata) => discriminant_type_metadata,
None => { None => {
@ -1641,7 +1638,7 @@ fn prepare_enum_metadata<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
debug_context(cx).created_enum_disr_types debug_context(cx).created_enum_disr_types
.borrow_mut() .borrow_mut()
.insert(enum_def_id, discriminant_type_metadata); .insert(disr_type_key, discriminant_type_metadata);
discriminant_type_metadata discriminant_type_metadata
} }

View file

@ -32,7 +32,7 @@ use trans;
use trans::monomorphize; use trans::monomorphize;
use middle::ty::Ty; use middle::ty::Ty;
use session::config::{self, FullDebugInfo, LimitedDebugInfo, NoDebugInfo}; use session::config::{self, FullDebugInfo, LimitedDebugInfo, NoDebugInfo};
use util::nodemap::{DefIdMap, NodeMap, FnvHashMap, FnvHashSet}; use util::nodemap::{NodeMap, FnvHashMap, FnvHashSet};
use libc::c_uint; use libc::c_uint;
use std::cell::{Cell, RefCell}; use std::cell::{Cell, RefCell};
@ -41,6 +41,7 @@ use std::ptr;
use std::rc::Rc; use std::rc::Rc;
use syntax::codemap::{Span, Pos}; use syntax::codemap::{Span, Pos};
use syntax::{ast, codemap, ast_util}; use syntax::{ast, codemap, ast_util};
use syntax::attr::IntType;
use syntax::parse::token::{self, special_idents}; use syntax::parse::token::{self, special_idents};
pub mod gdb; pub mod gdb;
@ -73,7 +74,7 @@ pub struct CrateDebugContext<'tcx> {
builder: DIBuilderRef, builder: DIBuilderRef,
current_debug_location: Cell<InternalDebugLocation>, current_debug_location: Cell<InternalDebugLocation>,
created_files: RefCell<FnvHashMap<String, DIFile>>, created_files: RefCell<FnvHashMap<String, DIFile>>,
created_enum_disr_types: RefCell<DefIdMap<DIType>>, created_enum_disr_types: RefCell<FnvHashMap<(ast::DefId, IntType), DIType>>,
type_map: RefCell<TypeMap<'tcx>>, type_map: RefCell<TypeMap<'tcx>>,
namespace_map: RefCell<FnvHashMap<Vec<ast::Name>, Rc<NamespaceTreeNode>>>, namespace_map: RefCell<FnvHashMap<Vec<ast::Name>, Rc<NamespaceTreeNode>>>,
@ -94,7 +95,7 @@ impl<'tcx> CrateDebugContext<'tcx> {
builder: builder, builder: builder,
current_debug_location: Cell::new(InternalDebugLocation::UnknownLocation), current_debug_location: Cell::new(InternalDebugLocation::UnknownLocation),
created_files: RefCell::new(FnvHashMap()), created_files: RefCell::new(FnvHashMap()),
created_enum_disr_types: RefCell::new(DefIdMap()), created_enum_disr_types: RefCell::new(FnvHashMap()),
type_map: RefCell::new(TypeMap::new()), type_map: RefCell::new(TypeMap::new()),
namespace_map: RefCell::new(FnvHashMap()), namespace_map: RefCell::new(FnvHashMap()),
composite_types_completed: RefCell::new(FnvHashSet()), composite_types_completed: RefCell::new(FnvHashSet()),

View file

@ -0,0 +1,91 @@
// 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
// min-lldb-version: 310
// compile-flags:-g
// === GDB TESTS ===================================================================================
// gdb-command:run
// gdb-command:print eight_bytes1
// gdb-check:$1 = {{RUST$ENUM$DISR = Variant1, __0 = 100}, {RUST$ENUM$DISR = Variant1, __0 = 100}}
// gdb-command:print four_bytes1
// gdb-check:$2 = {{RUST$ENUM$DISR = Variant1, __0 = 101}, {RUST$ENUM$DISR = Variant1, __0 = 101}}
// gdb-command:print two_bytes1
// gdb-check:$3 = {{RUST$ENUM$DISR = Variant1, __0 = 102}, {RUST$ENUM$DISR = Variant1, __0 = 102}}
// gdb-command:print one_byte1
// gdb-check:$4 = {{RUST$ENUM$DISR = Variant1, __0 = 65 'A'}, {RUST$ENUM$DISR = Variant1, __0 = 65 'A'}}
// gdb-command:print eight_bytes2
// gdb-check:$5 = {{RUST$ENUM$DISR = Variant2, __0 = 100}, {RUST$ENUM$DISR = Variant2, __0 = 100}}
// gdb-command:print four_bytes2
// gdb-check:$6 = {{RUST$ENUM$DISR = Variant2, __0 = 101}, {RUST$ENUM$DISR = Variant2, __0 = 101}}
// gdb-command:print two_bytes2
// gdb-check:$7 = {{RUST$ENUM$DISR = Variant2, __0 = 102}, {RUST$ENUM$DISR = Variant2, __0 = 102}}
// gdb-command:print one_byte2
// gdb-check:$8 = {{RUST$ENUM$DISR = Variant2, __0 = 65 'A'}, {RUST$ENUM$DISR = Variant2, __0 = 65 'A'}}
// gdb-command:continue
// === LLDB TESTS ==================================================================================
// lldb-command:run
// lldb-command:print eight_bytes1
// lldb-check:[...]$0 = Variant1(100)
// lldb-command:print four_bytes1
// lldb-check:[...]$1 = Variant1(101)
// lldb-command:print two_bytes1
// lldb-check:[...]$2 = Variant1(102)
// lldb-command:print one_byte1
// lldb-check:[...]$3 = Variant1('A')
// lldb-command:print eight_bytes2
// lldb-check:[...]$4 = Variant2(100)
// lldb-command:print four_bytes2
// lldb-check:[...]$5 = Variant2(101)
// lldb-command:print two_bytes2
// lldb-check:[...]$6 = Variant2(102)
// lldb-command:print one_byte2
// lldb-check:[...]$7 = Variant2('A')
// lldb-command:continue
#![allow(unused_variables)]
#![allow(dead_code)]
#![omit_gdb_pretty_printer_section]
// This test case makes sure that we get correct type descriptions for the enum
// discriminant of different instantiations of the same generic enum type where,
// dependending on the generic type parameter(s), the discriminant has a
// different size in memory.
enum Enum<T> {
Variant1(T),
Variant2(T)
}
fn main() {
// These are ordered for descending size on purpose
let eight_bytes1 = Enum::Variant1(100.0f64);
let four_bytes1 = Enum::Variant1(101i32);
let two_bytes1 = Enum::Variant1(102i16);
let one_byte1 = Enum::Variant1(65u8);
let eight_bytes2 = Enum::Variant2(100.0f64);
let four_bytes2 = Enum::Variant2(101i32);
let two_bytes2 = Enum::Variant2(102i16);
let one_byte2 = Enum::Variant2(65u8);
zzz(); // #break
}
fn zzz() { () }