]> git.lizzy.rs Git - rust.git/log
rust.git
4 years agoUse the appropriate number of type arguments in suggestion
Esteban Küber [Tue, 10 Dec 2019 17:01:06 +0000 (09:01 -0800)]
Use the appropriate number of type arguments in suggestion

4 years agoFix rebase
Esteban Küber [Sat, 16 Nov 2019 20:39:45 +0000 (12:39 -0800)]
Fix rebase

4 years agoDeduplicate logic
Esteban Küber [Wed, 30 Oct 2019 00:28:39 +0000 (17:28 -0700)]
Deduplicate logic

4 years agoPoint at method call when type annotations are needed
Esteban Küber [Tue, 29 Oct 2019 23:49:01 +0000 (16:49 -0700)]
Point at method call when type annotations are needed

4 years agoAuto merge of #66681 - Mark-Simulacrum:toolstate-into-bootstrap, r=pietroalbini
bors [Tue, 10 Dec 2019 16:50:45 +0000 (16:50 +0000)]
Auto merge of #66681 - Mark-Simulacrum:toolstate-into-bootstrap, r=pietroalbini

Move toolstate checking into bootstrap

This intends no functional changes, merely translates the spread of shell/python into Rust.

One problematic area that I'd like to avoid but wasn't quite able to figure out how is the master branch script which is still in bash/python -- I cared less about that since it is orthogonal to the actual checking that we're doing, though as-is we're duplicating some code across Rust and that script.

r? @kennytm or maybe @pietroalbini

4 years agoMove CI to new builtin check-toolstate
Mark Rousskov [Sat, 23 Nov 2019 23:08:49 +0000 (18:08 -0500)]
Move CI to new builtin check-toolstate

4 years agoAdd toolstate checking into bootstrap
Mark Rousskov [Sat, 23 Nov 2019 17:43:21 +0000 (12:43 -0500)]
Add toolstate checking into bootstrap

This is not yet actually used by CI, but implements the logic for
checking that tools are properly building on beta/stable and during beta
cutoff week.

This attempts to mirror the checking functionality in
src/ci/docker/x86_64-gnu-tools/checktools.sh, and called scripts. It
does not attempt to run the relevant steps (that functionality was
originally desired to be moved into bootstrap as well, but doing so
proved more difficult than expected).

This is intended as a way to centralize and make clearer the logic
involved in toolstate checking. In particular, the previous logic was
spread across numerous python and shell scripts in such a way that made
interpretation quite difficult.

4 years agoAuto merge of #66277 - peter-wilkins:impl-from-wider-non-zeros, r=SimonSapin
bors [Tue, 10 Dec 2019 10:11:37 +0000 (10:11 +0000)]
Auto merge of #66277 - peter-wilkins:impl-from-wider-non-zeros, r=SimonSapin

From<NonZero*> impls for wider NonZero types

Closes: https://github.com/rust-lang/rust/issues/66291
4 years agoAuto merge of #67039 - xfix:manually-implement-pin-traits, r=nikomatsakis
bors [Tue, 10 Dec 2019 06:52:45 +0000 (06:52 +0000)]
Auto merge of #67039 - xfix:manually-implement-pin-traits, r=nikomatsakis

Use deref target in Pin trait implementations

Using deref target instead of pointer itself avoids providing access to `&Rc<T>` for malicious implementations, which would allow calling `Rc::get_mut`.

This is a breaking change necessary due to unsoundness, however the impact of it should be minimal.

This only fixes the issue with malicious `PartialEq` implementations, other `Pin` soundness issues are still here.

See <https://internals.rust-lang.org/t/unsoundness-in-pin/11311/73> for more details.

4 years agoAuto merge of #67184 - tmandry:rollup-mzqxtck, r=tmandry
bors [Tue, 10 Dec 2019 02:41:00 +0000 (02:41 +0000)]
Auto merge of #67184 - tmandry:rollup-mzqxtck, r=tmandry

Rollup of 11 pull requests

Successful merges:

 - #66892 (Format libcore with rustfmt (including tests and benches))
 - #67106 (resolve: Resolve visibilities on fields with non-builtin attributes)
 - #67113 (Print the visibility in `print_variant`.)
 - #67115 (Simplify `check_decl_no_pat`.)
 - #67119 (libstd miri tests: avoid warnings)
 - #67125 (Added ExactSizeIterator bound to return types)
 - #67138 (Simplify `Layout::extend_packed`)
 - #67145 (fix miri step debug printing)
 - #67149 (Do not ICE #67123)
 - #67155 (Move `Layout`s instead of binding by reference)
 - #67169 (inline some common methods on OsStr)

Failed merges:

r? @ghost

4 years agoRollup merge of #67169 - lzutao:inline_osstr, r=nagisa
Tyler Mandry [Mon, 9 Dec 2019 22:33:15 +0000 (14:33 -0800)]
Rollup merge of #67169 - lzutao:inline_osstr, r=nagisa

inline some common methods on OsStr

Closes #67150

4 years agoRollup merge of #67155 - kraai:move-instead-of-binding-to-reference, r=cramertj
Tyler Mandry [Mon, 9 Dec 2019 22:33:13 +0000 (14:33 -0800)]
Rollup merge of #67155 - kraai:move-instead-of-binding-to-reference, r=cramertj

Move `Layout`s instead of binding by reference

