]> git.lizzy.rs Git - rust.git/log
rust.git
2 years agoClean up `&args[..]`, use more readable `args.iter()` instead
Michael Howell [Sun, 22 May 2022 22:03:51 +0000 (15:03 -0700)]
Clean up `&args[..]`, use more readable `args.iter()` instead

2 years agoExtend `substs_to_args` into a perfectly-sized Vec almost every time
Michael Howell [Fri, 20 May 2022 15:48:17 +0000 (08:48 -0700)]
Extend `substs_to_args` into a perfectly-sized Vec almost every time

2 years agoShrink GenericArgs/PathSegment with boxed slices
Michael Howell [Thu, 19 May 2022 23:26:28 +0000 (16:26 -0700)]
Shrink GenericArgs/PathSegment with boxed slices

2 years agoRemove unused Hash impl from DocFragmentKind
Michael Howell [Thu, 19 May 2022 23:28:10 +0000 (16:28 -0700)]
Remove unused Hash impl from DocFragmentKind

2 years agoFix broken intra-doc link
Michael Howell [Thu, 19 May 2022 16:09:08 +0000 (09:09 -0700)]
Fix broken intra-doc link

2 years agoAuto merge of #97246 - GuillaumeGomez:rollup-btcok8x, r=GuillaumeGomez
bors [Sat, 21 May 2022 11:28:48 +0000 (11:28 +0000)]
Auto merge of #97246 - GuillaumeGomez:rollup-btcok8x, r=GuillaumeGomez

Rollup of 7 pull requests

Successful merges:

 - #97190 (Add implicit call to from_str via parse in documentation)
 - #97218 (Add eslint checks)
 - #97219 (make ptr::invalid not the same as a regular int2ptr cast)
 - #97223 (Remove quadratic behaviour from -Zunpretty=hir-tree.)
 - #97232 (typo)
 - #97237 (Add some more weird-exprs)
 - #97238 (Bump LLVM fetched from CI to fix run-make)

Failed merges:

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

2 years agoRollup merge of #97238 - Mark-Simulacrum:bump-ci-llvm, r=jyn514
Guillaume Gomez [Sat, 21 May 2022 09:39:54 +0000 (11:39 +0200)]
Rollup merge of #97238 - Mark-Simulacrum:bump-ci-llvm, r=jyn514

Bump LLVM fetched from CI to fix run-make

cc `@yaahc,` who found this while testing locally

Ideally we'd detect this in CI and catch it, but at least we have a comment now which should hopefully prevent this from happening in the future.

r? `@pietroalbini` or `@jyn514`

2 years agoRollup merge of #97237 - oberien:patch-1, r=Dylan-DPC
Guillaume Gomez [Sat, 21 May 2022 09:39:53 +0000 (11:39 +0200)]
Rollup merge of #97237 - oberien:patch-1, r=Dylan-DPC

Add some more weird-exprs

Continuing from https://github.com/rust-lang/rust/pull/86713 (which stalled due to a thinking emoji), I'd like to "improve" the `weird-exprs.rs`-file (as I can't reopen that PR).

2 years agoRollup merge of #97232 - tshepang:typo, r=Dylan-DPC
Guillaume Gomez [Sat, 21 May 2022 09:39:52 +0000 (11:39 +0200)]
Rollup merge of #97232 - tshepang:typo, r=Dylan-DPC

typo

2 years agoRollup merge of #97223 - cjgillot:linear-hir-tree, r=jackh726
Guillaume Gomez [Sat, 21 May 2022 09:39:51 +0000 (11:39 +0200)]
Rollup merge of #97223 - cjgillot:linear-hir-tree, r=jackh726

Remove quadratic behaviour from -Zunpretty=hir-tree.

Closes https://github.com/rust-lang/rust/issues/97115

2 years agoRollup merge of #97219 - RalfJung:ptr-invalid, r=thomcc
Guillaume Gomez [Sat, 21 May 2022 09:39:50 +0000 (11:39 +0200)]
Rollup merge of #97219 - RalfJung:ptr-invalid, r=thomcc

make ptr::invalid not the same as a regular int2ptr cast

In Miri, we would like to distinguish `ptr::invalid` from `ptr::from_exposed_provenance`, so that we can provide better diagnostics issues like https://github.com/rust-lang/miri/issues/2134, and so that we can detect the UB in programs like
```rust
fn main() {
    let x = 0u8;
    let original_ptr = &x as *const u8;
    let addr = original_ptr.expose_addr();
    let new_ptr: *const u8 = core::ptr::invalid(addr);
    unsafe {
        dbg!(*new_ptr);
    }
}
```

To achieve that, the two functions need to have different implementations. Currently, both are just `as` casts. We *could* add an intrinsic for this, but it turns out `transmute` already has the right behavior, at least as far as Miri is concerned. So I propose we just use that.

Cc `@Gankra`

2 years agoRollup merge of #97218 - GuillaumeGomez:eslint-checks, r=notriddle
Guillaume Gomez [Sat, 21 May 2022 09:39:49 +0000 (11:39 +0200)]
Rollup merge of #97218 - GuillaumeGomez:eslint-checks, r=notriddle

