]> git.lizzy.rs Git - rust.git/log
rust.git
3 years agoRollup merge of #84728 - camelid:sized-param-sugg-test, r=Mark-Simulacrum
Dylan DPC [Thu, 6 May 2021 22:38:36 +0000 (00:38 +0200)]
Rollup merge of #84728 - camelid:sized-param-sugg-test, r=Mark-Simulacrum

Add test for suggestion to borrow unsized function parameters

Closes #82820.

This is a regression test for #82820.

This test case is included in more general tests, but I think the error
regressed because there were a bunch of other diagnostic changes in the
test that obscured this regression.

Hopefully, having a test specific to the suggestion, and running rustfix
for the test, will prevent this error from regressing in the future.

3 years agoRollup merge of #84500 - tmandry:compiletest-run-flag, r=Mark-Simulacrum
Dylan DPC [Thu, 6 May 2021 22:38:35 +0000 (00:38 +0200)]
Rollup merge of #84500 - tmandry:compiletest-run-flag, r=Mark-Simulacrum

Add --run flag to compiletest

This controls whether run-* tests actually get run.

r? ```@Mark-Simulacrum```

3 years agoRollup merge of #84409 - mzohreva:mz/tls-dtors-before-join, r=jethrogb
Dylan DPC [Thu, 6 May 2021 22:38:33 +0000 (00:38 +0200)]
Rollup merge of #84409 - mzohreva:mz/tls-dtors-before-join, r=jethrogb

Ensure TLS destructors run before thread joins in SGX

The excellent test is from ```@jethrogb```

For context see: https://github.com/rust-lang/rust/pull/83416#discussion_r617282907

3 years agoAuto merge of #79930 - tgnottingham:bufwriter_performance, r=m-ou-se
bors [Thu, 6 May 2021 20:04:32 +0000 (20:04 +0000)]
Auto merge of #79930 - tgnottingham:bufwriter_performance, r=m-ou-se

Optimize BufWriter

3 years agoAdd test for suggestion to borrow unsized function parameters
Camelid [Thu, 29 Apr 2021 23:22:31 +0000 (16:22 -0700)]
Add test for suggestion to borrow unsized function parameters

This is a regression test for #82820.

This test case is included in more general tests, but I think the error
regressed because there were a bunch of other diagnostic changes in the
test that obscured this regression.

Hopefully, having a test specific to the suggestion, and running rustfix
for the test, will prevent this error from regressing in the future.

3 years agoAuto merge of #84559 - jackh726:issue-84398, r=nikomatsakis
bors [Thu, 6 May 2021 17:42:32 +0000 (17:42 +0000)]
Auto merge of #84559 - jackh726:issue-84398, r=nikomatsakis

Deduplicate ParamCandidates with the same value except for bound vars

Fixes #84398

This is kind of a hack. I wonder if we can get other types of candidates that are the same except for bound vars. This won't be a problem with Chalk, since we don't really need to know that there are two different "candidates" if they both give the same final substitution.

r? `@nikomatsakis`

3 years agojoin_orders_after_tls_destructors: ensure thread 2 is launched before thread 1 enters...
Mohsen Zohrevandi [Thu, 6 May 2021 16:36:26 +0000 (09:36 -0700)]
join_orders_after_tls_destructors: ensure thread 2 is launched before thread 1 enters TLS destructors

3 years agoAuto merge of #84982 - Dylan-DPC:rollup-q4cbec2, r=Dylan-DPC
bors [Thu, 6 May 2021 15:19:39 +0000 (15:19 +0000)]
Auto merge of #84982 - Dylan-DPC:rollup-q4cbec2, r=Dylan-DPC

Rollup of 8 pull requests

Successful merges:

 - #83507 (Implement RFC 2951: Native link modifiers)
 - #84328 (Stablize {HashMap,BTreeMap}::into_{keys,values})
 - #84712 (Simplify chdir implementation and minimize unsafe block)
 - #84851 (:arrow_up: rust-analyzer)
 - #84923 (Only compute Obligation `cache_key` once  in `register_obligation_at`)
 - #84945 (E0583: Include secondary path in error message)
 - #84949 (Fix typo in `MaybeUninit::array_assume_init` safety comment)
 - #84950 (Revert PR 83866)

Failed merges:

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

3 years agoPick candidate with fewer bound vars
Jack Huey [Thu, 6 May 2021 14:19:51 +0000 (10:19 -0400)]
Pick candidate with fewer bound vars

3 years agoRollup merge of #84950 - pietroalbini:revert-3478f83c0, r=Mark-Simulacrum
Dylan DPC [Thu, 6 May 2021 11:31:01 +0000 (13:31 +0200)]
Rollup merge of #84950 - pietroalbini:revert-3478f83c0, r=Mark-Simulacrum

Revert PR 83866

https://github.com/rust-lang/rust/pull/83866 caused multiple test failures when Rust's channel is changed from nightly to anything else. The PR will have to be landed again after the test suite is fixed.

The two kinds of test failures were:

* Rustdoc tests failed because the links in the generated HTML didn't point at nightly anymore, see https://github.com/rust-lang/rust/pull/84909#issuecomment-832028701
* Rustdoc UI tests failed because the links included in error messages didn't point at nightly anymore, see https://github.com/rust-lang/rust/pull/84909#issuecomment-832517722

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

3 years agoRollup merge of #84949 - sdroege:maybe-unint-typo, r=m-ou-se
Dylan DPC [Thu, 6 May 2021 11:31:00 +0000 (13:31 +0200)]
Rollup merge of #84949 - sdroege:maybe-unint-typo, r=m-ou-se

Fix typo in `MaybeUninit::array_assume_init` safety comment

And also add backticks around `MaybeUninit`.

3 years agoRollup merge of #84945 - fee1-dead:E0583-better-message, r=petrochenkov
Dylan DPC [Thu, 6 May 2021 11:30:59 +0000 (13:30 +0200)]
Rollup merge of #84945 - fee1-dead:E0583-better-message, r=petrochenkov

E0583: Include secondary path in error message

Fixes #84819.

