]> git.lizzy.rs Git - rust.git/log
rust.git
3 years agoRollup merge of #76522 - matthiaskrgr:redundant_clone, r=jonas-schievink
Tyler Mandry [Wed, 9 Sep 2020 22:06:05 +0000 (15:06 -0700)]
Rollup merge of #76522 - matthiaskrgr:redundant_clone, r=jonas-schievink

remove redundant clones

(clippy::redundant_clone)

3 years agoRollup merge of #76516 - pietroalbini:github-releases, r=Mark-Simulacrum
Tyler Mandry [Wed, 9 Sep 2020 22:06:04 +0000 (15:06 -0700)]
Rollup merge of #76516 - pietroalbini:github-releases, r=Mark-Simulacrum

Enable GitHub Releases synchronization

This PR enables the triagebot feature to automatically populate [GitHub Releases](https://github.com/rust-lang/rust/releases) for this repository based on the changelog. See https://github.com/rust-lang/triagebot/pull/811 for the implementation of this feature on triagebot's side, and more insights on how it works.

Note: once this lands people subscribed to the ~~firehose~~ rust-lang/rust repository will probably receive a ton of notifications for all the releases being created, but this should be a one-time thing.

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

3 years agoRollup merge of #76515 - jumbatm:issue76496-reproducibility-regression, r=oli-obk
Tyler Mandry [Wed, 9 Sep 2020 22:06:02 +0000 (15:06 -0700)]
Rollup merge of #76515 - jumbatm:issue76496-reproducibility-regression, r=oli-obk

SessionDiagnostic: Fix non-determinism in generated format string.

Fixes #76496.

r? @oli-obk

3 years agoRollup merge of #76504 - Flying-Toast:master, r=lcnr
Tyler Mandry [Wed, 9 Sep 2020 22:06:00 +0000 (15:06 -0700)]
Rollup merge of #76504 - Flying-Toast:master, r=lcnr

Capitalize safety comments

3 years agoRollup merge of #76493 - moonheart08:unique-quick, r=jyn514
Tyler Mandry [Wed, 9 Sep 2020 22:05:59 +0000 (15:05 -0700)]
Rollup merge of #76493 - moonheart08:unique-quick, r=jyn514

Remove a stray ignore-tidy-undocumented-unsafe

There were no undocumented unsafe blocks in the file. This shouldn't require any special review.

3 years agoRollup merge of #76481 - moonheart08:vec_deque_constify, r=sfackler
Tyler Mandry [Wed, 9 Sep 2020 22:05:56 +0000 (15:05 -0700)]
Rollup merge of #76481 - moonheart08:vec_deque_constify, r=sfackler

Convert repetitive target_pointer_width checks to const solution.

Simply a quick code tidying change. Not sure if more needs to be said.

3 years agoRollup merge of #76473 - ortem:fix-gcc-warning, r=jonas-schievink
Tyler Mandry [Wed, 9 Sep 2020 22:05:54 +0000 (15:05 -0700)]
Rollup merge of #76473 - ortem:fix-gcc-warning, r=jonas-schievink

Add missed spaces to GCC-WARNING.txt

3 years agoRollup merge of #76465 - jyn514:auto-versioning, r=elichai
Tyler Mandry [Wed, 9 Sep 2020 22:05:53 +0000 (15:05 -0700)]
Rollup merge of #76465 - jyn514:auto-versioning, r=elichai

Add a script to automatically update Rust/Clang versions in documentation

From https://github.com/rust-lang/rust/pull/76402#issuecomment-687974508.

r? @elichai

3 years agoRollup merge of #76430 - pickfire:patch-7, r=steveklabnik
Tyler Mandry [Wed, 9 Sep 2020 22:05:51 +0000 (15:05 -0700)]
Rollup merge of #76430 - pickfire:patch-7, r=steveklabnik

Add align to rustc-attrs unstable book

3 years agoRollup merge of #76313 - richkadel:mir-spanview-2, r=wesleywiser
Tyler Mandry [Wed, 9 Sep 2020 22:05:49 +0000 (15:05 -0700)]
Rollup merge of #76313 - richkadel:mir-spanview-2, r=wesleywiser

Improved the MIR spanview output

* Adds missing "tail" spans (spans that continue beyond the end of
overlapping spans)
* Adds a caret to highlight empty spans associated with MIR elements
that have a position, but otherwise would not be visible.
* Adds visual pointing brackets at the beginning and end of each span

<img width="590" alt="Screen Shot 2020-09-03 at 8 38 08 PM" src="https://user-images.githubusercontent.com/3827298/92202571-25510c00-ee34-11ea-89bc-89eea939476d.png">
<img width="1061" alt="Screen Shot 2020-09-03 at 8 41 04 PM" src="https://user-images.githubusercontent.com/3827298/92202629-49145200-ee34-11ea-8fda-fc6e62c80736.png">
<img width="1113" alt="Screen Shot 2020-09-06 at 5 42 57 PM" src="https://user-images.githubusercontent.com/3827298/92339198-ca085f00-f069-11ea-96d1-c01ced50e2ba.png">
<img width="1692" alt="Screen Shot 2020-09-06 at 5 45 54 PM" src="https://user-images.githubusercontent.com/3827298/92339209-d4c2f400-f069-11ea-94c0-b4d36c200878.png">

r? @tmandry
FYI: @wesleywiser

3 years agoRollup merge of #76141 - jyn514:config.toml, r=Mark-Simulacrum
Tyler Mandry [Wed, 9 Sep 2020 22:05:47 +0000 (15:05 -0700)]
Rollup merge of #76141 - jyn514:config.toml, r=Mark-Simulacrum

Address review comments about config.toml from rustc-dev-guide PR

This info was lost in https://github.com/rust-lang/rust/pull/74334. See also https://github.com/rust-lang/rustc-dev-guide/pull/795#pullrequestreview-478197674.
r? @Mark-Simulacrum or @eddyb

3 years agoRollup merge of #75984 - kornelski:typeormodule, r=matthewjasper
Tyler Mandry [Wed, 9 Sep 2020 22:05:45 +0000 (15:05 -0700)]
Rollup merge of #75984 - kornelski:typeormodule, r=matthewjasper

Improve unresolved use error message

"use of undeclared type or module `foo`" doesn't mention that it could be a crate.

This error can happen when users forget to add a dependency to `Cargo.toml`, so I think it's important to mention that it could be a missing crate.

I've used a heuristic based on Rust's naming conventions. It complains about an unknown type if the ident starts with an upper-case letter, and crate or module otherwise. It seems to work very well. The expanded error help covers both an unknown type and a missing crate case.

3 years agoRollup merge of #75094 - 0dvictor:cgu, r=oli-obk
Tyler Mandry [Wed, 9 Sep 2020 22:05:43 +0000 (15:05 -0700)]
Rollup merge of #75094 - 0dvictor:cgu, r=oli-obk

Add `-Z combine_cgu` flag

Introduce a compiler option to let rustc combines all regular CGUs into a single one at the end of compilation.

Part of Issue #64191

3 years agoAuto merge of #74595 - lcnr:ConstEvaluatable-fut-compat, r=oli-obk
bors [Wed, 9 Sep 2020 20:04:04 +0000 (20:04 +0000)]
Auto merge of #74595 - lcnr:ConstEvaluatable-fut-compat, r=oli-obk

make `ConstEvaluatable` more strict

relevant zulip discussion: https://rust-lang.zulipchat.com/#narrow/stream/146212-t-compiler.2Fconst-eval/topic/.60ConstEvaluatable.60.20generic.20functions/near/204125452

Let's see how much this impacts. Depending on how this goes this should probably be a future compat warning.

Short explanation: we currently forbid anonymous constants which depend on generic types, e.g. `[0; std::mem::size_of::<T>]` currently errors.

We previously checked this by evaluating the constant and returned an error if that failed. This however allows things like
```rust
const fn foo<T>() -> usize {
    if std::mem::size_of::<*mut T>() < 8 { // size of *mut T does not depend on T
        std::mem::size_of::<T>()
    } else {
        8
    }
}

fn test<T>() {
    let _ = [0; foo::<T>()];
}
```
which is a backwards compatibility hazard. This also has worrying interactions with mir optimizations (https://github.com/rust-lang/rust/pull/74491#issuecomment-661890421) and intrinsics (#74538).

r? `@oli-obk` `@eddyb`

3 years agofix test on 32 bit systems
Bastian Kauschke [Wed, 9 Sep 2020 18:10:23 +0000 (20:10 +0200)]
fix test on 32 bit systems

3 years agoAuto merge of #73971 - ssomers:slice_slasher, r=Mark-Simulacrum
bors [Wed, 9 Sep 2020 17:40:46 +0000 (17:40 +0000)]
Auto merge of #73971 - ssomers:slice_slasher, r=Mark-Simulacrum

BTreeMap mutable iterators should not take any reference to visited nodes during iteration

Fixes #73915, overlapping mutable references during BTreeMap iteration

r? `@RalfJung`

3 years agoremove redundant clones
Matthias Krüger [Wed, 9 Sep 2020 14:32:55 +0000 (16:32 +0200)]
remove redundant clones

(clippy::redundant_clone)

3 years agoAuto merge of #76445 - jyn514:doctests, r=Mark-Simulacrum,ollie27
bors [Wed, 9 Sep 2020 13:33:01 +0000 (13:33 +0000)]
Auto merge of #76445 - jyn514:doctests, r=Mark-Simulacrum,ollie27

Make rustdoc output deterministic for UI tests

Closes https://github.com/rust-lang/rust/issues/76442 (hopefully, since it's non-deterministic I don't have a way to test).

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

3 years agoBTreeMap: avoid aliasing by avoiding slices
Stein Somers [Sun, 16 Aug 2020 17:07:30 +0000 (19:07 +0200)]
BTreeMap: avoid aliasing by avoiding slices

3 years agomake as_leaf return a raw pointer, to reduce aliasing assumptions
Ralf Jung [Thu, 2 Jul 2020 08:36:56 +0000 (10:36 +0200)]
make as_leaf return a raw pointer, to reduce aliasing assumptions

3 years agoAuto merge of #76513 - rust-lang:rust-analyzer-2020-09-09, r=jonas-schievink
bors [Wed, 9 Sep 2020 11:28:17 +0000 (11:28 +0000)]
Auto merge of #76513 - rust-lang:rust-analyzer-2020-09-09, r=jonas-schievink

:arrow_up: rust-analyzer

r? `@ghost`

3 years agoFix non-determinism in generated format string.
jumbatm [Wed, 9 Sep 2020 11:23:25 +0000 (21:23 +1000)]
Fix non-determinism in generated format string.

3 years ago:arrow_up: rust-analyzer
Jonas Schievink [Wed, 9 Sep 2020 10:41:32 +0000 (12:41 +0200)]
:arrow_up: rust-analyzer

3 years agoAuto merge of #76406 - GuillaumeGomez:create-e0774, r=pickfire,jyn514
bors [Wed, 9 Sep 2020 08:23:33 +0000 (08:23 +0000)]
Auto merge of #76406 - GuillaumeGomez:create-e0774, r=pickfire,jyn514

Create E0774

3 years agoAdd `-Z combine_cgu` flag
Victor Ding [Wed, 9 Sep 2020 04:51:16 +0000 (14:51 +1000)]
Add `-Z combine_cgu` flag

Introduce a compiler option to let rustc combines all regular CGUs into
a single one at the end of compilation.

Part of Issue #64191

3 years agoAuto merge of #76463 - camelid:improve-E0607-explanation, r=jyn514
bors [Wed, 9 Sep 2020 06:33:03 +0000 (06:33 +0000)]
Auto merge of #76463 - camelid:improve-E0607-explanation, r=jyn514

Improve wording of E0607 explanation

`@rustbot` modify labels: A-diagnostics C-enhancement

3 years agoAuto merge of #76453 - camelid:fix-css-crate-list, r=GuillaumeGomez,ollie27
bors [Wed, 9 Sep 2020 04:35:40 +0000 (04:35 +0000)]
Auto merge of #76453 - camelid:fix-css-crate-list, r=GuillaumeGomez,ollie27

rustdoc: Fix font CSS for crate lists

I had put it in the wrong file in #76126. This should fix it now. Thank
you to `@ollie27` for pointing this out!

---

`@rustbot` modify labels: T-rustdoc C-bug

3 years agoAuto merge of #76418 - jyn514:readme, r=Dylan-DPC
bors [Wed, 9 Sep 2020 02:40:27 +0000 (02:40 +0000)]
Auto merge of #76418 - jyn514:readme, r=Dylan-DPC

Move sections about contributing closer together in the README

This makes it easier to find what to do if you're interested in contributing.

3 years agoCapitalize safety comments
Flying-Toast [Wed, 9 Sep 2020 02:37:18 +0000 (22:37 -0400)]
Capitalize safety comments

3 years agoCapitalize safety comments
Flying-Toast [Wed, 9 Sep 2020 02:26:44 +0000 (22:26 -0400)]
Capitalize safety comments

3 years agoAuto merge of #76502 - Dylan-DPC:rollup-2c4zz0t, r=Dylan-DPC
bors [Wed, 9 Sep 2020 00:08:13 +0000 (00:08 +0000)]
Auto merge of #76502 - Dylan-DPC:rollup-2c4zz0t, r=Dylan-DPC

Rollup of 10 pull requests

Successful merges:

 - #76162 (Make duration_since documentation more clear)
 - #76355 (remove public visibility previously needed for rustfmt)
 - #76374 (Improve ayu doc source line number contrast)
 - #76379 (rustbuild: Remove `Mode::Codegen`)
 - #76389 (Fix HashMap visualizers in Visual Studio (Code))
 - #76396 (Fix typo in tracking issue template)
 - #76401 (Add help note to unconstrained const parameter)
 - #76402 (Update linker-plugin-lto.md to contain up to rust 1.46)
 - #76403 (Fix documentation for TyCtxt::all_impls)
 - #76498 (Update cargo)

Failed merges:

 - #76458 (Add drain_filter method to HashMap and HashSet)

r? `@ghost`

3 years agoRollup merge of #76498 - ehuss:update-cargo, r=ehuss
Dylan DPC [Tue, 8 Sep 2020 23:35:26 +0000 (01:35 +0200)]
Rollup merge of #76498 - ehuss:update-cargo, r=ehuss

Update cargo

8 commits in 126907a7cfccbe93778530e6a6bbaa3adb6c515c..875e0123259b0b6299903fe4aea0a12ecde9324f
2020-08-31 20:42:11 +0000 to 2020-09-08 20:17:21 +0000
- Lowercase and remove periods in error messages for consistency (rust-lang/cargo#8655)
- Allow running build-man.sh from any directory (rust-lang/cargo#8682)
- docs: add details for cargo check pass where cargo build fail (rust-lang/cargo#8677)
- Fix nightly exported_priv_warning test. (rust-lang/cargo#8678)
- fix mdbook test with ```ignore/text/sh/console (rust-lang/cargo#8674)
- End CACHEDIR.TAG with newline (rust-lang/cargo#8672)
- Fixed the fossil repo initialization actually run commands (rust-lang/cargo#8671)
- Remove asciidoc attribute in cargo-metadata man page. (rust-lang/cargo#8670)

3 years agoRollup merge of #76403 - scileo:doc-all-impls, r=lcnr
Dylan DPC [Tue, 8 Sep 2020 23:35:23 +0000 (01:35 +0200)]
Rollup merge of #76403 - scileo:doc-all-impls, r=lcnr

Fix documentation for TyCtxt::all_impls

`TyCtxt::all_impls` documentation was wrong about the return type.

3 years agoRollup merge of #76402 - elichai:patch-2, r=wesleywiser
Dylan DPC [Tue, 8 Sep 2020 23:35:22 +0000 (01:35 +0200)]
Rollup merge of #76402 - elichai:patch-2, r=wesleywiser

Update linker-plugin-lto.md to contain up to rust 1.46

Hi,
this is the same as https://github.com/rust-lang/rust/pull/72290, if anyone has suggestions on how to automate this please say :)
otherwise, you can check the versions I've added via:

```sh
$ rustup install 1.44.0
$ rustc +1.44.0 -Vv
rustc 1.44.0 (49cae5576 2020-06-01)
binary: rustc
commit-hash: 49cae55760da0a43428eba73abcb659bb70cf2e4
commit-date: 2020-06-01
host: x86_64-unknown-linux-gnu
release: 1.44.0
LLVM version: 9.0

$ rustup install 1.45.0
$ rustc +1.45.0 -Vv
rustc 1.45.0 (5c1f21c3b 2020-07-13)
binary: rustc
commit-hash: 5c1f21c3b82297671ad3ae1e8c942d2ca92e84f2
commit-date: 2020-07-13
host: x86_64-unknown-linux-gnu
release: 1.45.0
LLVM version: 10.0

$ rustup install 1.46.0
$ rustc +stable -Vv
rustc 1.46.0 (04488afe3 2020-08-24)
binary: rustc
commit-hash: 04488afe34512aa4c33566eb16d8c912a3ae04f9
commit-date: 2020-08-24
host: x86_64-unknown-linux-gnu
release: 1.46.0
LLVM version: 10.0
```

3 years agoRollup merge of #76401 - JulianKnodt:i68366, r=lcnr
Dylan DPC [Tue, 8 Sep 2020 23:35:20 +0000 (01:35 +0200)]
Rollup merge of #76401 - JulianKnodt:i68366, r=lcnr

Add help note to unconstrained const parameter

Resolves #68366, since it is currently intended behaviour.
If demonstrating `T -> U` is injective, there should be an additional word that it is not **yet** supported.

r? @lcnr

3 years agoRollup merge of #76396 - dylni:fix-typo-in-tracking-issue-template, r=jonas-schievink
Dylan DPC [Tue, 8 Sep 2020 23:35:18 +0000 (01:35 +0200)]
Rollup merge of #76396 - dylni:fix-typo-in-tracking-issue-template, r=jonas-schievink

Fix typo in tracking issue template

3 years agoRollup merge of #76389 - MaulingMonkey:pr-natvis-hashmap-vsc, r=petrochenkov
Dylan DPC [Tue, 8 Sep 2020 23:35:17 +0000 (01:35 +0200)]
Rollup merge of #76389 - MaulingMonkey:pr-natvis-hashmap-vsc, r=petrochenkov

Fix HashMap visualizers in Visual Studio (Code)

CDB (as used in unit tests) doesn't care that we're using static_cast between unrelated types (`u8*` to `tuple<$T1, $T2>*`).
Visual Studio & Visual Studio Code care.  These should've been reinterpret_cast or C casts.

Credit to @petrochenkov per https://github.com/rust-lang/rust/issues/76352 for helping catch this.

### Testing

```cmd
x.py test --stage 1 src/tools/tidy
x.py test --stage 1 --build x86_64-pc-windows-msvc src\test\debuginfo
```

3 years agoRollup merge of #76379 - petrochenkov:nodegen, r=Mark-Simulacrum
Dylan DPC [Tue, 8 Sep 2020 23:35:15 +0000 (01:35 +0200)]
Rollup merge of #76379 - petrochenkov:nodegen, r=Mark-Simulacrum

rustbuild: Remove `Mode::Codegen`

It's no longer used.

3 years agoRollup merge of #76374 - pickfire:patch-4, r=Cldfire
Dylan DPC [Tue, 8 Sep 2020 23:35:13 +0000 (01:35 +0200)]
Rollup merge of #76374 - pickfire:patch-4, r=Cldfire

Improve ayu doc source line number contrast

Improve contrast of foreground line number.

Before

![image](https://user-images.githubusercontent.com/4687791/92305696-1bf2ab80-efbc-11ea-8b5c-a24c4f6261e0.png)

After

![image](https://user-images.githubusercontent.com/4687791/92305700-2a40c780-efbc-11ea-9061-dbfcb1e71980.png)

r? @Cldfire

I think we should add the line for light and dark theme too, it looks better and clearer that way.

3 years agoRollup merge of #76355 - calebcartwright:reduce-rustfmt-visibility, r=nikomatsakis
Dylan DPC [Tue, 8 Sep 2020 23:35:11 +0000 (01:35 +0200)]
Rollup merge of #76355 - calebcartwright:reduce-rustfmt-visibility, r=nikomatsakis

remove public visibility previously needed for rustfmt

`submod_path_from_attr` in rustc_expand::module was previously public because it was also consumed by rustfmt. However, we've done a bit of refactoring in rustfmt and no longer need to use this function.

This changes the visibility to the parent mod as was originally going to be done before the rustfmt dependency was realized (https://github.com/rust-lang/rust/commit/c189565edc5c9fc516170885b3a3061b936205fb#diff-cd1b379893bae95f7991d5a3f3c6d337R201)

3 years agoRollup merge of #76162 - abrausch:documentation-fix-duration_since, r=jyn514
Dylan DPC [Tue, 8 Sep 2020 23:35:10 +0000 (01:35 +0200)]
Rollup merge of #76162 - abrausch:documentation-fix-duration_since, r=jyn514

Make duration_since documentation more clear

3 years agoUpdate cargo
Eric Huss [Tue, 8 Sep 2020 22:10:21 +0000 (15:10 -0700)]
Update cargo

3 years agoMake duration_since documentation more clear
Alexander Brausch [Mon, 31 Aug 2020 14:20:24 +0000 (16:20 +0200)]
Make duration_since documentation more clear

3 years agoRemove a stray ignore-tidy-undocumented-unsafe
moonheart08 [Tue, 8 Sep 2020 20:00:47 +0000 (15:00 -0500)]
Remove a stray ignore-tidy-undocumented-unsafe
There were no undocumented unsafe blocks in the file.

3 years agoUpdate tests
Guillaume Gomez [Sat, 5 Sep 2020 12:55:15 +0000 (14:55 +0200)]
Update tests

3 years agoCreate new E0774 code error
Guillaume Gomez [Sat, 5 Sep 2020 12:55:08 +0000 (14:55 +0200)]
Create new E0774 code error

3 years agoUpdate library/alloc/src/collections/vec_deque.rs
Braden Nelson [Tue, 8 Sep 2020 18:11:08 +0000 (13:11 -0500)]
Update library/alloc/src/collections/vec_deque.rs

Replace lshift with multiply

Co-authored-by: Mara Bos <m-ou.se@m-ou.se>
3 years agoAuto merge of #76332 - Mark-Simulacrum:bootstrap-llvm, r=pietroalbini
bors [Tue, 8 Sep 2020 16:01:26 +0000 (16:01 +0000)]
Auto merge of #76332 - Mark-Simulacrum:bootstrap-llvm, r=pietroalbini

Add rust-dev component to support rustc development

This is preparatory work for permitting rustc developers to use CI-built LLVM rather than building it locally. Unlike distro-built LLVM, CI built LLVM is essentially guaranteed to behave perfectly for local development -- it is fully up to date, and carries all necessary patches.

This is a separate PR from #76349 because it needs to land before that one, since we want a master build with the full CI LLVM to be available for easier testing.

3 years agoConvert MAXIMUM_ZST_CAPACITY to be calculated in a
moonheart08 [Tue, 8 Sep 2020 15:35:35 +0000 (10:35 -0500)]
Convert MAXIMUM_ZST_CAPACITY to be calculated in a
const instead of multiple target_pointer_width checks.

3 years agofix test
Bastian Kauschke [Tue, 8 Sep 2020 14:47:19 +0000 (16:47 +0200)]
fix test

3 years agoadd tracking issue, fix rebase
Bastian Kauschke [Tue, 1 Sep 2020 14:17:41 +0000 (16:17 +0200)]
add tracking issue, fix rebase

3 years agoadd tests
Bastian Kauschke [Thu, 6 Aug 2020 20:32:12 +0000 (22:32 +0200)]
add tests

3 years agoreview
Bastian Kauschke [Thu, 6 Aug 2020 20:12:21 +0000 (22:12 +0200)]
review

3 years agoconvert to future compat lint
Bastian Kauschke [Thu, 6 Aug 2020 08:48:36 +0000 (10:48 +0200)]
convert to future compat lint

3 years agomake `ConstEvaluatable` more strict
Bastian Kauschke [Thu, 6 Aug 2020 08:00:08 +0000 (10:00 +0200)]
make `ConstEvaluatable` more strict

3 years agoAuto merge of #76469 - RalfJung:miri, r=RalfJung
bors [Tue, 8 Sep 2020 11:56:09 +0000 (11:56 +0000)]
Auto merge of #76469 - RalfJung:miri, r=RalfJung

update Miri

Fixes https://github.com/rust-lang/rust/issues/76337
r? `@ghost` Cc `@rust-lang/miri`

3 years agoAuto merge of #76308 - wesleywiser:enable_simplifyarmidentity_mir_opt, r=oli-obk
bors [Tue, 8 Sep 2020 09:27:23 +0000 (09:27 +0000)]
Auto merge of #76308 - wesleywiser:enable_simplifyarmidentity_mir_opt, r=oli-obk

Enable the SimplifyArmIdentity MIR optimization at mir-opt-level=1

r? `@ghost`

3 years agoAdd missed spaces to GCC-WARNING.txt
ortem [Tue, 8 Sep 2020 09:20:49 +0000 (12:20 +0300)]
Add missed spaces to GCC-WARNING.txt

3 years agoupdate Miri
Ralf Jung [Tue, 8 Sep 2020 08:50:52 +0000 (10:50 +0200)]
update Miri

3 years agotriagebot: enable github releases synchronization
Pietro Albini [Tue, 8 Sep 2020 08:43:52 +0000 (10:43 +0200)]
triagebot: enable github releases synchronization

3 years agoAuto merge of #76423 - Mark-Simulacrum:stable-bootstrap, r=jyn514
bors [Tue, 8 Sep 2020 07:08:50 +0000 (07:08 +0000)]
Auto merge of #76423 - Mark-Simulacrum:stable-bootstrap, r=jyn514

Make bootstrap build on beta

This is generally a good idea, and will help with being able to build bootstrap
without Python over time as it means we can "just" build with cargo +beta build
rather than needing the user to set environment variables. This is a minor step,
but a necessary one on that road.

r? `@jyn514`

3 years agoAuto merge of #75585 - RalfJung:demotion, r=oli-obk
bors [Tue, 8 Sep 2020 05:13:42 +0000 (05:13 +0000)]
Auto merge of #75585 - RalfJung:demotion, r=oli-obk

Do not promote &mut of a non-ZST ever

Since ~pre-1.0~ 1.36, we have accepted code like this:
```rust
static mut TEST: &'static mut [i32] = {
    let x = &mut [1,2,3];
    x
};
```
I tracked it back to https://github.com/rust-lang/rust/pull/21744, but unfortunately could not find any discussion or RFC that would explain why we thought this was a good idea. And it's not, it breaks all sorts of things -- see https://github.com/rust-lang/rust/issues/75556.

To fix https://github.com/rust-lang/rust/issues/75556, we have to stop promoting non-ZST mutable references no matter the context, which is what this PR does. It's a breaking change.

Notice that this still works, since it does not rely on promotion:
```rust
static mut TEST: &'static mut [i32] = &mut [0,1,2];
```

Cc `@rust-lang/wg-const-eval`

3 years agoAuto merge of #76210 - Mark-Simulacrum:tracing-update, r=oli-obk
bors [Tue, 8 Sep 2020 03:22:31 +0000 (03:22 +0000)]
Auto merge of #76210 - Mark-Simulacrum:tracing-update, r=oli-obk

Tracing update

This does not bring the more significant changes that are coming down the pipeline, but since I've already prepared the PR leaving it up :)

See https://github.com/rust-lang/rust/pull/76210#issuecomment-685065938:
> Unfortunately, tracing 0.1.20 — which contained the change to reduce the amount of code generated by the tracing macros — had to be yanked, as it broke previously-compiling code for some downstream crates. I've not yet had the chance to fix this and release a new patch. So, in order to benefit from the changes to reduce generated code, you'll need to wait until there's a new version of tracing as well as tracing-attributes and tracing-core.

3 years agoAdd a script to automatically update Rust/Clang versions
Joshua Nelson [Tue, 8 Sep 2020 02:06:23 +0000 (22:06 -0400)]
Add a script to automatically update Rust/Clang versions

3 years agoAdd "For example,"
Camelid [Tue, 8 Sep 2020 01:48:22 +0000 (18:48 -0700)]
Add "For example,"

3 years agoImprove wording of E0607 explanation
Camelid [Tue, 8 Sep 2020 01:25:14 +0000 (18:25 -0700)]
Improve wording of E0607 explanation

3 years agoUnstable book rust-attrs does not work on generics
Ivan Tham [Tue, 8 Sep 2020 01:08:25 +0000 (09:08 +0800)]
Unstable book rust-attrs does not work on generics

Co-authored-by: Peter Todd <pete@petertodd.org>
3 years agoAuto merge of #75138 - jumbatm:session-diagnostic-derive, r=oli-obk
bors [Tue, 8 Sep 2020 00:58:43 +0000 (00:58 +0000)]
Auto merge of #75138 - jumbatm:session-diagnostic-derive, r=oli-obk

Add derive macro for specifying diagnostics using attributes.

Introduces `#[derive(SessionDiagnostic)]`, a derive macro for specifying structs that can be converted to Diagnostics using directions given by attributes on the struct and its fields. Currently, the following attributes have been implemented:
- `#[code = "..."]` -- this sets the Diagnostic's error code, and must be provided on the struct iself (ie, not on a field). Equivalent to calling `code`.
- `#[message = "..."]` -- this sets the Diagnostic's primary error message.
- `#[label = "..."]` -- this must be applied to fields of type `Span`, and is equivalent to `span_label`
- `#[suggestion(..)]` -- this allows a suggestion message to be supplied. This attribute must be applied to a field of type `Span` or `(Span, Applicability)`, and is equivalent to calling `span_suggestion`. Valid arguments are:
    - `message = "..."` -- this sets the suggestion message.
    - (Optional) `code = "..."` -- this suggests code for the suggestion. Defaults to empty.

`suggestion`also  comes with other variants: `#[suggestion_short(..)]`, `#[suggestion_hidden(..)]` and `#[suggestion_verbose(..)]` which all take the same keys.

Within the strings passed to each attribute, fields can be referenced without needing to be passed explicitly into the format string -- eg, `#[error = "{ident} already declared"] ` will set the error message to `format!("{} already declared", &self.ident)`. Any fields on the struct can be referenced in this way.

Additionally, for any of these attributes, Option fields can be used to only optionally apply the decoration -- for example:

```rust
#[derive(SessionDiagnostic)]
#[code = "E0123"]
struct SomeKindOfError {
    ...
    #[suggestion(message = "informative error message")]
    opt_sugg: Option<(Span, Applicability)>
    ...
}
```
will not emit a suggestion if `opt_sugg` is `None`.

We plan on iterating on this macro further; this PR is a start.

Closes #61132.

r? `@oli-obk`

3 years agoMake rustdoc output deterministic for UI tests
Joshua Nelson [Tue, 8 Sep 2020 00:32:09 +0000 (20:32 -0400)]
Make rustdoc output deterministic for UI tests

3 years agoAuto merge of #76044 - ecstatic-morse:dataflow-lattice, r=oli-obk
bors [Mon, 7 Sep 2020 21:29:43 +0000 (21:29 +0000)]
Auto merge of #76044 - ecstatic-morse:dataflow-lattice, r=oli-obk

Support dataflow problems on arbitrary lattices

This PR implements last of the proposed extensions I mentioned in the design meeting for the original dataflow refactor. It extends the current dataflow framework to work with arbitrary lattices, not just `BitSet`s. This is a prerequisite for dataflow-enabled MIR const-propagation. Personally, I am skeptical of the usefulness of doing const-propagation pre-monomorphization, since many useful constants only become known after monomorphization (e.g. `size_of::<T>()`) and users have a natural tendency to hand-optimize the rest. It's probably worth exprimenting with, however, and others have shown interest cc `@rust-lang/wg-mir-opt.`

The `Idx` associated type is moved from `AnalysisDomain` to `GenKillAnalysis` and replaced with an associated `Domain` type that must implement `JoinSemiLattice`. Like before, each `Analysis` defines the "bottom value" for its domain, but can no longer override the dataflow join operator. Analyses that want to use set intersection must now use the `lattice::Dual` newtype. `GenKillAnalysis` impls have an additional requirement that `Self::Domain: BorrowMut<BitSet<Self::Idx>>`, which effectively means that they must use `BitSet<Self::Idx>` or `lattice::Dual<BitSet<Self::Idx>>` as their domain.

Most of these changes were mechanical. However, because a `Domain` is no longer always a powerset of some index type, we can no longer use an `IndexVec<BasicBlock, GenKillSet<A::Idx>>>` to store cached block transfer functions. Instead, we use a boxed `dyn Fn` trait object. I discuss a few alternatives to the current approach in a commit message.

The majority of new lines of code are to preserve existing Graphviz diagrams for those unlucky enough to have to debug dataflow analyses. I find these diagrams incredibly useful when things are going wrong and considered regressing them unacceptable, especially the pretty-printing of `MovePathIndex`s, which are used in many dataflow analyses. This required a parallel `fmt` trait used only for printing dataflow domains, as well as a refactoring of the `graphviz` module now that we cannot expect the domain to be a `BitSet`. Some features did have to be removed, such as the gen/kill display mode (which I didn't use but existed to mirror the output of the old dataflow framework) and line wrapping. Since I had to rewrite much of it anyway, I took the opportunity to switch to a `Visitor` for printing dataflow state diffs instead of using cursors, which are error prone for code that must be generic over both forward and backward analyses. As a side-effect of this change, we no longer have quadratic behavior when writing graphviz diagrams for backward dataflow analyses.

r? `@pnkfelix`

3 years agorustdoc: Fix font CSS for crate lists
Camelid [Mon, 7 Sep 2020 20:54:31 +0000 (13:54 -0700)]
rustdoc: Fix font CSS for crate lists

I had put it in the wrong file in #76126. This should fix it now. Thank
you to @ollie27 for pointing this out!

3 years agoAdd regression test and help note
kadmin [Sun, 6 Sep 2020 04:34:20 +0000 (04:34 +0000)]
Add regression test and help note

3 years agoDedicated rust development tarball
Mark Rousskov [Fri, 4 Sep 2020 17:59:14 +0000 (13:59 -0400)]
Dedicated rust development tarball

This currently includes libLLVM, llvm-config, and FileCheck, but will perhaps
expand to more tooling overtime. It should be considered entirely unstable and
may change at any time.

3 years agoAuto merge of #74366 - t-rapp:tr-bufreader-pos, r=LukasKalbertodt
bors [Mon, 7 Sep 2020 11:09:41 +0000 (11:09 +0000)]
Auto merge of #74366 - t-rapp:tr-bufreader-pos, r=LukasKalbertodt

Implement Seek::stream_position() for BufReader

Optimization over `BufReader::seek()` for getting the current position without flushing the internal buffer.

Related to #31100. Based on the code in #70577.

3 years agoAuto merge of #76395 - dylni:adjust-documentation-for-slice-check-range, r=jyn514
bors [Mon, 7 Sep 2020 09:16:46 +0000 (09:16 +0000)]
Auto merge of #76395 - dylni:adjust-documentation-for-slice-check-range, r=jyn514

Adjust documentation for slice_check_range

Adjust documentation for #76393.

3 years agoImplement Seek::stream_position() for BufReader
Tobias Rapp [Tue, 1 Sep 2020 07:22:35 +0000 (09:22 +0200)]
Implement Seek::stream_position() for BufReader

Optimization over BufReader::seek() for getting the current position
without flushing the internal buffer.

Related to #31100. Based on code in #70577.

3 years agoAdd align to rustc-attrs unstable book
Ivan Tham [Mon, 7 Sep 2020 07:10:31 +0000 (15:10 +0800)]
Add align to rustc-attrs unstable book

3 years agoAuto merge of #76368 - ayushmishra2005:move_str_contact_library, r=jyn514
bors [Mon, 7 Sep 2020 05:20:46 +0000 (05:20 +0000)]
Auto merge of #76368 - ayushmishra2005:move_str_contact_library, r=jyn514

Added str tests in library

Added str tests in library  as a part of #76268

r? @matklad

3 years agoAuto merge of #76409 - jonas-schievink:fix-r-a-on-libcore, r=Mark-Simulacrum
bors [Mon, 7 Sep 2020 02:20:44 +0000 (02:20 +0000)]
Auto merge of #76409 - jonas-schievink:fix-r-a-on-libcore, r=Mark-Simulacrum

Remove unneeded `#[cfg(not(test))]` from libcore

This fixes rust-analyzer inside these modules (currently it does not analyze them, assuming they're configured out).

3 years agoImproved the MIR spanview output
Rich Kadel [Fri, 4 Sep 2020 03:31:18 +0000 (20:31 -0700)]
Improved the MIR spanview output

* Adds missing "tail" spans (spans that continue beyond the end of
overlapping spans)
* Adds a caret to highlight empty spans associated with MIR elements
that have a position, but otherwise would not be visible.
* Adds visual pointing brackets at the beginning and end of each span

3 years agoMake bootstrap build on stable
Mark Rousskov [Sun, 6 Sep 2020 23:38:26 +0000 (19:38 -0400)]
Make bootstrap build on stable

This is generally a good idea, and will help with being able to build bootstrap
without Python over time as it means we can "just" build with cargo +beta build
rather than needing the user to set environment variables. This is a minor step,
but a necessary one on that road.

3 years agoAuto merge of #76422 - Dylan-DPC:rollup-0579ucb, r=Dylan-DPC
bors [Mon, 7 Sep 2020 00:33:47 +0000 (00:33 +0000)]
Auto merge of #76422 - Dylan-DPC:rollup-0579ucb, r=Dylan-DPC

Rollup of 18 pull requests

Successful merges:

 - #76273 (Move some Vec UI tests into alloc unit tests)
 - #76274 (Allow try blocks as the argument to return expressions)
 - #76287 (Remove an unnecessary allowed lint)
 - #76293 (Implementation of incompatible features error)
 - #76299 (Make `Ipv4Addr` and `Ipv6Addr` const tests unit tests under `library`)
 - #76302 (Address review comments on `Peekable::next_if`)
 - #76303 (Link to `#capacity-and-reallocation` when using with_capacity)
 - #76305 (Move various ui const tests to `library`)
 - #76309 (Indent a note to make folding work nicer)
 - #76312 (time.rs: Make spelling of "Darwin" consistent)
 - #76318 (Use ops::ControlFlow in rustc_data_structures::graph::iterate)
 - #76324 (Move Vec slice UI tests in library)
 - #76338 (add some intra-doc links to `Iterator`)
 - #76340 (Remove unused duplicated `trivial_dropck_outlives`)
 - #76344 (Improve docs for `std::env::args()`)
 - #76346 (Docs: nlink example typo)
 - #76358 (Minor grammar fix in doc comment for soft-deprecated methods)
 - #76364 (Disable atomics on avr target.)

Failed merges:

 - #76304 (Make delegation methods of `std::net::IpAddr` unstably const)

r? @ghost

3 years agoRollup merge of #76364 - fusion-engineering-forks:avr-no-atomic, r=jonas-schievink
Dylan DPC [Sun, 6 Sep 2020 23:18:17 +0000 (01:18 +0200)]
Rollup merge of #76364 - fusion-engineering-forks:avr-no-atomic, r=jonas-schievink

Disable atomics on avr target.

`max_atomic_width` was missing in the spec, which means it fell back to the pointer width of 16 bits.

Fixes #76363.

3 years agoRollup merge of #76358 - Wilfred:patch-3, r=lcnr
Dylan DPC [Sun, 6 Sep 2020 23:18:15 +0000 (01:18 +0200)]
Rollup merge of #76358 - Wilfred:patch-3, r=lcnr

Minor grammar fix in doc comment for soft-deprecated methods

3 years agoRollup merge of #76346 - gillespiecd:nlinks-docs, r=Dylan-DPC
Dylan DPC [Sun, 6 Sep 2020 23:18:13 +0000 (01:18 +0200)]
Rollup merge of #76346 - gillespiecd:nlinks-docs, r=Dylan-DPC

Docs: nlink example typo

Small typo fix for the `nlink` function, extra whitespace before the `use` declaration

3 years agoRollup merge of #76344 - camelid:patch-6, r=KodrAus
Dylan DPC [Sun, 6 Sep 2020 23:18:12 +0000 (01:18 +0200)]
Rollup merge of #76344 - camelid:patch-6, r=KodrAus

Improve docs for `std::env::args()`

@rustbot modify labels: T-doc

3 years agoRollup merge of #76340 - jonas-schievink:rm-dupe, r=Mark-Simulacrum
Dylan DPC [Sun, 6 Sep 2020 23:18:10 +0000 (01:18 +0200)]
Rollup merge of #76340 - jonas-schievink:rm-dupe, r=Mark-Simulacrum

Remove unused duplicated `trivial_dropck_outlives`

The copy that is actually in use now lives here:

https://github.com/rust-lang/rust/blob/d2454643e137bde519786ee9e650c455d7ad6f34/compiler/rustc_trait_selection/src/traits/query/dropck_outlives.rs#L84

3 years agoRollup merge of #76338 - euclio:intra-link-iterator, r=jyn514
Dylan DPC [Sun, 6 Sep 2020 23:18:08 +0000 (01:18 +0200)]
Rollup merge of #76338 - euclio:intra-link-iterator, r=jyn514

add some intra-doc links to `Iterator`

3 years agoRollup merge of #76324 - ayushmishra2005:move_vec_tests_in_library, r=matklad
Dylan DPC [Sun, 6 Sep 2020 23:18:07 +0000 (01:18 +0200)]
Rollup merge of #76324 - ayushmishra2005:move_vec_tests_in_library, r=matklad

Move Vec slice UI tests in library

Moved some of Vec slice UI tests in Library as a part of #76268

r? @matklad

3 years agoRollup merge of #76318 - scottmcm:one-control-flow, r=ecstatic-morse
Dylan DPC [Sun, 6 Sep 2020 23:18:05 +0000 (01:18 +0200)]
Rollup merge of #76318 - scottmcm:one-control-flow, r=ecstatic-morse

Use ops::ControlFlow in rustc_data_structures::graph::iterate

Since I only know about this because you mentioned it,
r? @ecstatic-morse

If we're not supposed to use new `core` things in compiler for a while then feel free to close, but it felt reasonable to merge the two types since they're the same, and it might be convenient for people to use `?` in their traversal code.

(This doesn't do the type parameter swap; NoraCodes has signed up to do that one.)

3 years agoRollup merge of #76312 - numbermaniac:patch-1, r=shepmaster
Dylan DPC [Sun, 6 Sep 2020 23:18:03 +0000 (01:18 +0200)]
Rollup merge of #76312 - numbermaniac:patch-1, r=shepmaster

time.rs: Make spelling of "Darwin" consistent

On line 89 of this file, the OS name is written as "Darwin", but on line 162 it is written in all-caps. Darwin is usually spelt as a standard proper noun, i.e. "Darwin", rather than in all-caps.

This change makes that form consistent in both places.

3 years agoRollup merge of #76309 - lzutao:indent-note, r=jyn514
Dylan DPC [Sun, 6 Sep 2020 23:18:01 +0000 (01:18 +0200)]
Rollup merge of #76309 - lzutao:indent-note, r=jyn514

Indent a note to make folding work nicer

Sublime Text folds code based on indentation. It maybe an unnecessary change, but does it look nicer after that ?

3 years agoRollup merge of #76305 - CDirkx:const-tests, r=matklad
Dylan DPC [Sun, 6 Sep 2020 23:17:59 +0000 (01:17 +0200)]
Rollup merge of #76305 - CDirkx:const-tests, r=matklad

Move various ui const tests to `library`

Move:
 - `src\test\ui\consts\const-nonzero.rs` to `library\core`
 - `src\test\ui\consts\ascii.rs` to `library\core`
 - `src\test\ui\consts\cow-is-borrowed` to `library\alloc`

Part of #76268

r? @matklad

3 years agoRollup merge of #76303 - jyn514:vec-assert-doc, r=Dylan-DPC
Dylan DPC [Sun, 6 Sep 2020 23:17:56 +0000 (01:17 +0200)]
Rollup merge of #76303 - jyn514:vec-assert-doc, r=Dylan-DPC

Link to `#capacity-and-reallocation` when using with_capacity

Follow up to https://github.com/rust-lang/rust/pull/76058#discussion_r479655750.
r? @pickfire

3 years agoRollup merge of #76302 - jyn514:peekable-2, r=Dylan-DPC
Dylan DPC [Sun, 6 Sep 2020 23:17:54 +0000 (01:17 +0200)]
Rollup merge of #76302 - jyn514:peekable-2, r=Dylan-DPC

Address review comments on `Peekable::next_if`

r? @pickfire
See https://github.com/rust-lang/rust/pull/72310#pullrequestreview-480895893 for context.

3 years agoRollup merge of #76299 - CDirkx:ip-tests, r=matklad
Dylan DPC [Sun, 6 Sep 2020 23:17:52 +0000 (01:17 +0200)]
Rollup merge of #76299 - CDirkx:ip-tests, r=matklad

Make `Ipv4Addr` and `Ipv6Addr` const tests unit tests under `library`

These tests are about the standard library, not the compiler itself, thus should live in `library`, see #76268.

3 years agoRollup merge of #76293 - Amjad50:incompatible_features_error, r=lcnr
Dylan DPC [Sun, 6 Sep 2020 23:17:50 +0000 (01:17 +0200)]
Rollup merge of #76293 - Amjad50:incompatible_features_error, r=lcnr

Implementation of incompatible features error

Proposal of a new error: Incompatible features

This error should happen if two features which are not compatible are used together.

For now the only incompatible features are `const_generics` and `min_const_generics`

fixes #76280

3 years agoRollup merge of #76287 - lzutao:rm-allowed, r=jyn514
Dylan DPC [Sun, 6 Sep 2020 23:17:48 +0000 (01:17 +0200)]
Rollup merge of #76287 - lzutao:rm-allowed, r=jyn514

Remove an unnecessary allowed lint

It is outdated.

3 years agoRollup merge of #76274 - scottmcm:fix-76271, r=petrochenkov
Dylan DPC [Sun, 6 Sep 2020 23:17:46 +0000 (01:17 +0200)]
Rollup merge of #76274 - scottmcm:fix-76271, r=petrochenkov

Allow try blocks as the argument to return expressions

Fixes #76271

I don't think this needs to be edition-aware (phew) since `return try` in 2015 is also the start of an expression, just with a struct literal instead of a block (`return try { x: 4, y: 5 }`).

3 years agoRollup merge of #76273 - CraftSpider:master, r=matklad
Dylan DPC [Sun, 6 Sep 2020 23:17:45 +0000 (01:17 +0200)]
Rollup merge of #76273 - CraftSpider:master, r=matklad

Move some Vec UI tests into alloc unit tests

A bit of work towards #76268, makes a number of the Vec UI tests that are simply running code into unit tests. Ensured that they are being run when testing liballoc locally.