Add eslint checks

The first check is to ensure that `=>` is always surrounded with whitespaces.

The second is to ensure that the dict objects looks like this: `{"a": 2}` and not `{"a" : 2}` or `{"a":2}`.

r? ``@notriddle``

2 years agoRollup merge of #97190 - SylvainDe:master, r=Dylan-DPC
Guillaume Gomez [Sat, 21 May 2022 09:39:48 +0000 (11:39 +0200)]
Rollup merge of #97190 - SylvainDe:master, r=Dylan-DPC

Add implicit call to from_str via parse in documentation

The documentation mentions "FromStr’s from_str method is often used implicitly,
through str’s parse method. See parse’s documentation for examples.".

It may be nicer to show that in the code example as well.

2 years agoAuto merge of #93963 - GuillaumeGomez:reduce-clean-type-size, r=notriddle
bors [Sat, 21 May 2022 09:04:05 +0000 (09:04 +0000)]
Auto merge of #93963 - GuillaumeGomez:reduce-clean-type-size, r=notriddle

rustdoc: Reduce clean::Type size

There is no need to keep the `DefId` around since it's allow used to compute if we should show a cast or not. As such, we can simply directly store the boolean.

I think it's not what you had in mind `@camelid` but I guess it's still an improvement? :wink:

It was discussed in https://github.com/rust-lang/rust/pull/93941.

r? `@camelid`

2 years agoAuto merge of #97239 - jhpratt:remove-crate-vis, r=joshtriplett
bors [Sat, 21 May 2022 06:38:49 +0000 (06:38 +0000)]
Auto merge of #97239 - jhpratt:remove-crate-vis, r=joshtriplett

Remove `crate` visibility modifier

FCP to remove this syntax is just about complete in #53120. Once it completes, this should be merged ASAP to avoid merge conflicts.

The first two commits remove usage of the feature in this repository, while the last removes the feature itself.

2 years agoRemove `crate` visibility modifier in libs, tests
Jacob Pratt [Sat, 21 May 2022 01:06:44 +0000 (21:06 -0400)]
Remove `crate` visibility modifier in libs, tests

2 years agoAuto merge of #96923 - eholk:fix-fake-read, r=nikomatsakis
bors [Sat, 21 May 2022 04:21:38 +0000 (04:21 +0000)]
Auto merge of #96923 - eholk:fix-fake-read, r=nikomatsakis

Drop Tracking: Implement `fake_read` callback

This PR updates drop tracking's use of `ExprUseVisitor` so that we treat `fake_read` events as borrows. Without doing this, we were not handling match expressions correctly, which showed up as a breakage in the `addassign-yield.rs` test. We did not previously notice this because we still had rather large temporary scopes that we held borrows for, which changed in #94309.

This PR also includes a variant of the `addassign-yield.rs` test case to make sure we continue to have correct behavior here with drop tracking.

r? `@nikomatsakis`

2 years agoAuto merge of #96605 - Urgau:string-retain-codegen, r=thomcc
bors [Sat, 21 May 2022 01:56:51 +0000 (01:56 +0000)]
Auto merge of #96605 - Urgau:string-retain-codegen, r=thomcc

Improve codegen of String::retain method

This pull-request improve the codegen of the `String::retain` method.

Using `unwrap_unchecked` helps the optimizer to not generate a panicking path that will never be taken for valid UTF-8 like string.

Using `encode_utf8` saves us from an expensive call to `memcpy`, as the optimizer is unable to realize that `ch_len <= 4` and so can generate much better assembly code.

https://rust.godbolt.org/z/z73ohenfc

2 years agoRemove `crate` visibility usage in compiler
Jacob Pratt [Fri, 20 May 2022 23:51:09 +0000 (19:51 -0400)]
Remove `crate` visibility usage in compiler

2 years agoAuto merge of #95824 - zx2c4-forks:grnd_insecure, r=thomcc
bors [Fri, 20 May 2022 23:11:12 +0000 (23:11 +0000)]
Auto merge of #95824 - zx2c4-forks:grnd_insecure, r=thomcc

Use GRND_INSECURE instead of /dev/urandom when possible

From reading the source code, it appears like the desired semantic of
std::unix::rand is to always provide some bytes and never block. For
that reason GRND_NONBLOCK is checked before calling getrandom(0), so
that getrandom(0) won't block. If it would block, then the function
falls back to using /dev/urandom, which for the time being doesn't
block. There are some drawbacks to using /dev/urandom, however, and so
getrandom(GRND_INSECURE) was created as a replacement for this exact
circumstance.

getrandom(GRND_INSECURE) is the same as /dev/urandom, except:

- It won't leave a warning in dmesg if used at early boot time, which is
  a common occurance (and the reason why I found this issue);

- It won't introduce a tiny delay at early boot on newer kernels when
  /dev/urandom tries to opportunistically create jitter entropy;

- It only requires 1 syscall, rather than 3.

