diff options
| author | bors <bors@rust-lang.org> | 2023-09-22 19:57:07 +0000 | 
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2023-09-22 19:57:07 +0000 | 
| commit | aadb5718dd9a2f4b9c64893baedfe1f5991d6bbd (patch) | |
| tree | 9e9bcde725b945801aa3cf91b23d4d22899f03f0 /compiler/rustc_middle/src/error.rs | |
| parent | 959b2c703d45f06962da3afa086bdda70d42efcf (diff) | |
| parent | 8d81d5a909551631b51177f976f68ac02dcafd11 (diff) | |
| download | rust-aadb5718dd9a2f4b9c64893baedfe1f5991d6bbd.tar.gz rust-aadb5718dd9a2f4b9c64893baedfe1f5991d6bbd.zip  | |
Auto merge of #116001 - fmease:validate-crate-name-extern-cli-opt, r=est31
[breaking change] Validate crate name in `--extern` [MCP 650] Reject non-ASCII-identifier crate names passed to the CLI option `--extern` (`rustc`, `rustdoc`). Implements [MCP 650](https://github.com/rust-lang/compiler-team/issues/650) (except that we only allow ASCII identifiers not arbitrary Rust identifiers). Fixes #113035. [As mentioned on Zulip](https://rust-lang.zulipchat.com/#narrow/stream/233931-t-compiler.2Fmajor-changes/topic/Disallow.20non-identifier-valid.20--extern.20cr.E2.80.A6.20compiler-team.23650/near/376826988), doing a crater run probably doesn't make sense since it wouldn't yield anything. Most users don't interact with `rustc` directly but only ever through Cargo which always passes a valid crate name to `--extern` when it invokes `rustc` and `rustdoc`. In any case, the user wouldn't be able to use such a crate name in the source code anyway. Note that I'm not using [`rustc_session::output::validate_crate_name`](https://doc.rust-lang.org/nightly/nightly-rustc/rustc_session/output/fn.validate_crate_name.html) (used for `--crate-name` and `#![crate_name]`) since the latter doesn't reject non-ASCII crate names and ones that start with a digit. As an aside, I've also thought about getting rid of `validate_crate_name` entirely in a separate PR (with another MCP) in favor of `is_ascii_ident` to reject more weird `--crate-name`s, `#![crate_name]`s and file names but I think that would lead to a lot of actual breakage, namely because of file names starting with a digit. In `tests/ui` 9 tests would be impacted for example. CC `@estebank` r? `@est31`
Diffstat (limited to 'compiler/rustc_middle/src/error.rs')
0 files changed, 0 insertions, 0 deletions
