KEMBAR78
Rollup of 7 pull requests by Zalathar · Pull Request #138974 · rust-lang/rust · GitHub
Skip to content

Conversation

@Zalathar
Copy link
Contributor

Successful merges:

r? @ghost
@rustbot modify labels: rollup

Create a similar rollup

azhogin and others added 21 commits March 17, 2025 12:49
…ugaring assignments.

An assignment such as

(a, b) = (b, c);

desugars to the HIR

{ let (lhs, lhs) = (b, c); a = lhs; b = lhs; };

The repeated `lhs` leads to multiple Locals assigned to the same DILocalVariable. Rather than
attempting to fix that, get rid of the debug info for these bindings that don't even exist
in the program to begin with.

Fixes rust-lang#138198
Since `{ ident: ident }` is a parse error, these fields are dead.
thanks to the removal of type ascription.
StructLiteralNeedingParens is no longer reachable always giving
precedence to StructLiteralNotAllowedHere.

As an aside: The former error struct shouldn't've existed in the
first place. We should've just used the latter in this branch.
This makes it a lot easier to add smaller regression tests
related to "incorrectly placed" struct literals.
…st cases

Note that issue-111692.rs was incorrectly named: It's a regression test for
issue [#]112278, not for [#]111692. That's been addressed, too.
This reverts commit e3e74bc.

The comment that was used to justify the change was outdated.
…ool-fix, r=fee1-dead

Target modifiers fix for bool flags without value

Fixed support of boolean flags without values: `-Zbool-flag` is now consistent with `-Zbool-flag=true` in another crate.

When flag is explicitly set to default value, target modifier will not be set in crate metainfo (`-Zflag=false` when `false` is a default value for the flag).

Improved error notification when target modifier flag is absent in a crate ("-Zflag unset").
Example:
```
note: `-Zreg-struct-return=true` in this crate is incompatible with unset `-Zreg-struct-return` in dependency `default_reg_struct_return`
```
Don't produce debug information for compiler-introduced-vars when desugaring assignments.

An assignment such as

(a, b) = (b, c);

desugars to the HIR

{ let (lhs, lhs) = (b, c); a = lhs; b = lhs; };

The repeated `lhs` leads to multiple Locals assigned to the same DILocalVariable. Rather than attempting to fix that, get rid of the debug info for these bindings that don't even exist in the program to begin with.

Fixes rust-lang#138198

r? `@jieyouxu`
…scr, r=compiler-errors

Mostly parser: Eliminate code that's been dead / semi-dead since the removal of type ascription syntax

**Disclaimer**: This PR is intended to mostly clean up code as opposed to bringing about behavioral changes. Therefore it doesn't aim to address any of the 'FIXME: remove after a month [dated: 2023-05-02]: "type ascription syntax has been removed, see issue [#]101728"'.

---

By commit:

1. Removes truly dead code:
   * Since 1.71 (rust-lang#109128) `let _ = { f: x };` is a syntax error as opposed to a semantic error which allows the parse-time diagnostic (suggestion) "*struct literal body without path // you might have forgotten […]*" to kick in.
   * The analysis-time diagnostic (suggestion) from <=1.70 "*cannot find value \`f\` in this scope // you might have forgotten […]*" is therefore no longer reachable.
2. Updates `is_certainly_not_a_block` to be in line with the current grammar:
   * The seq. `{ ident:` is definitely not the start of a block. Before the removal of ty ascr, `{ ident: ty_start` would begin a block expr.
   * This shouldn't make more code compile IINM, it should *ultimately* only affect diagnostics.
   * For example, `if T { f: () } {}` will now be interpreted as an `if` with struct lit `T { f: () }` as its *condition* (which is banned in the parser anyway) as opposed to just `T` (with the *consequent* being `f : ()` which is also invalid (since 1.71)). The diagnostics are almost the same because we have two separate parse recovery procedures + diagnostics: `StructLiteralNeedingParens` (*invalid struct lit*) before and `StructLiteralNotAllowedHere` (*struct lits aren't allowed here*) now, as you can see from the diff.
   * (As an aside, even before this PR, fn `maybe_suggest_struct_literal` should've just used the much older & clearer `StructLiteralNotAllowedHere`)
   * NB: This does sadly regress the compiler output for `tests/ui/parser/type-ascription-in-pattern.rs` but that can be fixed in follow-up PRs. It's not super important IMO and a natural consequence.
3. Removes code that's become dead due to the prior commit.
   * Basically reverts rust-lang#106620 + rust-lang#112475 (without regressing rustc's output!).
   * Now the older & more robust parse recovery procedure (cc `StructLiteralNotAllowedHere`) takes care of the cases the removed code used to handle.
   * This automatically fixes the suggestions for \[[playground](https://play.rust-lang.org/?version=stable&mode=debug&edition=2024&gist=7e2030163b11ee96d17adc3325b01780)\]:
     * `if Ty::<i32> { f: K }.m() {}`: `if Ty::<i32> { SomeStruct { f: K } }.m() {}` (broken) → ` if (Ty::<i32> { f: K }).m() {}`
     * `if <T as Trait>::Out { f: K::<> }.m() {}`: `if <T as Trait>(::Out { f: K::<> }).m() {}` (broken) → `if (<T as Trait>::Out { f: K::<> }).m() {}`
4. Merge and simplify UI tests pertaining to this issue, so it's easier to add more regression tests like for the two cases mentioned above.
5. Merge UI tests and add the two regression tests.

Best reviewed commit by commit (on request I'll partially squash after approval).
…marcoieni

Add bootstrap step diff to CI job analysis

This PR adds another analysis to the job analysis report in GitHub summary. It compares (diffs) bootstrap steps executed by the parent run and by the current commit. This will help us figure out if the bootstrap invocation did something different than before, and also how did the duration of individual steps and bootstrap invocations change.

Can be tested on the rust-lang#119899 PR like this:
```bash
$ curl https://ci-artifacts.rust-lang.org/rustc-builds/3d3394eb64ee2f99ad1a2b849b376220fd38263e/metrics-mingw-check.json > metrics.json
$ cargo run --manifest-path src/ci/citool/Cargo.toml postprocess-metrics metrics.json --job-name mingw-check --parent 961351c > out.md
```

r? `@marcoie`
…i-obk

Ensure `define_opaque` attrs are accounted for in HIR hash

Fixes rust-lang#138948

r? oli-obk
…, r=Zalathar

Revert "Make MatchPairTree::place non-optional"

Reverts a part of rust-lang#137875. Fixes rust-lang#138958.

cc `@Zalathar`
Fix typo in error message

Fix typo from rust-lang#137809.

r? `@Noratrieb`
@rustbot rustbot added A-testsuite Area: The testsuite used to check the correctness of rustc A-tidy Area: The tidy tool S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. T-bootstrap Relevant to the bootstrap subteam: Rust's build system (x.py and src/bootstrap) T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. T-infra Relevant to the infrastructure team, which will review and decide on the PR/issue. T-libs Relevant to the library team, which will review and decide on the PR/issue. rollup A PR which is a rollup labels Mar 26, 2025
@Zalathar
Copy link
Contributor Author

@bors r+ rollup=never p=5

@bors
Copy link
Collaborator

bors commented Mar 26, 2025

📌 Commit 46a40be has been approved by Zalathar

It is now in the queue for this repository.

@bors bors added S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Mar 26, 2025
@bors
Copy link
Collaborator

bors commented Mar 26, 2025

⌛ Testing commit 46a40be with merge f1bc669...

@bors
Copy link
Collaborator

bors commented Mar 26, 2025

☀️ Test successful - checks-actions
Approved by: Zalathar
Pushing f1bc669 to master...

@bors bors added the merged-by-bors This PR was explicitly merged by bors. label Mar 26, 2025
@bors bors merged commit f1bc669 into rust-lang:master Mar 26, 2025
7 checks passed
@rustbot rustbot added this to the 1.87.0 milestone Mar 26, 2025
@github-actions
Copy link
Contributor

What is this? This is an experimental post-merge analysis report that shows differences in test outcomes between the merged PR and its parent PR.

Comparing 65899c0 (parent) -> f1bc669 (this PR)

Test differences

Show 73 test diffs

Stage 1

  • [codegen] tests/codegen/assign-desugar-debuginfo.rs: [missing] -> pass (J1)
  • [incremental] tests/incremental/define-opaques.rs: [missing] -> pass (J1)
  • [ui] tests/ui/closures/upvar-or-pattern-issue-138958.rs: [missing] -> pass (J1)
  • [ui] tests/ui/parser/issues/issue-111692.rs: pass -> [missing] (J1)
  • [ui] tests/ui/parser/method-call-on-struct-literal-in-if-condition.rs: pass -> [missing] (J1)
  • [ui] tests/ui/parser/struct-literal-in-for.rs: pass -> [missing] (J1)
  • [ui] tests/ui/parser/struct-literal-in-if.rs: pass -> [missing] (J1)
  • [ui] tests/ui/parser/struct-literal-in-match-discriminant.rs: pass -> [missing] (J1)
  • [ui] tests/ui/parser/struct-literal-in-while.rs: pass -> [missing] (J1)
  • [ui] tests/ui/parser/struct-literal-restrictions-in-lamda.rs: pass -> [missing] (J1)
  • [ui] tests/ui/parser/struct-literal-variant-in-if.rs: pass -> [missing] (J1)
  • [ui] tests/ui/parser/struct-literals-in-invalid-places.rs: [missing] -> pass (J1)
  • [ui] tests/ui/target_modifiers/no_value_bool.rs#error: [missing] -> pass (J1)
  • [ui] tests/ui/target_modifiers/no_value_bool.rs#error_explicit: [missing] -> pass (J1)
  • [ui] tests/ui/target_modifiers/no_value_bool.rs#ok: [missing] -> pass (J1)
  • [ui] tests/ui/target_modifiers/no_value_bool.rs#ok_explicit: [missing] -> pass (J1)
  • errors::verify_metadata_incompatible_target_modifiers_l_missed_77: [missing] -> pass (J2)
  • errors::verify_metadata_incompatible_target_modifiers_r_missed_78: [missing] -> pass (J2)
  • errors::verify_metadata_unknown_target_modifier_unsafe_allowed_77: pass -> [missing] (J2)
  • errors::verify_metadata_unknown_target_modifier_unsafe_allowed_79: [missing] -> pass (J2)

Stage 2

  • [ui] tests/ui/closures/upvar-or-pattern-issue-138958.rs: [missing] -> pass (J0)
  • [ui] tests/ui/parser/issues/issue-111692.rs: pass -> [missing] (J0)
  • [ui] tests/ui/parser/method-call-on-struct-literal-in-if-condition.rs: pass -> [missing] (J0)
  • [ui] tests/ui/parser/struct-literal-in-for.rs: pass -> [missing] (J0)
  • [ui] tests/ui/parser/struct-literal-in-if.rs: pass -> [missing] (J0)
  • [ui] tests/ui/parser/struct-literal-in-match-discriminant.rs: pass -> [missing] (J0)
  • [ui] tests/ui/parser/struct-literal-in-while.rs: pass -> [missing] (J0)
  • [ui] tests/ui/parser/struct-literal-restrictions-in-lamda.rs: pass -> [missing] (J0)
  • [ui] tests/ui/parser/struct-literal-variant-in-if.rs: pass -> [missing] (J0)
  • [ui] tests/ui/parser/struct-literals-in-invalid-places.rs: [missing] -> pass (J0)
  • [ui] tests/ui/target_modifiers/no_value_bool.rs#error: [missing] -> pass (J0)
  • [ui] tests/ui/target_modifiers/no_value_bool.rs#error_explicit: [missing] -> pass (J0)
  • [ui] tests/ui/target_modifiers/no_value_bool.rs#ok: [missing] -> pass (J0)
  • [ui] tests/ui/target_modifiers/no_value_bool.rs#ok_explicit: [missing] -> pass (J0)
  • [codegen] tests/codegen/assign-desugar-debuginfo.rs: [missing] -> pass (J3)
  • [incremental] tests/incremental/define-opaques.rs: [missing] -> pass (J3)

Additionally, 37 doctest diffs were found. These are ignored, as they are noisy.

Job group index

  • J0: aarch64-apple, aarch64-gnu, arm-android, armhf-gnu, dist-i586-gnu-i586-i686-musl, i686-gnu-1, i686-gnu-nopt-1, i686-msvc-1, test-various, x86_64-apple-2, x86_64-gnu, x86_64-gnu-llvm-18-1, x86_64-gnu-llvm-18-2, x86_64-gnu-llvm-19-1, x86_64-gnu-llvm-19-2, x86_64-gnu-nopt, x86_64-gnu-stable, x86_64-mingw-1, x86_64-msvc-1
  • J1: x86_64-gnu-llvm-18-3, x86_64-gnu-llvm-19-3
  • J2: aarch64-apple, aarch64-gnu, i686-gnu-2, i686-gnu-nopt-2, i686-mingw-2, i686-mingw-3, i686-msvc-2, x86_64-apple-1, x86_64-gnu, x86_64-gnu-llvm-18-3, x86_64-gnu-llvm-19-3, x86_64-gnu-nopt, x86_64-gnu-stable, x86_64-mingw-2, x86_64-msvc-2
  • J3: aarch64-apple, aarch64-gnu, arm-android, armhf-gnu, dist-i586-gnu-i586-i686-musl, i686-gnu-1, i686-gnu-nopt-1, i686-msvc-1, test-various, x86_64-apple-1, x86_64-gnu, x86_64-gnu-llvm-18-1, x86_64-gnu-llvm-18-2, x86_64-gnu-llvm-19-1, x86_64-gnu-llvm-19-2, x86_64-gnu-nopt, x86_64-gnu-stable, x86_64-mingw-1, x86_64-msvc-1

@rust-timer
Copy link
Collaborator

📌 Perf builds for each rolled up PR:

PR# Message Perf Build Sha
#138483 Target modifiers fix for bool flags without value 01ce11600a6e1c963f1997713be61880051869dc (link)
#138818 Don't produce debug information for compiler-introduced-var… b936c44860d4fb233a2bb13c482c92c359c62f79 (link)
#138898 Mostly parser: Eliminate code that's been dead / semi-dead … d5847fb5bd930b17b2f465d2b8d383adca117b57 (link)
#138930 Add bootstrap step diff to CI job analysis 1491cae1248b6969764b044f8ae2786fc06bae39 (link)
#138954 Ensure define_opaque attrs are accounted for in HIR hash 176bc48a4e9a40ee75c139b1d4652568f603d03f (link)
#138959 Revert "Make MatchPairTree::place non-optional" 56645a8323f898de3c9f7b29a8c3748ff990d394 (link)
#138967 Fix typo in error message aa51d275c7ca64eb68ceb638ddef6d603806b054 (link)

previous master: 65899c06f1

In the case of a perf regression, run the following command for each PR you suspect might be the cause: @rust-timer build $SHA

@rust-timer
Copy link
Collaborator

Finished benchmarking commit (f1bc669): comparison URL.

Overall result: ✅ improvements - no action needed

@rustbot label: -perf-regression

Instruction count

This is the most reliable metric that we have; it was used to determine the overall result at the top of this comment. However, even this metric can sometimes exhibit noise.

mean range count
Regressions ❌
(primary)
- - 0
Regressions ❌
(secondary)
- - 0
Improvements ✅
(primary)
- - 0
Improvements ✅
(secondary)
-0.1% [-0.1%, -0.1%] 1
All ❌✅ (primary) - - 0

Max RSS (memory usage)

Results (primary 3.4%)

This is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment.

mean range count
Regressions ❌
(primary)
8.1% [8.1%, 8.1%] 1
Regressions ❌
(secondary)
- - 0
Improvements ✅
(primary)
-1.3% [-1.3%, -1.3%] 1
Improvements ✅
(secondary)
- - 0
All ❌✅ (primary) 3.4% [-1.3%, 8.1%] 2

Cycles

Results (secondary -2.8%)

This is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment.

mean range count
Regressions ❌
(primary)
- - 0
Regressions ❌
(secondary)
- - 0
Improvements ✅
(primary)
- - 0
Improvements ✅
(secondary)
-2.8% [-2.8%, -2.8%] 1
All ❌✅ (primary) - - 0

Binary size

Results (primary -0.0%, secondary -0.0%)

This is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment.

mean range count
Regressions ❌
(primary)
- - 0
Regressions ❌
(secondary)
- - 0
Improvements ✅
(primary)
-0.0% [-0.0%, -0.0%] 8
Improvements ✅
(secondary)
-0.0% [-0.0%, -0.0%] 13
All ❌✅ (primary) -0.0% [-0.0%, -0.0%] 8

Bootstrap: 777.72s -> 777.678s (-0.01%)
Artifact size: 365.81 MiB -> 365.82 MiB (0.00%)

@Zalathar Zalathar deleted the rollup-568cpmy branch March 27, 2025 00:44
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

A-testsuite Area: The testsuite used to check the correctness of rustc A-tidy Area: The tidy tool merged-by-bors This PR was explicitly merged by bors. rollup A PR which is a rollup S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. T-bootstrap Relevant to the bootstrap subteam: Rust's build system (x.py and src/bootstrap) T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. T-infra Relevant to the infrastructure team, which will review and decide on the PR/issue. T-libs Relevant to the library team, which will review and decide on the PR/issue.

Projects

None yet

Development

Successfully merging this pull request may close these issues.