Other than that, it returns the same "quality" of randomness as
/dev/urandom, and never blocks.

It's only available on kernels ≥5.6, so we try to use it, cache the
result of that attempt, and fall back to to the previous code if it
didn't work.

2 years agoBump LLVM fetched from CI to fix run-make
Mark Rousskov [Fri, 20 May 2022 22:56:21 +0000 (18:56 -0400)]
Bump LLVM fetched from CI to fix run-make

2 years agoAdd back thinking emoji
oberien [Fri, 20 May 2022 22:17:33 +0000 (00:17 +0200)]
Add back thinking emoji

2 years agoAdd a function returning itself to weird-exprs
Jaro Fietz [Tue, 29 Jun 2021 18:28:44 +0000 (20:28 +0200)]
Add a function returning itself to weird-exprs

2 years agoAdd unicode identifier to weird-exprs
Jaro Fietz [Tue, 29 Jun 2021 18:22:44 +0000 (20:22 +0200)]
Add unicode identifier to weird-exprs

Use unicode identifiers and a unicode emoji in weird-exprs.rs

2 years agoMake the most special expression even more special
Jaro Fietz [Tue, 29 Jun 2021 13:13:43 +0000 (15:13 +0200)]
Make the most special expression even more special

Add or-pattern syntax in argument position

2 years agoUse GRND_INSECURE instead of /dev/urandom when possible
Jason A. Donenfeld [Fri, 8 Apr 2022 20:09:44 +0000 (22:09 +0200)]
Use GRND_INSECURE instead of /dev/urandom when possible

From reading the source code, it appears like the desired semantic of
std::unix::rand is to always provide some bytes and never block. For
that reason GRND_NONBLOCK is checked before calling getrandom(0), so
that getrandom(0) won't block. If it would block, then the function
falls back to using /dev/urandom, which for the time being doesn't
block. There are some drawbacks to using /dev/urandom, however, and so
getrandom(GRND_INSECURE) was created as a replacement for this exact
circumstance.

getrandom(GRND_INSECURE) is the same as /dev/urandom, except:

- It won't leave a warning in dmesg if used at early boot time, which is
  a common occurance (and the reason why I found this issue);

- It won't introduce a tiny delay at early boot on newer kernels when
  /dev/urandom tries to opportunistically create jitter entropy;

- It only requires 1 syscall, rather than 3.

Other than that, it returns the same "quality" of randomness as
/dev/urandom, and never blocks.

It's only available on kernels ≥5.6, so we try to use it, cache the
result of that attempt, and fall back to to the previous code if it
didn't work.

2 years agoUpdate libc dependency of std to 0.2.126
Jason A. Donenfeld [Fri, 20 May 2022 21:52:05 +0000 (23:52 +0200)]
Update libc dependency of std to 0.2.126

This is required for the next commit, which uses libc::GRND_INSECURE.

2 years agoAuto merge of #95418 - cjgillot:more-disk, r=davidtwco
bors [Fri, 20 May 2022 20:49:55 +0000 (20:49 +0000)]
Auto merge of #95418 - cjgillot:more-disk, r=davidtwco

Cache more queries on disk

One of the principles of incremental compilation is to allow saving results on disk to avoid recomputing them.
This PR investigates persisting a lot of queries whose result are to be saved into metadata.
Some of the queries are cheap reads from HIR, but we may also want to get rid of these reads for incremental lowering.

2 years agotypo
Tshepang Lekhonkhobe [Fri, 20 May 2022 20:02:20 +0000 (22:02 +0200)]
typo

2 years agoUpdate compiler/rustc_typeck/src/check/generator_interior/drop_ranges/record_consumed...
Niko Matsakis [Fri, 20 May 2022 19:54:22 +0000 (15:54 -0400)]
Update compiler/rustc_typeck/src/check/generator_interior/drop_ranges/record_consumed_borrow.rs

2 years agoAdd eslint key-spacing check
Guillaume Gomez [Fri, 20 May 2022 15:05:20 +0000 (17:05 +0200)]
Add eslint key-spacing check

2 years agoAdd eslint arrow-spacing check
Guillaume Gomez [Fri, 20 May 2022 15:04:21 +0000 (17:04 +0200)]
Add eslint arrow-spacing check

2 years agoAuto merge of #97224 - matthiaskrgr:rollup-it5nw68, r=matthiaskrgr
bors [Fri, 20 May 2022 18:21:26 +0000 (18:21 +0000)]
Auto merge of #97224 - matthiaskrgr:rollup-it5nw68, r=matthiaskrgr

Rollup of 7 pull requests

Successful merges:

 - #97109 (Fix misleading `cannot infer type for type parameter` error)
 - #97187 (Reverse condition in Vec::retain_mut doctest)
 - #97201 (Fix typo)
 - #97203 (Minor tweaks to rustc book summary formatting.)
 - #97208 (Do not emit the lint `unused_attributes` for *inherent* `#[doc(hidden)]` associated items)
 - #97215 (Add complexity estimation of iterating over HashSet and HashMap)
 - #97220 (Add regression test for#81827)