3 years agoRollup merge of #84923 - estebank:as_cache_key-once, r=petrochenkov
Dylan DPC [Thu, 6 May 2021 11:30:58 +0000 (13:30 +0200)]
Rollup merge of #84923 - estebank:as_cache_key-once, r=petrochenkov

Only compute Obligation `cache_key` once  in `register_obligation_at`

3 years agoRollup merge of #84851 - lnicola:rust-analyzer-2021-05-03, r=jonas-schievink
Dylan DPC [Thu, 6 May 2021 11:30:56 +0000 (13:30 +0200)]
Rollup merge of #84851 - lnicola:rust-analyzer-2021-05-03, r=jonas-schievink

:arrow_up: rust-analyzer

3 years agoRollup merge of #84712 - joshtriplett:simplify-chdir, r=yaahc
Dylan DPC [Thu, 6 May 2021 11:30:55 +0000 (13:30 +0200)]
Rollup merge of #84712 - joshtriplett:simplify-chdir, r=yaahc

Simplify chdir implementation and minimize unsafe block

3 years agoRollup merge of #84328 - Folyd:stablize_map_into_keys_values, r=m-ou-se
Dylan DPC [Thu, 6 May 2021 11:30:54 +0000 (13:30 +0200)]
Rollup merge of #84328 - Folyd:stablize_map_into_keys_values, r=m-ou-se

Stablize {HashMap,BTreeMap}::into_{keys,values}

I would propose to stabilize `{HashMap,BTreeMap}::into_{keys,values}`( aka. `map_into_keys_values`).

Closes #75294.

3 years agoRollup merge of #83507 - luqmana:native-link-modifiers, r=petrochenkov
Dylan DPC [Thu, 6 May 2021 11:30:51 +0000 (13:30 +0200)]
Rollup merge of #83507 - luqmana:native-link-modifiers, r=petrochenkov

Implement RFC 2951: Native link modifiers

A first attempt at implementing https://github.com/rust-lang/rfcs/pull/2951 / https://github.com/rust-lang/compiler-team/issues/356.

Tracking Issue: https://github.com/rust-lang/rust/issues/81490

Introduces feature flags for the general syntax (`native_link_modifiers`) and each modifier (`native_link_modifiers_{as_needed,bundle,verbatim,whole_archive}`).

r? `@petrochenkov`

3 years agoAuto merge of #84965 - the8472:lazy-delayed-diagnostics, r=Mark-Simulacrum
bors [Thu, 6 May 2021 11:29:29 +0000 (11:29 +0000)]
Auto merge of #84965 - the8472:lazy-delayed-diagnostics, r=Mark-Simulacrum

lazify backtrace formatting for delayed diagnostics

Formatting backtraces causes debug info to be parsed, which is superfluous work if the delayed bugs get cleared later.

Lazifying them results in these speedups for the UI testsuite:

|       | debuginfo = 0 | debuginfo = 1 | debuginfo = 2 |
|-------|---------------|---------------|---------------|
| eager | 31.59s        | 37.55s        | 42.64s        |
| lazy  | 30.44s        | 30.86s        | 34.07s        |

3 years agoAuto merge of #84468 - iladin:iladin/fix-84467, r=petrochenkov
bors [Thu, 6 May 2021 07:02:06 +0000 (07:02 +0000)]
Auto merge of #84468 - iladin:iladin/fix-84467, r=petrochenkov

Fix#84467 linker_args with --target=sparcv9-sun-solaris

Trying to cross-compile for sparcv9-sun-solaris
getting a error message for -zignore

Introduced when -z -ignore was seperated here
22d0ab0

No formatting done

Reproduce

``` bash
rustup target add sparcv9-sun-solaris
cargo new --bin hello && cd hello && cargo run --target=sparcv9-sun-solaris
```

config.toml

[target.sparcv9-sun-solaris]
linker = "gcc"

3 years agoAuto merge of #84266 - QuiltOS:statically-disallow-global-oom-handling, r=Mark-Simulacrum
bors [Thu, 6 May 2021 04:41:20 +0000 (04:41 +0000)]
Auto merge of #84266 - QuiltOS:statically-disallow-global-oom-handling, r=Mark-Simulacrum