4 years agoRollup merge of #67149 - JohnTitor:fix-ice-1, r=Dylan-DPC
Tyler Mandry [Mon, 9 Dec 2019 22:33:12 +0000 (14:33 -0800)]
Rollup merge of #67149 - JohnTitor:fix-ice-1, r=Dylan-DPC

Do not ICE #67123

Fixes #67123

r? @matthewjasper

4 years agoRollup merge of #67145 - RalfJung:miri-step, r=oli-obk
Tyler Mandry [Mon, 9 Dec 2019 22:33:10 +0000 (14:33 -0800)]
Rollup merge of #67145 - RalfJung:miri-step, r=oli-obk

fix miri step debug printing

r? @oli-obk

4 years agoRollup merge of #67138 - kraai:simplify-Layout-extend_packed, r=Amanieu
Tyler Mandry [Mon, 9 Dec 2019 22:33:09 +0000 (14:33 -0800)]
Rollup merge of #67138 - kraai:simplify-Layout-extend_packed, r=Amanieu

Simplify `Layout::extend_packed`

4 years agoRollup merge of #67125 - hashedone:master, r=petrochenkov
Tyler Mandry [Mon, 9 Dec 2019 22:33:08 +0000 (14:33 -0800)]
Rollup merge of #67125 - hashedone:master, r=petrochenkov

Added ExactSizeIterator bound to return types

Fixes #66865

4 years agoRollup merge of #67119 - RalfJung:miri-test-libstd, r=alexcrichton
Tyler Mandry [Mon, 9 Dec 2019 22:33:06 +0000 (14:33 -0800)]
Rollup merge of #67119 - RalfJung:miri-test-libstd, r=alexcrichton

libstd miri tests: avoid warnings

Ignore tests in a way that all the code still gets compiled, to get rid of all the "unused" warnings that otherwise show up when running the test suite in Miri.

4 years agoRollup merge of #67115 - Centril:simplify-check-decl-no-pat, r=davidtwco
Tyler Mandry [Mon, 9 Dec 2019 22:33:05 +0000 (14:33 -0800)]
Rollup merge of #67115 - Centril:simplify-check-decl-no-pat, r=davidtwco

Simplify `check_decl_no_pat`.

r? @davidtwco

4 years agoRollup merge of #67113 - Centril:enum-vis-pretty-fix, r=davidtwco
Tyler Mandry [Mon, 9 Dec 2019 22:33:03 +0000 (14:33 -0800)]
Rollup merge of #67113 - Centril:enum-vis-pretty-fix, r=davidtwco

Print the visibility in `print_variant`.

r? @davidtwco
cc @dtolnay for `syn` awareness.

4 years agoRollup merge of #67106 - petrochenkov:docerr, r=matthewjasper
Tyler Mandry [Mon, 9 Dec 2019 22:33:02 +0000 (14:33 -0800)]
Rollup merge of #67106 - petrochenkov:docerr, r=matthewjasper

resolve: Resolve visibilities on fields with non-builtin attributes

Follow-up to https://github.com/rust-lang/rust/pull/66669.

The first commit is primary (and also a backport candidate), the other ones are further cleanups.
In this case it's not strictly necessary to avoid reporting errors during speculative resolution because 1) all visibilities are resolved non-speculatively sooner or later and 2) error reporting infrastructure merges identical errors with identical spans anyway.

Fixes https://github.com/rust-lang/rust/issues/67006
r? @matthewjasper

4 years agoRollup merge of #66892 - dtolnay:fmt5, r=KodrAus
Tyler Mandry [Mon, 9 Dec 2019 22:33:00 +0000 (14:33 -0800)]
Rollup merge of #66892 - dtolnay:fmt5, r=KodrAus

Format libcore with rustfmt (including tests and benches)

Important: two small non-rustfmt changes that will need close review:

- I added `#[rustfmt::skip]` to two manually arranged tables in src/libcore/benches/ascii.rs; see first commit in the PR.
- I added `// ignore-tidy-filelength` to src/libcore/ptr/mod.rs because rustfmt puts it over tidy's 3000 line limit; see second commit in the PR. I filed #66891 to follow up on breaking up that file. For now though having it be formatted is more important than having it below the line limit.

---

As with my previous formatting PRs, I am avoiding causing merge conflicts in other PRs by only touches those files that are not involved in any currently open PR. Files that appear in new PRs between when this PR is opened and when it makes it to the top of the bors queue will be reverted from this PR.

The list of files involved in open PRs is determined by querying GitHub's GraphQL API [with this script](https://gist.github.com/dtolnay/aa9c34993dc051a4f344d1b10e4487e8).

With the list of files from the script in outstanding_files, the relevant commands were:

```
$ find src/libcore -name '*.rs' \
    | xargs rustfmt --edition=2018 --unstable-features --skip-children
$ rg libcore outstanding_files | xargs git checkout --
```

To confirm no funny business:

```
$ git checkout $THIS_COMMIT^
$ git show --pretty= --name-only $THIS_COMMIT \
    | xargs rustfmt --edition=2018 --unstable-features --skip-children
$ git diff $THIS_COMMIT  # there should be no difference
```

r? @Dylan-DPC

4 years agoAdded ExactSizeIterator bound to return types
Bartłomiej Kuras [Mon, 9 Dec 2019 16:38:24 +0000 (17:38 +0100)]
Added ExactSizeIterator bound to return types

This reverts commit d97379a96e594820b9e865ae56cb8d753bf6b06a.

4 years agoAuto merge of #67110 - tmandry:bump-compiler-builtins, r=alexcrichton
bors [Mon, 9 Dec 2019 19:42:48 +0000 (19:42 +0000)]
Auto merge of #67110 - tmandry:bump-compiler-builtins, r=alexcrichton