Failed merges:

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

2 years agoRollup merge of #97220 - JohnTitor:issue-81827, r=compiler-errors
Matthias Krüger [Fri, 20 May 2022 17:54:45 +0000 (19:54 +0200)]
Rollup merge of #97220 - JohnTitor:issue-81827, r=compiler-errors

Add regression test for#81827

Closes #81827
r? `@compiler-errors`

2 years agoRollup merge of #97215 - AngelicosPhosphoros:add_hashtable_iteration_complexity_note...
Matthias Krüger [Fri, 20 May 2022 17:54:44 +0000 (19:54 +0200)]
Rollup merge of #97215 - AngelicosPhosphoros:add_hashtable_iteration_complexity_note, r=thomcc

Add complexity estimation of iterating over HashSet and HashMap

It is not obvious (at least for me) that complexity of iteration over hash tables depends on capacity and not length. Especially comparing with other containers like Vec or String. I think, this behaviour is worth mentioning.

I run benchmark which tests iteration time for maps with length 50 and different capacities and get this results:
```
capacity - time
64       - 203.87 ns
256      - 351.78 ns
1024     - 607.87 ns
4096     - 965.82 ns
16384    - 3.1188 us
```

If you want to dig why it behaves such way, you can look current implementation in [hashbrown code](https://github.com/rust-lang/hashbrown/blob/f3a9f211d06f78c5beb81ac22ea08fdc269e068f/src/raw/mod.rs#L1933).

Benchmarks code would be presented in PR related to this commit.

2 years agoRollup merge of #97208 - fmease:fix-issue-97205, r=oli-obk
Matthias Krüger [Fri, 20 May 2022 17:54:43 +0000 (19:54 +0200)]
Rollup merge of #97208 - fmease:fix-issue-97205, r=oli-obk

Do not emit the lint `unused_attributes` for *inherent* `#[doc(hidden)]` associated items

Fixes #97205 (embarrassing oversight from #96008).

`@rustbot` label A-lint

2 years agoRollup merge of #97203 - ehuss:rustc-summary-formatting, r=Dylan-DPC
Matthias Krüger [Fri, 20 May 2022 17:54:42 +0000 (19:54 +0200)]
Rollup merge of #97203 - ehuss:rustc-summary-formatting, r=Dylan-DPC

Minor tweaks to rustc book summary formatting.

This includes a few minor tweaks to the summary/titles of chapters for the rustc book:

* Use a consistent chapter capitalization and hyphenation.
* Move "Codegen Options" underneath "Command-line Arguments". I feel like they are two closely related chapters, where codegen is just a subset of the total arguments.
* Move "Target Tier Policy" underneath "Platform Support". That chapter includes that policy for platform support, and thus I feel it is more closely related to that grouping.

2 years agoRollup merge of #97201 - ydah:fix_spelling, r=GuillaumeGomez
Matthias Krüger [Fri, 20 May 2022 17:54:41 +0000 (19:54 +0200)]
Rollup merge of #97201 - ydah:fix_spelling, r=GuillaumeGomez

Fix typo

This PR is fixes typo "avaiable" to "available".

2 years agoRollup merge of #97187 - ajtribick:patch-1, r=thomcc
Matthias Krüger [Fri, 20 May 2022 17:54:40 +0000 (19:54 +0200)]
Rollup merge of #97187 - ajtribick:patch-1, r=thomcc

Reverse condition in Vec::retain_mut doctest

I find that the doctest for `Vec::retain_mut` is easier to read and understand when the `if` block corresponds to the path that returns `true` and the `else` block returns `false`. Having the `if` block be the `false` path led me to stare at the example for somewhat longer than I probably had to.

2 years agoRollup merge of #97109 - TaKO8Ki:fix-misleading-cannot-infer-type-for-type-parameter...
Matthias Krüger [Fri, 20 May 2022 17:54:39 +0000 (19:54 +0200)]
Rollup merge of #97109 - TaKO8Ki:fix-misleading-cannot-infer-type-for-type-parameter-error, r=oli-obk

Fix misleading `cannot infer type for type parameter` error

closes #93198

2 years agoRemove quadratic behaviour from -Zunpretty=hir-tree.
Camille GILLOT [Fri, 20 May 2022 17:34:31 +0000 (19:34 +0200)]
Remove quadratic behaviour from -Zunpretty=hir-tree.

2 years agoAdd regression test for #81827
Yuki Okushi [Fri, 20 May 2022 16:32:02 +0000 (01:32 +0900)]
Add regression test for #81827

2 years agoAdd complexity estimation of iterating over HashSet and HashMap
AngelicosPhosphoros [Fri, 20 May 2022 12:38:04 +0000 (15:38 +0300)]
Add complexity estimation of iterating over HashSet and HashMap

It is not obvious (at least for me) that complexity of iteration over hash tables depends on capacity and not length. Especially comparing with other containers like Vec or String. I think, this behaviour is worth mentioning.

I run benchmark which tests iteration time for maps with length 50 and different capacities and get this results:
```
capacity - time
64       - 203.87 ns
256      - 351.78 ns
1024     - 607.87 ns
4096     - 965.82 ns
16384    - 3.1188 us
```

If you want to dig why it behaves such way, you can look current implementation in [hashbrown code](https://github.com/rust-lang/hashbrown/blob/f3a9f211d06f78c5beb81ac22ea08fdc269e068f/src/raw/mod.rs#L1933).

Benchmarks code would be presented in PR related to this commit.

2 years agoAuto merge of #96833 - cjgillot:ast-lifetimes-single, r=petrochenkov
bors [Fri, 20 May 2022 15:40:33 +0000 (15:40 +0000)]
Auto merge of #96833 - cjgillot:ast-lifetimes-single, r=petrochenkov

Lint single-use lifetimes during AST resolution

This PR rewrites `single_use_lifetime` and `unused_lifetime` lints to be based on the AST.
We have more information at our disposal, so we can reduce the amount of false positives.

Remaining false positive: single-use lifetimes in argument-position impl-trait.
I'm waiting for https://github.com/rust-lang/rust/issues/96529 to be fixed to have a clean and proper solution here.

Closes https://github.com/rust-lang/rust/issues/54079
Closes https://github.com/rust-lang/rust/issues/55057
Closes https://github.com/rust-lang/rust/issues/55058
Closes https://github.com/rust-lang/rust/issues/60554
Closes https://github.com/rust-lang/rust/issues/69952

r? `@petrochenkov`

2 years agomake ptr::invalid not the same as a regular int2ptr cast
Ralf Jung [Fri, 20 May 2022 15:16:41 +0000 (17:16 +0200)]
make ptr::invalid not the same as a regular int2ptr cast

2 years agoreport ambiguous type parameters when their parents are impl or fn
Takayuki Maeda [Fri, 20 May 2022 04:49:41 +0000 (13:49 +0900)]
report ambiguous type parameters when their parents are impl or fn

fix ci error

emit err for `impl_item`

2 years agoAuto merge of #97211 - GuillaumeGomez:rollup-jul7x7e, r=GuillaumeGomez
bors [Fri, 20 May 2022 13:18:37 +0000 (13:18 +0000)]
Auto merge of #97211 - GuillaumeGomez:rollup-jul7x7e, r=GuillaumeGomez

Rollup of 6 pull requests

Successful merges:

 - #96565 (rustdoc: show implementations on `#[fundamental]` wrappers)
 - #97179 (Add new lint to enforce whitespace after keywords)
 - #97185 (interpret/validity: separately control checking numbers for being init and non-ptr)
 - #97188 (Remove unneeded null pointer asserts in ptr2int casts)
 - #97189 (Update .mailmap)
 - #97192 (Say "last" instead of "rightmost" in the documentation for `std::str:rfind`)

Failed merges:

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

2 years agoRollup merge of #97192 - sunfishcode:sunfishcode/rightmost, r=thomcc
Guillaume Gomez [Fri, 20 May 2022 12:03:06 +0000 (14:03 +0200)]
Rollup merge of #97192 - sunfishcode:sunfishcode/rightmost, r=thomcc

Say "last" instead of "rightmost" in the documentation for `std::str:rfind`

In the documentation comment for `std::str::rfind`, say "last" instead
of "rightmost" to describe the match that `rfind` finds. This follows the
spirit of #30459, for which `trim_left` and `trim_right` were replaced by
`trim_start` and `trim_end` to be more clear about how they work on
text which is displayed right-to-left.

2 years agoRollup merge of #97189 - pvdrz:patch-1, r=Mark-Simulacrum
Guillaume Gomez [Fri, 20 May 2022 12:03:05 +0000 (14:03 +0200)]
Rollup merge of #97189 - pvdrz:patch-1, r=Mark-Simulacrum

Update .mailmap

2 years agoRollup merge of #97188 - carbotaniuman:remove-null-assert, r=RalfJung
Guillaume Gomez [Fri, 20 May 2022 12:03:04 +0000 (14:03 +0200)]
Rollup merge of #97188 - carbotaniuman:remove-null-assert, r=RalfJung

Remove unneeded null pointer asserts in ptr2int casts

This removes an assert that a pointer with address 0 has no provenance. This change is needed to support permissive provenance work in Miri, and seems justified by `ptr.with_addr(0)` working and a discussion on Zulip regarding LLVM semantics.

r? `@RalfJung`

2 years agoRollup merge of #97185 - RalfJung:number-validity, r=oli-obk
Guillaume Gomez [Fri, 20 May 2022 12:03:03 +0000 (14:03 +0200)]
Rollup merge of #97185 - RalfJung:number-validity, r=oli-obk

interpret/validity: separately control checking numbers for being init and non-ptr

This lets Miri control this in a more fine-grained way.

r? `@oli-obk`

2 years agoRollup merge of #97179 - GuillaumeGomez:eslint-lint, r=notriddle
Guillaume Gomez [Fri, 20 May 2022 12:03:02 +0000 (14:03 +0200)]
Rollup merge of #97179 - GuillaumeGomez:eslint-lint, r=notriddle

Add new lint to enforce whitespace after keywords

r? `@notriddle`

2 years agoRollup merge of #96565 - notriddle:notriddle/impl-box, r=camelid
Guillaume Gomez [Fri, 20 May 2022 12:03:01 +0000 (14:03 +0200)]
Rollup merge of #96565 - notriddle:notriddle/impl-box, r=camelid

rustdoc: show implementations on `#[fundamental]` wrappers

Fixes #92940

2 years agoAuto merge of #95309 - lcnr:dropck-cleanup, r=nikomatsakis
bors [Fri, 20 May 2022 10:37:48 +0000 (10:37 +0000)]
Auto merge of #95309 - lcnr:dropck-cleanup, r=nikomatsakis

rewrite `ensure_drop_params_and_item_params_correspond`

actually relating types here seems like it's overkill

2 years agoLint single-use-lifetimes on the AST.
Camille GILLOT [Tue, 10 May 2022 19:15:30 +0000 (21:15 +0200)]
Lint single-use-lifetimes on the AST.

2 years agoIntroduce BareFnTy::decl_span and fix generics span.
Camille GILLOT [Tue, 10 May 2022 19:17:21 +0000 (21:17 +0200)]
Introduce BareFnTy::decl_span and fix generics span.

2 years agoIntroduce LifetimeCtxt.
Camille GILLOT [Tue, 10 May 2022 17:56:46 +0000 (19:56 +0200)]
Introduce LifetimeCtxt.

2 years ago`bool` to custom enum
lcnr [Mon, 4 Apr 2022 08:56:59 +0000 (10:56 +0200)]
`bool` to custom enum

2 years agoupdate error message
lcnr [Tue, 29 Mar 2022 05:29:59 +0000 (07:29 +0200)]
update error message

2 years agoupdate comments
lcnr [Fri, 25 Mar 2022 13:49:14 +0000 (14:49 +0100)]
update comments

2 years agorewrite `ensure_drop_params_and_item_params_correspond`
lcnr [Wed, 23 Mar 2022 09:06:29 +0000 (10:06 +0100)]
rewrite `ensure_drop_params_and_item_params_correspond`

2 years agomove unique param check into `rustc_middle`
lcnr [Wed, 23 Mar 2022 08:41:31 +0000 (09:41 +0100)]
move unique param check into `rustc_middle`

2 years agoDo not warn on inherent doc(hidden) assoc items
León Orell Valerian Liehr [Fri, 20 May 2022 08:19:23 +0000 (10:19 +0200)]
Do not warn on inherent doc(hidden) assoc items

2 years agoAuto merge of #96422 - tmccombs:mutex-unpoison, r=m-ou-se
bors [Fri, 20 May 2022 08:06:56 +0000 (08:06 +0000)]
Auto merge of #96422 - tmccombs:mutex-unpoison, r=m-ou-se

Add functions to un-poison Mutex and RwLock

See discussion at https://internals.rust-lang.org/t/unpoisoning-a-mutex/16521/3

2 years agoRemove references to guards in documentation for clear_poison
Thayne McCombs [Fri, 20 May 2022 06:15:26 +0000 (00:15 -0600)]
Remove references to guards in documentation for clear_poison

2 years agoAuto merge of #97147 - Mark-Simulacrum:stage0-bump, r=pietroalbini
bors [Fri, 20 May 2022 05:44:52 +0000 (05:44 +0000)]
Auto merge of #97147 - Mark-Simulacrum:stage0-bump, r=pietroalbini

stage0 bootstrap bump

r? `@pietroalbini`

2 years agoAuto merge of #97029 - eholk:drop-tracking-yielding-in-match-guard, r=nikomatsakis
bors [Fri, 20 May 2022 03:27:01 +0000 (03:27 +0000)]
Auto merge of #97029 - eholk:drop-tracking-yielding-in-match-guard, r=nikomatsakis

generator_interior: Count match pattern bindings as borrowed for the whole guard expression

The test case `yielding-in-match-guard.rs` was failing with `-Zdrop-tracking` enabled. The reason is that the copy of a local (`y`) was not counted as a borrow in typeck, while MIR did consider this as borrowed.

The correct thing to do here is to count pattern bindings are borrowed for the whole guard. Instead, what we were doing is to record the type at the use site of the variable and check if the variable comes from a borrowed pattern. Due to the fix for #57017, we were considering too small of a scope for this variable, which meant it was not counted as borrowed.

Because we now unconditionally record the borrow, rather than only for bindings that are used, this PR is also able to remove a lot of the logic around match bindings that was there before.

r? `@nikomatsakis`

2 years agoMinor tweaks to rustc book summary formatting.
Eric Huss [Fri, 20 May 2022 02:06:01 +0000 (19:06 -0700)]
Minor tweaks to rustc book summary formatting.

2 years agoFix typo
ydah [Fri, 20 May 2022 01:39:10 +0000 (10:39 +0900)]
Fix typo

This PR is fixes typo "avaiable" to "available".

2 years agoAuto merge of #97027 - cuviper:yesalias-refcell, r=thomcc
bors [Fri, 20 May 2022 01:05:53 +0000 (01:05 +0000)]
Auto merge of #97027 - cuviper:yesalias-refcell, r=thomcc

Use pointers in `cell::{Ref,RefMut}` to avoid `noalias`

When `Ref` and `RefMut` were based on references, they would get LLVM `noalias` attributes that were incorrect, because that alias guarantee is only true until the guard drops. A `&RefCell` on the same value can get a new borrow that aliases the previous guard, possibly leading to miscompilation. Using `NonNull` pointers in `Ref` and `RefCell` avoids `noalias`.

Fixes the library side of #63787, but we still might want to explore language solutions there.

2 years agoUpdate IfLet syntax
Eric Holk [Thu, 19 May 2022 23:32:06 +0000 (16:32 -0700)]
Update IfLet syntax

2 years agoRemove old match guard pattern tracking code
Eric Holk [Tue, 17 May 2022 23:00:53 +0000 (16:00 -0700)]
Remove old match guard pattern tracking code

This is subsumed by the new changes that count pattern variables as
bound for the whole guard expression.

2 years agoBorrow guard patterns for the body of the guard
Eric Holk [Tue, 17 May 2022 22:36:39 +0000 (15:36 -0700)]
Borrow guard patterns for the body of the guard

2 years agoRevert "Count copies of locals as borrowed temporaries"
Eric Holk [Tue, 17 May 2022 22:04:05 +0000 (15:04 -0700)]
Revert "Count copies of locals as borrowed temporaries"

This reverts commit 0d270b5e9f48268735f9a05462df65c9d1039855.

2 years agoCount copies of locals as borrowed temporaries
Eric Holk [Fri, 13 May 2022 21:24:41 +0000 (14:24 -0700)]
Count copies of locals as borrowed temporaries

2 years agoFurther reduce test case
Eric Holk [Fri, 13 May 2022 20:38:36 +0000 (13:38 -0700)]
Further reduce test case

Thanks to @tmiasko for this one!

2 years agoAdd drop tracking version of yielding-in-match-guard.rs
Eric Holk [Wed, 11 May 2022 00:58:18 +0000 (17:58 -0700)]
Add drop tracking version of yielding-in-match-guard.rs

2 years agoAuto merge of #97180 - Dylan-DPC:rollup-aa5j2yw, r=Dylan-DPC
bors [Thu, 19 May 2022 22:43:00 +0000 (22:43 +0000)]
Auto merge of #97180 - Dylan-DPC:rollup-aa5j2yw, r=Dylan-DPC

Rollup of 6 pull requests

Successful merges:

 - #96539 (Add release notes for 1.61.0)
 - #97142 (move processing of `source_scope_data` into `MutVisitor`'s impl of `Integrator` when inline)
 - #97155 (Fix doc typo)
 - #97169 (Improve `u32 as char` cast diagnostic)
 - #97170 (Remove unnecessay .report() on ExitCode)
 - #97171 (Add regression test for #88119)

Failed merges:

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

2 years agoSay "last" instead of "rightmost" in the documentation for `std::str::rfind`.
Dan Gohman [Thu, 19 May 2022 22:26:34 +0000 (15:26 -0700)]
Say "last" instead of "rightmost" in the documentation for `std::str::rfind`.

In the documentation comment for `std::str::rfind`, say "last" instead
of "rightmost" to describe the match that `rfind` finds. This follows the
spirit of #30459, for which `trim_left` and `trim_right` were replaced by
`trim_start` and `trim_end` to be more clear about how they work on
text which is displayed right-to-left.

2 years agoAdd implicit call to from_str via parse in documentation
SylvainDe [Thu, 19 May 2022 19:58:39 +0000 (21:58 +0200)]
Add implicit call to from_str via parse in documentation

The documentation mentions "FromStr’s from_str method is often used implicitly,
through str’s parse method. See parse’s documentation for examples.".

It may be nicer to show that in the code example as well.

2 years agoUpdate .mailmap
Christian Poveda [Thu, 19 May 2022 19:13:13 +0000 (14:13 -0500)]
Update .mailmap

2 years agoReverse condition in Vec::retain_mut doctest
ajtribick [Thu, 19 May 2022 18:54:16 +0000 (20:54 +0200)]
Reverse condition in Vec::retain_mut doctest

2 years agoRemove unneeded asserts
carbotaniuman [Thu, 19 May 2022 18:51:53 +0000 (13:51 -0500)]
Remove unneeded asserts

2 years agofmt
Ralf Jung [Thu, 19 May 2022 18:34:37 +0000 (20:34 +0200)]
fmt

2 years agobless 32bit
Ralf Jung [Thu, 19 May 2022 18:20:36 +0000 (20:20 +0200)]
bless 32bit

2 years agointerpret/validity: separately control checking numbers for being init and non-ptr
Ralf Jung [Thu, 19 May 2022 18:16:25 +0000 (20:16 +0200)]
interpret/validity: separately control checking numbers for being init and non-ptr

2 years agoRollup merge of #97171 - JohnTitor:issue-88119, r=compiler-errors
Dylan DPC [Thu, 19 May 2022 15:22:51 +0000 (17:22 +0200)]
Rollup merge of #97171 - JohnTitor:issue-88119, r=compiler-errors

Add regression test for #88119

Closes #88119

2 years agoRollup merge of #97170 - benediktwerner:master, r=JohnTitor
Dylan DPC [Thu, 19 May 2022 15:22:51 +0000 (17:22 +0200)]
Rollup merge of #97170 - benediktwerner:master, r=JohnTitor

Remove unnecessay .report() on ExitCode

Since #93442, the return type is `ExitCode` anyway so there's no need to do a conversion using `.report()` (which is now just a no-op).

2 years agoRollup merge of #97169 - gimbles:u32-diagnostic, r=petrochenkov
Dylan DPC [Thu, 19 May 2022 15:22:50 +0000 (17:22 +0200)]
Rollup merge of #97169 - gimbles:u32-diagnostic, r=petrochenkov

Improve `u32 as char` cast diagnostic

Fixes #97160

2 years agoRollup merge of #97155 - alygin:patch-1, r=JohnTitor
Dylan DPC [Thu, 19 May 2022 15:22:49 +0000 (17:22 +0200)]
Rollup merge of #97155 - alygin:patch-1, r=JohnTitor

Fix doc typo

Fixes a minor doc typo for `atomic::fence()`.

2 years agoRollup merge of #97142 - SparrowLii:inline, r=tmiasko
Dylan DPC [Thu, 19 May 2022 15:22:48 +0000 (17:22 +0200)]
Rollup merge of #97142 - SparrowLii:inline, r=tmiasko

move processing of `source_scope_data` into `MutVisitor`'s impl of `Integrator` when inline

This PR fixes the FIXME in the inline mir-opt which moves processing of `source_scope_data` into `MutVisitor`'s impl of `Integrator` when inline

2 years agoRollup merge of #96539 - tmandry:relnotes-1.61, r=Mark-Simulacrum
Dylan DPC [Thu, 19 May 2022 15:22:47 +0000 (17:22 +0200)]
Rollup merge of #96539 - tmandry:relnotes-1.61, r=Mark-Simulacrum

Add release notes for 1.61.0

cc `@rust-lang/release`

2 years agoAdd new lint to enforce whitespace after keywords
Guillaume Gomez [Thu, 19 May 2022 15:19:08 +0000 (17:19 +0200)]
Add new lint to enforce whitespace after keywords

2 years agoImprove u32 to char diagnostic
gimbles [Thu, 19 May 2022 14:33:40 +0000 (20:03 +0530)]
Improve u32 to char diagnostic

2 years agoAuto merge of #97024 - lcnr:simplify_type-sus, r=<try>
bors [Thu, 19 May 2022 13:08:51 +0000 (13:08 +0000)]
Auto merge of #97024 - lcnr:simplify_type-sus, r=<try>

`simplify_type` improvements and cursed docs

the existing `TreatParams` enum pretty much mixes everything up. Not sure why this looked right to me in #94057

This also includes two changes which impact perf:
- `ty::Projection` with inference vars shouldn't be treated as a rigid type, even if fully normalized
- `ty::Placeholder` only unifies with itself, so actually return `Some` for them

r? `@nikomatsakis`

2 years agoAdd regression test for #88119
Yuki Okushi [Thu, 19 May 2022 11:51:32 +0000 (20:51 +0900)]
Add regression test for #88119

2 years agoRemove unnecessay .report() on ExitCode
benediktwerner [Thu, 19 May 2022 09:47:36 +0000 (11:47 +0200)]
Remove unnecessay .report() on ExitCode

2 years agoAuto merge of #97114 - klensy:cursor-ref, r=petrochenkov
bors [Thu, 19 May 2022 09:27:55 +0000 (09:27 +0000)]
Auto merge of #97114 - klensy:cursor-ref, r=petrochenkov

use CursorRef more

This allows skipping clone of `TreeAndSpacing` (and `TokenTree`).

2 years agoChange clear_poison to take the lock instead of a guard
Thayne McCombs [Thu, 19 May 2022 07:53:41 +0000 (01:53 -0600)]
Change clear_poison to take the lock instead of a guard

2 years agoAuto merge of #97103 - luqmana:asm-unwind-cleanup, r=Amanieu,tmiasko
bors [Thu, 19 May 2022 06:57:59 +0000 (06:57 +0000)]
Auto merge of #97103 - luqmana:asm-unwind-cleanup, r=Amanieu,tmiasko

Update MIR passes to handle unwinding Inline Asm

Some more follow up fixes from https://github.com/rust-lang/rust/pull/95864#issuecomment-1094165398

r? `@Amanieu`