]> git.lizzy.rs Git - rust.git/log
rust.git
2 years agoAdd package.json in gitignore
Guillaume Gomez [Tue, 1 Feb 2022 16:14:59 +0000 (17:14 +0100)]
Add package.json in gitignore

2 years agoAuto merge of #93457 - matthiaskrgr:rollup-e43ry1l, r=matthiaskrgr
bors [Sat, 29 Jan 2022 16:08:35 +0000 (16:08 +0000)]
Auto merge of #93457 - matthiaskrgr:rollup-e43ry1l, r=matthiaskrgr

Rollup of 8 pull requests

Successful merges:

 - #88205 (Add Explanation For Error E0772)
 - #92274 (Add `intrinsics::const_deallocate`)
 - #93236 (Make `NonNull::new` `const`)
 - #93299 (Fix dot separator when there is no source link)
 - #93410 (kmc-solid: Implement `net::FileDesc::duplicate`)
 - #93424 (fix nit)
 - #93431 (remove unused `jemallocator` crate)
 - #93453 (Add GUI theme change test)

Failed merges:

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

2 years agoRollup merge of #93453 - GuillaumeGomez:theme-change-test, r=jsha
Matthias Krüger [Sat, 29 Jan 2022 13:46:35 +0000 (14:46 +0100)]
Rollup merge of #93453 - GuillaumeGomez:theme-change-test, r=jsha

Add GUI theme change test

r? `@jsha`

2 years agoRollup merge of #93431 - lqd:remove-jemallocator, r=Mark-Simulacrum
Matthias Krüger [Sat, 29 Jan 2022 13:46:34 +0000 (14:46 +0100)]
Rollup merge of #93431 - lqd:remove-jemallocator, r=Mark-Simulacrum

remove unused `jemallocator` crate

When it was noticed that the rustc binary wasn't actually using jemalloc via `#[global_allocator]` and that was removed, the dependency remained.

Tests pass locally with a `jemalloc = true` build, but I'll trigger a try build to ensure I haven't missed an edge-case somewhere.

r? ```@ghost``` until that completes

2 years agoRollup merge of #93424 - lcnr:nit, r=spastorino
Matthias Krüger [Sat, 29 Jan 2022 13:46:33 +0000 (14:46 +0100)]
Rollup merge of #93424 - lcnr:nit, r=spastorino

fix nit

2 years agoRollup merge of #93410 - solid-rs:feat-kmc-solid-net-dup, r=dtolnay
Matthias Krüger [Sat, 29 Jan 2022 13:46:32 +0000 (14:46 +0100)]
Rollup merge of #93410 - solid-rs:feat-kmc-solid-net-dup, r=dtolnay

kmc-solid: Implement `net::FileDesc::duplicate`

This PR implements `std::sys::solid::net::FileDesc::duplicate`, which was accidentally left out when this target was added by #86191.

2 years agoRollup merge of #93299 - GuillaumeGomez:dot-separator-no-source, r=jsha
Matthias Krüger [Sat, 29 Jan 2022 13:46:32 +0000 (14:46 +0100)]
Rollup merge of #93299 - GuillaumeGomez:dot-separator-no-source, r=jsha

Fix dot separator when there is no source link

Fixes #92973.

We did well adding this test since there was a bug:

![Screenshot from 2022-01-25 17-05-48](https://user-images.githubusercontent.com/3050060/151016535-39b45f52-e1e0-4963-ad19-532e24ec4c9b.png)

r? `@jsha`

2 years agoRollup merge of #93236 - woppopo:const_nonnull_new, r=oli-obk
Matthias Krüger [Sat, 29 Jan 2022 13:46:31 +0000 (14:46 +0100)]
Rollup merge of #93236 - woppopo:const_nonnull_new, r=oli-obk

Make `NonNull::new` `const`

Tracking issue: #93235

2 years agoRollup merge of #92274 - woppopo:const_deallocate, r=oli-obk
Matthias Krüger [Sat, 29 Jan 2022 13:46:30 +0000 (14:46 +0100)]
Rollup merge of #92274 - woppopo:const_deallocate, r=oli-obk

Add `intrinsics::const_deallocate`

Tracking issue: #79597
Related: #91884

This allows deallocation of a memory allocated by `intrinsics::const_allocate`. At the moment, this can be only used to reduce memory usage, but in the future this may be useful to detect memory leaks (If an allocated memory remains after evaluation, raise an error...?).

2 years agoRollup merge of #88205 - danii:e0772, r=GuillaumeGomez
Matthias Krüger [Sat, 29 Jan 2022 13:46:29 +0000 (14:46 +0100)]
Rollup merge of #88205 - danii:e0772, r=GuillaumeGomez

Add Explanation For Error E0772

I've added an error explanation for the error code E0772.

Assists with #61137

2 years agoAuto merge of #92312 - BGR360:needs-test, r=Mark-Simulacrum
bors [Sat, 29 Jan 2022 13:04:51 +0000 (13:04 +0000)]
Auto merge of #92312 - BGR360:needs-test, r=Mark-Simulacrum

Add tests for three old ICEs

Closes #84044
Closes #91594
Closes #89066

2 years agoDocument about some behaviors of `const_(de)allocate` and add some tests.
woppopo [Sat, 29 Jan 2022 10:13:23 +0000 (19:13 +0900)]
Document about some behaviors of `const_(de)allocate` and add some tests.

2 years agoExtend theme change GUI test
Guillaume Gomez [Sat, 29 Jan 2022 09:44:27 +0000 (10:44 +0100)]
Extend theme change GUI test

2 years agoUpdate browser-ui-test version to 0.5.8
Guillaume Gomez [Sat, 29 Jan 2022 09:44:18 +0000 (10:44 +0100)]
Update browser-ui-test version to 0.5.8

2 years agoAuto merge of #93351 - anp:fuchsia-remove-dir-all, r=tmandry
bors [Sat, 29 Jan 2022 09:01:01 +0000 (09:01 +0000)]
Auto merge of #93351 - anp:fuchsia-remove-dir-all, r=tmandry

Bump libc and fix remove_dir_all on Fuchsia after CVE fix

With the previous `is_dir` impl, we would attempt to unlink
a directory in the None branch, but Fuchsia supports returning
ENOTEMPTY from unlinkat() without the AT_REMOVEDIR flag because
we don't currently differentiate unlinking files and directories
by default.

On the Fuchsia side I've opened https://fxbug.dev/92273 to discuss
whether this is the correct behavior, but it doesn't seem like
addressing the error code is necessary to make our tests happy.

Depends on https://github.com/rust-lang/libc/pull/2654 since we
apparently haven't needed to reference DT_UNKNOWN before this.

2 years agoAuto merge of #93434 - Mark-Simulacrum:apple-various, r=pietroalbini
bors [Sat, 29 Jan 2022 02:20:00 +0000 (02:20 +0000)]
Auto merge of #93434 - Mark-Simulacrum:apple-various, r=pietroalbini

Move tier-2 (without host tools) apple targets to separate builder

One-off (likely fairly unreliable, but give some idea) measurements:

* dist-apple-various (new):  2h10m
* dist-x86_64-apple: 2h55m -> 2h36m (cutting roughly 20 minutes)

2 years agoAdd test for old ICE in #89066
Ben Reeves [Mon, 27 Dec 2021 06:24:19 +0000 (00:24 -0600)]
Add test for old ICE in #89066

2 years agoAdd test for old ICE in #91594
Ben Reeves [Mon, 27 Dec 2021 06:09:19 +0000 (00:09 -0600)]
Add test for old ICE in #91594

2 years agoAdd test for old ICE
Ben Reeves [Mon, 27 Dec 2021 05:30:46 +0000 (23:30 -0600)]
Add test for old ICE

The ICE from #84044 no longer occurs.

2 years agoAuto merge of #93427 - matthiaskrgr:rollup-esd3ixl, r=matthiaskrgr
bors [Fri, 28 Jan 2022 23:20:38 +0000 (23:20 +0000)]
Auto merge of #93427 - matthiaskrgr:rollup-esd3ixl, r=matthiaskrgr

Rollup of 10 pull requests

Successful merges:

 - #92611 (Add links to the reference and rust by example for asm! docs and lints)
 - #93158 (wasi: implement `sock_accept` and enable networking)
 - #93239 (Add os::unix::net::SocketAddr::from_path)
 - #93261 (Some unwinding related cg_ssa cleanups)
 - #93295 (Avoid double panics when using `TempDir` in tests)
 - #93353 (Unimpl {Add,Sub,Mul,Div,Rem,BitXor,BitOr,BitAnd}<$t> for Saturating<$t>)
 - #93356 (Edit docs introduction for `std::cmp::PartialOrd`)
 - #93375 (fix typo `documenation`)
 - #93399 (rustbuild: Fix compiletest warning when building outside of root.)
 - #93404 (Fix a typo from #92899)

Failed merges:

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

2 years agoFix remove_dir_all on Fuchsia after CVE fix.
Adam Perry [Wed, 26 Jan 2022 22:32:21 +0000 (22:32 +0000)]
Fix remove_dir_all on Fuchsia after CVE fix.

With the previous `is_dir` impl, we would attempt to unlink
a directory in the None branch, but Fuchsia supports returning
ENOTEMPTY from unlinkat() without the AT_REMOVEDIR flag because
we don't currently differentiate unlinking files and directories
by default.

On the Fuchsia side I've opened https://fxbug.dev/92273 to discuss
whether this is the correct behavior, but it doesn't seem like
addressing the error code is necessary to make our tests happy.

Updates std's libc crate to include DT_UNKNOWN for Fuchsia.

2 years agoAuto merge of #93426 - pnkfelix:issue-91671-backport-llvm-fix, r=nikic
bors [Fri, 28 Jan 2022 20:11:52 +0000 (20:11 +0000)]
Auto merge of #93426 - pnkfelix:issue-91671-backport-llvm-fix, r=nikic

backport llvm fix for issue 91671.

fix #91671

2 years agoMove target-only apple targets to separate builder
Mark Rousskov [Fri, 28 Jan 2022 17:26:36 +0000 (12:26 -0500)]
Move target-only apple targets to separate builder

2 years agoAdd Explanation For Error E0772
Daniel Conley [Fri, 28 Jan 2022 16:00:56 +0000 (11:00 -0500)]
Add Explanation For Error E0772

2 years agoremove unused `jemallocator` crate
Rémy Rakic [Fri, 28 Jan 2022 15:56:05 +0000 (16:56 +0100)]
remove unused `jemallocator` crate

2 years agobackport llvm fix for issue 91671.
Felix S. Klock II [Fri, 28 Jan 2022 14:22:16 +0000 (09:22 -0500)]
backport llvm fix for issue 91671.

2 years agoRollup merge of #93404 - rust-lang:scottmcm-patch-1, r=wesleywiser
Matthias Krüger [Fri, 28 Jan 2022 14:20:30 +0000 (15:20 +0100)]
Rollup merge of #93404 - rust-lang:scottmcm-patch-1, r=wesleywiser

Fix a typo from #92899

Just happened to notice this in passing

2 years agoRollup merge of #93399 - ehuss:fix-compiletest-path-relative, r=Mark-Simulacrum
Matthias Krüger [Fri, 28 Jan 2022 14:20:29 +0000 (15:20 +0100)]
Rollup merge of #93399 - ehuss:fix-compiletest-path-relative, r=Mark-Simulacrum

rustbuild: Fix compiletest warning when building outside of root.

This fixes a warning that would happen when passing arguments to compiletest (like `x.py test src/test/ui`) when running `x.py` outside of the root source directory. For example, the CI builders do this, which causes a confusing warning message. This also fixes it so that passing a full path works (like `x.py test src/test/ui/hello.rs`) in the same scenario (previously it would just ignore the `hello.rs` part).

2 years agoRollup merge of #93375 - Kvicii:ISSUE_93374, r=notriddle
Matthias Krüger [Fri, 28 Jan 2022 14:20:28 +0000 (15:20 +0100)]
Rollup merge of #93375 - Kvicii:ISSUE_93374, r=notriddle

fix typo `documenation`

2 years agoRollup merge of #93356 - pierwill:partialord-headline, r=dtolnay
Matthias Krüger [Fri, 28 Jan 2022 14:20:27 +0000 (15:20 +0100)]
Rollup merge of #93356 - pierwill:partialord-headline, r=dtolnay

Edit docs introduction for `std::cmp::PartialOrd`

This makes `PartialOrd` consistent with the other three traits in this module, which all include links to their corresponding mathematical concepts on Wikipedia.

<img width="500" alt="Screen Shot 2022-01-26 at 10 24 23 PM" src="https://user-images.githubusercontent.com/19642016/151291720-decd85ed-cd6e-4be0-84a9-619b98ceb386.png">

2 years agoRollup merge of #93353 - kellerkindt:saturating_int_assign_impl, r=joshtriplett
Matthias Krüger [Fri, 28 Jan 2022 14:20:26 +0000 (15:20 +0100)]
Rollup merge of #93353 - kellerkindt:saturating_int_assign_impl, r=joshtriplett

Unimpl {Add,Sub,Mul,Div,Rem,BitXor,BitOr,BitAnd}<$t> for Saturating<$t>

Tracking issue #92354

Analog to 9648b313cc8896970a12f45b3bb5c0593c3d510f #93208 reduce `saturating_int_assign_impl` (#93208) to:

```rust
let mut value = Saturating(2u8);
value += 3u8;
value -= 1u8;
value *= 2u8;
value /= 2u8;
value %= 2u8;
value ^= 255u8;
value |= 123u8;
value &= 2u8;
```

See https://github.com/rust-lang/rust/pull/93208#issuecomment-1022564429

2 years agoRollup merge of #93295 - ChrisDenton:tempdir-double-panic, r=dtolnay
Matthias Krüger [Fri, 28 Jan 2022 14:20:25 +0000 (15:20 +0100)]
Rollup merge of #93295 - ChrisDenton:tempdir-double-panic, r=dtolnay

Avoid double panics when using `TempDir` in tests

`TempDir` could panic on drop if `remove_dir_all` returns an error. If this happens while already panicking, the test process would abort and therefore not show the test results.

This PR tries to avoid such double panics.

2 years agoRollup merge of #93261 - bjorn3:cg_ssa_refactor6, r=cjgillot
Matthias Krüger [Fri, 28 Jan 2022 14:20:24 +0000 (15:20 +0100)]
Rollup merge of #93261 - bjorn3:cg_ssa_refactor6, r=cjgillot

Some unwinding related cg_ssa cleanups

These should make it a bit easier for alternative codegen backends to implement unwinding.

2 years agoRollup merge of #93239 - Thomasdezeeuw:socketaddr_creation, r=m-ou-se
Matthias Krüger [Fri, 28 Jan 2022 14:20:23 +0000 (15:20 +0100)]
Rollup merge of #93239 - Thomasdezeeuw:socketaddr_creation, r=m-ou-se

Add os::unix::net::SocketAddr::from_path

Creates a new SocketAddr from a path, supports both regular paths and
abstract namespaces.

Note that `SocketAddr::from_abstract_namespace` could be removed after this as `SocketAddr::unix` also supports abstract namespaces.

Updates #65275
Unblocks https://github.com/tokio-rs/mio/issues/1527

r? `@m-ou-se`

2 years agoRollup merge of #93158 - haraldh:wasi_sock_accept, r=dtolnay
Matthias Krüger [Fri, 28 Jan 2022 14:20:22 +0000 (15:20 +0100)]
Rollup merge of #93158 - haraldh:wasi_sock_accept, r=dtolnay

wasi: implement `sock_accept` and enable networking

With the addition of `sock_accept()` to snapshot1, simple networking via a passed `TcpListener` is possible. This PR implements the basics to make a simple server work.

See also:
* [wasmtime tracking issue](https://github.com/bytecodealliance/wasmtime/issues/3730)
* [wasmtime PR](https://github.com/bytecodealliance/wasmtime/pull/3711)

TODO:
* [ ] Discussion of `SocketAddr` return value for `::accept()`

```rust
        Ok((
            TcpStream::from_inner(unsafe { Socket::from_raw_fd(fd as _) }),
            // WASI has no concept of SocketAddr yet
            // return an unspecified IPv4Addr
            SocketAddr::new(Ipv4Addr::UNSPECIFIED.into(), 0),
        ))
```

2 years agoRollup merge of #92611 - Amanieu:asm-reference, r=m-ou-se
Matthias Krüger [Fri, 28 Jan 2022 14:20:21 +0000 (15:20 +0100)]
Rollup merge of #92611 - Amanieu:asm-reference, r=m-ou-se

Add links to the reference and rust by example for asm! docs and lints

These were previously removed in #91728 due to broken links.

cc ``@ehuss`` since this updates the rust-by-example submodule

2 years agofix nit
lcnr [Fri, 28 Jan 2022 14:02:47 +0000 (15:02 +0100)]
fix nit

2 years agoUpdate tracking issue for unix_socket_creation
Thomas de Zeeuw [Fri, 28 Jan 2022 14:00:17 +0000 (15:00 +0100)]
Update tracking issue for unix_socket_creation

2 years agoAuto merge of #93006 - michaelwoerister:fix-unsized-ptr-debuginfo, r=davidtwco,oli-obk
bors [Fri, 28 Jan 2022 12:46:13 +0000 (12:46 +0000)]
Auto merge of #93006 - michaelwoerister:fix-unsized-ptr-debuginfo, r=davidtwco,oli-obk

Fix debuginfo for pointers/references to unsized types

This PR makes the compiler emit fat pointer debuginfo in all cases. Before, we sometimes got thin-pointer debuginfo, making it impossible to fully interpret the pointed to memory in debuggers. The code is actually cleaner now, especially around generation of trait object pointer debuginfo.

Fixes https://github.com/rust-lang/rust/issues/92718

~~Blocked on https://github.com/rust-lang/rust/pull/92729.~~

2 years agowasi: enable TcpListener and TcpStream
Harald Hoyer [Fri, 21 Jan 2022 13:19:48 +0000 (14:19 +0100)]
wasi: enable TcpListener and TcpStream

With the addition of `sock_accept()` to snapshot1, simple networking via
a passed `TcpListener` is possible. This patch implements the basics to
make a simple server work.

Signed-off-by: Harald Hoyer <harald@profian.com>
2 years agowasi: update to wasi 0.11.0
Harald Hoyer [Fri, 21 Jan 2022 13:19:13 +0000 (14:19 +0100)]
wasi: update to wasi 0.11.0

To make use of `sock_accept()`, update the wasi crate to `0.11.0`.

Signed-off-by: Harald Hoyer <harald@profian.com>
2 years agoAuto merge of #90677 - bobrippling:suggest-tuple-parens, r=camelid
bors [Fri, 28 Jan 2022 09:46:22 +0000 (09:46 +0000)]
Auto merge of #90677 - bobrippling:suggest-tuple-parens, r=camelid

Suggest tuple-parentheses for enum variants

This follows on from #86493 / #86481, making the parentheses suggestion. To summarise, given the following code:

```rust
fn f() -> Option<(i32, i8)> {
    Some(1, 2)
}
```

The current output is:

```
error[E0061]: this enum variant takes 1 argument but 2 arguments were supplied
 --> b.rs:2:5
  |
2 |     Some(1, 2)
  |     ^^^^ -  - supplied 2 arguments
  |     |
  |     expected 1 argument

error: aborting due to previous error

For more information about this error, try `rustc --explain E0061`.
```

With this change, `rustc` will now suggest parentheses when:
- The callee is expecting a single tuple argument
- The number of arguments passed matches the element count in the above tuple
- The arguments' types match the tuple's fields

```
error[E0061]: this enum variant takes 1 argument but 2 arguments were supplied
 --> b.rs:2:5
  |
2 |     Some(1, 2)
  |     ^^^^ -  - supplied 2 arguments
  |
help: use parentheses to construct a tuple
  |
2 |     Some((1, 2))
  |          +    +
```

2 years ago[debuginfo] Fix and unify handling of fat pointers in debuginfo: Don't mark fat point...
Michael Woerister [Fri, 28 Jan 2022 09:41:36 +0000 (10:41 +0100)]
[debuginfo] Fix and unify handling of fat pointers in debuginfo: Don't mark fat pointer fields as artificial.

LLDB does not seem to see fields if they are marked with DW_AT_artificial
which breaks pretty printers that use these fields for decoding fat pointers.

2 years agoAdd a test case for using NonNull::new in const context
woppopo [Fri, 28 Jan 2022 09:41:35 +0000 (18:41 +0900)]
Add a test case for using NonNull::new in const context

2 years agotest_const_allocate_at_runtime
woppopo [Fri, 28 Jan 2022 08:27:33 +0000 (17:27 +0900)]
test_const_allocate_at_runtime

2 years agoEdit docs introduction for `std::cmp::PartialOrd`
pierwill [Thu, 27 Jan 2022 02:57:46 +0000 (20:57 -0600)]
Edit docs introduction for `std::cmp::PartialOrd`

This makes `PartialOrd` consistent with the other three traits in this
module, which all include links to their respective mathematical concepts
on Wikipedia.

2 years agoAuto merge of #93343 - lqd:attrs, r=spastorino
bors [Fri, 28 Jan 2022 06:28:08 +0000 (06:28 +0000)]
Auto merge of #93343 - lqd:attrs, r=spastorino

Only traverse attrs once while checking for coherence override attributes

In coherence, while checking for negative impls override attributes: only traverse the `DefId`s' attributes once.

This PR is an easy way to get back some of the small perf loss in #93175

2 years agokmc-solid: Implement `FileDesc::duplicate`
Tomoaki Kawada [Fri, 28 Jan 2022 05:53:54 +0000 (14:53 +0900)]
kmc-solid: Implement `FileDesc::duplicate`

2 years agofix typo `documenation`
Kvicii [Fri, 28 Jan 2022 02:26:49 +0000 (10:26 +0800)]
fix typo `documenation`

2 years agoFix a typo from #92899
scottmcm [Fri, 28 Jan 2022 01:35:33 +0000 (01:35 +0000)]
Fix a typo from #92899

Just happened to notice this in passing

2 years agoAuto merge of #93376 - flip1995:clippyup, r=Manishearth
bors [Fri, 28 Jan 2022 01:33:00 +0000 (01:33 +0000)]
Auto merge of #93376 - flip1995:clippyup, r=Manishearth

Update Clippy

r? `@Manishearth`

2 years agorustbuild: Fix compiletest warning when building outside of root.
Eric Huss [Thu, 27 Jan 2022 23:57:38 +0000 (15:57 -0800)]
rustbuild: Fix compiletest warning when building outside of root.

2 years agoAuto merge of #93390 - matthiaskrgr:rollup-4xeki5w, r=matthiaskrgr
bors [Thu, 27 Jan 2022 22:34:34 +0000 (22:34 +0000)]
Auto merge of #93390 - matthiaskrgr:rollup-4xeki5w, r=matthiaskrgr

Rollup of 8 pull requests

Successful merges:

 - #91641 (Define c_char using cfg_if rather than repeating 40-line cfg)
 - #92899 (Mention std::iter::zip in Iterator::zip docs)
 - #93193 (Add test for stable hash uniqueness of adjacent field values)
 - #93325 (Introduce a limit to Levenshtein distance computation)
 - #93339 (rustdoc: add test case for multiple traits and erased names)
 - #93357 (Clarify the `usage-of-qualified-ty` error message.)
 - #93363 (`#[rustc_pass_by_value]` cleanup)
 - #93365 (More arena cleanups)

Failed merges:

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

2 years agoRollup merge of #93365 - nnethercote:more-arena-cleanups, r=oli-obk
Matthias Krüger [Thu, 27 Jan 2022 21:32:30 +0000 (22:32 +0100)]
Rollup merge of #93365 - nnethercote:more-arena-cleanups, r=oli-obk

More arena cleanups

A sequel to #90990.

r? `@oli-obk`

2 years agoRollup merge of #93363 - lcnr:pass-by-value, r=petrochenkov
Matthias Krüger [Thu, 27 Jan 2022 21:32:29 +0000 (22:32 +0100)]
Rollup merge of #93363 - lcnr:pass-by-value, r=petrochenkov

`#[rustc_pass_by_value]` cleanup

2 years agoRollup merge of #93357 - nnethercote:clarify-usage-of-qualified-ty, r=lcnr
Matthias Krüger [Thu, 27 Jan 2022 21:32:28 +0000 (22:32 +0100)]
Rollup merge of #93357 - nnethercote:clarify-usage-of-qualified-ty, r=lcnr

Clarify the `usage-of-qualified-ty` error message.

I found this message confusing when I encountered it. This commit makes
it clearer that you have to import the unqualified type yourself.

r? `@lcnr`

2 years agoRollup merge of #93339 - notriddle:notriddle/test-generics-multi-trait, r=GuillaumeGomez
Matthias Krüger [Thu, 27 Jan 2022 21:32:27 +0000 (22:32 +0100)]
Rollup merge of #93339 - notriddle:notriddle/test-generics-multi-trait, r=GuillaumeGomez

rustdoc: add test case for multiple traits and erased names

https://github.com/rust-lang/rust/pull/92339#discussion_r792805289

2 years agoRollup merge of #93325 - tmiasko:lev, r=davidtwco
Matthias Krüger [Thu, 27 Jan 2022 21:32:26 +0000 (22:32 +0100)]
Rollup merge of #93325 - tmiasko:lev, r=davidtwco

Introduce a limit to Levenshtein distance computation

Incorporate distance limit from `find_best_match_for_name` directly into
Levenshtein distance computation.

Use the string size difference as a lower bound on the distance and exit
early when it exceeds the specified limit.

After finding a candidate within a limit, lower the limit further to
restrict the search space.

2 years agoRollup merge of #93193 - Kobzol:stable-hash-permutation-test, r=the8472
Matthias Krüger [Thu, 27 Jan 2022 21:32:24 +0000 (22:32 +0100)]
Rollup merge of #93193 - Kobzol:stable-hash-permutation-test, r=the8472

Add test for stable hash uniqueness of adjacent field values

This PR adds a simple test to check that stable hash will produce a different hash if the order of two values that have the same combined bit pattern changes.

r? `@the8472`

2 years agoRollup merge of #92899 - cameron1024:zip-docs, r=dtolnay
Matthias Krüger [Thu, 27 Jan 2022 21:32:23 +0000 (22:32 +0100)]
Rollup merge of #92899 - cameron1024:zip-docs, r=dtolnay

Mention std::iter::zip in Iterator::zip docs

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

I'm not sure about the wording. I think it's alright, but happy to change.

2 years agoRollup merge of #91641 - dtolnay:cchar-if, r=Mark-Simulacrum
Matthias Krüger [Thu, 27 Jan 2022 21:32:23 +0000 (22:32 +0100)]
Rollup merge of #91641 - dtolnay:cchar-if, r=Mark-Simulacrum

Define c_char using cfg_if rather than repeating 40-line cfg

Libstd has a 40-line cfg that defines the targets on which `c_char` is unsigned, and then repeats the same cfg with `not(…)` for the targets on which `c_char` is signed.

This PR replaces it with a `cfg_if!` in which an `else` takes care of the signed case.

I confirmed that `x.py doc library/std` inlines the type alias because c_char_definition is not a publicly accessible path:

![Screenshot from 2021-12-07 13-42-07](https://user-images.githubusercontent.com/1940490/145110596-f1058406-9f32-44ff-9a81-1dfd19b4a24f.png)

2 years agoTouch up PR 92899 Iterator::zip docs
David Tolnay [Thu, 27 Jan 2022 20:41:03 +0000 (12:41 -0800)]
Touch up PR 92899 Iterator::zip docs

2 years agoClarify `ArenaAllocatable`'s second parameter.
Nicholas Nethercote [Tue, 25 Jan 2022 23:46:40 +0000 (10:46 +1100)]
Clarify `ArenaAllocatable`'s second parameter.

It's simply a binary thing to allow different behaviour for `Copy` vs
`!Copy` types. The new code makes this much clearer; I was scratching my
head over the old code for some time.

2 years agoAdd some comments.
Nicholas Nethercote [Tue, 25 Jan 2022 23:33:41 +0000 (10:33 +1100)]
Add some comments.

2 years ago[debuginfo] Fix and unify handling of fat pointers in debuginfo: Change doc comment...
Michael Woerister [Thu, 27 Jan 2022 15:55:48 +0000 (16:55 +0100)]
[debuginfo] Fix and unify handling of fat pointers in debuginfo: Change doc comment so it is not interpreted as doc-test.

2 years agoMerge commit 'a98e7ab8b94485be6bd03e0c6b8682ecab5b52e6' into clippyup
flip1995 [Thu, 27 Jan 2022 14:12:45 +0000 (15:12 +0100)]
Merge commit 'a98e7ab8b94485be6bd03e0c6b8682ecab5b52e6' into clippyup

2 years agofix typo `documenation`
Kvicii [Thu, 27 Jan 2022 14:07:17 +0000 (22:07 +0800)]
fix typo `documenation`

2 years agoAuto merge of #8359 - flip1995:rustup, r=flip1995
bors [Thu, 27 Jan 2022 13:48:23 +0000 (13:48 +0000)]
Auto merge of #8359 - flip1995:rustup, r=flip1995

Rustup

r? `@ghost`

changelog: none

2 years agoBump nightly version -> 2022-01-27
flip1995 [Thu, 27 Jan 2022 13:23:42 +0000 (14:23 +0100)]
Bump nightly version -> 2022-01-27

2 years agoMerge remote-tracking branch 'upstream/master' into rustup
flip1995 [Thu, 27 Jan 2022 13:23:31 +0000 (14:23 +0100)]
Merge remote-tracking branch 'upstream/master' into rustup

2 years ago[debuginfo] Fix and unify handling of fat pointers in debuginfo: Fix some debuginfo...
Michael Woerister [Tue, 25 Jan 2022 11:14:17 +0000 (12:14 +0100)]
[debuginfo] Fix and unify handling of fat pointers in debuginfo: Fix some debuginfo tests for old GDB versions and 32-bit targets.

2 years agotry apply `rustc_pass_by_value` to `Span`
lcnr [Thu, 27 Jan 2022 07:17:13 +0000 (08:17 +0100)]
try apply `rustc_pass_by_value` to `Span`

2 years agoUse sockaddr_un in unix SocketAddr::from_path
Thomas de Zeeuw [Thu, 27 Jan 2022 08:54:28 +0000 (09:54 +0100)]
Use sockaddr_un in unix SocketAddr::from_path

2 years agoMake sockaddr_un safe and use copy_nonoverlapping
Thomas de Zeeuw [Thu, 27 Jan 2022 08:52:59 +0000 (09:52 +0100)]
Make sockaddr_un safe and use copy_nonoverlapping

The creation of libc::sockaddr_un is a safe operation, no need for it to
be unsafe.

This also uses the more performant copy_nonoverlapping instead of an
iterator.

2 years agoupdate pass_by_value
lcnr [Thu, 27 Jan 2022 06:58:33 +0000 (07:58 +0100)]
update pass_by_value

2 years agomention std::iter::zip in Iterator::zip docs
cameron [Thu, 27 Jan 2022 06:47:52 +0000 (06:47 +0000)]
mention std::iter::zip in Iterator::zip docs

2 years agoClarify the `usage-of-qualified-ty` error message.
Nicholas Nethercote [Thu, 27 Jan 2022 00:10:37 +0000 (11:10 +1100)]
Clarify the `usage-of-qualified-ty` error message.

I found this message confusing when I encountered it. This commit makes
it clearer that you have to import the unqualified type yourself.

2 years agoAuto merge of #92889 - tmiasko:unbounded-recursion, r=ecstatic-morse
bors [Thu, 27 Jan 2022 06:21:53 +0000 (06:21 +0000)]
Auto merge of #92889 - tmiasko:unbounded-recursion, r=ecstatic-morse

Ignore unwinding edges when checking for unconditional recursion

The unconditional recursion lint determines if all execution paths
eventually lead to a self-recursive call.

The implementation always follows unwinding edges which limits its
practical utility. For example, it would not lint function `f` because a
call to `g` might unwind. It also wouldn't lint function `h` because an
overflow check preceding the self-recursive call might unwind:

```rust
pub fn f() {
    g();
    f();
}

pub fn g() { /* ... */ }

pub fn h(a: usize) {
  h(a + 1);
}
```

To avoid the issue, assume that terminators that might continue
execution along non-unwinding edges do so.

Fixes #78474.

2 years agoAuto merge of #93081 - nikic:aarch64-fix, r=cuviper
bors [Thu, 27 Jan 2022 01:53:24 +0000 (01:53 +0000)]
Auto merge of #93081 - nikic:aarch64-fix, r=cuviper

Update LLVM submodule

Update LLVM to fix #92786.

2 years agoAuto merge of #93352 - matthiaskrgr:rollup-5peret4, r=matthiaskrgr
bors [Wed, 26 Jan 2022 22:54:26 +0000 (22:54 +0000)]
Auto merge of #93352 - matthiaskrgr:rollup-5peret4, r=matthiaskrgr

Rollup of 7 pull requests

Successful merges:

 - #90247 (Improve Duration::try_from_secs_f32/64 accuracy by directly processing exponent and mantissa)
 - #91861 (Replace iterator-based construction of collections by `Into<T>`)
 - #92098 (add OpenBSD platform-support page)
 - #92134 (Add x86_64-pc-windows-msvc linker-plugin-lto instructions)
 - #92256 (Improve selection errors for `~const` trait bounds)
 - #92778 (fs: Use readdir() instead of readdir_r() on Linux and Android)
 - #93338 (Update minifier crate version to 0.0.42)

Failed merges:

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

2 years agoUnimpl {Add,Sub,Mul,Div,Rem,BitXor,BitOr,BitAnd}<$t> for Saturating<$t>
Michael Watzko [Wed, 26 Jan 2022 21:00:26 +0000 (22:00 +0100)]
Unimpl {Add,Sub,Mul,Div,Rem,BitXor,BitOr,BitAnd}<$t> for Saturating<$t>

Analog to 9648b313cc8896970a12f45b3bb5c0593c3d510f #93208

2 years agoRollup merge of #93338 - GuillaumeGomez:update-minifier, r=notriddle
Matthias Krüger [Wed, 26 Jan 2022 22:45:24 +0000 (23:45 +0100)]
Rollup merge of #93338 - GuillaumeGomez:update-minifier, r=notriddle

Update minifier crate version to 0.0.42

Some issues on the CSS minification.

r? `@notriddle`

2 years agoRollup merge of #92778 - tavianator:linux-readdir-no-r, r=joshtriplett
Matthias Krüger [Wed, 26 Jan 2022 22:45:23 +0000 (23:45 +0100)]
Rollup merge of #92778 - tavianator:linux-readdir-no-r, r=joshtriplett

fs: Use readdir() instead of readdir_r() on Linux and Android

See #40021 for more details.  Fixes #86649.  Fixes #34668.

2 years agoRollup merge of #92256 - fee1-dead:improve-selection-err, r=oli-obk
Matthias Krüger [Wed, 26 Jan 2022 22:45:22 +0000 (23:45 +0100)]
Rollup merge of #92256 - fee1-dead:improve-selection-err, r=oli-obk

Improve selection errors for `~const` trait bounds

2 years agoRollup merge of #92134 - nico-abram:patch-1, r=michaelwoerister
Matthias Krüger [Wed, 26 Jan 2022 22:45:21 +0000 (23:45 +0100)]
Rollup merge of #92134 - nico-abram:patch-1, r=michaelwoerister

Add x86_64-pc-windows-msvc linker-plugin-lto instructions

I had some trouble getting cross language LTO working for this target, in part because the very few links of documentation I could find were linux-centric and because of a few very specific errors I ran into. I'm not sure if this is the correct place to document this, but this is one of the first links I found when looking for documentation so it might be the best place for it.

2 years agoRollup merge of #92098 - semarie:openbsd-platform, r=pietroalbini
Matthias Krüger [Wed, 26 Jan 2022 22:45:20 +0000 (23:45 +0100)]
Rollup merge of #92098 - semarie:openbsd-platform, r=pietroalbini

add OpenBSD platform-support page

It mentions x86_64, i686, aarch64 and sparc64 which are actively maintained and used on OpenBSD (binaries provided by standard package distribution on OpenBSD).

I volontary kept `powerpc-unknown-openbsd` unmentioned as it was added by `@Yn0ga` in #82733, and I am unaware if it is functional or not (I doubt as I added libc support only few days ago, and std `c_char` signess was wrong). `@Yn0ga` maybe you comment on your `powerpc-unknown-openbsd` usage ?

2 years agoRollup merge of #91861 - juniorbassani:use-from-array-in-collections-examples, r...
Matthias Krüger [Wed, 26 Jan 2022 22:45:19 +0000 (23:45 +0100)]
Rollup merge of #91861 - juniorbassani:use-from-array-in-collections-examples, r=yaahc

Replace iterator-based construction of collections by `Into<T>`

Just a few quality of life improvements in the doc examples. I also removed some `Vec`s in favor of arrays.

2 years agoRollup merge of #90247 - newpavlov:duration_float_fract, r=nagisa
Matthias Krüger [Wed, 26 Jan 2022 22:45:18 +0000 (23:45 +0100)]
Rollup merge of #90247 - newpavlov:duration_float_fract, r=nagisa

Improve Duration::try_from_secs_f32/64 accuracy by directly processing exponent and mantissa

Closes: #90225
The methods now implement direct processing of exponent and mantissa, which should result in the best possible conversion accuracy (modulo truncation, i.e. float value of 19.995 ns will be represented as 19 ns).

2 years agorustdoc: add test case for multiple traits and erased names
Michael Howell [Wed, 26 Jan 2022 16:24:36 +0000 (09:24 -0700)]
rustdoc: add test case for multiple traits and erased names

https://github.com/rust-lang/rust/pull/92339#discussion_r792805289

2 years agoAuto merge of #93301 - spastorino:perf-test-1, r=oli-obk
bors [Wed, 26 Jan 2022 19:45:09 +0000 (19:45 +0000)]
Auto merge of #93301 - spastorino:perf-test-1, r=oli-obk

Store hir_id_to_def_id in OwnerInfo.

This is for perf test purposes only. Related to #89278

2 years agoAuto merge of #8350 - dswij:8331, r=Manishearth
bors [Wed, 26 Jan 2022 19:19:28 +0000 (19:19 +0000)]
Auto merge of #8350 - dswij:8331, r=Manishearth

fix bad suggestion on `numeric_literal`

closes #8331

changelog: [`numeric_literal`]  fix suggestion not showing sign

2 years agoOnly traverse attrs once while checking for coherence override
Rémy Rakic [Wed, 26 Jan 2022 17:32:02 +0000 (18:32 +0100)]
Only traverse attrs once while checking for coherence override

2 years agoUpdate minifier crate version to 0.0.42
Guillaume Gomez [Wed, 26 Jan 2022 16:24:34 +0000 (17:24 +0100)]
Update minifier crate version to 0.0.42

2 years agoFilter out local_id == 0, those are already considered on the call site
Santiago Pastorino [Wed, 26 Jan 2022 12:53:17 +0000 (09:53 -0300)]
Filter out local_id == 0, those are already considered on the call site

2 years agoBless incremental tests.
Camille GILLOT [Sun, 26 Sep 2021 12:37:23 +0000 (14:37 +0200)]
Bless incremental tests.

2 years agoImprove Duration::try_from_secs_f32/64 accuracy by directly processing exponent and...
Артём Павлов [Artyom Pavlov] [Wed, 26 Jan 2022 15:14:25 +0000 (18:14 +0300)]
Improve Duration::try_from_secs_f32/64 accuracy by directly processing exponent and mantissa

2 years agoIgnore unwinding edges when checking for unconditional recursion
Tomasz Miąsko [Fri, 14 Jan 2022 00:00:00 +0000 (00:00 +0000)]
Ignore unwinding edges when checking for unconditional recursion

The unconditional recursion lint determines if all execution paths
eventually lead to a self-recursive call.

The implementation always follows unwinding edges which limits its
practical utility. For example, it would not lint function `f` because a
call to `g` might unwind. It also wouldn't lint function `h` because an
overflow check preceding the self-recursive call might unwind:

```rust
pub fn f() {
    g();
    f();
}

pub fn g() { /* ... */ }

pub fn h(a: usize) {
  h(a + 1);
}
```

To avoid the issue, assume that terminators that might continue
execution along non-unwinding edges do so.

2 years agoAuto merge of #91840 - JakobDegen:fix_early_otherwise, r=oli-obk
bors [Wed, 26 Jan 2022 12:10:54 +0000 (12:10 +0000)]
Auto merge of #91840 - JakobDegen:fix_early_otherwise, r=oli-obk

Fix the unsoundness in the `early_otherwise_branch` mir opt pass

Closes #78496 .

This change is a significant rewrite of much of the pass. Exactly what it does is documented in the source file (with ascii art!), and all the changes that are made to the MIR that are not trivially sound are carefully documented. That being said, this is my first time touching MIR, so there are probably some invariants I did not know about that I broke.

This version of the optimization is also somewhat more flexible than the original; for example, we do not care how or where the value on which the parent is switching is computed. There is no requirement that any types be the same. This could be made even more flexible in the future by allowing a wider range of statements in the bodies of `BBC, BBD` (as long as they are all the same of course). This should be a good first step though.

Probably needs a perf run.

r? `@oli-obk` who reviewed things the last time this was touched

2 years agoIntroduce a limit to Levenshtein distance computation
Tomasz Miąsko [Thu, 20 Jan 2022 00:00:00 +0000 (00:00 +0000)]
Introduce a limit to Levenshtein distance computation

Incorporate distance limit from `find_best_match_for_name` directly into
Levenshtein distance computation.

Use the string size difference as a lower bound on the distance and exit
early when it exceeds the specified limit.

After finding a candidate within a limit, lower the limit further to
restrict the search space.

2 years agoCheck namespace before computing the Levenshtein distance
Tomasz Miąsko [Mon, 17 Jan 2022 00:00:00 +0000 (00:00 +0000)]
Check namespace before computing the Levenshtein distance