Bump compiler-builtins

- https://github.com/rust-lang/compiler-builtins/pull/306
- https://github.com/rust-lang/compiler-builtins/pull/309
- https://github.com/rust-lang/compiler-builtins/pull/310
- https://github.com/rust-lang/compiler-builtins/pull/311
- https://github.com/rust-lang/compiler-builtins/pull/312
- https://github.com/rust-lang/compiler-builtins/pull/313
- https://github.com/rust-lang/compiler-builtins/pull/315
- https://github.com/rust-lang/compiler-builtins/pull/317
- https://github.com/rust-lang/compiler-builtins/pull/323
- https://github.com/rust-lang/compiler-builtins/pull/324
- https://github.com/rust-lang/compiler-builtins/pull/328

Adds support for backtraces from `__rust_probestack` plus other goodies.

r? @alexcrichton

4 years agoresolve: Make visibility resolution more speculative
Vadim Petrochenkov [Fri, 6 Dec 2019 22:49:21 +0000 (01:49 +0300)]
resolve: Make visibility resolution more speculative

To avoid potential duplicate diagnostics and separate the error reporting logic

4 years agoresolve: Cleanup some field processing code
Vadim Petrochenkov [Fri, 6 Dec 2019 21:55:02 +0000 (00:55 +0300)]
resolve: Cleanup some field processing code

4 years agoresolve: Resolve visibilities on fields with non-builtin attributes
Vadim Petrochenkov [Fri, 6 Dec 2019 21:03:58 +0000 (00:03 +0300)]
resolve: Resolve visibilities on fields with non-builtin attributes

4 years agoAuto merge of #67096 - mark-i-m:fix-rustc-guide-2, r=ehuss
bors [Mon, 9 Dec 2019 14:07:20 +0000 (14:07 +0000)]
Auto merge of #67096 - mark-i-m:fix-rustc-guide-2, r=ehuss

Update rustc-guide

4 years agoAuto merge of #67016 - lqd:placeholder_loans, r=matthewjasper
bors [Mon, 9 Dec 2019 10:50:41 +0000 (10:50 +0000)]
Auto merge of #67016 - lqd:placeholder_loans, r=matthewjasper

In which we implement illegal subset relations errors using Polonius

This PR is the rustc side of implementing subset errors using Polonius. That is, in
```rust
fn foo<'a, 'b>(x: &'a u32, y: &'b u32) -> &'a u32 {
    y
}
```
returning `y` requires that `'b: 'a` but we have no evidence of that, so this is an error. (Evidence that the relation holds could come from explicit bounds, or via implied bounds).

Polonius outputs one such error per CFG point where the free region's placeholder loan unexpectedly flowed into another free region. While all these CFG locations could be useful in diagnostics in the future, rustc does not do that (and the duplication is only partially handled in the rest of the errors/diagnostics infrastructure, e.g. duplicate suggestions will be shown by the "outlives suggestions" or some of the `#[rustc_*]` NLL/MIR debug dumps), so I deduplicated the errors.

(The ordering also matters, otherwise some of the elided lifetime naming would change behaviour).

I've blessed a couple of tests, where the output is currently suboptimal:
- the `hrtb-perfect-forwarding` tests mix subset errors with higher-ranked subtyping, however the plan is for chalk to eventually take care of some of this to generate polonius constraints (i.e. it's not polonius' job). Until that happens, polonius will not see the error that NLL sees.
- some other tests have errors and diagnostics specific to `'static`, I _believe_ this to be because of it being treated as more "special" than in polonius. I believe the output is not wrong, but could be better, and appears elsewhere (I feel we'll need to look at polonius' handling of `'static` at some point in the future, maybe to match a bit more what NLL does when it produces errors)

I'll create a tracking issue in the polonius repo to record these 2 points (and a general "we'll need to go over the blessed output" issue, much like we did for NLLs)

The last blessed test is because it's an improvement: in this case, more errors/suggestions were computed, instead of the existing code path where this case apparently stops at the first error.

The `Naive` variant in Polonius computes those errors, so this PR also switches the default variant to that, as we're also in the process of temporarily deactivating all other variants (which exist mostly for performance considerations) until we have completed more work on completeness and correctness, before focusing on efficiency once again.

While most of the correctness in this PR is hidden in the polonius compare-mode (which of course passes locally), I've added a couple of smoke-tests to the existing ones, so that we have some confidence that it works (and keeps working) until we're in a position where we can run them on CI.

As mentioned during yesterday's wg-polonius meeting, @nikomatsakis has already read through most of this PR (and which is matching  what they thought needed to be done [during the recent Polonius sprint](https://hackmd.io/CGMNjt1hR_qYtsR9hgdGmw#Compiler-notes-on-generating-the-placeholder-loans-support)), but Matthew was hopefully going to review (again, not urgent), so:

r? @matthewjasper

(This updates to the latest `polonius-engine` release, and I'm not sure whether `Cargo.lock` updates can easily be rolled up, but apart from that: this changes little that's tested on CI, so seems safe-ish to rollup ?)

4 years agoinline some common methods on OsStr
Lzu Tao [Mon, 9 Dec 2019 10:39:57 +0000 (10:39 +0000)]
inline some common methods on OsStr

4 years agoDo not ICE on closure
Yuki Okushi [Sun, 8 Dec 2019 11:54:54 +0000 (20:54 +0900)]
Do not ICE on closure