alloc: Add unstable Cfg feature `no-global_oom_handling

For certain sorts of systems, programming, it's deemed essential that
all allocation failures be explicitly handled where they occur. For
example, see Linus Torvald's opinion in [1]. Merely not calling global
panic handlers, or always `try_reserving` first (for vectors), is not
deemed good enough, because the mere presence of the global OOM handlers
is burdens static analysis.

One option for these projects to use rust would just be to skip `alloc`,
rolling their own allocation abstractions.  But this would, in my
opinion be a real shame. `alloc` has a few `try_*` methods already, and
we could easily have more. Features like custom allocator support also
demonstrate and existing to support diverse use-cases with the same
abstractions.

A natural way to add such a feature flag would a Cargo feature, but
there are currently uncertainties around how std library crate's Cargo
features may or not be stable, so to avoid any risk of stabilizing by
mistake we are going with a more low-level "raw cfg" token, which
cannot be interacted with via Cargo alone.

Note also that since there is no notion of "default cfg tokens" outside
of Cargo features, we have to invert the condition from
`global_oom_handling` to to `not(no_global_oom_handling)`. This breaks
the monotonicity that would be important for a Cargo feature (i.e.
turning on more features should never break compatibility), but it
doesn't matter for raw cfg tokens which are not intended to be
"constraint solved" by Cargo or anything else.

To support this use-case we create a new feature, "global-oom-handling",
on by default, and put the global OOM handler infra and everything else
it that depends on it behind it. By default, nothing is changed, but
users concerned about global handling can make sure it is disabled, and
be confident that all OOM handling is local and explicit.

For this first iteration, non-flat collections are outright disabled.
`Vec` and `String` don't yet have `try_*` allocation methods, but are
kept anyways since they can be oom-safely created "from parts", and we
hope to add those `try_` methods in the future.

[1]: https://lore.kernel.org/lkml/CAHk-=wh_sNLoz84AUUzuqXEsYH35u=8HV3vK-jbRbJ_B-JjGrg@mail.gmail.com/

3 years agoE0583: Include secondary path in error message
Deadbeef [Wed, 5 May 2021 08:00:18 +0000 (16:00 +0800)]
E0583: Include secondary path in error message

3 years agoImplement RFC 2951: Native link modifiers
Luqman Aden [Thu, 25 Mar 2021 04:45:09 +0000 (21:45 -0700)]
Implement RFC 2951: Native link modifiers

This commit implements both the native linking modifiers infrastructure
as well as an initial attempt at the individual modifiers from the RFC.
It also introduces a feature flag for the general syntax along with
individual feature flags for each modifier.

3 years agolazify backtrace formatting for delayed diagnostics
The8472 [Wed, 5 May 2021 20:52:58 +0000 (22:52 +0200)]
lazify backtrace formatting for delayed diagnostics

This defers backtrace formatting to the point where we
actually want to flush delayed diagnostics. If they are discarded
before that point then we can avoid invoking the backtrace formatting
machinery which will parse debug info and symbol tables.

for debuginfo=2 this leads to a 20% walltime reduction of the UI testsuite

3 years agoalloc: Add unstable Cfg feature `no-global_oom_handling`
John Ericson [Sat, 17 Apr 2021 00:18:04 +0000 (20:18 -0400)]
alloc: Add unstable Cfg feature `no-global_oom_handling`

For certain sorts of systems, programming, it's deemed essential that
all allocation failures be explicitly handled where they occur. For
example, see Linus Torvald's opinion in [1]. Merely not calling global
panic handlers, or always `try_reserving` first (for vectors), is not
deemed good enough, because the mere presence of the global OOM handlers
is burdens static analysis.

One option for these projects to use rust would just be to skip `alloc`,
rolling their own allocation abstractions.  But this would, in my
opinion be a real shame. `alloc` has a few `try_*` methods already, and
we could easily have more. Features like custom allocator support also
demonstrate and existing to support diverse use-cases with the same
abstractions.

A natural way to add such a feature flag would a Cargo feature, but
there are currently uncertainties around how std library crate's Cargo
features may or not be stable, so to avoid any risk of stabilizing by
mistake we are going with a more low-level "raw cfg" token, which
cannot be interacted with via Cargo alone.

Note also that since there is no notion of "default cfg tokens" outside
of Cargo features, we have to invert the condition from
`global_oom_handling` to to `not(no_global_oom_handling)`. This breaks
the monotonicity that would be important for a Cargo feature (i.e.
turning on more features should never break compatibility), but it
doesn't matter for raw cfg tokens which are not intended to be
"constraint solved" by Cargo or anything else.

To support this use-case we create a new feature, "global-oom-handling",
on by default, and put the global OOM handler infra and everything else
it that depends on it behind it. By default, nothing is changed, but
users concerned about global handling can make sure it is disabled, and
be confident that all OOM handling is local and explicit.

For this first iteration, non-flat collections are outright disabled.
`Vec` and `String` don't yet have `try_*` allocation methods, but are
kept anyways since they can be oom-safely created "from parts", and we
hope to add those `try_` methods in the future.

[1]: https://lore.kernel.org/lkml/CAHk-=wh_sNLoz84AUUzuqXEsYH35u=8HV3vK-jbRbJ_B-JjGrg@mail.gmail.com/

3 years agoRemote test for alloc `extern_crate` feature.
John Ericson [Wed, 5 May 2021 20:20:39 +0000 (16:20 -0400)]
Remote test for alloc `extern_crate` feature.

This functionality was removed in
45bf1ed1a1123122ded05ae2eedaf0f190e52726, but the test was left by
mistake.

3 years agoAuto merge of #84956 - RalfJung:rollup-m70mx2n, r=RalfJung
bors [Wed, 5 May 2021 17:45:41 +0000 (17:45 +0000)]
Auto merge of #84956 - RalfJung:rollup-m70mx2n, r=RalfJung

Rollup of 11 pull requests

Successful merges:

 - #83553 (Update `ptr` docs with regards to `ptr::addr_of!`)
 - #84183 (Update RELEASES.md for 1.52.0)
 - #84709 (Add doc alias for `chdir` to `std::env::set_current_dir`)
 - #84803 (Reduce duplication in `impl_dep_tracking_hash` macros)
 - #84808 (Account for unsatisfied bounds in E0599)
 - #84843 (use else if in std library )
 - #84865 (rustbuild: Pass a `threads` flag that works to windows-gnu lld)
 - #84878 (Clarify documentation for `[T]::contains`)
 - #84882 (platform-support: Center the contents of the `std` and `host` columns)
 - #84903 (Remove `rustc_middle::mir::interpret::CheckInAllocMsg::NullPointerTest`)
 - #84913 (Do not ICE on invalid const param)

Failed merges:

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

3 years agoRollup merge of #84913 - estebank:issue-84831, r=varkor
Ralf Jung [Wed, 5 May 2021 15:52:29 +0000 (17:52 +0200)]
Rollup merge of #84913 - estebank:issue-84831, r=varkor

Do not ICE on invalid const param

When encountering a path that can't have generics, do not call
`generics_of`. This would happen when writing something like
`path::this_is_a_mod<const_val>`.

Fix #84831.

3 years agoRollup merge of #84903 - hyd-dev:dead-check-in-alloc-msg, r=RalfJung
Ralf Jung [Wed, 5 May 2021 15:52:28 +0000 (17:52 +0200)]
Rollup merge of #84903 - hyd-dev:dead-check-in-alloc-msg, r=RalfJung

Remove `rustc_middle::mir::interpret::CheckInAllocMsg::NullPointerTest`

Removing it per https://github.com/rust-lang/rust/pull/84842#discussion_r625589674: it's a dead enum variant.

Note that `PointerArithmeticTest` also seems dead:
```
$ rg -F PointerArithmeticTest -C5
compiler/rustc_middle/src/mir/interpret/error.rs
169-
170-/// Details of why a pointer had to be in-bounds.
171-#[derive(Debug, Copy, Clone, TyEncodable, TyDecodable, HashStable)]
172-pub enum CheckInAllocMsg {
173-    MemoryAccessTest,
174:    PointerArithmeticTest,
175-    InboundsTest,
176-}
177-
178-impl fmt::Display for CheckInAllocMsg {
179-    /// When this is printed as an error the context looks like this
--
182-        write!(
183-            f,
184-            "{}",
185-            match *self {
186-                CheckInAllocMsg::MemoryAccessTest => "memory access",
187:                CheckInAllocMsg::PointerArithmeticTest => "pointer arithmetic",
188-                CheckInAllocMsg::InboundsTest => "inbounds test",
189-            }
190-        )
191-    }
192-}
```
Not sure if that is also desirable to be removed, however.

3 years agoRollup merge of #84882 - joshtriplett:platform-support-formatting, r=Dylan-DPC
Ralf Jung [Wed, 5 May 2021 15:52:27 +0000 (17:52 +0200)]
Rollup merge of #84882 - joshtriplett:platform-support-formatting, r=Dylan-DPC

platform-support: Center the contents of the `std` and `host` columns

Minor formatting improvement.

3 years agoRollup merge of #84878 - jimblandy:contains-doc-fix, r=joshtriplett
Ralf Jung [Wed, 5 May 2021 15:52:26 +0000 (17:52 +0200)]
Rollup merge of #84878 - jimblandy:contains-doc-fix, r=joshtriplett

Clarify documentation for `[T]::contains`

Change the documentation to correctly characterize when the suggested alternative to `contains` applies, and correctly explain why it works.

Fixes #84877

3 years agoRollup merge of #84865 - petrochenkov:llthread, r=Mark-Simulacrum
Ralf Jung [Wed, 5 May 2021 15:52:25 +0000 (17:52 +0200)]
Rollup merge of #84865 - petrochenkov:llthread, r=Mark-Simulacrum

rustbuild: Pass a `threads` flag that works to windows-gnu lld

MinGW driver for COFF LLD doesn't currently translate GNU-style `--threads=N` to native `/threads:N`, so we have to pass the option in its native form to avoid an error.

Also pass the `threads` flag to lld-link (windows-msvc lld) as well.

3 years agoRollup merge of #84843 - wcampbell0x2a:use-else-if-let, r=dtolnay
Ralf Jung [Wed, 5 May 2021 15:52:24 +0000 (17:52 +0200)]
Rollup merge of #84843 - wcampbell0x2a:use-else-if-let, r=dtolnay

use else if in std library

Decreases indentation and improves readability

3 years agoRollup merge of #84808 - estebank:issue-84769, r=petrochenkov
Ralf Jung [Wed, 5 May 2021 15:52:23 +0000 (17:52 +0200)]
Rollup merge of #84808 - estebank:issue-84769, r=petrochenkov

Account for unsatisfied bounds in E0599

Fix #84769, follow up to #84499, #83667.

3 years agoRollup merge of #84803 - jyn514:duplicate-macros, r=petrochenkov
Ralf Jung [Wed, 5 May 2021 15:52:22 +0000 (17:52 +0200)]
Rollup merge of #84803 - jyn514:duplicate-macros, r=petrochenkov

Reduce duplication in `impl_dep_tracking_hash` macros

Cherry-picked from https://github.com/rust-lang/rust/pull/84234 since it will be a while until it lands.

3 years agoRollup merge of #84709 - joshtriplett:doc-alias-chdir, r=dtolnay
Ralf Jung [Wed, 5 May 2021 15:52:20 +0000 (17:52 +0200)]
Rollup merge of #84709 - joshtriplett:doc-alias-chdir, r=dtolnay

Add doc alias for `chdir` to `std::env::set_current_dir`

Searching for `chdir` in the Rust documentation produces no useful
results.

I wrote some code recently that called `libc::chdir` and manually
handled errors, because I didn't realize that the safe
`std::env::set_current_dir` existed. I searched for `chdir` and
`change_dir` and `change_directory` (the latter two based on the
precedent of unabbreviating set by `create_dir`), and I also read
through `std::fs` expecting to potentially find it there. Given that
none of those led to `std::env::set_current_dir`, I think that provides
sufficient justification to add this specific alias.

3 years agoRollup merge of #84183 - rust-lang:relnotes-1.52.0, r=pietroalbini
Ralf Jung [Wed, 5 May 2021 15:52:19 +0000 (17:52 +0200)]
Rollup merge of #84183 - rust-lang:relnotes-1.52.0, r=pietroalbini

Update RELEASES.md for 1.52.0

### [Rendered](https://github.com/rust-lang/rust/blob/relnotes-1.52.0/RELEASES.md)

r? ````````@Mark-Simulacrum````````
cc ````````@rust-lang/release````````

3 years agoRollup merge of #83553 - jfrimmel:addr-of, r=m-ou-se
Ralf Jung [Wed, 5 May 2021 15:52:18 +0000 (17:52 +0200)]
Rollup merge of #83553 - jfrimmel:addr-of, r=m-ou-se

Update `ptr` docs with regards to `ptr::addr_of!`

This updates the documentation since `ptr::addr_of!` and `ptr::addr_of_mut!` are now stable. One might remove the distinction between the sections `# On packed structs` and `# Examples`, as the old section on packed structs was primarily to prevent users of doing undefined behavior, which is not necessary anymore.

