Rollup merge of #133847 - nnethercote:rm-Z-show-span, r=compiler-errors
Remove `-Zshow-span`. It's very old (added in #12087). It's strange, and it's not clear what its use cases are. It only works with the crate root file because it runs before expansion. I suspect it won't be missed. r? `@estebank`
This commit is contained in:
commit
a4dc9634a8
8 changed files with 1 additions and 91 deletions
|
@ -207,8 +207,6 @@ ast_passes_precise_capturing_duplicated = duplicate `use<...>` precise capturing
|
||||||
|
|
||||||
ast_passes_precise_capturing_not_allowed_here = `use<...>` precise capturing syntax not allowed in {$loc}
|
ast_passes_precise_capturing_not_allowed_here = `use<...>` precise capturing syntax not allowed in {$loc}
|
||||||
|
|
||||||
ast_passes_show_span = {$msg}
|
|
||||||
|
|
||||||
ast_passes_stability_outside_std = stability attributes may not be used outside of the standard library
|
ast_passes_stability_outside_std = stability attributes may not be used outside of the standard library
|
||||||
|
|
||||||
ast_passes_static_without_body =
|
ast_passes_static_without_body =
|
||||||
|
|
|
@ -779,14 +779,6 @@ pub(crate) struct IncompatibleFeatures {
|
||||||
pub f2: Symbol,
|
pub f2: Symbol,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Diagnostic)]
|
|
||||||
#[diag(ast_passes_show_span)]
|
|
||||||
pub(crate) struct ShowSpan {
|
|
||||||
#[primary_span]
|
|
||||||
pub span: Span,
|
|
||||||
pub msg: &'static str,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Diagnostic)]
|
#[derive(Diagnostic)]
|
||||||
#[diag(ast_passes_negative_bound_not_supported)]
|
#[diag(ast_passes_negative_bound_not_supported)]
|
||||||
pub(crate) struct NegativeBoundUnsupported {
|
pub(crate) struct NegativeBoundUnsupported {
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
//! The `rustc_ast_passes` crate contains passes which validate the AST in `syntax`
|
//! The `rustc_ast_passes` crate contains passes which validate the AST in `syntax`
|
||||||
//! parsed by `rustc_parse` and then lowered, after the passes in this crate,
|
//! parsed by `rustc_parse` and then lowered, after the passes in this crate,
|
||||||
//! by `rustc_ast_lowering`.
|
//! by `rustc_ast_lowering`.
|
||||||
//!
|
|
||||||
//! The crate also contains other misc AST visitors, e.g. `node_count` and `show_span`.
|
|
||||||
|
|
||||||
// tidy-alphabetical-start
|
// tidy-alphabetical-start
|
||||||
#![allow(internal_features)]
|
#![allow(internal_features)]
|
||||||
|
@ -18,6 +16,5 @@
|
||||||
pub mod ast_validation;
|
pub mod ast_validation;
|
||||||
mod errors;
|
mod errors;
|
||||||
pub mod feature_gate;
|
pub mod feature_gate;
|
||||||
pub mod show_span;
|
|
||||||
|
|
||||||
rustc_fluent_macro::fluent_messages! { "../messages.ftl" }
|
rustc_fluent_macro::fluent_messages! { "../messages.ftl" }
|
||||||
|
|
|
@ -1,68 +0,0 @@
|
||||||
//! Span debugger
|
|
||||||
//!
|
|
||||||
//! This module shows spans for all expressions in the crate
|
|
||||||
//! to help with compiler debugging.
|
|
||||||
|
|
||||||
use std::str::FromStr;
|
|
||||||
|
|
||||||
use rustc_ast as ast;
|
|
||||||
use rustc_ast::visit;
|
|
||||||
use rustc_ast::visit::Visitor;
|
|
||||||
use rustc_errors::DiagCtxtHandle;
|
|
||||||
|
|
||||||
use crate::errors;
|
|
||||||
|
|
||||||
enum Mode {
|
|
||||||
Expression,
|
|
||||||
Pattern,
|
|
||||||
Type,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl FromStr for Mode {
|
|
||||||
type Err = ();
|
|
||||||
fn from_str(s: &str) -> Result<Mode, ()> {
|
|
||||||
let mode = match s {
|
|
||||||
"expr" => Mode::Expression,
|
|
||||||
"pat" => Mode::Pattern,
|
|
||||||
"ty" => Mode::Type,
|
|
||||||
_ => return Err(()),
|
|
||||||
};
|
|
||||||
Ok(mode)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct ShowSpanVisitor<'a> {
|
|
||||||
dcx: DiagCtxtHandle<'a>,
|
|
||||||
mode: Mode,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> Visitor<'a> for ShowSpanVisitor<'a> {
|
|
||||||
fn visit_expr(&mut self, e: &'a ast::Expr) {
|
|
||||||
if let Mode::Expression = self.mode {
|
|
||||||
self.dcx.emit_warn(errors::ShowSpan { span: e.span, msg: "expression" });
|
|
||||||
}
|
|
||||||
visit::walk_expr(self, e);
|
|
||||||
}
|
|
||||||
|
|
||||||
fn visit_pat(&mut self, p: &'a ast::Pat) {
|
|
||||||
if let Mode::Pattern = self.mode {
|
|
||||||
self.dcx.emit_warn(errors::ShowSpan { span: p.span, msg: "pattern" });
|
|
||||||
}
|
|
||||||
visit::walk_pat(self, p);
|
|
||||||
}
|
|
||||||
|
|
||||||
fn visit_ty(&mut self, t: &'a ast::Ty) {
|
|
||||||
if let Mode::Type = self.mode {
|
|
||||||
self.dcx.emit_warn(errors::ShowSpan { span: t.span, msg: "type" });
|
|
||||||
}
|
|
||||||
visit::walk_ty(self, t);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn run(dcx: DiagCtxtHandle<'_>, mode: &str, krate: &ast::Crate) {
|
|
||||||
let Ok(mode) = mode.parse() else {
|
|
||||||
return;
|
|
||||||
};
|
|
||||||
let mut v = ShowSpanVisitor { dcx, mode };
|
|
||||||
visit::walk_crate(&mut v, krate);
|
|
||||||
}
|
|
|
@ -418,9 +418,7 @@ fn run_compiler(
|
||||||
return early_exit();
|
return early_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if sess.opts.unstable_opts.parse_crate_root_only
|
if sess.opts.unstable_opts.parse_crate_root_only {
|
||||||
|| sess.opts.unstable_opts.show_span.is_some()
|
|
||||||
{
|
|
||||||
return early_exit();
|
return early_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -54,10 +54,6 @@ pub(crate) fn parse<'a>(sess: &'a Session) -> Result<ast::Crate> {
|
||||||
})
|
})
|
||||||
.map_err(|parse_error| parse_error.emit())?;
|
.map_err(|parse_error| parse_error.emit())?;
|
||||||
|
|
||||||
if let Some(ref s) = sess.opts.unstable_opts.show_span {
|
|
||||||
rustc_ast_passes::show_span::run(sess.dcx(), s, &krate);
|
|
||||||
}
|
|
||||||
|
|
||||||
if sess.opts.unstable_opts.input_stats {
|
if sess.opts.unstable_opts.input_stats {
|
||||||
input_stats::print_ast_stats(&krate, "PRE EXPANSION AST STATS", "ast-stats-1");
|
input_stats::print_ast_stats(&krate, "PRE EXPANSION AST STATS", "ast-stats-1");
|
||||||
}
|
}
|
||||||
|
|
|
@ -844,7 +844,6 @@ fn test_unstable_options_tracking_hash() {
|
||||||
tracked!(sanitizer_recover, SanitizerSet::ADDRESS);
|
tracked!(sanitizer_recover, SanitizerSet::ADDRESS);
|
||||||
tracked!(saturating_float_casts, Some(true));
|
tracked!(saturating_float_casts, Some(true));
|
||||||
tracked!(share_generics, Some(true));
|
tracked!(share_generics, Some(true));
|
||||||
tracked!(show_span, Some(String::from("abc")));
|
|
||||||
tracked!(simulate_remapped_rust_src_base, Some(PathBuf::from("/rustc/abc")));
|
tracked!(simulate_remapped_rust_src_base, Some(PathBuf::from("/rustc/abc")));
|
||||||
tracked!(small_data_threshold, Some(16));
|
tracked!(small_data_threshold, Some(16));
|
||||||
tracked!(split_lto_unit, Some(true));
|
tracked!(split_lto_unit, Some(true));
|
||||||
|
|
|
@ -2038,8 +2038,6 @@ written to standard error output)"),
|
||||||
"make the current crate share its generic instantiations"),
|
"make the current crate share its generic instantiations"),
|
||||||
shell_argfiles: bool = (false, parse_bool, [UNTRACKED],
|
shell_argfiles: bool = (false, parse_bool, [UNTRACKED],
|
||||||
"allow argument files to be specified with POSIX \"shell-style\" argument quoting"),
|
"allow argument files to be specified with POSIX \"shell-style\" argument quoting"),
|
||||||
show_span: Option<String> = (None, parse_opt_string, [TRACKED],
|
|
||||||
"show spans in the crate root file, for compiler debugging (expr|pat|ty)"),
|
|
||||||
simulate_remapped_rust_src_base: Option<PathBuf> = (None, parse_opt_pathbuf, [TRACKED],
|
simulate_remapped_rust_src_base: Option<PathBuf> = (None, parse_opt_pathbuf, [TRACKED],
|
||||||
"simulate the effect of remap-debuginfo = true at bootstrapping by remapping path \
|
"simulate the effect of remap-debuginfo = true at bootstrapping by remapping path \
|
||||||
to rust's source base directory. only meant for testing purposes"),
|
to rust's source base directory. only meant for testing purposes"),
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue