]> git.lizzy.rs Git - rust.git/log
rust.git
2 years agoRollup merge of #90783 - camelid:update-miri, r=RalfJung
Matthias Krüger [Wed, 10 Nov 2021 22:04:27 +0000 (23:04 +0100)]
Rollup merge of #90783 - camelid:update-miri, r=RalfJung

Update Miri

Fixes #90763.

This is the last step in landing rust-lang/miri#1340!

r? `@RalfJung`

2 years agoRollup merge of #90736 - Lokathor:inline-asm-docs-updates, r=Amanieu
Matthias Krüger [Wed, 10 Nov 2021 22:04:26 +0000 (23:04 +0100)]
Rollup merge of #90736 - Lokathor:inline-asm-docs-updates, r=Amanieu

adjust documented inline-asm register constraints

This change more clearly specifies how `reg` and `reg_thumb` work with ARM, Thumb2, and Thumb1 code.

Based upon the [llvm documentation](https://llvm.org/docs/LangRef.html#supported-constraint-code-list) for register constraint codes.
To be clear, this just updates the docs to match what already happens with rustc/llvm.
No change in the compiler is required to make it match this new documentation.

2 years agoRollup merge of #89930 - cuviper:avoid-clone3, r=joshtriplett
Matthias Krüger [Wed, 10 Nov 2021 22:04:25 +0000 (23:04 +0100)]
Rollup merge of #89930 - cuviper:avoid-clone3, r=joshtriplett

Only use `clone3` when needed for pidfd

In #89522 we learned that `clone3` is interacting poorly with Gentoo's
`sandbox` tool. We only need that for the unstable pidfd extensions, so
otherwise avoid that and use a normal `fork`.

This is a re-application of beta #89924, now that we're aware that we need
more than just a temporary release fix. I also reverted 12fbabd27f700, as
that was just fallout from using `clone3` instead of `fork`.

r? `@Mark-Simulacrum`
cc `@joshtriplett`

2 years agoUpdate Miri
Noah Lev [Wed, 10 Nov 2021 20:42:51 +0000 (12:42 -0800)]
Update Miri

This is the last step in landing rust-lang/miri#1340!

2 years agoAuto merge of #90759 - yanok:llvm-dbginfo-fix, r=nikic
bors [Wed, 10 Nov 2021 12:56:29 +0000 (12:56 +0000)]
Auto merge of #90759 - yanok:llvm-dbginfo-fix, r=nikic

Update llvm submodule

This includes debug info generation fix, that fixes #90301.

Also includes WASM backend related fix for https://bugs.llvm.org/show_bug.cgi?id=52352
(I haven't found a corresponding Rust bug).

2 years agoUpdate llvm submodule
Ilya Yanok [Wed, 10 Nov 2021 10:52:59 +0000 (10:52 +0000)]
Update llvm submodule

This includes debug info generation fix, that fixes #90301.

Also includes WASM backend related fix for https://bugs.llvm.org/show_bug.cgi?id=52352
(I haven't found a corresponding Rust bug).

2 years agoAuto merge of #88670 - camelid:miri-uninit-num, r=RalfJung
bors [Wed, 10 Nov 2021 09:36:03 +0000 (09:36 +0000)]
Auto merge of #88670 - camelid:miri-uninit-num, r=RalfJung

miri: Detect uninitialized integers and floats

Part of rust-lang/miri#1340.

Companion Miri PR: rust-lang/miri#1904

r? `@RalfJung`

2 years agoAuto merge of #90754 - matthiaskrgr:rollup-v0483m5, r=matthiaskrgr
bors [Wed, 10 Nov 2021 06:15:50 +0000 (06:15 +0000)]
Auto merge of #90754 - matthiaskrgr:rollup-v0483m5, r=matthiaskrgr

Rollup of 3 pull requests

Successful merges:

 - #90690 (kmc-solid: Avoid the use of `asm_const`)
 - #90748 (Add a real tracking issue for `CommandExt::groups`)
 - #90751 (Update books)

Failed merges:

r? `@ghost`
`@rustbot` modify labels: rollup

2 years agoRollup merge of #90751 - ehuss:update-books, r=ehuss
Matthias Krüger [Wed, 10 Nov 2021 05:02:56 +0000 (06:02 +0100)]
Rollup merge of #90751 - ehuss:update-books, r=ehuss

Update books

## nomicon

1 commits in 358e6a61d5f4f0496d0a81e70cdcd25d05307342..c6b4bf831e9a40aec34f53067d20634839a6778b
2021-10-20 11:23:12 -0700 to 2021-11-09 02:30:56 +0900
- Replace some use of variant with covariant (rust-lang/nomicon#322)

## book

11 commits in fd9299792852c9a368cb236748781852f75cdac6..5c5dbc5b196c9564422b3193264f3288d2a051ce
2021-10-22 21:59:46 -0400 to 2021-11-09 19:30:43 -0500
- Fix constants link.
- Fix updated anchor
- Propagate edits to chapter 2 back
- Edits to nostarch's chapter 3 edits
- ch 3 from nostarch
- Fix Cargo.toml snippet about custom derive macros
- Snapshot of chapter 9 for nostarch
- Create tmp/src for converting quotes, not sure why this broke but ok
- Update question mark to better explain where it can be used
- Clarify sentence about Results in functions that don't return Result. Fixes rust-lang/book#2912.
- Merge pull request rust-lang/book#2913 from covariant/patch-1

## rust-by-example

2 commits in 27f1ff5e440ef78828b68ab882b98e1b10d9af32..e9d45342d7a6c1def4731f1782d87ea317ba30c3
2021-10-13 08:04:40 -0300 to 2021-11-02 13:33:03 -0500
- Enums: Linked-List Needs Re-Wording (rust-lang/rust-by-example#1469)
- fix: Use the point as top left corner for `square` (rust-lang/rust-by-example#1471)

## rustc-dev-guide

13 commits in b06008731af0f7d07cd0614e820c8276dfed1c18..196ef69aa68f2cef44f37566ee7db37daf00301b
2021-10-21 15:13:09 -0500 to 2021-11-07 07:48:47 -0600
- Fix typo: [upv.rs_mentioned] -> [upvars_mentioned]
- Add note to emphasize replacing TARGET_TRIPLE (rust-lang/rustc-dev-guide#1250)
- Remove some legacy test suites.
- tiny capitalization fix
- Fix date
- Update some date-check comments
- Ensure date-check cron job is using latest stable Rust
- enhance subtree docs, link to clippy docs
- Edit introduction to bootstrapping
- Some minor adjustments to the diagnostic documentation
- Edit "About this guide" for semantic line feeds
- Fix `rustc_mir` related links (rust-lang/rustc-dev-guide#1228)
- Add documentation for LLVM CFI support

## edition-guide

3 commits in 7c0088ca744d293a5f4b1e2ac378e7c23d30fe55..27f4a84d3852e9416cae5861254fa53a825c56bd
2021-10-05 13:28:05 +0200 to 2021-11-08 10:13:20 -0500
- Add a missing period (rust-lang/edition-guide#271)
- Fix syntax error in code example (rust-lang/edition-guide#270)
- Fixed an example error of prelude.md (rust-lang/edition-guide#269)

2 years agoRollup merge of #90748 - cuviper:track-setgroups, r=dtolnay
Matthias Krüger [Wed, 10 Nov 2021 05:02:55 +0000 (06:02 +0100)]
Rollup merge of #90748 - cuviper:track-setgroups, r=dtolnay

Add a real tracking issue for `CommandExt::groups`

The `unstable` attribute referenced the closed RFE #38527, so I filed tracking issue #90747.

2 years agoRollup merge of #90690 - solid-rs:fix-kmc-solid-asm-const, r=Mark-Simulacrum
Matthias Krüger [Wed, 10 Nov 2021 05:02:54 +0000 (06:02 +0100)]
Rollup merge of #90690 - solid-rs:fix-kmc-solid-asm-const, r=Mark-Simulacrum

kmc-solid: Avoid the use of `asm_const`

This PR removes the use of [the now-separated-out `asm_const` compiler feature][1] in `std::sys::solid` to fix the [`*-kmc-solid_*`](https://doc.rust-lang.org/nightly/rustc/platform-support/kmc-solid.html) Tier 3 targets.

[1]: https://github.com/rust-lang/rust/pull/90348

2 years agoAuto merge of #90663 - ken-matsui:support-early-stopping-too-old-tidy-for-macos,...
bors [Wed, 10 Nov 2021 03:11:44 +0000 (03:11 +0000)]
Auto merge of #90663 - ken-matsui:support-early-stopping-too-old-tidy-for-macos, r=Mark-Simulacrum

Support early stopping too old pre-installed `tidy` command for macOS in the HTML checker

This PR brings early stopping the HTML checker before errors, which leave some macOS users confused, and suggesting installing a newer `tidy` command.

The pre-installed `tidy` command on macOS is too old, released on 31 October 2006. Additionally, I can see the same date at [StackOverflow](https://stackoverflow.com/questions/22283382/overwrite-osx-tidy
) seven years ago. The `tidy` does not support two indispensable options: `--mute-id` and `--mute`. So, the `./x.py test` command fails with a bunch of errors due not to muting them.

I could confirm the `./x.py test` command before installing a newer `tidy` failed and its command after the installation succeeded.

2 years agoUpdate books
Eric Huss [Wed, 10 Nov 2021 03:11:01 +0000 (19:11 -0800)]
Update books

2 years agoAdd a real tracking issue for `CommandExt::groups`
Josh Stone [Wed, 10 Nov 2021 01:28:56 +0000 (17:28 -0800)]
Add a real tracking issue for `CommandExt::groups`

2 years agomiri: Detect uninitialized integers and floats
Noah Lev [Sat, 4 Sep 2021 23:07:20 +0000 (16:07 -0700)]
miri: Detect uninitialized integers and floats

Change the Miri engine to allow configuring whether to check
initialization of integers and floats. This allows the Miri tool to
optionally check for initialization if requested by the user.

2 years agoUpdate src/doc/unstable-book/src/library-features/asm.md
Lokathor [Tue, 9 Nov 2021 22:52:55 +0000 (15:52 -0700)]
Update src/doc/unstable-book/src/library-features/asm.md

Co-authored-by: Josh Triplett <josh@joshtriplett.org>
2 years agoUpdate src/doc/unstable-book/src/library-features/asm.md
Lokathor [Tue, 9 Nov 2021 22:52:46 +0000 (15:52 -0700)]
Update src/doc/unstable-book/src/library-features/asm.md

Co-authored-by: Josh Triplett <josh@joshtriplett.org>
2 years agoadjust documented register constraints to match https://llvm.org/docs/LangRef.html...
Lokathor [Tue, 9 Nov 2021 20:30:30 +0000 (13:30 -0700)]
adjust documented register constraints to match https://llvm.org/docs/LangRef.html#supported-constraint-code-list

2 years agoAuto merge of #90734 - matthiaskrgr:rollup-e1euotp, r=matthiaskrgr
bors [Tue, 9 Nov 2021 20:09:53 +0000 (20:09 +0000)]
Auto merge of #90734 - matthiaskrgr:rollup-e1euotp, r=matthiaskrgr

Rollup of 7 pull requests

Successful merges:

 - #89561 (Type inference for inline consts)
 - #90035 (implement rfc-2528 type_changing-struct-update)
 - #90613 (Allow to run a specific rustdoc-js* test)
 - #90683 (Make `compiler-docs` only control the default instead of being a hard off-switch)
 - #90685 (x.py: remove fixme by deleting code)
 - #90701 (Record more artifact sizes during self-profiling.)
 - #90723 (Better document `Box` and `alloc::alloc::box_free` connection)

Failed merges:

r? `@ghost`
`@rustbot` modify labels: rollup

2 years agoRollup merge of #90723 - asquared31415:box_docs, r=jyn514
Matthias Krüger [Tue, 9 Nov 2021 18:00:46 +0000 (19:00 +0100)]
Rollup merge of #90723 - asquared31415:box_docs, r=jyn514

Better document `Box` and `alloc::alloc::box_free` connection

The internal `alloc::alloc::box_free` function requires that its signature matches the `owned_box` struct's declaration, but previously that connection was only documented on the `box_free` function.

This PR makes the documentation two-way to help anyone making theoretical changes to `Box` to see the connection, since changes are more likely to originate from `Box`.

2 years agoRollup merge of #90701 - michaelwoerister:more-artifact-sizes, r=davidtwco
Matthias Krüger [Tue, 9 Nov 2021 18:00:45 +0000 (19:00 +0100)]
Rollup merge of #90701 - michaelwoerister:more-artifact-sizes, r=davidtwco

Record more artifact sizes during self-profiling.

This PR adds artifact size recording for

- "linked artifacts" (executables, RLIBs, dylibs, static libs)
- object files
- dwo files
- assembly files
- crate metadata
- LLVM bitcode files
- LLVM IR files
- codegen unit size estimates

Currently the identifiers emitted for these are hard-coded as string literals. Is it worth adding constants to https://github.com/rust-lang/measureme/blob/master/measureme/src/rustc.rs instead? We don't do that for query names and the like -- but artifact kinds might be more stable than query names.

2 years agoRollup merge of #90685 - jyn514:remove-dead-code, r=Mark-Simulacrum
Matthias Krüger [Tue, 9 Nov 2021 18:00:44 +0000 (19:00 +0100)]
Rollup merge of #90685 - jyn514:remove-dead-code, r=Mark-Simulacrum

x.py: remove fixme by deleting code

As far as I can tell, this parameter was never used, so just delete it
as unnecessary.

2 years agoRollup merge of #90683 - jyn514:compiler-docs, r=Mark-Simulacrum
Matthias Krüger [Tue, 9 Nov 2021 18:00:43 +0000 (19:00 +0100)]
Rollup merge of #90683 - jyn514:compiler-docs, r=Mark-Simulacrum

Make `compiler-docs` only control the default instead of being a hard off-switch

This also fixes `x doc src/tools/clippy` when compiler-docs is disabled.

See https://github.com/rust-lang/rust/pull/90354#issuecomment-955854508.

r? ``@Mark-Simulacrum``

2 years agoRollup merge of #90613 - GuillaumeGomez:specific-rustdoc-js-test, r=Mark-Simulacrum
Matthias Krüger [Tue, 9 Nov 2021 18:00:42 +0000 (19:00 +0100)]
Rollup merge of #90613 - GuillaumeGomez:specific-rustdoc-js-test, r=Mark-Simulacrum

Allow to run a specific rustdoc-js* test

r? ``@Mark-Simulacrum``

2 years agoRollup merge of #90035 - SparrowLii:rfc2528, r=jackh726
Matthias Krüger [Tue, 9 Nov 2021 18:00:41 +0000 (19:00 +0100)]
Rollup merge of #90035 - SparrowLii:rfc2528, r=jackh726

implement rfc-2528 type_changing-struct-update

This PR implement rfc2528-type_changing-struct-update.
The main change process is as follows:
1. Move the processing part of `base_expr` into `check_expr_struct_fields` to avoid returning `remaining_fields` (a relatively complex hash table)
2. Before performing the type consistency check(`check_expr_has_type_or_error`), if the `type_changing_struct_update` feature is set, enter a different processing flow, otherwise keep the original flow
3. In the case of the same structure definition, check each field in `remaining_fields`. If the field in `base_expr` is not the suptype of the field in `adt_ty`, an error(`FeildMisMatch`) will be reported.

The MIR part does not need to be changed, because only the items contained in `remaining_fields` will be extracted from `base_expr` when MIR is generated. This means that fields with different types in `base_expr` will not be used
Updates #86618
cc `@nikomatsakis`

2 years agoRollup merge of #89561 - nbdd0121:const_typeck, r=nikomatsakis
Matthias Krüger [Tue, 9 Nov 2021 18:00:40 +0000 (19:00 +0100)]
Rollup merge of #89561 - nbdd0121:const_typeck, r=nikomatsakis

Type inference for inline consts

Fixes #78132
Fixes #78174
Fixes #81857
Fixes #89964

Perform type checking/inference of inline consts in the same context as the outer def, similar to what is currently done to closure.

Doing so would require `closure_base_def_id` of the inline const to return the outer def, and since `closure_base_def_id` can be called on non-local crate (and thus have no HIR available), a new `DefKind` is created for inline consts.

The type of the generated anon const can capture lifetime of outer def, so we couldn't just use the typeck result as the type of the inline const's def. Closure has a similar issue, and it uses extra type params `CK, CS, U` to capture closure kind, input/output signature and upvars. I use a similar approach for inline consts, letting it have an extra type param `R`, and then `typeof(InlineConst<[paremt generics], R>)` would just be `R`. In borrowck region requirements are also propagated to the outer MIR body just like it's currently done for closure.

With this PR, inline consts in expression position are quitely usable now; however the usage in pattern position is still incomplete -- since those does not remain in the MIR borrowck couldn't verify the lifetime there. I have left an ignored test as a FIXME.

Some disucssions can be found on [this Zulip thread](https://rust-lang.zulipchat.com/#narrow/stream/260443-project-const-generics/topic/inline.20consts.20typeck).
cc `````@spastorino````` `````@lcnr`````
r? `````@nikomatsakis`````

`````@rustbot````` label A-inference F-inline_const T-compiler

2 years agoAuto merge of #86041 - bstrie:unmagic-array-copy, r=jackh726
bors [Tue, 9 Nov 2021 17:13:44 +0000 (17:13 +0000)]
Auto merge of #86041 - bstrie:unmagic-array-copy, r=jackh726

Replace Copy/Clone compiler magic on arrays with library impls

With const generics the compiler no longer needs to fake these impls.

2 years agoAllow to run a specific rustdoc-js* test
Guillaume Gomez [Fri, 5 Nov 2021 14:58:14 +0000 (15:58 +0100)]
Allow to run a specific rustdoc-js* test

2 years agoAuto merge of #90724 - JohnTitor:rollup-zg0kbm3, r=JohnTitor
bors [Tue, 9 Nov 2021 14:12:54 +0000 (14:12 +0000)]
Auto merge of #90724 - JohnTitor:rollup-zg0kbm3, r=JohnTitor

Rollup of 6 pull requests

Successful merges:

 - #87530 (Add comments regarding superfluous `!Sync` impls)
 - #90591 (treat illumos like solaris in failing ui tests which need it)
 - #90678 (Add some GATs-related regression tests)
 - #90688 (enable `dotprod` target feature in arm)
 - #90708 (Add a note about feature(explicit_generic_args_with_impl_trait) to the relevant error message)
 - #90720 (Update cargo)

Failed merges:

r? `@ghost`
`@rustbot` modify labels: rollup

2 years agoRollup merge of #90720 - ehuss:update-cargo, r=ehuss
Yuki Okushi [Tue, 9 Nov 2021 13:02:26 +0000 (22:02 +0900)]
Rollup merge of #90720 - ehuss:update-cargo, r=ehuss

Update cargo

4 commits in 94ca096afbf25f670e76e07dca754fcfe27134be..2e2a16e983f597da62bc132eb191bc3276d4b1bb
2021-10-29 14:45:06 +0000 to 2021-11-08 15:13:38 +0000
- Fix debug panic on download with redirect body. (rust-lang/cargo#10048)
- no need to clone (rust-lang/cargo#10051)
- Update curl. (rust-lang/cargo#10040)
- Fix --scrape-examples-target-crate using package name (with dashes) instead of crate name (with underscores) (rust-lang/cargo#10037)

2 years agoRollup merge of #90708 - NieDzejkob:feature-note, r=jackh726
Yuki Okushi [Tue, 9 Nov 2021 13:02:25 +0000 (22:02 +0900)]
Rollup merge of #90708 - NieDzejkob:feature-note, r=jackh726

Add a note about feature(explicit_generic_args_with_impl_trait) to the relevant error message

Fixes #90615

2 years agoRollup merge of #90688 - SparrowLii:dotprod, r=Amanieu
Yuki Okushi [Tue, 9 Nov 2021 13:02:24 +0000 (22:02 +0900)]
Rollup merge of #90688 - SparrowLii:dotprod, r=Amanieu

enable `dotprod` target feature in arm

To implement `vdot` neon insturction in stdarch, we need to enable `dotprod` target feature in arm in rustc.
r? `@Amanieu`

2 years agoRollup merge of #90678 - JohnTitor:add-some-gats-tests, r=jackh726
Yuki Okushi [Tue, 9 Nov 2021 13:02:23 +0000 (22:02 +0900)]
Rollup merge of #90678 - JohnTitor:add-some-gats-tests, r=jackh726

Add some GATs-related regression tests

Closes #88595, closes #90014
r? `@jackh726`

2 years agoRollup merge of #90591 - richlowe:illumos-ui-target, r=Mark-Simulacrum
Yuki Okushi [Tue, 9 Nov 2021 13:02:22 +0000 (22:02 +0900)]
Rollup merge of #90591 - richlowe:illumos-ui-target, r=Mark-Simulacrum

treat illumos like solaris in failing ui tests which need it

Just adding the right cfg target for tests which fail because they don't know illumos is a thing.

(cc `````@jclulow)`````

2 years agoRollup merge of #87530 - bstrie:commentsync, r=bstrie
Yuki Okushi [Tue, 9 Nov 2021 13:02:21 +0000 (22:02 +0900)]
Rollup merge of #87530 - bstrie:commentsync, r=bstrie

Add comments regarding superfluous `!Sync` impls

2 years agodocument Box and box_free connection
asquared31415 [Tue, 9 Nov 2021 12:13:53 +0000 (07:13 -0500)]
document Box and box_free connection

2 years agoAuto merge of #90700 - fee1-dead:select-returns-vec, r=davidtwco
bors [Tue, 9 Nov 2021 11:16:38 +0000 (11:16 +0000)]
Auto merge of #90700 - fee1-dead:select-returns-vec, r=davidtwco

Make `select_*` methods return `Vec` for `TraitEngine`

This reduces some complexity as an empty vec means no errors and non-empty vec means errors occurred.

2 years agoUpdate cargo
Eric Huss [Tue, 9 Nov 2021 08:22:06 +0000 (00:22 -0800)]
Update cargo

2 years agoAuto merge of #87337 - jyn514:lint-error, r=oli-obk,flip1995
bors [Tue, 9 Nov 2021 08:21:10 +0000 (08:21 +0000)]
Auto merge of #87337 - jyn514:lint-error, r=oli-obk,flip1995

Don't abort compilation after giving a lint error

The only reason to use `abort_if_errors` is when the program is so broken that either:
1. later passes get confused and ICE
2. any diagnostics from later passes would be noise

This is never the case for lints, because the compiler has to be able to deal with `allow`-ed lints.
So it can continue to lint and compile even if there are lint errors.

Closes https://github.com/rust-lang/rust/issues/82761. This is a WIP because I have a feeling it will exit with 0 even if there were lint errors; I don't have a computer that can build rustc locally at the moment.

2 years agoAuto merge of #90485 - camsteffen:fmt-args-less-bind, r=m-ou-se
bors [Tue, 9 Nov 2021 05:33:16 +0000 (05:33 +0000)]
Auto merge of #90485 - camsteffen:fmt-args-less-bind, r=m-ou-se

Don't destructure args tuple in format_args!

This allows Clippy to parse the HIR more simply since `arg0` is changed to `_args.0`. (cc rust-lang/rust-clippy#7843). From rustc's perspective, I think this is something between a lateral move and a tiny improvement since there are fewer bindings.

r? `@m-ou-se`

2 years agoAuto merge of #90695 - GuillaumeGomez:rollup-kxvvw4o, r=GuillaumeGomez
bors [Tue, 9 Nov 2021 01:30:23 +0000 (01:30 +0000)]
Auto merge of #90695 - GuillaumeGomez:rollup-kxvvw4o, r=GuillaumeGomez

Rollup of 4 pull requests

Successful merges:

 - #90494 (ARMv6K Horizon OS panic change)
 - #90652 (use filter(|x| matches!(..)) instead of filter_map(|x| match x ... => Some(xy)))
 - #90657 (Fix bug with `#[doc]` string single-character last lines)
 - #90689 (:arrow_up: rust-analyzer)

Failed merges:

r? `@ghost`
`@rustbot` modify labels: rollup

2 years agoAdd some GATs-related regression tests
Yuki Okushi [Mon, 8 Nov 2021 00:45:15 +0000 (09:45 +0900)]
Add some GATs-related regression tests

2 years agoAuto merge of #90443 - camelid:rustdoc-subst, r=GuillaumeGomez
bors [Mon, 8 Nov 2021 21:37:59 +0000 (21:37 +0000)]
Auto merge of #90443 - camelid:rustdoc-subst, r=GuillaumeGomez

Merge `DocContext.{ty,lt,ct}_substs` into one map

It should be impossible to have more than one entry with a particular
key across the three maps, so they should be one map. In addition to
making it impossible for multiple entries to exist, this should improve
memory usage since now only one map is allocated on the stack and heap.

r? `@GuillaumeGomez`

2 years agoAttempt to address perf regressions with #[inline]
bstrie [Mon, 8 Nov 2021 20:51:56 +0000 (15:51 -0500)]
Attempt to address perf regressions with #[inline]

2 years agoAdd a note about feature(explicit_generic_args_with_impl_trait) to the relevant error...
Jakub Kądziołka [Mon, 8 Nov 2021 17:39:22 +0000 (18:39 +0100)]
Add a note about feature(explicit_generic_args_with_impl_trait) to the relevant error message

2 years agoUpdate Copy/Clone documentation WRT arrays
bstrie [Sat, 5 Jun 2021 21:20:51 +0000 (17:20 -0400)]
Update Copy/Clone documentation WRT arrays

2 years agoimpl Copy/Clone for arrays in std, not in compiler
bstrie [Sat, 5 Jun 2021 21:17:35 +0000 (17:17 -0400)]
impl Copy/Clone for arrays in std, not in compiler

2 years agoAdd comments regarding superfluous `!Sync` impls
bstrie [Tue, 27 Jul 2021 22:50:34 +0000 (18:50 -0400)]
Add comments regarding superfluous `!Sync` impls

2 years agoRecord more artifact sizes during self-profiling.
Michael Woerister [Mon, 8 Nov 2021 15:59:36 +0000 (16:59 +0100)]
Record more artifact sizes during self-profiling.

2 years agofmt
Deadbeef [Mon, 8 Nov 2021 15:55:51 +0000 (23:55 +0800)]
fmt

2 years agoMake select_* methods return Vec for TraitEngine
Deadbeef [Mon, 8 Nov 2021 15:35:23 +0000 (23:35 +0800)]
Make select_* methods return Vec for TraitEngine

2 years agoRollup merge of #90689 - lnicola:rust-analyzer-2021-11-08, r=lnicola
Guillaume Gomez [Mon, 8 Nov 2021 14:15:25 +0000 (15:15 +0100)]
Rollup merge of #90689 - lnicola:rust-analyzer-2021-11-08, r=lnicola

:arrow_up: rust-analyzer

r? ``@ghost``

2 years agoRollup merge of #90657 - GuillaumeGomez:one-char-last-line-removed, r=jyn514
Guillaume Gomez [Mon, 8 Nov 2021 14:15:24 +0000 (15:15 +0100)]
Rollup merge of #90657 - GuillaumeGomez:one-char-last-line-removed, r=jyn514

Fix bug with `#[doc]` string single-character last lines

Fixes #90618.

This is because `.iter().all(|c| c == '*')` returns `true` if there is no character checked. And in case the last line has only one character, it simply returns `true`, making the last line behind removed.

2 years agoRollup merge of #90652 - matthiaskrgr:unnnec_filter_map, r=jyn514
Guillaume Gomez [Mon, 8 Nov 2021 14:15:23 +0000 (15:15 +0100)]
Rollup merge of #90652 - matthiaskrgr:unnnec_filter_map, r=jyn514

use filter(|x| matches!(..)) instead of filter_map(|x| match x ... => Some(xy))

2 years agoRollup merge of #90494 - Meziu:armv6k-3ds-target, r=sanxiyn
Guillaume Gomez [Mon, 8 Nov 2021 14:15:22 +0000 (15:15 +0100)]
Rollup merge of #90494 - Meziu:armv6k-3ds-target, r=sanxiyn

ARMv6K Horizon OS panic change

After a small change to `backtrace-rs` ([#448](https://github.com/rust-lang/backtrace-rs/pull/448)), `PanicStrategy::Unwind` is now fully supported.

2 years agoAuto merge of #90361 - Mark-Simulacrum:always-verify, r=michaelwoerister
bors [Mon, 8 Nov 2021 13:38:08 +0000 (13:38 +0000)]
Auto merge of #90361 - Mark-Simulacrum:always-verify, r=michaelwoerister

Enable verification for 1/32th of queries loaded from disk

This is a limited enabling of incremental verification for query results loaded from disk, which previously did not run without -Zincremental-verify-ich. If enabled for all queries, we see a probably unacceptable hit of ~50% in the worst case, so this pairs back the verification to a more limited set based on the hash key.

Per collected [perf results](https://github.com/rust-lang/rust/pull/84227#issuecomment-953350582), this is a regression of at most 7% on coercions opt incr-unchanged, and typically less than 0.5% on other benchmarks (largely limited to incr-unchanged). I believe this is acceptable performance to land, and we can either ratchet it up or down fairly easily.

We have no real sense of whether this will lead to a large amount of assertions in the wild, but since those assertions may lead to miscompilations today, it seems potentially warranted. We have a good bit of lead time until the next stable release, though the holiday season will also start soon; we may wish to discuss the timing of enabling this and weigh the desire to prevent (possible) miscompilations against assertions.

cc `@rust-lang/wg-incr-comp`

2 years agokmc-solid: Avoid the use of `asm_const`
Tomoaki Kawada [Mon, 8 Nov 2021 09:27:24 +0000 (18:27 +0900)]
kmc-solid: Avoid the use of `asm_const`

2 years ago:arrow_up: rust-analyzer
Laurențiu Nicola [Mon, 8 Nov 2021 10:07:03 +0000 (12:07 +0200)]
:arrow_up: rust-analyzer

2 years agoenable `dotprod` target feature in arm
SparrowLii [Mon, 8 Nov 2021 08:24:50 +0000 (16:24 +0800)]
enable `dotprod` target feature in arm

2 years agoAuto merge of #90675 - camelid:cleanup-impl, r=jyn514
bors [Mon, 8 Nov 2021 08:21:51 +0000 (08:21 +0000)]
Auto merge of #90675 - camelid:cleanup-impl, r=jyn514

rustdoc: Cleanup `clean::Impl` and other parts of `clean`

This PR cleans up and reduces the size of `clean::Impl`, makes some other small performance improvements, and removes some Clean impls that are either unnecessary or potentially confusing.

r? `@jyn514`

2 years agoAuto merge of #90680 - calebcartwright:rustfmt-sync, r=calebcartwright
bors [Mon, 8 Nov 2021 05:13:41 +0000 (05:13 +0000)]
Auto merge of #90680 - calebcartwright:rustfmt-sync, r=calebcartwright

sync rustfmt subtree

2 years agox.py: remove fixme by deleting code
Joshua Nelson [Mon, 8 Nov 2021 04:45:15 +0000 (04:45 +0000)]
x.py: remove fixme by deleting code

As far as I can tell, this parameter was never used, so just delete it
as unnecessary.

2 years agoMake `compiler-docs` only control the default instead of being a hard off-switch
Joshua Nelson [Mon, 8 Nov 2021 04:16:34 +0000 (04:16 +0000)]
Make `compiler-docs` only control the default instead of being a hard off-switch

This also fixes `x doc src/tools/clippy` when compiler-docs is disabled.

2 years agoMerge commit 'ea199bacef07213dbe008841b89c450e3bf0c638' into rustfmt-sync
Caleb Cartwright [Mon, 8 Nov 2021 02:37:34 +0000 (20:37 -0600)]
Merge commit 'ea199bacef07213dbe008841b89c450e3bf0c638' into rustfmt-sync

2 years agorustdoc: Remove top-level wrappers for `ImplKind` methods
Noah Lev [Mon, 8 Nov 2021 02:26:37 +0000 (18:26 -0800)]
rustdoc: Remove top-level wrappers for `ImplKind` methods

The `ImplKind` methods can just be used directly instead.

2 years agoAuto merge of #89488 - c410-f3r:testsssssss, r=petrochenkov
bors [Mon, 8 Nov 2021 02:04:31 +0000 (02:04 +0000)]
Auto merge of #89488 - c410-f3r:testsssssss, r=petrochenkov

Move some tests to more reasonable directories - 8

cc #73494
r? `@petrochenkov`

2 years agoMerge pull request #5070 from calebcartwright/rustup-2021-11-s1
Caleb Cartwright [Mon, 8 Nov 2021 01:40:15 +0000 (19:40 -0600)]
Merge pull request #5070 from calebcartwright/rustup-2021-11-s1

subtree sync

2 years agoUse `has_errors_or_lint_errors` in rustdoc instead of `abort_if_errors()`
Joshua Nelson [Thu, 16 Sep 2021 05:35:23 +0000 (05:35 +0000)]
Use `has_errors_or_lint_errors` in rustdoc instead of `abort_if_errors()`

Rustdoc is special as usual and doesn't go through RunCompiler, so it
needs its own explicit checks. The rest of the tools go through
RunCompiler, so they should be fine.

2 years agoDon't proceed to codegen if there are lint errors
Joshua Nelson [Thu, 22 Jul 2021 23:47:46 +0000 (23:47 +0000)]
Don't proceed to codegen if there are lint errors

2 years agoDon't abort compilation after giving a lint error
Joshua Nelson [Wed, 21 Jul 2021 03:23:22 +0000 (23:23 -0400)]
Don't abort compilation after giving a lint error

The only reason to use `abort_if_errors` is when the program is so broken that either:
1. later passes get confused and ICE
2. any diagnostics from later passes would be noise

This is never the case for lints, because the compiler has to be able to deal with `allow`-ed lints.
So it can continue to lint and compile even if there are lint errors.

2 years agochore: bump toolchain
Caleb Cartwright [Mon, 8 Nov 2021 01:06:24 +0000 (19:06 -0600)]
chore: bump toolchain

2 years agoAuto merge of #88368 - jyn514:metadata-error, r=petrochenkov
bors [Sun, 7 Nov 2021 23:03:55 +0000 (23:03 +0000)]
Auto merge of #88368 - jyn514:metadata-error, r=petrochenkov

 Improve error when an .rlib can't be parsed

This usually describes either an error in the compiler itself or some
sort of IO error. Either way, we should report it to the user rather
than just saying "crate not found".

This only gives an error if the crate couldn't be loaded at all - if the
compiler finds another .rlib or .rmeta file which was valid, it will
continue to compile the crate.

Example output:
```
error[E0785]: found invalid metadata files for crate `foo`
 --> bar.rs:3:24
  |
3 |         println!("{}", foo::FOO_11_49[0]);
  |                        ^^^
  |
  = warning: failed to parse rlib '/home/joshua/test-rustdoc/libfoo.rlib': Invalid archive extended name offset
```

cc `@ehuss`

2 years agoMerge remote-tracking branch 'upstream/master' into rustup-2021-11-s1
Caleb Cartwright [Sun, 7 Nov 2021 20:44:33 +0000 (14:44 -0600)]
Merge remote-tracking branch 'upstream/master' into rustup-2021-11-s1

2 years agoAuto merge of #90668 - matthiaskrgr:clippy_nov7, r=jyn514
bors [Sun, 7 Nov 2021 20:04:54 +0000 (20:04 +0000)]
Auto merge of #90668 - matthiaskrgr:clippy_nov7, r=jyn514

more clippy fixes

2 years agoRemove Clean impl for `&T`
Noah Lev [Sun, 7 Nov 2021 17:23:33 +0000 (09:23 -0800)]
Remove Clean impl for `&T`

2 years agoRemove unused Clean impl for `Rc<T>`
Noah Lev [Sun, 7 Nov 2021 17:20:35 +0000 (09:20 -0800)]
Remove unused Clean impl for `Rc<T>`

2 years agoRemove Clean impl for `Vec<T>`
Noah Lev [Sun, 7 Nov 2021 17:19:25 +0000 (09:19 -0800)]
Remove Clean impl for `Vec<T>`

2 years agoRemove Clean impl for `IndexVec<T>`
Noah Lev [Sun, 7 Nov 2021 17:09:10 +0000 (09:09 -0800)]
Remove Clean impl for `IndexVec<T>`

2 years agoRemove Clean impl for `Option<T>`
Noah Lev [Sun, 7 Nov 2021 17:06:50 +0000 (09:06 -0800)]
Remove Clean impl for `Option<T>`

2 years agorustdoc: Use `ty::ImplPolarity` instead of custom enum
Noah Lev [Sun, 7 Nov 2021 16:57:33 +0000 (08:57 -0800)]
rustdoc: Use `ty::ImplPolarity` instead of custom enum

2 years agoUse an enum to record polarity in `clean::Impl`
Noah Lev [Sun, 7 Nov 2021 16:52:28 +0000 (08:52 -0800)]
Use an enum to record polarity in `clean::Impl`

2 years agorustdoc: Refactor `Impl.{synthetic,blanket_impl}` into enum
Noah Lev [Sun, 7 Nov 2021 06:10:01 +0000 (23:10 -0700)]
rustdoc: Refactor `Impl.{synthetic,blanket_impl}` into enum

This change has two advantages:

1. It makes the possible states clearer, and it makes it impossible to
   construct invalid states, such as a blanket impl that is also an auto
   trait impl.

2. It shrinks the size of `Impl` a bit, since now there is only one
   field, rather than two.

2 years agomore clippy fixes
Matthias Krüger [Sun, 7 Nov 2021 09:33:27 +0000 (10:33 +0100)]
more clippy fixes

2 years agoAuto merge of #90671 - petrochenkov:astnaming, r=jackh726
bors [Sun, 7 Nov 2021 15:19:11 +0000 (15:19 +0000)]
Auto merge of #90671 - petrochenkov:astnaming, r=jackh726

ast: Fix naming conventions in AST structures

TraitKind -> Trait
TyAliasKind -> TyAlias
ImplKind -> Impl
FnKind -> Fn

All `*Kind`s in AST are supposed to be enums.

Tuple structs are converted to braced structs for the types above, and fields are reordered in syntactic order.

Also, mutable AST visitor now correctly visit spans in defaultness, unsafety, impl polarity and constness.

Noticed when reviewing #90076.

2 years agoImprove error when an .rlib can't be parsed
Joshua Nelson [Thu, 26 Aug 2021 18:37:44 +0000 (18:37 +0000)]
Improve error when an .rlib can't be parsed

This usually describes either an error in the compiler itself or some
sort of IO error. Either way, we should report it to the user rather
than just saying "crate not found".

This only gives an error if the crate couldn't be loaded at all - if the
compiler finds another .rlib or .rmeta file which was valid, it will
continue to compile the crate.

Example output:
```
error[E0785]: found invalid metadata files for crate `foo`
 --> bar.rs:3:24
  |
3 |         println!("{}", foo::FOO_11_49[0]);
  |                        ^^^
  |
  = warning: failed to parse rlib '/home/joshua/test-rustdoc/libfoo.rlib': Invalid archive extended name offset
```

2 years agorefactor: dedupe associated item visitation
Caleb Cartwright [Sat, 6 Nov 2021 22:12:25 +0000 (17:12 -0500)]
refactor: dedupe associated item visitation

2 years agoast: Fix naming conventions in AST structures
Vadim Petrochenkov [Sun, 7 Nov 2021 08:43:49 +0000 (16:43 +0800)]
ast: Fix naming conventions in AST structures

TraitKind -> Trait
TyAliasKind -> TyAlias
ImplKind -> Impl
FnKind -> Fn

All `*Kind`s in AST are supposed to be enums.

Tuple structs are converted to braced structs for the types above, and fields are reordered in syntactic order.

Also, mutable AST visitor now correctly visit spans in defaultness, unsafety, impl polarity and constness.

2 years agoast: Fix naming conventions in AST structures
Vadim Petrochenkov [Sun, 7 Nov 2021 08:43:49 +0000 (16:43 +0800)]
ast: Fix naming conventions in AST structures

TraitKind -> Trait
TyAliasKind -> TyAlias
ImplKind -> Impl
FnKind -> Fn

All `*Kind`s in AST are supposed to be enums.

Tuple structs are converted to braced structs for the types above, and fields are reordered in syntactic order.

Also, mutable AST visitor now correctly visit spans in defaultness, unsafety, impl polarity and constness.

2 years agoAuto merge of #89310 - joshtriplett:available-concurrency-affinity, r=m-ou-se
bors [Sun, 7 Nov 2021 11:53:25 +0000 (11:53 +0000)]
Auto merge of #89310 - joshtriplett:available-concurrency-affinity, r=m-ou-se

Make `std::thread::available_concurrency` support process-limited number of CPUs

Use `libc::sched_getaffinity` and count the number of CPUs in the returned mask. This handles cases where the process doesn't have access to all CPUs, such as when limited via `taskset` or similar.

This also covers cgroup cpusets.

2 years agorustdoc: Remove redundant `Impl.span` field
Noah Lev [Sun, 31 Oct 2021 21:49:32 +0000 (14:49 -0700)]
rustdoc: Remove redundant `Impl.span` field

It can be computed on-demand in `Item::span()`.

2 years agoAuto merge of #90348 - Amanieu:asm_feature_gates, r=joshtriplett
bors [Sun, 7 Nov 2021 04:59:42 +0000 (04:59 +0000)]
Auto merge of #90348 - Amanieu:asm_feature_gates, r=joshtriplett

Add features gates for experimental asm features

This PR splits off parts of `asm!` into separate features because they are not ready for stabilization.

Specifically this adds:
- `asm_const` for `const` operands.
- `asm_sym` for `sym` operands.
- `asm_experimental_arch` for architectures other than x86, x86_64, arm, aarch64 and riscv.

r? `@nagisa`

2 years agoRename functions reflect that inline const is also "typeck_child"
Gary Guo [Sat, 6 Nov 2021 20:01:35 +0000 (20:01 +0000)]
Rename functions reflect that inline const is also "typeck_child"

2 years agoFix closures within inline const
Gary Guo [Sat, 23 Oct 2021 23:26:40 +0000 (00:26 +0100)]
Fix closures within inline const

2 years agoAdd a FIXME note about what's missing
Gary Guo [Sun, 3 Oct 2021 15:05:55 +0000 (16:05 +0100)]
Add a FIXME note about what's missing

2 years agoEnsure closure requirements are proven for inline const
Gary Guo [Sun, 3 Oct 2021 22:14:33 +0000 (23:14 +0100)]
Ensure closure requirements are proven for inline const

2 years agoAdd unit test for issue 78174
Gary Guo [Sun, 3 Oct 2021 15:04:30 +0000 (16:04 +0100)]
Add unit test for issue 78174

2 years agoAdd unit test for issue 78132
Gary Guo [Sun, 3 Oct 2021 15:03:34 +0000 (16:03 +0100)]
Add unit test for issue 78132

2 years agoImplement type inference for inline consts
Gary Guo [Sat, 2 Oct 2021 12:12:33 +0000 (13:12 +0100)]
Implement type inference for inline consts

In most cases it is handled in the same way as closures.

2 years agoGive inline const separate DefKind
Gary Guo [Sat, 2 Oct 2021 11:59:26 +0000 (12:59 +0100)]
Give inline const separate DefKind

2 years agoRestrict tests that use needs-asm-support to non-experimental
Amanieu d'Antras [Wed, 3 Nov 2021 16:10:09 +0000 (16:10 +0000)]
Restrict tests that use needs-asm-support to non-experimental
architectures