Technically there is now wrong/outdated documentation on stable, but I don't think this is worth a point release 😉

Fixes #83509.

``````````@rustbot`````````` modify labels: T-doc

3 years agoBump map_into_keys_values stable version to 1.54.0.
Mara Bos [Wed, 5 May 2021 14:40:06 +0000 (16:40 +0200)]
Bump map_into_keys_values stable version to 1.54.0.

3 years agoAuto merge of #84200 - CDirkx:os, r=m-ou-se
bors [Wed, 5 May 2021 14:15:19 +0000 (14:15 +0000)]
Auto merge of #84200 - CDirkx:os, r=m-ou-se

Move all `sys::ext` modules to `os`

This PR moves all `sys::ext` modules to `os`, centralizing the location of all `os` code and simplifying the dependencies between `os` and `sys`.

Because this also removes all uses `cfg_if!` on publicly exported items, where after #81969 there were still a few left, this should properly work around https://github.com/rust-analyzer/rust-analyzer/issues/6038.

`@rustbot` label: +T-libs-impl

3 years agoRevert PR 83866
Pietro Albini [Wed, 5 May 2021 09:57:10 +0000 (11:57 +0200)]
Revert PR 83866

That PR caused multiple test failures when Rust's channel is changed
from nightly to anything else. The commit will have to be landed again
after the test suite is fixed.