4 years agoAuto merge of #67004 - estebank:issue-66958, r=eddyb
bors [Mon, 9 Dec 2019 05:16:48 +0000 (05:16 +0000)]
Auto merge of #67004 - estebank:issue-66958, r=eddyb

Do not ICE on async fn with non-Copy infered type arg

Fix #66958.

4 years agoAuto merge of #67003 - cjgillot:corrida, r=Mark-Simulacrum
bors [Mon, 9 Dec 2019 01:57:07 +0000 (01:57 +0000)]
Auto merge of #67003 - cjgillot:corrida, r=Mark-Simulacrum

Fix TypedArena returning wrong pointers for recursive allocations

Closes #67001

4 years agomove from non zero impls to `libcore/convert/num.rs`
Peter [Sun, 8 Dec 2019 23:16:18 +0000 (23:16 +0000)]
move from non zero impls to `libcore/convert/num.rs`

4 years agoAuto merge of #66984 - GuillaumeGomez:move-clean-types, r=kinnison
bors [Sun, 8 Dec 2019 22:44:01 +0000 (22:44 +0000)]
Auto merge of #66984 - GuillaumeGomez:move-clean-types, r=kinnison

Move clean types into their own file

This PR is just about moving clean types into their own files to make the code more clear and keep all `Clean` trait implementations on their own.

r? @kinnison

4 years agoAuto merge of #66981 - michaelwoerister:measureme-0.5.0, r=Mark-Simulacrum
bors [Sun, 8 Dec 2019 19:43:29 +0000 (19:43 +0000)]
Auto merge of #66981 - michaelwoerister:measureme-0.5.0, r=Mark-Simulacrum

Update measureme crate to 0.5.0

This PR updates the `measureme` self-profiling crate to the latest release. Heads up, this version changes the trace file format, so the `summarize` tool on perf.rlo needs to be updated to 0.5 too.

r? @Mark-Simulacrum
cc @wesleywiser

4 years agoAuto merge of #66730 - hermitcore:master, r=alexcrichton
bors [Sun, 8 Dec 2019 16:34:38 +0000 (16:34 +0000)]
Auto merge of #66730 - hermitcore:master, r=alexcrichton

remove dependency from libhermit

The build process of the unikernel HermitCore is redesigned and doesn't longer depend on libhermit.

4 years agoMove `Layout`s instead of binding by reference
Matthew Kraai [Sun, 8 Dec 2019 13:34:03 +0000 (08:34 -0500)]
Move `Layout`s instead of binding by reference

4 years agoAuto merge of #67147 - RalfJung:miri, r=RalfJung
bors [Sun, 8 Dec 2019 13:10:52 +0000 (13:10 +0000)]
Auto merge of #67147 - RalfJung:miri, r=RalfJung

update Miri

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

4 years agoupdate Miri
Ralf Jung [Sun, 8 Dec 2019 10:34:36 +0000 (11:34 +0100)]
update Miri

4 years agofix miri step debug printing
Ralf Jung [Sun, 8 Dec 2019 09:48:06 +0000 (10:48 +0100)]
fix miri step debug printing

4 years agoAuto merge of #67140 - Centril:rollup-h7rbw7y, r=Centril
bors [Sun, 8 Dec 2019 06:02:54 +0000 (06:02 +0000)]
Auto merge of #67140 - Centril:rollup-h7rbw7y, r=Centril

Rollup of 5 pull requests

Successful merges:

 - #66325 (Change unused_labels from allow to warn)
 - #66991 (Cleanup BodyCache)
 - #67101 (use `#[allow(unused_attributes)]` to paper over incr.comp problem)
 - #67114 (Make `ForeignItem` an alias of `Item`.)
 - #67129 (Fixes typo)

Failed merges:

 - #66886 (Remove the borrow check::nll submodule)

r? @ghost

4 years agoRollup merge of #67129 - remexre:patch-1, r=Dylan-DPC
Mazdak Farrokhzad [Sun, 8 Dec 2019 02:39:50 +0000 (03:39 +0100)]
Rollup merge of #67129 - remexre:patch-1, r=Dylan-DPC

Fixes typo

`legacy_disrectory_ownership` vs `legacy_directory_ownership`

4 years agoRollup merge of #67114 - Centril:foreign-item-alias, r=petrochenkov
Mazdak Farrokhzad [Sun, 8 Dec 2019 02:39:48 +0000 (03:39 +0100)]
Rollup merge of #67114 - Centril:foreign-item-alias, r=petrochenkov

Make `ForeignItem` an alias of `Item`.

Working towards the merging of items in AST and syntactically.

r? @petrochenkov

4 years agoRollup merge of #67101 - rust-lang:ostrich, r=Mark-Simulacrum
Mazdak Farrokhzad [Sun, 8 Dec 2019 02:39:47 +0000 (03:39 +0100)]
Rollup merge of #67101 - rust-lang:ostrich, r=Mark-Simulacrum

use `#[allow(unused_attributes)]` to paper over incr.comp problem

Paper over the problem in #58633.

r? @Mark-Simulacrum

4 years agoRollup merge of #66991 - Nashenas88:body_cache_cleanup, r=eddyb
Mazdak Farrokhzad [Sun, 8 Dec 2019 02:39:45 +0000 (03:39 +0100)]
Rollup merge of #66991 - Nashenas88:body_cache_cleanup, r=eddyb

Cleanup BodyCache

After this PR:

