1
Fork 0

auto merge of #12087 : sanxiyn/rust/show-span, r=huonw

This commit is contained in:
bors 2014-02-07 03:26:34 -08:00
commit c3ccaacc6c
5 changed files with 49 additions and 3 deletions

View file

@ -518,6 +518,10 @@ pub fn compile_input(sess: Session, cfg: ast::CrateConfig, input: &Input,
let (outputs, trans) = { let (outputs, trans) = {
let (expanded_crate, ast_map) = { let (expanded_crate, ast_map) = {
let crate = phase_1_parse_input(sess, cfg, input); let crate = phase_1_parse_input(sess, cfg, input);
if sess.show_span() {
front::show_span::run(sess, &crate);
return;
}
if stop_after_phase_1(sess) { return; } if stop_after_phase_1(sess) { return; }
let loader = &mut Loader::new(sess); let loader = &mut Loader::new(sess);
phase_2_configure_and_expand(sess, loader, crate) phase_2_configure_and_expand(sess, loader, crate)

View file

@ -60,6 +60,7 @@ debugging_opts!(
BORROWCK_STATS, BORROWCK_STATS,
NO_LANDING_PADS, NO_LANDING_PADS,
DEBUG_LLVM, DEBUG_LLVM,
SHOW_SPAN,
COUNT_TYPE_SIZES, COUNT_TYPE_SIZES,
META_STATS, META_STATS,
NO_OPT, NO_OPT,
@ -95,6 +96,7 @@ pub fn debugging_opts_map() -> ~[(&'static str, &'static str, u64)] {
("no-landing-pads", "omit landing pads for unwinding", ("no-landing-pads", "omit landing pads for unwinding",
NO_LANDING_PADS), NO_LANDING_PADS),
("debug-llvm", "enable debug output from LLVM", DEBUG_LLVM), ("debug-llvm", "enable debug output from LLVM", DEBUG_LLVM),
("show-span", "show spans for compiler debugging", SHOW_SPAN),
("count-type-sizes", "count the sizes of aggregate types", ("count-type-sizes", "count the sizes of aggregate types",
COUNT_TYPE_SIZES), COUNT_TYPE_SIZES),
("meta-stats", "gather metadata statistics", META_STATS), ("meta-stats", "gather metadata statistics", META_STATS),
@ -351,6 +353,9 @@ impl Session_ {
pub fn no_landing_pads(&self) -> bool { pub fn no_landing_pads(&self) -> bool {
self.debugging_opt(NO_LANDING_PADS) self.debugging_opt(NO_LANDING_PADS)
} }
pub fn show_span(&self) -> bool {
self.debugging_opt(SHOW_SPAN)
}
// DEPRECATED. This function results in a lot of allocations when they // DEPRECATED. This function results in a lot of allocations when they
// are not necessary. // are not necessary.

View file

@ -0,0 +1,36 @@
// Copyright 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.
//! Span debugger
//!
//! This module shows spans for all expressions in the crate
//! to help with compiler debugging.
use syntax::ast;
use syntax::visit;
use syntax::visit::Visitor;
use driver::session::Session;
struct ShowSpanVisitor {
sess: Session
}
impl Visitor<()> for ShowSpanVisitor {
fn visit_expr(&mut self, e: &ast::Expr, _: ()) {
self.sess.span_note(e.span, "expression");
visit::walk_expr(self, e, ());
}
}
pub fn run(sess: Session, crate: &ast::Crate) {
let mut v = ShowSpanVisitor { sess: sess };
visit::walk_crate(&mut v, crate, ());
}

View file

@ -97,6 +97,7 @@ pub mod front {
pub mod std_inject; pub mod std_inject;
pub mod assign_node_ids_and_map; pub mod assign_node_ids_and_map;
pub mod feature_gate; pub mod feature_gate;
pub mod show_span;
} }
pub mod back { pub mod back {

View file

@ -1771,7 +1771,7 @@ impl Parser {
self.commit_expr_expecting(*es.last().unwrap(), token::RPAREN); self.commit_expr_expecting(*es.last().unwrap(), token::RPAREN);
return if es.len() == 1 && !trailing_comma { return if es.len() == 1 && !trailing_comma {
self.mk_expr(lo, self.span.hi, ExprParen(es[0])) self.mk_expr(lo, hi, ExprParen(es[0]))
} }
else { else {
self.mk_expr(lo, hi, ExprTup(es)) self.mk_expr(lo, hi, ExprTup(es))
@ -1994,7 +1994,7 @@ impl Parser {
seq_sep_trailing_disallowed(token::COMMA), seq_sep_trailing_disallowed(token::COMMA),
|p| p.parse_expr() |p| p.parse_expr()
); );
hi = self.span.hi; hi = self.last_span.hi;
es.unshift(e); es.unshift(e);
let nd = self.mk_method_call(i, tys, es, NoSugar); let nd = self.mk_method_call(i, tys, es, NoSugar);
@ -2510,7 +2510,7 @@ impl Parser {
parse_decl: |&mut Parser| -> P<FnDecl>, parse_decl: |&mut Parser| -> P<FnDecl>,
parse_body: |&mut Parser| -> @Expr) parse_body: |&mut Parser| -> @Expr)
-> @Expr { -> @Expr {
let lo = self.last_span.lo; let lo = self.span.lo;
let decl = parse_decl(self); let decl = parse_decl(self);
let body = parse_body(self); let body = parse_body(self);
let fakeblock = P(ast::Block { let fakeblock = P(ast::Block {