3 years agoAuto merge of #84886 - Xanewok:update-rls-and-rustfmt, r=Xanewok
bors [Wed, 5 May 2021 11:05:27 +0000 (11:05 +0000)]
Auto merge of #84886 - Xanewok:update-rls-and-rustfmt, r=Xanewok

Update RLS and Rustfmt

Closes #84537. Closes #84538.

I know there's https://github.com/rust-lang/rust/pull/82208 in progress but I'm not sure which we want to land first.

Also, I'm getting Rustfmt test failures due to inner attributes not permitted:
<details>

```
error: an inner attribute is not permitted in this context
 --> tests/target/issue-3592.rs:4:13
  |
4 |             #![cfg(unix)]
  |             ^^^^^^^^^^^^^
  |
  = note: inner attributes, like `#![no_std]`, annotate the item enclosing them, and are usually found at the beginning of source files. Outer attributes, like `#[test]`, annotate the item following them.

error: an inner attribute is not permitted in this context
 --> tests/target/issue-3592.rs:8:13
  |
8 |             #![cfg(not(unix))]
  |             ^^^^^^^^^^^^^^^^^^
  |
  = note: inner attributes, like `#![no_std]`, annotate the item enclosing them, and are usually found at the beginning of source files. Outer attributes, like `#[test]`, annotate the item following them.

error: an inner attribute is not permitted in this context
   --> tests/source/match.rs:413:9
    |
413 |         #![allow(simple_match)]
    |         ^^^^^^^^^^^^^^^^^^^^^^^
    |
    = note: inner attributes, like `#![no_std]`, annotate the item enclosing them, and are usually found at the beginning of source files. Outer attributes, like `#[test]`, annotate the item following them.

error: an inner attribute is not permitted in this context
   --> tests/target/match.rs:444:9
    |
444 |         #![allow(simple_match)]
    |         ^^^^^^^^^^^^^^^^^^^^^^^
    |
    = note: inner attributes, like `#![no_std]`, annotate the item enclosing them, and are usually found at the beginning of source files. Outer attributes, like `#[test]`, annotate the item following them.