- `BodyCache` is renamed to `BodyAndCache`
- `ReadOnlyBodyCache` is renamed to `ReadOnlyBodyAndCache`
- `ReadOnlyBodyAndCache::body` fn is removed and all calls to it are replaced by a deref (possible due to fix of its `Deref` imp in #65947)

cc @eddyb @oli-obk

4 years agoRollup merge of #66325 - BartMassey:master, r=joshtriplett
Mazdak Farrokhzad [Sun, 8 Dec 2019 02:39:43 +0000 (03:39 +0100)]
Rollup merge of #66325 - BartMassey:master, r=joshtriplett

Change unused_labels from allow to warn

Fixes #66324, making the unused_labels lint warn instead of allow by default. I'm told @rust-lang/lang will need to review this, and perhaps will want to do a crater run.

4 years agoSimplify `Layout::extend_packed`
Matthew Kraai [Fri, 6 Dec 2019 17:09:56 +0000 (09:09 -0800)]
Simplify `Layout::extend_packed`

4 years agoleave a FIXME
Mazdak Farrokhzad [Fri, 6 Dec 2019 21:21:31 +0000 (22:21 +0100)]
leave a FIXME

4 years agouse `#[allow(unused_attributes)]` to paper over incr.comp problem
Mazdak Farrokhzad [Fri, 6 Dec 2019 21:17:32 +0000 (22:17 +0100)]
use `#[allow(unused_attributes)]` to paper over incr.comp problem

4 years agoAuto merge of #65881 - anp:implicit-caller-location, r=eddyb,oli-obk
bors [Sat, 7 Dec 2019 21:14:39 +0000 (21:14 +0000)]
Auto merge of #65881 - anp:implicit-caller-location, r=eddyb,oli-obk

Implement #[track_caller] attribute. (RFC 2091 4/N)

Implements the `#[track_caller]` attribute in both const and codegen contexts.

The const implementation walks up the stack to find the nearest untracked callsite.

The codegen implementation adds an implicit argument to tracked function calls, and populates it with either a call to the previously-landed intrinsic or if the caller has `#[track_caller]` with a copy of the location passed to the current function.

Also includes a little cleanup and a few comments in the other caller location areas.

[Depends on: 65664](https://github.com/rust-lang/rust/pull/65664)
[RFC 2091 text](https://github.com/rust-lang/rfcs/blob/master/text/2091-inline-semantic.md)
[Tracking issue](https://github.com/rust-lang/rust/issues/47809)
[Tracking doc](https://paper.dropbox.com/doc/track_rfc_2091_impl-notes--Anf1NwnIb0xcRv31YLIadyj0Ag-rwCdRc2fi2yvRZ7syGZ9q#:uid=863513134494965680023183&h2=TODO-actually-pass-location-to)

4 years agoFixes typo
Nathan Ringo [Sat, 7 Dec 2019 20:09:43 +0000 (14:09 -0600)]
Fixes typo

`legacy_disrectory_ownership` vs `legacy_directory_ownership`

4 years agoAdded ExactSizeIterator bound to return types
Bartłomiej Kuras [Sat, 7 Dec 2019 18:37:09 +0000 (19:37 +0100)]
Added ExactSizeIterator bound to return types
in librustc in several places

4 years agoExplicitly refer to operator methods in Pin impls
Konrad Borowski [Sat, 7 Dec 2019 15:23:43 +0000 (16:23 +0100)]
Explicitly refer to operator methods in Pin impls

4 years agoAuto merge of #66927 - RalfJung:engines-dont-panic, r=oli-obk
bors [Sat, 7 Dec 2019 14:46:30 +0000 (14:46 +0000)]
Auto merge of #66927 - RalfJung:engines-dont-panic, r=oli-obk

Miri core engine: use throw_ub instead of throw_panic

See https://github.com/rust-lang/rust/issues/66902 for context: panicking is not really an "interpreter error", but just part of a normal Rust execution. This is a first step towards removing the `InterpError::Panic` variant: the core Miri engine does not use it any more.

ConstProp and ConstEval still use it, though. This will be addressed in future PRs.

From what I can tell, all the error messages this removes are actually duplicates.

r? @oli-obk @wesleywiser

4 years agofix warnings with cfg(miri)
Ralf Jung [Sat, 7 Dec 2019 11:47:18 +0000 (12:47 +0100)]
fix warnings with cfg(miri)

4 years agoliballoc: ignore tests in Miri instead of removing them entirely
Ralf Jung [Sat, 7 Dec 2019 11:42:19 +0000 (12:42 +0100)]
liballoc: ignore tests in Miri instead of removing them entirely

4 years agolibcore: ignore tests in Miri instead of removing them entirely
Ralf Jung [Sat, 7 Dec 2019 11:38:13 +0000 (12:38 +0100)]
libcore: ignore tests in Miri instead of removing them entirely

4 years agoSimplify `check_decl_no_pat`.
Mazdak Farrokhzad [Sun, 1 Dec 2019 11:43:39 +0000 (12:43 +0100)]
Simplify `check_decl_no_pat`.

4 years agoMake `ForeignItem` an alias of `Item`.
Mazdak Farrokhzad [Sat, 30 Nov 2019 17:10:59 +0000 (18:10 +0100)]
Make `ForeignItem` an alias of `Item`.

4 years agoPrint the visibility in `print_variant`.
Mazdak Farrokhzad [Sun, 1 Dec 2019 22:30:33 +0000 (23:30 +0100)]
Print the visibility in `print_variant`.

4 years agoFormat libcore with rustfmt (including tests and benches)
David Tolnay [Sat, 7 Dec 2019 04:18:12 +0000 (20:18 -0800)]
Format libcore with rustfmt (including tests and benches)

4 years agoSuppress libcore/ptr/mod.rs filelength lint
David Tolnay [Sat, 30 Nov 2019 04:41:53 +0000 (20:41 -0800)]
Suppress libcore/ptr/mod.rs filelength lint

4 years agoExclude manually arranged ascii tables from rustfmt
David Tolnay [Sat, 30 Nov 2019 04:36:28 +0000 (20:36 -0800)]
Exclude manually arranged ascii tables from rustfmt

4 years agoAuto merge of #66882 - mati865:znver1_fix, r=nikomatsakis
bors [Sat, 7 Dec 2019 02:46:10 +0000 (02:46 +0000)]
Auto merge of #66882 - mati865:znver1_fix, r=nikomatsakis

Update LLVM submodule

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

Credit for finding the cause goes to `eddyb`.

4 years agoAdd additional layer of #[track_caller] to test, avoid const prop.
Adam Perry [Sat, 7 Dec 2019 01:10:47 +0000 (17:10 -0800)]
Add additional layer of #[track_caller] to test, avoid const prop.

4 years agoAddress review feedback.
Adam Perry [Sat, 7 Dec 2019 01:05:51 +0000 (17:05 -0800)]
Address review feedback.

4 years agoCaller location is propagated via immediates rather than memory.
Adam Perry [Sat, 7 Dec 2019 00:09:40 +0000 (16:09 -0800)]
Caller location is propagated via immediates rather than memory.

4 years agoAlways call const fns with #[track_caller].
Adam Perry [Fri, 6 Dec 2019 15:11:28 +0000 (07:11 -0800)]
Always call const fns with #[track_caller].

The caller location is passed as an implicit argument, so we must consider it when checking the sizedness of arguments.

4 years agoBump compiler-builtins
Tyler Mandry [Sat, 7 Dec 2019 02:32:59 +0000 (18:32 -0800)]
Bump compiler-builtins

4 years agoAuto merge of #67104 - Centril:rollup-07vahh9, r=Centril
bors [Fri, 6 Dec 2019 23:35:00 +0000 (23:35 +0000)]
Auto merge of #67104 - Centril:rollup-07vahh9, r=Centril

Rollup of 10 pull requests

Successful merges:

 - #66606 (Add feature gate for mut refs in const fn)
 - #66841 (Add `{f32,f64}::approx_unchecked_to<Int>` unsafe methods)
 - #67009 (Emit coercion suggestions in more places)
 - #67052 (Ditch `parse_in_attr`)
 - #67071 (Do not ICE on closure typeck)
 - #67078 (accept union inside enum if not followed by identifier)
 - #67090 (Change "either" to "any" in Layout::from_size_align's docs)
 - #67092 (Fix comment typos in src/libcore/alloc.rs)
 - #67094 (get rid of __ in field names)
 - #67102 (Add note to src/ci/docker/README.md about multiple docker images)

Failed merges:

 - #67101 (use `#[allow(unused_attributes)]` to paper over incr.comp problem)

r? @ghost

4 years agoRollup merge of #67102 - Aaron1011:patch-3, r=Mark-Simulacrum
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:27:08 +0000 (23:27 +0100)]
Rollup merge of #67102 - Aaron1011:patch-3, r=Mark-Simulacrum

Add note to src/ci/docker/README.md about multiple docker images

I spent a while debugging a strage linker error about an outdated `glibc` version, only to discover that it was caused by a stale `obj` directory. It wasn't obviously to be that using the same obj dir with multiple Docker images (for the same target triple) could be a problem.

This commit adds a note to the README, which should hopefully be helpful to anyone else who runs into this issue.

4 years agoRollup merge of #67094 - RalfJung:fields, r=Mark-Simulacrum
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:27:06 +0000 (23:27 +0100)]
Rollup merge of #67094 - RalfJung:fields, r=Mark-Simulacrum

get rid of __ in field names

This old work-around should not be needed any more.

4 years agoRollup merge of #67092 - kraai:us-to-is, r=jonas-schievink
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:27:05 +0000 (23:27 +0100)]
Rollup merge of #67092 - kraai:us-to-is, r=jonas-schievink

Fix comment typos in src/libcore/alloc.rs

4 years agoRollup merge of #67090 - kraai:either-to-any, r=jonas-schievink
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:27:03 +0000 (23:27 +0100)]
Rollup merge of #67090 - kraai:either-to-any, r=jonas-schievink

Change "either" to "any" in Layout::from_size_align's docs

4 years agoRollup merge of #67078 - kamleshbhalui:master, r=Centril
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:27:02 +0000 (23:27 +0100)]
Rollup merge of #67078 - kamleshbhalui:master, r=Centril

