Skip to content

Commit

Permalink
Use -Z unstable-options for span debugger
Browse files Browse the repository at this point in the history
  • Loading branch information
sanxiyn committed Dec 27, 2014
1 parent 9554794 commit d4da758
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 8 deletions.
6 changes: 4 additions & 2 deletions src/librustc/session/config.rs
Expand Up @@ -105,6 +105,7 @@ pub struct Options {
pub prints: Vec<PrintRequest>,
pub cg: CodegenOptions,
pub color: ColorConfig,
pub show_span: Option<String>,
pub externs: HashMap<String, Vec<String>>,
pub crate_name: Option<String>,
/// An optional name to use as the crate for std during std injection,
Expand Down Expand Up @@ -211,6 +212,7 @@ pub fn basic_options() -> Options {
prints: Vec::new(),
cg: basic_codegen_options(),
color: Auto,
show_span: None,
externs: HashMap::new(),
crate_name: None,
alt_std_name: None,
Expand Down Expand Up @@ -259,7 +261,6 @@ debugging_opts! {
BORROWCK_STATS,
NO_LANDING_PADS,
DEBUG_LLVM,
SHOW_SPAN,
COUNT_TYPE_SIZES,
META_STATS,
GC,
Expand Down Expand Up @@ -298,7 +299,6 @@ pub fn debugging_opts_map() -> Vec<(&'static str, &'static str, u64)> {
("no-landing-pads", "omit landing pads for unwinding",
NO_LANDING_PADS),
("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),
("meta-stats", "gather metadata statistics", META_STATS),
Expand Down Expand Up @@ -820,6 +820,7 @@ pub fn rustc_optgroups() -> Vec<RustcOptGroup> {
`flowgraph=<nodeid>` (graphviz formatted flowgraph for node), or
`everybody_loops` (all function bodies replaced with `loop {}`).",
"TYPE"),
opt::opt_u("", "show-span", "Show spans for compiler debugging", "expr|pat|ty"),
opt::flagopt("", "dep-info",
"Output dependency info to <filename> after compiling, \
in a format suitable for use by Makefiles", "FILENAME"),
Expand Down Expand Up @@ -1122,6 +1123,7 @@ pub fn build_session_options(matches: &getopts::Matches) -> Options {
prints: prints,
cg: cg,
color: color,
show_span: None,
externs: externs,
crate_name: crate_name,
alt_std_name: None,
Expand Down
3 changes: 0 additions & 3 deletions src/librustc/session/mod.rs
Expand Up @@ -199,9 +199,6 @@ impl Session {
pub fn no_landing_pads(&self) -> bool {
self.debugging_opt(config::NO_LANDING_PADS)
}
pub fn show_span(&self) -> bool {
self.debugging_opt(config::SHOW_SPAN)
}
pub fn unstable_options(&self) -> bool {
self.debugging_opt(config::UNSTABLE_OPTIONS)
}
Expand Down
4 changes: 2 additions & 2 deletions src/librustc_driver/driver.rs
Expand Up @@ -138,7 +138,7 @@ pub fn phase_1_parse_input(sess: &Session, cfg: ast::CrateConfig, input: &Input)
krate.encode(&mut json).unwrap();
}

if sess.show_span() {
if sess.opts.show_span.is_some() {
syntax::show_span::run(sess.diagnostic(), &krate);
}

Expand Down Expand Up @@ -542,7 +542,7 @@ pub fn stop_after_phase_1(sess: &Session) -> bool {
debug!("invoked with --parse-only, returning early from compile_input");
return true;
}
if sess.show_span() {
if sess.opts.show_span.is_some() {
return true;
}
return sess.opts.debugging_opts & config::AST_JSON_NOEXPAND != 0;
Expand Down
6 changes: 5 additions & 1 deletion src/librustc_driver/lib.rs
Expand Up @@ -132,7 +132,7 @@ fn run_compiler(args: &[String]) {
_ => early_error("multiple input filenames provided")
};

let sess = build_session(sopts, input_file_path, descriptions);
let mut sess = build_session(sopts, input_file_path, descriptions);
let cfg = config::build_configuration(&sess);
if print_crate_info(&sess, Some(&input), &odir, &ofile) {
return
Expand Down Expand Up @@ -160,6 +160,10 @@ fn run_compiler(args: &[String]) {
None => {/* continue */ }
}

if sess.unstable_options() {
sess.opts.show_span = matches.opt_str("show-span");
}

let r = matches.opt_strs("Z");
if r.contains(&("ls".to_string())) {
match input {
Expand Down

0 comments on commit d4da758

Please sign in to comment.