test test::system_tests ... FAILED
test test::idempotence_tests ... FAILED
```

</details>

but let's see what CI says, first.

cc `@calebcartwright`

3 years agoAdd `yansi-term` as a permitted dependency
Joshua Nelson [Sun, 2 May 2021 19:06:24 +0000 (15:06 -0400)]
Add `yansi-term` as a permitted dependency

3 years agoUpdate RLS and Rustfmt
Igor Matuszewski [Mon, 3 May 2021 20:59:35 +0000 (22:59 +0200)]
Update RLS and Rustfmt

3 years agoFix typo in `MaybeUninit::array_assume_init` safety comment
Sebastian Dröge [Wed, 5 May 2021 09:31:38 +0000 (12:31 +0300)]
Fix typo in `MaybeUninit::array_assume_init` safety comment

And also add backticks around `MaybeUninit`.

3 years agoAuto merge of #84794 - ChrisDenton:dedup-native-libs, r=petrochenkov
bors [Wed, 5 May 2021 03:56:26 +0000 (03:56 +0000)]
Auto merge of #84794 - ChrisDenton:dedup-native-libs, r=petrochenkov

Deduplicate native libs before they are passed to the linker

Stop spamming the linker with the same native library over and over again, if they directly follow from each other. This would help prevent [this situation](https://github.com/MSxDOS/ntapi/issues/2).

Issue #38460 has been open since 2016 so I think it's worth making an incomplete fix that at least addresses the most common symptom and without otherwise changing how Rust handles native libs. This PR is intended to be easy to revert (if necessary) when a more permanent fix is implemented.

3 years agoAuto merge of #84915 - Mark-Simulacrum:bitset-xor-eq, r=jackh726
bors [Wed, 5 May 2021 01:23:01 +0000 (01:23 +0000)]
Auto merge of #84915 - Mark-Simulacrum:bitset-xor-eq, r=jackh726

Retain data in vectorized registers for longer

This seems to be a mild performance improvement on the keccak crate at least, though not sure it'll show up more broadly.

3 years agoAuto merge of #84707 - Stupremee:remove-fake-defids-in-rustdoc, r=jyn514,GuillaumeGomez
bors [Tue, 4 May 2021 20:56:49 +0000 (20:56 +0000)]
Auto merge of #84707 - Stupremee:remove-fake-defids-in-rustdoc, r=jyn514,GuillaumeGomez

Get rid of fake `DefId`s in rustdoc

Right now there are *many* errors left, but I wanted to show the current state since all that is left to do is fixing the errors.

Resolves #83183

r? `@jyn514`

3 years agoOnly compute Obligation `cache_key` once in `register_obligation_at`
Esteban Küber [Tue, 4 May 2021 18:57:53 +0000 (11:57 -0700)]
Only compute Obligation `cache_key` once  in `register_obligation_at`

3 years agoAuto merge of #84900 - hyd-dev:miri, r=RalfJung
bors [Tue, 4 May 2021 18:35:08 +0000 (18:35 +0000)]
Auto merge of #84900 - hyd-dev:miri, r=RalfJung

Update Miri

This should fix #84848.

r? `@RalfJung`

3 years agoAdd type to differentiate between fake and real DefId's
Justus K [Thu, 29 Apr 2021 19:36:54 +0000 (21:36 +0200)]
Add type to differentiate between fake and real DefId's

3 years agoChange bitwise operator to more easily keep data in vector registers
Mark Rousskov [Tue, 4 May 2021 15:53:57 +0000 (11:53 -0400)]
Change bitwise operator to more easily keep data in vector registers

3 years agoDo not ICE on invalid const param
Esteban Küber [Tue, 4 May 2021 15:41:40 +0000 (08:41 -0700)]
Do not ICE on invalid const param

When encountering a path that can't have generics, do not call
`generics_of`. This would happen when writing something like
`path::this_is_a_mod<const_val>`.

Fix #84831.

3 years agoAuto merge of #84894 - joshtriplett:clang-12, r=Mark-Simulacrum
bors [Tue, 4 May 2021 15:03:50 +0000 (15:03 +0000)]
Auto merge of #84894 - joshtriplett:clang-12, r=Mark-Simulacrum

Update clang to 12.0.0 on Windows and macOS

Needed for https://github.com/rust-lang/rust/pull/84764 . Tarballs
already uploaded to the CI mirror bucket.

3 years agoAuto merge of #84017 - Smittyvb:int-literal-underscores, r=jyn514
bors [Tue, 4 May 2021 10:42:13 +0000 (10:42 +0000)]
Auto merge of #84017 - Smittyvb:int-literal-underscores, r=jyn514

Valid underscores in hex/octal/binary literal docs

Currently hex/octal/binary literals with computed values are displayed like `0_xff_fff_fffu32`, which is invalid since underscores can't be in the middle of integer prefixes. This properly formats prefixed integers.

This causes  [`std::u32::MAX`](https://doc.rust-lang.org/std/u32/constant.MAX.html) to be displayed as
```rust
pub const MAX: u32 = u32::MAX; // 0_xff_fff_fffu32
```

This PR changes it to be displayed as:
```rust
pub const MAX: u32 = u32::MAX; // 0xffff_ffffu32
```

3 years agoRemove `rustc_middle::mir::interpret::CheckInAllocMsg::NullPointerTest`
hyd-dev [Tue, 4 May 2021 10:27:02 +0000 (18:27 +0800)]
Remove `rustc_middle::mir::interpret::CheckInAllocMsg::NullPointerTest`

3 years agoUpdate Miri
hyd-dev [Tue, 4 May 2021 09:07:39 +0000 (17:07 +0800)]
Update Miri

3 years agoAuto merge of #83213 - rylev:update-lints-to-errors, r=nikomatsakis
bors [Tue, 4 May 2021 08:09:23 +0000 (08:09 +0000)]
Auto merge of #83213 - rylev:update-lints-to-errors, r=nikomatsakis

Update BARE_TRAIT_OBJECT and ELLIPSIS_INCLUSIVE_RANGE_PATTERNS to errors in Rust 2021

This addresses https://github.com/rust-lang/rust/pull/81244 by updating two lints to errors in the Rust 2021 edition.

r? `@estebank`

3 years agoUpdate clang to 12.0.0 on Windows and macOS
Josh Triplett [Tue, 4 May 2021 05:54:50 +0000 (22:54 -0700)]
Update clang to 12.0.0 on Windows and macOS

Needed for https://github.com/rust-lang/rust/pull/84764 . Tarballs
already uploaded to the CI mirror bucket.

3 years agoAuto merge of #84874 - joshtriplett:ci-extract-llvm-win64-installer, r=Mark-Simulacrum
bors [Tue, 4 May 2021 05:40:24 +0000 (05:40 +0000)]
Auto merge of #84874 - joshtriplett:ci-extract-llvm-win64-installer, r=Mark-Simulacrum

CI: Extract LLVM win64 installer directly, using 7z

Currently, we have LLVM tarballs for win64, generated by someone running
the installer via wine and tarring up the result.

7z knows how to extract NSIS installers directly, and the result is
identical to our tarball, except that it doesn't include `Uninstall.exe`
(which we don't care about) and it includes the NSIS plugin directory
(which we also don't care about).

This simplifies the process of upgrading CI, and allows us to just
mirror the upstream release .exe directly. This also improves our
supply chain.

3 years agoAuto merge of #84833 - Mark-Simulacrum:thread-local-consts, r=varkor
bors [Tue, 4 May 2021 03:14:32 +0000 (03:14 +0000)]
Auto merge of #84833 - Mark-Simulacrum:thread-local-consts, r=varkor

"const" initialized thread locals in rustc

This appears to give a slight speedup on many of our benchmarks.

3 years agoAuto merge of #84472 - Aaron1011:conservative-paramenv-and, r=lcnr
bors [Tue, 4 May 2021 00:48:42 +0000 (00:48 +0000)]
Auto merge of #84472 - Aaron1011:conservative-paramenv-and, r=lcnr

Be more conservative about discarding caller_bound in `ParamEnv::and`

3 years agoValid underscores in hex/octal/binary literal docs
Smitty [Thu, 8 Apr 2021 21:18:25 +0000 (17:18 -0400)]
Valid underscores in hex/octal/binary literal docs

Currently hex/octal/binary literals with computed values are displayed
like `0_xff_fff_fffu32`, which is invalid since underscores can't be in
the middle of integer prefixes. This properly formats prefixed integers.

3 years agoUpdate `ptr` docs with regards to `ptr::addr_of!`
Julian Frimmel [Sat, 27 Mar 2021 10:44:39 +0000 (11:44 +0100)]
Update `ptr` docs with regards to `ptr::addr_of!`

This updates the documentation since `ptr::addr_of!` and
`ptr::addr_of_mut!` are now stable. One might remove the distinction
between the sections `# On packed structs` and `# Examples`, as the old
section on packed structs was primarily to prevent users of doing unde-
fined behavior, which is not necessary anymore.
There is also a new section in "how to obtain a pointer", which referen-
ces the `ptr::addr_of!` macros.

This commit contains squashed commits from code review.

Co-authored-by: Joshua Nelson <joshua@yottadb.com>
Co-authored-by: Mara Bos <m-ou.se@m-ou.se>
Co-authored-by: Soveu <marx.tomasz@gmail.com>
Co-authored-by: Ralf Jung <post@ralfj.de>
3 years agoplatform-support: Center the contents of the `std` and `host` columns
Josh Triplett [Mon, 3 May 2021 20:01:40 +0000 (13:01 -0700)]
platform-support: Center the contents of the `std` and `host` columns

3 years agoClarify documentation for `[T]::contains`. Fixes #84877.
Jim Blandy [Mon, 3 May 2021 19:01:16 +0000 (12:01 -0700)]
Clarify documentation for `[T]::contains`. Fixes #84877.