accept union inside enum if not followed by identifier

Fixes #66943

4 years agoRollup merge of #67071 - estebank:issue-66868, r=davidtwco
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:27:00 +0000 (23:27 +0100)]
Rollup merge of #67071 - estebank:issue-66868, r=davidtwco

Do not ICE on closure typeck

Tackle #66868.

r? @davidtwco

4 years agoRollup merge of #67052 - Centril:config-1, r=petrochenkov
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:26:59 +0000 (23:26 +0100)]
Rollup merge of #67052 - Centril:config-1, r=petrochenkov

Ditch `parse_in_attr`

Fixes #66940

r? @petrochenkov

4 years agoRollup merge of #67009 - Aaron1011:fix/coerce-suggestion, r=Centril
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:26:57 +0000 (23:26 +0100)]
Rollup merge of #67009 - Aaron1011:fix/coerce-suggestion, r=Centril

Emit coercion suggestions in more places

Fixes #66910

We have several different kinds of suggestions we can try to make when
type coercion fails. However, we were previously only emitting these
suggestions from `demand_coerce_diag`. This resulted in the compiler
failing to emit applicable suggestions in several different cases, such
as when the implicit return value of a function had the wrong type.

This commit adds a new `emit_coerce_suggestions` method, which tries to
emit a number of related suggestions. This method is called from both
`demand_coerce_diag` and `CoerceMany::coerce_inner`, which covers a much
wider range of cases than before.

