debuginfo: Clean the debuginfo module up a bit.
This commit is contained in:
parent
b048114718
commit
34a6fcf195
@ -182,7 +182,6 @@
|
|||||||
//! comparatively expensive to construct, though, `ty::type_id()` is still used
|
//! comparatively expensive to construct, though, `ty::type_id()` is still used
|
||||||
//! additionally as an optimization for cases where the exact same type has been
|
//! additionally as an optimization for cases where the exact same type has been
|
||||||
//! seen before (which is most of the time).
|
//! seen before (which is most of the time).
|
||||||
use self::FunctionDebugContextRepr::*;
|
|
||||||
use self::VariableAccess::*;
|
use self::VariableAccess::*;
|
||||||
use self::VariableKind::*;
|
use self::VariableKind::*;
|
||||||
use self::MemberOffset::*;
|
use self::MemberOffset::*;
|
||||||
@ -681,12 +680,8 @@ impl<'tcx> CrateDebugContext<'tcx> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct FunctionDebugContext {
|
pub enum FunctionDebugContext {
|
||||||
repr: FunctionDebugContextRepr,
|
RegularContext(Box<FunctionDebugContextData>),
|
||||||
}
|
|
||||||
|
|
||||||
enum FunctionDebugContextRepr {
|
|
||||||
DebugInfo(Box<FunctionDebugContextData>),
|
|
||||||
DebugInfoDisabled,
|
DebugInfoDisabled,
|
||||||
FunctionWithoutDebugInfo,
|
FunctionWithoutDebugInfo,
|
||||||
}
|
}
|
||||||
@ -696,13 +691,13 @@ impl FunctionDebugContext {
|
|||||||
cx: &CrateContext,
|
cx: &CrateContext,
|
||||||
span: Span)
|
span: Span)
|
||||||
-> &'a FunctionDebugContextData {
|
-> &'a FunctionDebugContextData {
|
||||||
match self.repr {
|
match *self {
|
||||||
DebugInfo(box ref data) => data,
|
FunctionDebugContext::RegularContext(box ref data) => data,
|
||||||
DebugInfoDisabled => {
|
FunctionDebugContext::DebugInfoDisabled => {
|
||||||
cx.sess().span_bug(span,
|
cx.sess().span_bug(span,
|
||||||
FunctionDebugContext::debuginfo_disabled_message());
|
FunctionDebugContext::debuginfo_disabled_message());
|
||||||
}
|
}
|
||||||
FunctionWithoutDebugInfo => {
|
FunctionDebugContext::FunctionWithoutDebugInfo => {
|
||||||
cx.sess().span_bug(span,
|
cx.sess().span_bug(span,
|
||||||
FunctionDebugContext::should_be_ignored_message());
|
FunctionDebugContext::should_be_ignored_message());
|
||||||
}
|
}
|
||||||
@ -846,6 +841,8 @@ pub fn create_global_var_metadata(cx: &CrateContext,
|
|||||||
|
|
||||||
/// Creates debug information for the given local variable.
|
/// Creates debug information for the given local variable.
|
||||||
///
|
///
|
||||||
|
/// This function assumes that there's a datum for each pattern component of the
|
||||||
|
/// local in `bcx.fcx.lllocals`.
|
||||||
/// Adds the created metadata nodes directly to the crate's IR.
|
/// Adds the created metadata nodes directly to the crate's IR.
|
||||||
pub fn create_local_var_metadata(bcx: Block, local: &ast::Local) {
|
pub fn create_local_var_metadata(bcx: Block, local: &ast::Local) {
|
||||||
if fn_should_be_ignored(bcx.fcx) {
|
if fn_should_be_ignored(bcx.fcx) {
|
||||||
@ -854,11 +851,10 @@ pub fn create_local_var_metadata(bcx: Block, local: &ast::Local) {
|
|||||||
|
|
||||||
let cx = bcx.ccx();
|
let cx = bcx.ccx();
|
||||||
let def_map = &cx.tcx().def_map;
|
let def_map = &cx.tcx().def_map;
|
||||||
|
let locals = bcx.fcx.lllocals.borrow();
|
||||||
|
|
||||||
pat_util::pat_bindings(def_map, &*local.pat, |_, node_id, span, path1| {
|
pat_util::pat_bindings(def_map, &*local.pat, |_, node_id, span, var_ident| {
|
||||||
let var_ident = path1.node;
|
let datum = match locals.get(&node_id) {
|
||||||
|
|
||||||
let datum = match bcx.fcx.lllocals.borrow().get(&node_id).cloned() {
|
|
||||||
Some(datum) => datum,
|
Some(datum) => datum,
|
||||||
None => {
|
None => {
|
||||||
bcx.sess().span_bug(span,
|
bcx.sess().span_bug(span,
|
||||||
@ -867,10 +863,15 @@ pub fn create_local_var_metadata(bcx: Block, local: &ast::Local) {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if unsafe { llvm::LLVMIsAAllocaInst(datum.val) } == ptr::null_mut() {
|
||||||
|
cx.sess().span_bug(span, "debuginfo::create_local_var_metadata() - \
|
||||||
|
Referenced variable location is not an alloca!");
|
||||||
|
}
|
||||||
|
|
||||||
let scope_metadata = scope_metadata(bcx.fcx, node_id, span);
|
let scope_metadata = scope_metadata(bcx.fcx, node_id, span);
|
||||||
|
|
||||||
declare_local(bcx,
|
declare_local(bcx,
|
||||||
var_ident,
|
var_ident.node,
|
||||||
datum.ty,
|
datum.ty,
|
||||||
scope_metadata,
|
scope_metadata,
|
||||||
DirectVariable { alloca: datum.val },
|
DirectVariable { alloca: datum.val },
|
||||||
@ -983,7 +984,7 @@ pub fn create_match_binding_metadata<'blk, 'tcx>(bcx: Block<'blk, 'tcx>,
|
|||||||
// for the binding. For ByRef bindings that's a `T*` but for ByMove bindings we
|
// for the binding. For ByRef bindings that's a `T*` but for ByMove bindings we
|
||||||
// actually have `T**`. So to get the actual variable we need to dereference once
|
// actually have `T**`. So to get the actual variable we need to dereference once
|
||||||
// more. For ByCopy we just use the stack slot we created for the binding.
|
// more. For ByCopy we just use the stack slot we created for the binding.
|
||||||
let var_type = match binding.trmode {
|
let var_access = match binding.trmode {
|
||||||
TrByCopy(llbinding) => DirectVariable {
|
TrByCopy(llbinding) => DirectVariable {
|
||||||
alloca: llbinding
|
alloca: llbinding
|
||||||
},
|
},
|
||||||
@ -1000,27 +1001,31 @@ pub fn create_match_binding_metadata<'blk, 'tcx>(bcx: Block<'blk, 'tcx>,
|
|||||||
variable_ident,
|
variable_ident,
|
||||||
binding.ty,
|
binding.ty,
|
||||||
scope_metadata,
|
scope_metadata,
|
||||||
var_type,
|
var_access,
|
||||||
LocalVariable,
|
LocalVariable,
|
||||||
binding.span);
|
binding.span);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates debug information for the given function argument.
|
/// Creates debug information for the given function argument.
|
||||||
///
|
///
|
||||||
|
/// This function assumes that there's a datum for each pattern component of the
|
||||||
|
/// argument in `bcx.fcx.lllocals`.
|
||||||
/// Adds the created metadata nodes directly to the crate's IR.
|
/// Adds the created metadata nodes directly to the crate's IR.
|
||||||
pub fn create_argument_metadata(bcx: Block, arg: &ast::Arg) {
|
pub fn create_argument_metadata(bcx: Block, arg: &ast::Arg) {
|
||||||
if fn_should_be_ignored(bcx.fcx) {
|
if fn_should_be_ignored(bcx.fcx) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
let fcx = bcx.fcx;
|
let def_map = &bcx.tcx().def_map;
|
||||||
let cx = fcx.ccx;
|
let scope_metadata = bcx
|
||||||
|
.fcx
|
||||||
|
.debug_context
|
||||||
|
.get_ref(bcx.ccx(), arg.pat.span)
|
||||||
|
.fn_metadata;
|
||||||
|
let locals = bcx.fcx.lllocals.borrow();
|
||||||
|
|
||||||
let def_map = &cx.tcx().def_map;
|
pat_util::pat_bindings(def_map, &*arg.pat, |_, node_id, span, var_ident| {
|
||||||
let scope_metadata = bcx.fcx.debug_context.get_ref(cx, arg.pat.span).fn_metadata;
|
let datum = match locals.get(&node_id) {
|
||||||
|
|
||||||
pat_util::pat_bindings(def_map, &*arg.pat, |_, node_id, span, path1| {
|
|
||||||
let llarg = match bcx.fcx.lllocals.borrow().get(&node_id).cloned() {
|
|
||||||
Some(v) => v,
|
Some(v) => v,
|
||||||
None => {
|
None => {
|
||||||
bcx.sess().span_bug(span,
|
bcx.sess().span_bug(span,
|
||||||
@ -1029,23 +1034,27 @@ pub fn create_argument_metadata(bcx: Block, arg: &ast::Arg) {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
if unsafe { llvm::LLVMIsAAllocaInst(llarg.val) } == ptr::null_mut() {
|
if unsafe { llvm::LLVMIsAAllocaInst(datum.val) } == ptr::null_mut() {
|
||||||
cx.sess().span_bug(span, "debuginfo::create_argument_metadata() - \
|
bcx.sess().span_bug(span, "debuginfo::create_argument_metadata() - \
|
||||||
Referenced variable location is not an alloca!");
|
Referenced variable location is not an alloca!");
|
||||||
}
|
}
|
||||||
|
|
||||||
let argument_index = {
|
let argument_index = {
|
||||||
let counter = &fcx.debug_context.get_ref(cx, span).argument_counter;
|
let counter = &bcx
|
||||||
|
.fcx
|
||||||
|
.debug_context
|
||||||
|
.get_ref(bcx.ccx(), span)
|
||||||
|
.argument_counter;
|
||||||
let argument_index = counter.get();
|
let argument_index = counter.get();
|
||||||
counter.set(argument_index + 1);
|
counter.set(argument_index + 1);
|
||||||
argument_index
|
argument_index
|
||||||
};
|
};
|
||||||
|
|
||||||
declare_local(bcx,
|
declare_local(bcx,
|
||||||
path1.node,
|
var_ident.node,
|
||||||
llarg.ty,
|
datum.ty,
|
||||||
scope_metadata,
|
scope_metadata,
|
||||||
DirectVariable { alloca: llarg.val },
|
DirectVariable { alloca: datum.val },
|
||||||
ArgumentVariable(argument_index),
|
ArgumentVariable(argument_index),
|
||||||
span);
|
span);
|
||||||
})
|
})
|
||||||
@ -1053,6 +1062,8 @@ pub fn create_argument_metadata(bcx: Block, arg: &ast::Arg) {
|
|||||||
|
|
||||||
/// Creates debug information for the given for-loop variable.
|
/// Creates debug information for the given for-loop variable.
|
||||||
///
|
///
|
||||||
|
/// This function assumes that there's a datum for each pattern component of the
|
||||||
|
/// loop variable in `bcx.fcx.lllocals`.
|
||||||
/// Adds the created metadata nodes directly to the crate's IR.
|
/// Adds the created metadata nodes directly to the crate's IR.
|
||||||
pub fn create_for_loop_var_metadata(bcx: Block, pat: &ast::Pat) {
|
pub fn create_for_loop_var_metadata(bcx: Block, pat: &ast::Pat) {
|
||||||
if fn_should_be_ignored(bcx.fcx) {
|
if fn_should_be_ignored(bcx.fcx) {
|
||||||
@ -1060,9 +1071,10 @@ pub fn create_for_loop_var_metadata(bcx: Block, pat: &ast::Pat) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let def_map = &bcx.tcx().def_map;
|
let def_map = &bcx.tcx().def_map;
|
||||||
|
let locals = bcx.fcx.lllocals.borrow();
|
||||||
|
|
||||||
pat_util::pat_bindings(def_map, pat, |_, node_id, span, spanned_ident| {
|
pat_util::pat_bindings(def_map, pat, |_, node_id, span, var_ident| {
|
||||||
let datum = match bcx.fcx.lllocals.borrow().get(&node_id).cloned() {
|
let datum = match locals.get(&node_id) {
|
||||||
Some(datum) => datum,
|
Some(datum) => datum,
|
||||||
None => {
|
None => {
|
||||||
bcx.sess().span_bug(span,
|
bcx.sess().span_bug(span,
|
||||||
@ -1079,7 +1091,7 @@ pub fn create_for_loop_var_metadata(bcx: Block, pat: &ast::Pat) {
|
|||||||
let scope_metadata = scope_metadata(bcx.fcx, node_id, span);
|
let scope_metadata = scope_metadata(bcx.fcx, node_id, span);
|
||||||
|
|
||||||
declare_local(bcx,
|
declare_local(bcx,
|
||||||
spanned_ident.node,
|
var_ident.node,
|
||||||
datum.ty,
|
datum.ty,
|
||||||
scope_metadata,
|
scope_metadata,
|
||||||
DirectVariable { alloca: datum.val },
|
DirectVariable { alloca: datum.val },
|
||||||
@ -1156,13 +1168,13 @@ pub fn get_cleanup_debug_loc_for_ast_node<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
pub fn set_source_location(fcx: &FunctionContext,
|
pub fn set_source_location(fcx: &FunctionContext,
|
||||||
node_id: ast::NodeId,
|
node_id: ast::NodeId,
|
||||||
span: Span) {
|
span: Span) {
|
||||||
match fcx.debug_context.repr {
|
match fcx.debug_context {
|
||||||
DebugInfoDisabled => return,
|
FunctionDebugContext::DebugInfoDisabled => return,
|
||||||
FunctionWithoutDebugInfo => {
|
FunctionDebugContext::FunctionWithoutDebugInfo => {
|
||||||
set_debug_location(fcx.ccx, UnknownLocation);
|
set_debug_location(fcx.ccx, UnknownLocation);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
DebugInfo(box ref function_debug_context) => {
|
FunctionDebugContext::RegularContext(box ref function_debug_context) => {
|
||||||
let cx = fcx.ccx;
|
let cx = fcx.ccx;
|
||||||
|
|
||||||
debug!("set_source_location: {}", cx.sess().codemap().span_to_string(span));
|
debug!("set_source_location: {}", cx.sess().codemap().span_to_string(span));
|
||||||
@ -1199,8 +1211,8 @@ pub fn clear_source_location(fcx: &FunctionContext) {
|
|||||||
/// switches source location emitting on and must therefore be called before the
|
/// switches source location emitting on and must therefore be called before the
|
||||||
/// first real statement/expression of the function is translated.
|
/// first real statement/expression of the function is translated.
|
||||||
pub fn start_emitting_source_locations(fcx: &FunctionContext) {
|
pub fn start_emitting_source_locations(fcx: &FunctionContext) {
|
||||||
match fcx.debug_context.repr {
|
match fcx.debug_context {
|
||||||
DebugInfo(box ref data) => {
|
FunctionDebugContext::RegularContext(box ref data) => {
|
||||||
data.source_locations_enabled.set(true)
|
data.source_locations_enabled.set(true)
|
||||||
},
|
},
|
||||||
_ => { /* safe to ignore */ }
|
_ => { /* safe to ignore */ }
|
||||||
@ -1218,7 +1230,7 @@ pub fn create_function_debug_context<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
param_substs: &Substs<'tcx>,
|
param_substs: &Substs<'tcx>,
|
||||||
llfn: ValueRef) -> FunctionDebugContext {
|
llfn: ValueRef) -> FunctionDebugContext {
|
||||||
if cx.sess().opts.debuginfo == NoDebugInfo {
|
if cx.sess().opts.debuginfo == NoDebugInfo {
|
||||||
return FunctionDebugContext { repr: DebugInfoDisabled };
|
return FunctionDebugContext::DebugInfoDisabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear the debug location so we don't assign them in the function prelude.
|
// Clear the debug location so we don't assign them in the function prelude.
|
||||||
@ -1228,7 +1240,7 @@ pub fn create_function_debug_context<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
if fn_ast_id == ast::DUMMY_NODE_ID {
|
if fn_ast_id == ast::DUMMY_NODE_ID {
|
||||||
// This is a function not linked to any source location, so don't
|
// This is a function not linked to any source location, so don't
|
||||||
// generate debuginfo for it.
|
// generate debuginfo for it.
|
||||||
return FunctionDebugContext { repr: FunctionWithoutDebugInfo };
|
return FunctionDebugContext::FunctionWithoutDebugInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
let empty_generics = ast_util::empty_generics();
|
let empty_generics = ast_util::empty_generics();
|
||||||
@ -1238,7 +1250,7 @@ pub fn create_function_debug_context<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
let (ident, fn_decl, generics, top_level_block, span, has_path) = match fnitem {
|
let (ident, fn_decl, generics, top_level_block, span, has_path) = match fnitem {
|
||||||
ast_map::NodeItem(ref item) => {
|
ast_map::NodeItem(ref item) => {
|
||||||
if contains_nodebug_attribute(item.attrs.as_slice()) {
|
if contains_nodebug_attribute(item.attrs.as_slice()) {
|
||||||
return FunctionDebugContext { repr: FunctionWithoutDebugInfo };
|
return FunctionDebugContext::FunctionWithoutDebugInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
match item.node {
|
match item.node {
|
||||||
@ -1255,9 +1267,7 @@ pub fn create_function_debug_context<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
match **item {
|
match **item {
|
||||||
ast::MethodImplItem(ref method) => {
|
ast::MethodImplItem(ref method) => {
|
||||||
if contains_nodebug_attribute(method.attrs.as_slice()) {
|
if contains_nodebug_attribute(method.attrs.as_slice()) {
|
||||||
return FunctionDebugContext {
|
return FunctionDebugContext::FunctionWithoutDebugInfo;
|
||||||
repr: FunctionWithoutDebugInfo
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
(method.pe_ident(),
|
(method.pe_ident(),
|
||||||
@ -1296,9 +1306,7 @@ pub fn create_function_debug_context<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
match **trait_method {
|
match **trait_method {
|
||||||
ast::ProvidedMethod(ref method) => {
|
ast::ProvidedMethod(ref method) => {
|
||||||
if contains_nodebug_attribute(method.attrs.as_slice()) {
|
if contains_nodebug_attribute(method.attrs.as_slice()) {
|
||||||
return FunctionDebugContext {
|
return FunctionDebugContext::FunctionWithoutDebugInfo;
|
||||||
repr: FunctionWithoutDebugInfo
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
(method.pe_ident(),
|
(method.pe_ident(),
|
||||||
@ -1319,7 +1327,7 @@ pub fn create_function_debug_context<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
ast_map::NodeForeignItem(..) |
|
ast_map::NodeForeignItem(..) |
|
||||||
ast_map::NodeVariant(..) |
|
ast_map::NodeVariant(..) |
|
||||||
ast_map::NodeStructCtor(..) => {
|
ast_map::NodeStructCtor(..) => {
|
||||||
return FunctionDebugContext { repr: FunctionWithoutDebugInfo };
|
return FunctionDebugContext::FunctionWithoutDebugInfo;
|
||||||
}
|
}
|
||||||
_ => cx.sess().bug(format!("create_function_debug_context: \
|
_ => cx.sess().bug(format!("create_function_debug_context: \
|
||||||
unexpected sort of node: {}",
|
unexpected sort of node: {}",
|
||||||
@ -1328,7 +1336,7 @@ pub fn create_function_debug_context<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
|
|
||||||
// This can be the case for functions inlined from another crate
|
// This can be the case for functions inlined from another crate
|
||||||
if span == codemap::DUMMY_SP {
|
if span == codemap::DUMMY_SP {
|
||||||
return FunctionDebugContext { repr: FunctionWithoutDebugInfo };
|
return FunctionDebugContext::FunctionWithoutDebugInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
let loc = span_start(cx, span);
|
let loc = span_start(cx, span);
|
||||||
@ -1395,22 +1403,23 @@ pub fn create_function_debug_context<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
|||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let scope_map = create_scope_map(cx,
|
||||||
|
fn_decl.inputs.as_slice(),
|
||||||
|
&*top_level_block,
|
||||||
|
fn_metadata,
|
||||||
|
fn_ast_id);
|
||||||
|
|
||||||
// Initialize fn debug context (including scope map and namespace map)
|
// Initialize fn debug context (including scope map and namespace map)
|
||||||
let fn_debug_context = box FunctionDebugContextData {
|
let fn_debug_context = box FunctionDebugContextData {
|
||||||
scope_map: RefCell::new(NodeMap::new()),
|
scope_map: RefCell::new(scope_map),
|
||||||
fn_metadata: fn_metadata,
|
fn_metadata: fn_metadata,
|
||||||
argument_counter: Cell::new(1),
|
argument_counter: Cell::new(1),
|
||||||
source_locations_enabled: Cell::new(false),
|
source_locations_enabled: Cell::new(false),
|
||||||
};
|
};
|
||||||
|
|
||||||
populate_scope_map(cx,
|
|
||||||
fn_decl.inputs.as_slice(),
|
|
||||||
&*top_level_block,
|
|
||||||
fn_metadata,
|
|
||||||
fn_ast_id,
|
|
||||||
&mut *fn_debug_context.scope_map.borrow_mut());
|
|
||||||
|
|
||||||
return FunctionDebugContext { repr: DebugInfo(fn_debug_context) };
|
|
||||||
|
return FunctionDebugContext::RegularContext(fn_debug_context);
|
||||||
|
|
||||||
fn get_function_signature<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
fn get_function_signature<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
|
||||||
fn_ast_id: ast::NodeId,
|
fn_ast_id: ast::NodeId,
|
||||||
@ -3176,8 +3185,8 @@ fn DIB(cx: &CrateContext) -> DIBuilderRef {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn fn_should_be_ignored(fcx: &FunctionContext) -> bool {
|
fn fn_should_be_ignored(fcx: &FunctionContext) -> bool {
|
||||||
match fcx.debug_context.repr {
|
match fcx.debug_context {
|
||||||
DebugInfo(_) => false,
|
FunctionDebugContext::RegularContext(_) => false,
|
||||||
_ => true
|
_ => true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3211,12 +3220,14 @@ fn get_namespace_and_span_for_item(cx: &CrateContext, def_id: ast::DefId)
|
|||||||
// what belongs to which scope, creating DIScope DIEs along the way, and
|
// what belongs to which scope, creating DIScope DIEs along the way, and
|
||||||
// introducing *artificial* lexical scope descriptors where necessary. These
|
// introducing *artificial* lexical scope descriptors where necessary. These
|
||||||
// artificial scopes allow GDB to correctly handle name shadowing.
|
// artificial scopes allow GDB to correctly handle name shadowing.
|
||||||
fn populate_scope_map(cx: &CrateContext,
|
fn create_scope_map(cx: &CrateContext,
|
||||||
args: &[ast::Arg],
|
args: &[ast::Arg],
|
||||||
fn_entry_block: &ast::Block,
|
fn_entry_block: &ast::Block,
|
||||||
fn_metadata: DISubprogram,
|
fn_metadata: DISubprogram,
|
||||||
fn_ast_id: ast::NodeId,
|
fn_ast_id: ast::NodeId)
|
||||||
scope_map: &mut NodeMap<DIScope>) {
|
-> NodeMap<DIScope> {
|
||||||
|
let mut scope_map = NodeMap::new();
|
||||||
|
|
||||||
let def_map = &cx.tcx().def_map;
|
let def_map = &cx.tcx().def_map;
|
||||||
|
|
||||||
struct ScopeStackEntry {
|
struct ScopeStackEntry {
|
||||||
@ -3242,11 +3253,14 @@ fn populate_scope_map(cx: &CrateContext,
|
|||||||
with_new_scope(cx,
|
with_new_scope(cx,
|
||||||
fn_entry_block.span,
|
fn_entry_block.span,
|
||||||
&mut scope_stack,
|
&mut scope_stack,
|
||||||
scope_map,
|
&mut scope_map,
|
||||||
|cx, scope_stack, scope_map| {
|
|cx, scope_stack, scope_map| {
|
||||||
walk_block(cx, fn_entry_block, scope_stack, scope_map);
|
walk_block(cx, fn_entry_block, scope_stack, scope_map);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
return scope_map;
|
||||||
|
|
||||||
|
|
||||||
// local helper functions for walking the AST.
|
// local helper functions for walking the AST.
|
||||||
fn with_new_scope<F>(cx: &CrateContext,
|
fn with_new_scope<F>(cx: &CrateContext,
|
||||||
scope_span: Span,
|
scope_span: Span,
|
||||||
@ -3482,7 +3496,7 @@ fn populate_scope_map(cx: &CrateContext,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ast::PatMac(_) => {
|
ast::PatMac(_) => {
|
||||||
cx.sess().span_bug(pat.span, "debuginfo::populate_scope_map() - \
|
cx.sess().span_bug(pat.span, "debuginfo::create_scope_map() - \
|
||||||
Found unexpanded macro.");
|
Found unexpanded macro.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3568,7 +3582,7 @@ fn populate_scope_map(cx: &CrateContext,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ast::ExprIfLet(..) => {
|
ast::ExprIfLet(..) => {
|
||||||
cx.sess().span_bug(exp.span, "debuginfo::populate_scope_map() - \
|
cx.sess().span_bug(exp.span, "debuginfo::create_scope_map() - \
|
||||||
Found unexpanded if-let.");
|
Found unexpanded if-let.");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3585,7 +3599,7 @@ fn populate_scope_map(cx: &CrateContext,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ast::ExprWhileLet(..) => {
|
ast::ExprWhileLet(..) => {
|
||||||
cx.sess().span_bug(exp.span, "debuginfo::populate_scope_map() - \
|
cx.sess().span_bug(exp.span, "debuginfo::create_scope_map() - \
|
||||||
Found unexpanded while-let.");
|
Found unexpanded while-let.");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3610,7 +3624,7 @@ fn populate_scope_map(cx: &CrateContext,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ast::ExprMac(_) => {
|
ast::ExprMac(_) => {
|
||||||
cx.sess().span_bug(exp.span, "debuginfo::populate_scope_map() - \
|
cx.sess().span_bug(exp.span, "debuginfo::create_scope_map() - \
|
||||||
Found unexpanded macro.");
|
Found unexpanded macro.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user