3 years agoCI: Extract LLVM win64 installer directly, using 7z
Josh Triplett [Mon, 3 May 2021 18:23:00 +0000 (11:23 -0700)]
CI: Extract LLVM win64 installer directly, using 7z

Currently, we have LLVM tarballs for win64, generated by someone running
the installer via wine and tarring up the result.

7z knows how to extract NSIS installers directly, and the result is
identical to our tarball, except that it doesn't include `Uninstall.exe`
(which we don't care about) and it includes the NSIS plugin directory
(which we also don't care about).

This simplifies the process of upgrading CI, and allows us to just
mirror the upstream release .exe directly. This also improves our
supply chain.

3 years agoChange `std::sys::unix::ext::fs::PermissionsExt::from_mode` to `std::os::imp::unix...
Christiaan Dirkx [Sun, 25 Apr 2021 11:10:19 +0000 (13:10 +0200)]
Change `std::sys::unix::ext::fs::PermissionsExt::from_mode` to `std::os::imp::unix::fs::PermissionsExt::from_mode` in Clippy

3 years agoAllow documenting on `hermit`
Christiaan Dirkx [Sun, 18 Apr 2021 02:16:02 +0000 (04:16 +0200)]
Allow documenting on `hermit`

3 years agoRework `os` to avoid using `cfg_if!` with public items
Christiaan Dirkx [Wed, 14 Apr 2021 19:36:13 +0000 (21:36 +0200)]
Rework `os` to avoid using `cfg_if!` with public items

3 years agoMove `std::sys::sgx::ext` to `std::os::fortanix_sgx`
Christiaan Dirkx [Thu, 4 Mar 2021 14:45:27 +0000 (15:45 +0100)]
Move `std::sys::sgx::ext` to `std::os::fortanix_sgx`

3 years agoMove `std::sys::wasi::ext` to `std::os::wasi`
Christiaan Dirkx [Thu, 4 Mar 2021 14:39:31 +0000 (15:39 +0100)]
Move `std::sys::wasi::ext` to `std::os::wasi`

3 years agoMove `std::sys::unix::ext` to `std::os::unix`
Christiaan Dirkx [Thu, 4 Mar 2021 14:26:41 +0000 (15:26 +0100)]
Move `std::sys::unix::ext` to `std::os::unix`

3 years agoMove `std::sys::windows::ext` to `std::os::windows`
Christiaan Dirkx [Thu, 4 Mar 2021 14:15:26 +0000 (15:15 +0100)]
Move `std::sys::windows::ext` to `std::os::windows`

3 years agoMove `std::sys::hermit::ext` to `std::os::hermit`
Christiaan Dirkx [Thu, 4 Mar 2021 13:14:44 +0000 (14:14 +0100)]
Move `std::sys::hermit::ext` to `std::os::hermit`

3 years agoCleanup `std::os`
Christiaan Dirkx [Thu, 4 Mar 2021 13:03:26 +0000 (14:03 +0100)]
Cleanup `std::os`

3 years agoAuto merge of #84862 - GuillaumeGomez:rollup-cbc93h4, r=GuillaumeGomez
bors [Mon, 3 May 2021 14:35:12 +0000 (14:35 +0000)]
Auto merge of #84862 - GuillaumeGomez:rollup-cbc93h4, r=GuillaumeGomez

Rollup of 6 pull requests

Successful merges:

 - #84835 (Add link to Issue #34202 in udp docs)
 - #84852 (Change librustdoc write!(.. \n) to writeln!(..); fix comment grammar)
 - #84854 (use double quotes and full path for E0761)
 - #84856 (Correct stability of ErrorKind::OutOfMemory)
 - #84858 (Fix stability attributes of byte-to-string specialization)
 - #84860 (Link to MCP from target tier policy)

Failed merges:

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

3 years agorustbuild: Pass a `threads` flag that works to windows-gnu lld
Vadim Petrochenkov [Mon, 3 May 2021 13:38:11 +0000 (16:38 +0300)]
rustbuild: Pass a `threads` flag that works to windows-gnu lld

MinGW driver for COFF LLD doesn't currently translate GNU-style `--threads=N` to native `/threads:N`, so we have to pass the option in its native form to avoid an error.

Also pass the `threads` flag to lld-link as well

3 years agoUpdate RELEASES.md for 1.52.0
Erin Power [Wed, 14 Apr 2021 09:34:20 +0000 (11:34 +0200)]
Update RELEASES.md for 1.52.0

3 years agoRollup merge of #84860 - badboy:link-to-mcp, r=GuillaumeGomez
Guillaume Gomez [Mon, 3 May 2021 13:08:12 +0000 (15:08 +0200)]
Rollup merge of #84860 - badboy:link-to-mcp, r=GuillaumeGomez

Link to MCP from target tier policy

Promoting new targets requires filing a MCP. Probably good to link to the documentation what that even is.

3 years agoRollup merge of #84858 - LingMan:patch-1, r=JohnTitor
Guillaume Gomez [Mon, 3 May 2021 13:08:11 +0000 (15:08 +0200)]
Rollup merge of #84858 - LingMan:patch-1, r=JohnTitor

Fix stability attributes of byte-to-string specialization

3 years agoRollup merge of #84856 - kornelski:enomem, r=JohnTitor
Guillaume Gomez [Mon, 3 May 2021 13:08:10 +0000 (15:08 +0200)]
Rollup merge of #84856 - kornelski:enomem, r=JohnTitor

Correct stability of ErrorKind::OutOfMemory

Fix for #84744

3 years agoRollup merge of #84854 - hi-rustin:rustin-patch-E0761, r=varkor
Guillaume Gomez [Mon, 3 May 2021 13:08:09 +0000 (15:08 +0200)]
Rollup merge of #84854 - hi-rustin:rustin-patch-E0761, r=varkor

use double quotes and full path for E0761

close https://github.com/rust-lang/rust/issues/84828

3 years agoRollup merge of #84852 - mautamu:master, r=GuillaumeGomez
Guillaume Gomez [Mon, 3 May 2021 13:08:07 +0000 (15:08 +0200)]
Rollup merge of #84852 - mautamu:master, r=GuillaumeGomez

Change librustdoc write!(.. \n) to writeln!(..); fix comment grammar

Howdy,

This PR does the following:
1. Updates the grammar of a comment in librustdoc.
2. Replaces a few write!(..\n) macros with writeln!(..\n) for clarity. (Please let me know if there is a reason why this might be wrong!)

Best,
Mautamu

3 years agoRollup merge of #84835 - wcampbell0x2a:add-issue-34202-link, r=m-ou-se
Guillaume Gomez [Mon, 3 May 2021 13:08:02 +0000 (15:08 +0200)]
Rollup merge of #84835 - wcampbell0x2a:add-issue-34202-link, r=m-ou-se

Add link to Issue #34202 in udp docs

3 years agoLink to MCP from target tier policy
Jan-Erik Rediger [Mon, 3 May 2021 11:48:56 +0000 (13:48 +0200)]
Link to MCP from target tier policy

3 years agouse `else if` in std library
wcampbell [Mon, 3 May 2021 00:06:17 +0000 (20:06 -0400)]
use `else if` in std library

Clippy: Decreases indentation and improves readability

Signed-off-by: wcampbell <wcampbell1995@gmail.com>
3 years agoFix stability attributes of byte-to-string specialization
LingMan [Mon, 3 May 2021 11:00:34 +0000 (13:00 +0200)]
Fix stability attributes of byte-to-string specialization

3 years agouse full path for E0761
hi-rustin [Mon, 3 May 2021 10:57:48 +0000 (18:57 +0800)]
use full path for E0761

3 years agoAuto merge of #83312 - petrochenkov:noinner, r=Aaron1011
bors [Mon, 3 May 2021 10:56:15 +0000 (10:56 +0000)]
Auto merge of #83312 - petrochenkov:noinner, r=Aaron1011

parser: Remove support for inner attributes on non-block expressions

Remove support for attributes like
```rust
fn attrs() {
    (#![print_target_and_args(fifth)] 1, 2);

    [#![print_target_and_args(sixth)] 1 , 2];
    [#![print_target_and_args(seventh)] true ; 5];

    match 0 {
        #![print_target_and_args(eighth)]
        _ => {}
    }

    MyStruct { #![print_target_and_args(ninth)] field: true };
}
```
They are
- useless
- unstable (modulo holes like https://github.com/rust-lang/rust/issues/65860)
- pessimize compiler performance, namely token collection for macros (cc https://github.com/rust-lang/rust/pull/82608)

I still want to run crater on this to check whether the stability holes are exploited in practice, and whether such attributes are used at all.

3 years agoparser: Remove support for inner attributes on non-block expressions
Vadim Petrochenkov [Fri, 19 Mar 2021 23:52:07 +0000 (02:52 +0300)]
parser: Remove support for inner attributes on non-block expressions

3 years agoCorrect stability of ErrorKind::OutOfMemory
Kornel [Mon, 3 May 2021 09:28:19 +0000 (10:28 +0100)]
Correct stability of ErrorKind::OutOfMemory

3 years agoAuto merge of #84845 - wcampbell0x2a:clippy-redundant-field-names, r=joshtriplett
bors [Mon, 3 May 2021 08:05:12 +0000 (08:05 +0000)]
Auto merge of #84845 - wcampbell0x2a:clippy-redundant-field-names, r=joshtriplett

[clippy] remove redundant field names

3 years agouse double quotes for E0761
hi-rustin [Mon, 3 May 2021 08:02:54 +0000 (16:02 +0800)]
use double quotes for E0761

3 years agoChange librustdoc write(.. \n) to writeln(..); fix comment in grammar
mautamu [Mon, 3 May 2021 07:14:56 +0000 (02:14 -0500)]
Change librustdoc write(.. \n) to writeln(..); fix comment in grammar

More grammar

3 years ago:arrow_up: rust-analyzer
Laurențiu Nicola [Mon, 3 May 2021 07:16:06 +0000 (10:16 +0300)]
:arrow_up: rust-analyzer

3 years agoAuto merge of #84842 - blkerby:null_lowercase, r=joshtriplett
bors [Mon, 3 May 2021 05:41:23 +0000 (05:41 +0000)]
Auto merge of #84842 - blkerby:null_lowercase, r=joshtriplett

Replace 'NULL' with 'null'

This replaces occurrences of "NULL" with "null" in docs, comments, and compiler error/lint messages. This is for the sake of consistency, as the lowercase "null" is already the dominant form in Rust. The all-caps NULL looks like the C macro (or SQL keyword), which seems out of place in a Rust context, given that NULL does not exist in the Rust language or standard library (instead having [`ptr::null()`](https://doc.rust-lang.org/stable/std/ptr/fn.null.html)).

3 years ago[clippy] remove redundant field names
wcampbell [Mon, 3 May 2021 00:24:17 +0000 (20:24 -0400)]
[clippy] remove redundant field names

Signed-off-by: wcampbell <wcampbell1995@gmail.com>
3 years agoAuto merge of #84840 - Dylan-DPC:rollup-uzk7w0h, r=Dylan-DPC
bors [Mon, 3 May 2021 00:17:16 +0000 (00:17 +0000)]
Auto merge of #84840 - Dylan-DPC:rollup-uzk7w0h, r=Dylan-DPC

Rollup of 6 pull requests

Successful merges:

 - #84072 (Allow setting `target_family` to multiple values, and implement `target_family="wasm"`)
 - #84744 (Add ErrorKind::OutOfMemory)
 - #84784 (Add help message to suggest const for unused type param)
 - #84811 (RustDoc: Fix bounds linking trait.Foo instead of traitalias.Foo)
 - #84818 (suggestion for unit enum variant when matched with a patern)
 - #84832 (Do not print visibility in external traits)

Failed merges:

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

3 years agoChange 'NULL' to 'null'
Brent Kerby [Sun, 2 May 2021 21:55:22 +0000 (15:55 -0600)]
Change 'NULL' to 'null'

3 years agoAdd link to Issue #34202 in udp docs
wcampbell [Sun, 2 May 2021 20:15:27 +0000 (16:15 -0400)]
Add link to Issue #34202 in udp docs

Signed-off-by: wcampbell <wcampbell1995@gmail.com>