We now suggest using `.await` in more cases where it is applicable,
among other improvements.

I'm not happy about disabling the `issue-59756`, but from what I can tell, the suggestion infrastructure in rustc lacks any way of indicating mutually exclusive suggestions (and compiletest lacks a way to only apply a subset of available suggestions).

4 years agoRollup merge of #66841 - SimonSapin:float_round_unchecked_to, r=rkruppe
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:26:55 +0000 (23:26 +0100)]
Rollup merge of #66841 - SimonSapin:float_round_unchecked_to, r=rkruppe

Add `{f32,f64}::approx_unchecked_to<Int>` unsafe methods

As discussed in https://github.com/rust-lang/rust/issues/10184

Currently, casting a floating point number to an integer with `as` is Undefined Behavior if the value is out of range. `-Z saturating-float-casts` fixes this soundness hole by making `as` “saturate” to the maximum or minimum value of the integer type (or zero for `NaN`), but has measurable negative performance impact in some benchmarks. There is some consensus in that thread for enabling saturation by default anyway, but provide an `unsafe fn` alternative for users who know through some other mean that their values are in range.

<del>The “fit” wording is copied from https://llvm.org/docs/LangRef.html#fptoui-to-instruction, but I’m not certain what it means exactly. Presumably this is after rounding towards zero, and the doc-test with `i8::MIN` seems to confirm this.</del> Clang presumably uses those LLVM intrinsics to implement C and C++ casts, whose respective standard specify that the value *after truncating to keep its integral part* must be representable in the target type.

4 years agoRollup merge of #66606 - christianpoveda:mut-refs-in-const-fn, r=oli-obk
Mazdak Farrokhzad [Fri, 6 Dec 2019 22:26:54 +0000 (23:26 +0100)]
Rollup merge of #66606 - christianpoveda:mut-refs-in-const-fn, r=oli-obk

Add feature gate for mut refs in const fn

r? @oli-obk

4 years agoAdd note to src/ci/docker/README.md about multiple docker images
Aaron Hill [Fri, 6 Dec 2019 21:38:57 +0000 (16:38 -0500)]
Add note to src/ci/docker/README.md about multiple docker images

I spent a while debugging a strage linker error about an outdated `glibc` version, only to discover that it was caused by a stale `obj` directory. It wasn't obviously to be that using the same obj dir with multiple Docker images (for the same target triple) could be a problem.

This commit adds a note to the README, which should hopefully be helpful to anyone else who runs into this issue.

4 years agoparse_meta: ditch parse_in_attr
Mazdak Farrokhzad [Thu, 5 Dec 2019 13:19:00 +0000 (14:19 +0100)]
parse_meta: ditch parse_in_attr

4 years agoderive: avoid parse_in_attr
Mazdak Farrokhzad [Thu, 5 Dec 2019 12:53:56 +0000 (13:53 +0100)]
derive: avoid parse_in_attr

4 years agocfg_attr: avoid .outer_tokens
Mazdak Farrokhzad [Thu, 5 Dec 2019 05:45:50 +0000 (06:45 +0100)]
cfg_attr: avoid .outer_tokens

4 years agoAuto merge of #65195 - varkor:to_option, r=Centril
bors [Fri, 6 Dec 2019 19:14:51 +0000 (19:14 +0000)]
Auto merge of #65195 - varkor:to_option, r=Centril

Rename `bool::then_*` to `bool::to_option_*` and use where appropriate

Name change following https://github.com/rust-lang/rfcs/pull/2757. Also try it out throughout the compiler in places I think makes the code more readable.

4 years agoreview comments
Esteban Küber [Thu, 5 Dec 2019 14:57:34 +0000 (06:57 -0800)]
review comments

4 years agoDo not ICE on async fn with non-Copy infered type arg
Esteban Küber [Tue, 3 Dec 2019 23:02:27 +0000 (15:02 -0800)]
Do not ICE on async fn with non-Copy infered type arg

Fix #66958.

4 years agoUpdate rustc-guide
Mark Mansi [Fri, 6 Dec 2019 17:26:18 +0000 (11:26 -0600)]
Update rustc-guide

4 years agoget rid of __ in field names
Ralf Jung [Fri, 6 Dec 2019 16:28:04 +0000 (17:28 +0100)]
get rid of __ in field names

4 years agoChange "wth" to "with" in `Layout::padding_needed_for` comment
Matthew Kraai [Fri, 6 Dec 2019 15:59:13 +0000 (07:59 -0800)]
Change "wth" to "with" in `Layout::padding_needed_for` comment

4 years agoChange "us" to "is" in Layout::for_value comment
Matthew Kraai [Fri, 6 Dec 2019 15:18:10 +0000 (07:18 -0800)]
Change "us" to "is" in Layout::for_value comment

