diff options
| author | yukang <moorekang@gmail.com> | 2023-09-10 00:01:32 +0800 |
|---|---|---|
| committer | yukang <moorekang@gmail.com> | 2023-09-10 10:02:35 +0800 |
| commit | 12888d246b83ed083a7e11a366f29e1ee1b2e0be (patch) | |
| tree | 82ce2e44d106c28aaa99bf119cea3deb782a04fc | |
| parent | 7f0fa485a6ea1cc2f324d8412d749ed4ecfbce2a (diff) | |
| download | rust-12888d246b83ed083a7e11a366f29e1ee1b2e0be.tar.gz rust-12888d246b83ed083a7e11a366f29e1ee1b2e0be.zip | |
Abort if check nightly options failed on stable
| -rw-r--r-- | compiler/rustc_session/src/config.rs | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/compiler/rustc_session/src/config.rs b/compiler/rustc_session/src/config.rs index f00472f181d..8ce2817ee45 100644 --- a/compiler/rustc_session/src/config.rs +++ b/compiler/rustc_session/src/config.rs @@ -2959,6 +2959,7 @@ pub mod nightly_options { ) { let has_z_unstable_option = matches.opt_strs("Z").iter().any(|x| *x == "unstable-options"); let really_allows_unstable_options = match_is_nightly_build(matches); + let mut nightly_options_on_stable = 0; for opt in flags.iter() { if opt.stability == OptionStability::Stable { @@ -2979,20 +2980,27 @@ pub mod nightly_options { } match opt.stability { OptionStability::Unstable => { + nightly_options_on_stable += 1; let msg = format!( "the option `{}` is only accepted on the nightly compiler", opt.name ); let _ = handler.early_error_no_abort(msg); - handler.early_note("selecting a toolchain with `+toolchain` arguments require a rustup proxy; see <https://rust-lang.github.io/rustup/concepts/index.html>"); - handler.early_help( - "consider switching to a nightly toolchain: `rustup default nightly`", - ); - handler.early_note("for more information about Rust's stability policy, see <https://doc.rust-lang.org/book/appendix-07-nightly-rust.html#unstable-features>"); } OptionStability::Stable => {} } } + if nightly_options_on_stable > 0 { + handler + .early_help("consider switching to a nightly toolchain: `rustup default nightly`"); + handler.early_note("selecting a toolchain with `+toolchain` arguments require a rustup proxy; see <https://rust-lang.github.io/rustup/concepts/index.html>"); + handler.early_note("for more information about Rust's stability policy, see <https://doc.rust-lang.org/book/appendix-07-nightly-rust.html#unstable-features>"); + handler.early_error(format!( + "{} nightly option{} were parsed", + nightly_options_on_stable, + if nightly_options_on_stable > 1 { "s" } else { "" } + )); + } } } |