4 years agoAuto merge of #67091 - JohnTitor:rollup-kitphze, r=JohnTitor
bors [Fri, 6 Dec 2019 15:11:35 +0000 (15:11 +0000)]
Auto merge of #67091 - JohnTitor:rollup-kitphze, r=JohnTitor

Rollup of 11 pull requests

Successful merges:

 - #66846 (Make try_mark_previous_green aware of cycles.)
 - #66959 (Remove potential cfgs duplicates)
 - #66988 (Fix angle bracket formatting when dumping MIR debug vars)
 - #66998 (Modified the testcases for VxWorks)
 - #67008 (rustdoc: Add test for fixed issue)
 - #67023 (SGX: Fix target linker used by bootstrap)
 - #67033 (Migrate to LLVM{Get,Set}ValueName2)
 - #67049 (Simplify {IoSlice, IoSliceMut}::advance examples and tests)
 - #67054 (codegen "unreachable" for invalid SetDiscriminant)
 - #67081 (Fix Query type docs)
 - #67085 (Remove boxed closures in address parser.)

Failed merges:

r? @ghost

4 years agoRollup merge of #67085 - reitermarkus:addr-parser, r=Mark-Simulacrum
Yuki Okushi [Fri, 6 Dec 2019 15:10:08 +0000 (00:10 +0900)]
Rollup merge of #67085 - reitermarkus:addr-parser, r=Mark-Simulacrum

Remove boxed closures in address parser.

Simplify address parser by removing unnecessary boxed closures.

Also relevant for https://github.com/rust-lang/rfcs/pull/2832.

4 years agoRollup merge of #67081 - osa1:fix_query_type_docs, r=Dylan-DPC
Yuki Okushi [Fri, 6 Dec 2019 15:10:07 +0000 (00:10 +0900)]
Rollup merge of #67081 - osa1:fix_query_type_docs, r=Dylan-DPC

Fix Query type docs

`give` no longer exists, `compute` is used to generate query results now.

4 years agoRollup merge of #67054 - RalfJung:set-discriminant-unreachable, r=oli-obk
Yuki Okushi [Fri, 6 Dec 2019 15:10:05 +0000 (00:10 +0900)]
Rollup merge of #67054 - RalfJung:set-discriminant-unreachable, r=oli-obk

codegen "unreachable" for invalid SetDiscriminant

Follow-up from https://github.com/rust-lang/rust/pull/66960. I also realized I don't understand our policy for using `abort` vs `unreachable`. AFAIK `abort` is safe to call and just aborts the process, while `unreachable` is UB. But sometimes we use both, like here

https://github.com/rust-lang/rust/blob/d825e35ee8325146e6c175a4c61bcb645b347d5e/src/librustc_codegen_ssa/mir/block.rs#L827-L828

and here

https://github.com/rust-lang/rust/blob/d825e35ee8325146e6c175a4c61bcb645b347d5e/src/librustc_codegen_ssa/mir/block.rs#L264-L265

The second case is even more confusing because that looks like an unreachable `return` to me, so why would we codegen a safe abort there?

r? @eddyb Cc @oli-obk

4 years agoRollup merge of #67049 - tmiasko:io-slice-advance, r=rkruppe
Yuki Okushi [Fri, 6 Dec 2019 15:10:04 +0000 (00:10 +0900)]
Rollup merge of #67049 - tmiasko:io-slice-advance, r=rkruppe

Simplify {IoSlice, IoSliceMut}::advance examples and tests

Remove unnecessary calls to `std::mem::replace` and make variables immutable.

4 years agoRollup merge of #67033 - cuviper:ValueName2, r=rkruppe
Yuki Okushi [Fri, 6 Dec 2019 15:10:02 +0000 (00:10 +0900)]
Rollup merge of #67033 - cuviper:ValueName2, r=rkruppe

Migrate to LLVM{Get,Set}ValueName2

The deprecated `LLVM{Get,Set}ValueName` only work with NUL-terminated
strings, but the `2` variants use explicit lengths, which fits better
with Rust strings and slices. We now use these in new helper functions
`llvm::{get,set}_value_name` that convert to/from `&[u8]`.

Closes #64223.
r? @rkruppe

4 years agoRollup merge of #67023 - jethrogb:jb/bootstrap-target-linker, r=alexcrichton
Yuki Okushi [Fri, 6 Dec 2019 15:10:00 +0000 (00:10 +0900)]
Rollup merge of #67023 - jethrogb:jb/bootstrap-target-linker, r=alexcrichton

SGX: Fix target linker used by bootstrap

Bootstrap, for some reason, overrides the target linker. This is not correct for x86_64-fortanix-unknown-sgx. Add such targets to the list of exceptions.

r? @alexcrichton

4 years agoRollup merge of #67008 - ollie27:rustdoc_issue_61732, r=Centril
Yuki Okushi [Fri, 6 Dec 2019 15:09:59 +0000 (00:09 +0900)]
Rollup merge of #67008 - ollie27:rustdoc_issue_61732, r=Centril

rustdoc: Add test for fixed issue

#61732 was almost certainly fixed by #63400.

Closes #61732

4 years agoRollup merge of #66998 - Wind-River:master_up, r=alexcrichton
Yuki Okushi [Fri, 6 Dec 2019 15:09:57 +0000 (00:09 +0900)]
Rollup merge of #66998 - Wind-River:master_up, r=alexcrichton

Modified the testcases for VxWorks