]> git.lizzy.rs Git - rust.git/log
rust.git
5 years agodocs: this llvm feature only supports the ELF object format
Jorge Aparicio [Wed, 26 Sep 2018 13:25:57 +0000 (15:25 +0200)]
docs: this llvm feature only supports the ELF object format

5 years agounstable-book: recommend an INFO section
Jorge Aparicio [Sun, 16 Sep 2018 19:43:33 +0000 (21:43 +0200)]
unstable-book: recommend an INFO section

that makes the output .stack_sizes section non-allocatable when linking with
either GNU LD or LLD

5 years agouse `rustc -Vv` in the run-make test
Jorge Aparicio [Sun, 16 Sep 2018 19:29:57 +0000 (21:29 +0200)]
use `rustc -Vv` in the run-make test

5 years agorun test only if LLVM version is >= 6.0.0
Jorge Aparicio [Sat, 15 Sep 2018 21:19:07 +0000 (23:19 +0200)]
run test only if LLVM version is >= 6.0.0

5 years agoadd run-make test
Jorge Aparicio [Thu, 13 Sep 2018 18:25:58 +0000 (20:25 +0200)]
add run-make test

5 years agodocument this feature in the unstable book
Jorge Aparicio [Thu, 13 Sep 2018 17:46:52 +0000 (19:46 +0200)]
document this feature in the unstable book

5 years agoadd -Z emit-stack-sizes
Jorge Aparicio [Thu, 13 Sep 2018 17:43:15 +0000 (19:43 +0200)]
add -Z emit-stack-sizes

5 years agoAuto merge of #53824 - ljedrz:begone_onevector, r=michaelwoerister
bors [Wed, 26 Sep 2018 10:04:42 +0000 (10:04 +0000)]
Auto merge of #53824 - ljedrz:begone_onevector, r=michaelwoerister

Remove OneVector, increase related SmallVec capacities

Removes the `OneVector` type alias (equivalent to `SmallVec<[T; 1]>`); it is used in scenarios where the capacity of 1 is often exceeded, which might be nullifying the performance wins (due to spilling to the heap) expected when using `SmallVec` instead of `Vec`.

The numbers I used in this PR are very rough estimates - it would probably be a good idea to adjust some/all of them, which is what this proposal is all about.

It might be a good idea to additionally create some local type aliases for the `SmallVec`s in the `Folder` trait, as they are repeated in quite a few spots; I'd be happy to apply this sort of adjustments.

5 years agoRemove OneVector
ljedrz [Thu, 30 Aug 2018 09:42:16 +0000 (11:42 +0200)]
Remove OneVector

5 years agoAuto merge of #54497 - ralexstokes:stabilize_pattern_parentheses, r=nikomatsakis
bors [Wed, 26 Sep 2018 07:38:19 +0000 (07:38 +0000)]
Auto merge of #54497 - ralexstokes:stabilize_pattern_parentheses, r=nikomatsakis

Stabilize pattern_parentheses feature

Addresses #51087 .

Stabilizes the previously unstable feature `pattern_parentheses` which enables the use of `()` in match patterns.

5 years agoAuto merge of #54548 - nrc:update, r=kennytm
bors [Wed, 26 Sep 2018 03:45:55 +0000 (03:45 +0000)]
Auto merge of #54548 - nrc:update, r=kennytm

Update rustfmt and RLS

r? @kennytm

5 years agoAuto merge of #54164 - mikhail-m1:54131, r=pnkfelix
bors [Wed, 26 Sep 2018 01:16:22 +0000 (01:16 +0000)]
Auto merge of #54164 - mikhail-m1:54131, r=pnkfelix

add "temporary value borrowed for too long" error

Issue #54131

r? @nikomatsakis

5 years agoAuto merge of #54575 - pietroalbini:rollup, r=pietroalbini
bors [Tue, 25 Sep 2018 22:52:16 +0000 (22:52 +0000)]
Auto merge of #54575 - pietroalbini:rollup, r=pietroalbini

Rollup of 12 pull requests

Successful merges:

 - #53518 (Add doc for impl From in char_convert)
 - #54058 (Introduce the partition_dedup/by/by_key methods for slices)
 - #54281 (Search box)
 - #54368 (Reduce code block sides padding)
 - #54498 (The project moved under the Mozilla umbrella)
 - #54518 (resolve: Do not block derive helper resolutions on single import resolutions)
 - #54522 (Fixed three small typos.)
 - #54529 (aarch64-pc-windows-msvc: Don't link libpanic_unwind to libtest.)
 - #54537 (Rename slice::exact_chunks() to slice::chunks_exact())
 - #54539 (Fix js error)
 - #54557 (incr.comp.: Don't automatically enable -Zshare-generics for incr. comp. builds.)
 - #54558 (Improvements to finding LLVM's FileCheck)

Failed merges:

r? @ghost

5 years agoUpdate rustfmt and RLS
Nick Cameron [Tue, 25 Sep 2018 02:40:42 +0000 (14:40 +1200)]
Update rustfmt and RLS

5 years agoRollup merge of #54558 - tromey:find-filecheck, r=nikomatsakis
Pietro Albini [Tue, 25 Sep 2018 20:34:51 +0000 (22:34 +0200)]
Rollup merge of #54558 - tromey:find-filecheck, r=nikomatsakis

Improvements to finding LLVM's FileCheck

This patch adds a few improvements to how the build system finds
LLVM's FileCheck program.

* On Fedora, the system LLVM installs FileCheck in the "llvm"
  subdirectory of the LLVM libdir.  This patch teaches the build
  system to look there.

* This adds a configure option to specify which llvm-config executable
  to use.  This is handy on systems that can parallel install multiple
  versions of LLVM; for example I can now:

    ./configure --llvm-config=/bin/llvm-config-5.0-64

  ... to build against LLVM 5, rather than whatever the default
  llvm-config might be.

* Finally, this adds a configure- and config.toml- option to set the
  path to FileCheck.  This is handy when building against an LLVM
  where FileCheck was not installed.  This happens on compatibility
  installs of LLVM on Fedora.

5 years agoRollup merge of #54557 - michaelwoerister:dont-auto-share-generics-for-incr-comp...
Pietro Albini [Tue, 25 Sep 2018 20:34:50 +0000 (22:34 +0200)]
Rollup merge of #54557 - michaelwoerister:dont-auto-share-generics-for-incr-comp, r=alexcrichton

incr.comp.: Don't automatically enable -Zshare-generics for incr. comp. builds.

So far the compiler would automatically enable sharing of monomorphizations for incremental builds. That was OK because without (Thin)LTO this could have very little impact on the runtime performance of the generated code. However, since https://github.com/rust-lang/rust/pull/53673, ThinLTO and incr. comp. can be combined, so the trade-off is not as clear anymore.

This PR removes the automatic tie between the two options. Whether monomorphizations are shared between crates or not now _only_ depends on the optimization level.

r? @alexcrichton

5 years agoRollup merge of #54539 - GuillaumeGomez:fix-js-error, r=QuietMisdreavus
Pietro Albini [Tue, 25 Sep 2018 20:34:48 +0000 (22:34 +0200)]
Rollup merge of #54539 - GuillaumeGomez:fix-js-error, r=QuietMisdreavus

Fix js error

r? @QuietMisdreavus

5 years agoRollup merge of #54537 - sdroege:chunks-exact, r=alexcrichton
Pietro Albini [Tue, 25 Sep 2018 20:34:47 +0000 (22:34 +0200)]
Rollup merge of #54537 - sdroege:chunks-exact, r=alexcrichton

Rename slice::exact_chunks() to slice::chunks_exact()

See https://github.com/rust-lang/rust/issues/47115#issuecomment-403090815
and https://github.com/rust-lang/rust/issues/47115#issuecomment-424053547

5 years agoRollup merge of #54529 - michaelwoerister:dont-unwind-test, r=alexcrichton
Pietro Albini [Tue, 25 Sep 2018 20:34:46 +0000 (22:34 +0200)]
Rollup merge of #54529 - michaelwoerister:dont-unwind-test, r=alexcrichton

aarch64-pc-windows-msvc: Don't link libpanic_unwind to libtest.

This implements the suggestion from https://github.com/rust-lang/rust/issues/54190#issuecomment-422904437 in order to unbreak bootstrapping for the `aarch64-pc-windows-msvc` target. With this applied and using MSVC 15.8.3 for linking the bootstrap actually works and I can cross-compile a hello-world program.

r? @alexcrichton

5 years agoRollup merge of #54522 - gardrek:patch-1, r=TimNN
Pietro Albini [Tue, 25 Sep 2018 20:34:44 +0000 (22:34 +0200)]
Rollup merge of #54522 - gardrek:patch-1, r=TimNN

Fixed three small typos.

5 years agoRollup merge of #54518 - petrochenkov:regr130, r=alexcrichton
Pietro Albini [Tue, 25 Sep 2018 20:34:43 +0000 (22:34 +0200)]
Rollup merge of #54518 - petrochenkov:regr130, r=alexcrichton

resolve: Do not block derive helper resolutions on single import resolutions

Derive helpers currently conflict with anything else, so if some resolution from a single import appears later, it will result in error anyway.

Fixes https://github.com/rust-lang/rust/issues/54471 (stable-to-beta regression)

r? @ghost

5 years agoRollup merge of #54498 - sylvestre:patch-1, r=frewsxcv
Pietro Albini [Tue, 25 Sep 2018 20:34:42 +0000 (22:34 +0200)]
Rollup merge of #54498 - sylvestre:patch-1, r=frewsxcv

The project moved under the Mozilla umbrella

5 years agoRollup merge of #54368 - GuillaumeGomez:reduce-side-padding, r=QuietMisdreavus
Pietro Albini [Tue, 25 Sep 2018 20:34:41 +0000 (22:34 +0200)]
Rollup merge of #54368 - GuillaumeGomez:reduce-side-padding, r=QuietMisdreavus

Reduce code block sides padding

Fixes #42013.

<img width="1440" alt="screen shot 2018-09-19 at 22 58 32" src="https://user-images.githubusercontent.com/3050060/45781266-c6525680-bc5f-11e8-8eb0-98fc4c22a96e.png">

r? @QuietMisdreavus

5 years agoRollup merge of #54281 - GuillaumeGomez:search-box, r=QuietMisdreavus
Pietro Albini [Tue, 25 Sep 2018 20:34:39 +0000 (22:34 +0200)]
Rollup merge of #54281 - GuillaumeGomez:search-box, r=QuietMisdreavus

Search box

Follow up of #54244.

r? @QuietMisdreavus

<img width="1440" alt="screen shot 2018-09-16 at 21 23 05" src="https://user-images.githubusercontent.com/3050060/45600056-cbf93380-b9f6-11e8-904a-d76ddbc5ed69.png">

5 years agoRollup merge of #54058 - Kerollmops:slice-dedup, r=shepmaster
Pietro Albini [Tue, 25 Sep 2018 20:34:38 +0000 (22:34 +0200)]
Rollup merge of #54058 - Kerollmops:slice-dedup, r=shepmaster

Introduce the partition_dedup/by/by_key methods for slices

This PR propose to add three methods to the slice type, the `partition_dedup`, `partition_dedup_by` and `partition_dedup_by_key`. The two other methods are based on `slice::partition_dedup_by`.

These methods take a mutable slice, deduplicates it and moves all duplicates to the end of it, returning two mutable slices, the first containing the deduplicated elements and the second all the duplicates unordered.

```rust
let mut slice = [1, 2, 2, 3, 3, 2];

let (dedup, duplicates) = slice.partition_dedup();

assert_eq!(dedup, [1, 2, 3, 2]);
assert_eq!(duplicates, [3, 2]);
```

The benefits of adding these methods is that it is now possible to:
  - deduplicate a slice without having to allocate and possibly clone elements on the heap, really useful for embedded stuff that can't allocate for example.
  - not loose duplicate elements, because, when using `Vec::dedup`, duplicates elements are dropped. These methods add more flexibillity to the user.

Note that this is near a copy/paste of the `Vec::dedup_by` function, once this method is stable the goal is to replace the algorithm in `Vec` by the following.

```rust
pub fn Vec::dedup_by<F>(&mut self, same_bucket: F)
    where F: FnMut(&mut T, &mut T) -> bool
{
    let (dedup, _) = self.as_mut_slice().partition_dedup_by(same_bucket);
    let len = dedup.len();
    self.truncate(len);
}
```

5 years agoRollup merge of #53518 - phungleson:fix-impl-from-for-convert, r=frewsxcv
Pietro Albini [Tue, 25 Sep 2018 20:34:37 +0000 (22:34 +0200)]
Rollup merge of #53518 - phungleson:fix-impl-from-for-convert, r=frewsxcv

Add doc for impl From in char_convert

As part of issue #51430 (cc @skade).

The impl is very simple, let me know if we need to go into any details.

5 years agoAuto merge of #53542 - alexreg:impl-trait-in-bindings, r=cramertj
bors [Tue, 25 Sep 2018 20:02:14 +0000 (20:02 +0000)]
Auto merge of #53542 - alexreg:impl-trait-in-bindings, r=cramertj

`impl trait` in bindings (feature: impl-trait-existential-types)

This PR enables `impl Trait` syntax (opaque types) to be used in bindings, e.g.

* `let foo: impl Clone = 1;`
* `static foo: impl Clone = 2;`
* `const foo: impl Clone = 3;`

This is part of [RFC 2071](https://github.com/rust-lang/rfcs/blob/master/text/2071-impl-trait-existential-types.md) ([tracking issue](https://github.com/rust-lang/rust/issues/34511)), but exists behind the separate feature gate `impl_trait_in_bindings`.

CC @cramertj @oli-obk @eddyb @Centril @varkor

5 years agoresolve: Do not block derive helper resolutions on single import resolutions
Vadim Petrochenkov [Sun, 23 Sep 2018 23:26:26 +0000 (02:26 +0300)]
resolve: Do not block derive helper resolutions on single import resolutions

Derive helpers conflict currently conflict with anything else, so if some resolution from a single import appears later, it will result in error anyway

5 years agoUpdate E0714 to E0716 in tests output
Mikhail Modin [Tue, 25 Sep 2018 15:24:20 +0000 (16:24 +0100)]
Update E0714 to E0716 in tests output

5 years agoAuto merge of #54411 - cramertj:await-keyword-error, r=nikomatsakis
bors [Tue, 25 Sep 2018 15:20:10 +0000 (15:20 +0000)]
Auto merge of #54411 - cramertj:await-keyword-error, r=nikomatsakis

Make "await" a pseudo-edition keyword

This change makes "await" ident an error in 2018 edition without async_await
feature and adds "await" to the 2018 edition keyword lint group that
suggest migration on the 2015 edition.

cc https://github.com/rust-lang/rust/issues/53834

r? @nikomatsakis

5 years agoImprovements to finding LLVM's FileCheck
Tom Tromey [Tue, 25 Sep 2018 15:13:02 +0000 (09:13 -0600)]
Improvements to finding LLVM's FileCheck

This patch adds a few improvements to how the build system finds
LLVM's FileCheck program.

* On Fedora, the system LLVM installs FileCheck in the "llvm"
  subdirectory of the LLVM libdir.  This patch teaches the build
  system to look there.

* This adds a configure option to specify which llvm-config executable
  to use.  This is handy on systems that can parallel install multiple
  versions of LLVM; for example I can now:

    ./configure --llvm-config=/bin/llvm-config-5.0-64

  ... to build against LLVM 5, rather than whatever the default
  llvm-config might be.

* Finally, this adds a configure- and config.toml- option to set the
  path to FileCheck.  This is handy when building against an LLVM
  where FileCheck was not installed.  This happens on compatibility
  installs of LLVM on Fedora.

5 years agoincr.comp.: Don't automatically enable -Zshare-generics for incr.comp. builds.
Michael Woerister [Tue, 25 Sep 2018 15:06:18 +0000 (17:06 +0200)]
incr.comp.: Don't automatically enable -Zshare-generics for incr.comp. builds.

5 years agoChange the diagnostic number from 714 to 716.
Felix S. Klock II [Tue, 25 Sep 2018 14:06:28 +0000 (16:06 +0200)]
Change the diagnostic number from 714 to 716.

5 years agoadd "temporary value dropped while borrowed" error
Mikhail Modin [Sun, 23 Sep 2018 15:30:46 +0000 (16:30 +0100)]
add "temporary value dropped while borrowed" error

Issue #54131

5 years agoAdd examples for doc
Son [Tue, 25 Sep 2018 11:59:58 +0000 (21:59 +1000)]
Add examples for doc

5 years agoAuto merge of #54430 - adrian-budau:master, r=alexcrichton
bors [Tue, 25 Sep 2018 09:33:00 +0000 (09:33 +0000)]
Auto merge of #54430 - adrian-budau:master, r=alexcrichton

Update musl to 1.1.20.

This fixes #54429

5 years agoAuto merge of #54317 - Centril:feature/dbg_macro, r=SimonSapin
bors [Tue, 25 Sep 2018 07:06:15 +0000 (07:06 +0000)]
Auto merge of #54317 - Centril:feature/dbg_macro, r=SimonSapin

Implement the dbg!(..) macro

Implements the `dbg!(..)` macro due to #54306.
cc https://github.com/rust-lang/rfcs/pull/2361

r? @alexcrichton

5 years agoAlso rename ExactChunks iterator name to ChunksExact
Sebastian Dröge [Tue, 25 Sep 2018 05:56:48 +0000 (08:56 +0300)]
Also rename ExactChunks iterator name to ChunksExact

5 years agoAuto merge of #53693 - scottmcm:marker-trait-attribute, r=nikomatsakis
bors [Tue, 25 Sep 2018 03:42:46 +0000 (03:42 +0000)]
Auto merge of #53693 - scottmcm:marker-trait-attribute, r=nikomatsakis

Support an explicit annotation for marker traits

From the tracking issue for rust-lang/rfcs#1268:
> It seems obvious that we should make a `#[marker]` annotation. ~ https://github.com/rust-lang/rust/issues/29864#issuecomment-368959441

This PR allows you to put `#[marker]` on a trait, at which point:
- [x] The trait must not have any items ~~All of the trait's items must have defaults~~
- [x] Any impl of the trait must be empty (not override any items)
- [x] But impls of the trait are allowed to overlap

r? @nikomatsakis

5 years agoAdded section to Unstable Book.
Alexander Regueiro [Fri, 21 Sep 2018 00:24:52 +0000 (01:24 +0100)]
Added section to Unstable Book.

5 years agoAdded tests.
Alexander Regueiro [Tue, 11 Sep 2018 16:55:05 +0000 (17:55 +0100)]
Added tests.

5 years agoHandle locals in closures properly.
Alexander Regueiro [Mon, 24 Sep 2018 03:25:23 +0000 (04:25 +0100)]
Handle locals in closures properly.

5 years agoHandle impl trait in MIR type checked for assignments.
Matthew Jasper [Sat, 8 Sep 2018 06:52:03 +0000 (07:52 +0100)]
Handle impl trait in MIR type checked for assignments.

5 years agoLower `impl Trait` types in locals.
Alexander Regueiro [Sun, 19 Aug 2018 02:40:50 +0000 (03:40 +0100)]
Lower `impl Trait` types in locals.

5 years agoAuto merge of #53438 - matthewjasper:permissive-match-access, r=pnkfelix
bors [Tue, 25 Sep 2018 01:04:12 +0000 (01:04 +0000)]
Auto merge of #53438 - matthewjasper:permissive-match-access, r=pnkfelix

[NLL] Be more permissive when checking access due to Match

Partially addresses #53114. notably, we should now have parity with AST borrowck. Matching on uninitialized values is still forbidden.

* ~~Give fake borrows for match their own `BorrowKind`~~
* ~~Allow borrows with this kind to happen on values that are already mutably borrowed.~~
* ~~Track borrows with this type even behind shared reference dereferences and consider all accesses to be deep when checking for conflicts with this borrow type. See [src/test/ui/issues/issue-27282-mutate-before-diverging-arm-3.rs](https://github.com/rust-lang/rust/commit/cb5c989598178af505fb215dd97afca8cc2b659f#diff-a2126cd3263a1f5342e2ecd5e699fbc6) for an example soundness issue this fixes (a case of #27282 that wasn't handled correctly).~~
* Create a new `BorrowKind`: `Shallow` (name can be bike-shed)
* `Shallow` borrows differ from shared borrows in that
  * When we check for access we treat them as a `Shallow(Some(_))` read
  * When we check for conflicts with them, if the borrow place is a strict prefix of the access place then we don't consider that a conflict.
    * For example, a `Shallow` borrow of `x` does not conflict with any access or borrow of `x.0` or `*x`
* Remove the current fake borrow in matches.
* When building matches, we take a `Shallow` borrow of any `Place` that we switch on or bind in a match, and any prefix of those places. (There are some optimizations where we do fewer borrows, but this shouldn't change semantics)
  * `match x { &Some(1) => (),  _ => (), }` would `Shallow` borrow `x`, `*x` and `(*x as Some).0` (the `*x` borrow is unnecessary, but I'm not sure how easy it would be to remove.)
* Replace the fake discriminant read with a `ReadForMatch`.
* Change ReadForMatch to only check for initializedness (to prevent `let x: !; match x {}`), but not conflicting borrows. It is still considered a use for liveness and `unsafe` checking.
* Give special cased error messages for this kind of borrow.

Table from the above issue after this PR

| Thing | AST | MIR | Want | Example |
| --- | --- | --- | --- |---|
| `let _ = <unsafe-field>` | 💚  | 💚  | ❌ |  [playground](https://play.rust-lang.org/?gist=bb7843e42fa5318c1043d04bd72abfe4&version=nightly&mode=debug&edition=2015) |
| `match <unsafe_field> { _ => () }` | ❌  | ❌ | ❌ | [playground](https://play.rust-lang.org/?gist=3e3af05fbf1fae28fab2aaf9412fb2ea&version=nightly&mode=debug&edition=2015) |
| `let _ = <moved>` | 💚  | 💚 | 💚 | [playground](https://play.rust-lang.org/?gist=91a6efde8288558e584aaeee0a50558b&version=nightly&mode=debug&edition=2015) |
| `match <moved> { _ => () }` | ❌ | ❌  | 💚 | [playground](https://play.rust-lang.org/?gist=804f8185040b2fe131f2c4a64b3048ca&version=nightly&mode=debug&edition=2015) |
| `let _ = <borrowed>` | 💚  | 💚 | 💚 | [playground](https://play.rust-lang.org/?gist=0e487c2893b89cb772ec2f2b7c5da876&version=nightly&mode=debug&edition=2015) |
| `match <borrowed> { _ => () }` | 💚  | 💚 | 💚 | [playground](https://play.rust-lang.org/?gist=0e487c2893b89cb772ec2f2b7c5da876&version=nightly&mode=debug&edition=2015) |

r? @nikomatsakis

5 years agoRename places_conflict to borrow_conflicts_with_place
Matthew Jasper [Sun, 23 Sep 2018 10:33:52 +0000 (11:33 +0100)]
Rename places_conflict to borrow_conflicts_with_place

This name better reflects the asymmetry of this function.

5 years agoUpdate mir opt tests
Matthew Jasper [Sat, 15 Sep 2018 10:18:45 +0000 (11:18 +0100)]
Update mir opt tests

5 years agoAdd a MIR transform to remove fake reads
Matthew Jasper [Sun, 23 Sep 2018 09:43:14 +0000 (10:43 +0100)]
Add a MIR transform to remove fake reads

As we are now creating borrows of places that may not be valid for
borrow checking matches, these have to be removed to avoid generating
broken code.

5 years agoUpdate ui tests
Matthew Jasper [Thu, 13 Sep 2018 21:04:09 +0000 (22:04 +0100)]
Update ui tests

5 years agoAdd tests for new match borrows
Matthew Jasper [Thu, 13 Sep 2018 21:04:00 +0000 (22:04 +0100)]
Add tests for new match borrows

5 years agoDon't check for conflicting borrows of `ReadForMatch`es
Matthew Jasper [Thu, 13 Sep 2018 20:36:15 +0000 (21:36 +0100)]
Don't check for conflicting borrows of `ReadForMatch`es

5 years agoAdd more fake borrows to matches
Matthew Jasper [Thu, 13 Sep 2018 20:35:24 +0000 (21:35 +0100)]
Add more fake borrows to matches

5 years agoBetter messages for errors from Shallow borrows
Matthew Jasper [Mon, 10 Sep 2018 21:34:38 +0000 (22:34 +0100)]
Better messages for errors from Shallow borrows

5 years agoAdd "Shallow" borrow kind
Matthew Jasper [Mon, 10 Sep 2018 21:33:45 +0000 (22:33 +0100)]
Add "Shallow" borrow kind

This allows treating the "fake" match borrows differently from shared
borrows.

5 years agoAuto merge of #54416 - christianpoveda:master, r=wesleywiser
bors [Mon, 24 Sep 2018 20:07:44 +0000 (20:07 +0000)]
Auto merge of #54416 - christianpoveda:master, r=wesleywiser

Extend MIR inlining to all operand variants

This fixes https://github.com/rust-lang/rust/issues/54193
r? @eddyb

5 years agoMake "await" a pseudo-edition keyword
Taylor Cramer [Fri, 21 Sep 2018 00:36:31 +0000 (17:36 -0700)]
Make "await" a pseudo-edition keyword

This change makes "await" ident an error in 2018 edition without async_await
feature and adds "await" to the 2018 edition keyword lint group that
suggest migration on the 2015 edition.

5 years agoFix JS error
Guillaume Gomez [Mon, 24 Sep 2018 20:04:23 +0000 (22:04 +0200)]
Fix JS error

5 years agoRename slice::exact_chunks() to slice::chunks_exact()
Sebastian Dröge [Mon, 24 Sep 2018 19:43:06 +0000 (22:43 +0300)]
Rename slice::exact_chunks() to slice::chunks_exact()

See https://github.com/rust-lang/rust/issues/47115#issuecomment-403090815
and https://github.com/rust-lang/rust/issues/47115#issuecomment-424053547

5 years agoAuto merge of #53783 - RalfJung:ptr-docs, r=alexcrichton
bors [Mon, 24 Sep 2018 17:36:44 +0000 (17:36 +0000)]
Auto merge of #53783 - RalfJung:ptr-docs, r=alexcrichton

Rewrite docs for pointer methods

This takes over https://github.com/rust-lang/rust/pull/51016 by @ecstatic-morse. They did most of the work, I just did some editing.

However, I realized one problem: This updates the docs for the "free functions" in `core::ptr`, but it does not update the copies of these docs for the inherent methods of the `*const T` and `*mut T` types. These getting out-of-sync is certainly bad, but I also don't feel like copying all this stuff around. Instead, we should remove this redundancy. Any good ideas?

5 years agoAuto merge of #54509 - matthewjasper:better-drop-access, r=pnkfelix
bors [Mon, 24 Sep 2018 14:47:17 +0000 (14:47 +0000)]
Auto merge of #54509 - matthewjasper:better-drop-access, r=pnkfelix

[NLL] Rework checking for borrows conflicting with drops

Previously, we would split the drop access into multiple checks for each
field of a struct/tuple/closure and through `Box` dereferences. This
changes this to check if the borrow is accessed by the drop in
`places_conflict`.

We also now handle enums containing `Drop` types.

Closes #53569

r? @nikomatsakis
cc @pnkfelix

5 years agoaarch64-pc-windows-msvc: Don't link libpanic_unwind to libtest.
Michael Woerister [Mon, 24 Sep 2018 12:37:09 +0000 (14:37 +0200)]
aarch64-pc-windows-msvc: Don't link libpanic_unwind to libtest.

5 years agoAuto merge of #54507 - csmoe:deny_overflow, r=varkor
bors [Mon, 24 Sep 2018 10:08:01 +0000 (10:08 +0000)]
Auto merge of #54507 - csmoe:deny_overflow, r=varkor

Deny the `overflowing_literals` lint for the 2018 edition

Closes https://github.com/rust-lang/rust/issues/54502
r? @varkor

5 years agoFixed three small typos.
gardrek [Mon, 24 Sep 2018 04:47:52 +0000 (23:47 -0500)]
Fixed three small typos.

5 years agoAuto merge of #54489 - matthiaskrgr:rls, r=kennytm
bors [Mon, 24 Sep 2018 04:32:24 +0000 (04:32 +0000)]
Auto merge of #54489 - matthiaskrgr:rls, r=kennytm

update rls to 32d457717ce37babef199fe4984b1e20d4e108d4

I patched rls to use the `rustc_tools_utils` supplied by the clippy submodule to get around the tidy warning.

Should fix rls and toolstate.

5 years agoAuto merge of #54495 - raventid:improve-e0425-message, r=estebank
bors [Mon, 24 Sep 2018 00:20:21 +0000 (00:20 +0000)]
Auto merge of #54495 - raventid:improve-e0425-message, r=estebank

Improve error message for E0424

Resolves #54369

r? @estebank

5 years agoAuto merge of #54485 - arielb1:avoid-ctor-attrs, r=eddyb
bors [Sun, 23 Sep 2018 21:46:59 +0000 (21:46 +0000)]
Auto merge of #54485 - arielb1:avoid-ctor-attrs, r=eddyb

avoid loading constructor attributes in AdtDef decoding

During metadata loading, the AdtDefs for every ADT in the universe need
to be loaded (for example, for coherence of builtin traits). For that,
the attributes of the AdtDef need to be loaded too.

The attributes of a struct are duplicated between 2 def ids - the
constructor def-id, and the "type" def id. Loading attributes for both
def-ids, which was done in #53721, slowed the compilation of small
crates by 2-3%. This PR makes sure we only load the attributes for the
"type" def-id, avoiding the slowdown.

r? @eddyb & cc @nnethercote

5 years agoAdd test to check if inlining works for any operand
Christian Poveda [Sat, 22 Sep 2018 21:48:33 +0000 (16:48 -0500)]
Add test to check if inlining works for any operand

5 years agodbg_macro: fix line numbers
Mazdak Farrokhzad [Sun, 23 Sep 2018 20:48:24 +0000 (22:48 +0200)]
dbg_macro: fix line numbers

5 years agoUpdate tests for changes to drop access
Matthew Jasper [Sun, 23 Sep 2018 15:19:00 +0000 (16:19 +0100)]
Update tests for changes to drop access

5 years agoRework checking for borrows conflicting with drops
Matthew Jasper [Sun, 23 Sep 2018 15:07:45 +0000 (16:07 +0100)]
Rework checking for borrows conflicting with drops

Previously, we would split the drop access into multiple checks for each
field of a struct/tuple/closure and through `Box` dereferences. This
changes this to check if the borrow is accessed by the drop in
places_conflict.

This also allows us to handle enums in a simpler way, since we don't
have to construct any new places.

5 years agoRemove irrelevant message about drop order
Matthew Jasper [Sun, 23 Sep 2018 14:56:14 +0000 (15:56 +0100)]
Remove irrelevant message about drop order

When dropping a self-borrowing struct we shouldn't add a "values in a
scope are dropped in the opposite order they are defined" message,
since there is only one value being dropped.

5 years agoAuto merge of #54229 - davidtwco:issue-52534, r=pnkfelix
bors [Sun, 23 Sep 2018 15:00:53 +0000 (15:00 +0000)]
Auto merge of #54229 - davidtwco:issue-52534, r=pnkfelix

[nll] borrows that must be valid for a free lifetime should explain why

Fixes #52534.

r? @nikomatsakis

5 years agoadd test for edition 2018
csmoe [Sun, 23 Sep 2018 14:59:06 +0000 (22:59 +0800)]
add test for edition 2018

5 years agodeny overflow literals
csmoe [Sun, 23 Sep 2018 14:58:47 +0000 (22:58 +0800)]
deny overflow literals

5 years agodbg_macro: only ignore cloudabi and emscripten
Mazdak Farrokhzad [Sun, 23 Sep 2018 13:59:34 +0000 (15:59 +0200)]
dbg_macro: only ignore cloudabi and emscripten

5 years agodbg_macro: more things...
Mazdak Farrokhzad [Sun, 23 Sep 2018 13:50:11 +0000 (15:50 +0200)]
dbg_macro:  more things...

5 years agoAuto merge of #54380 - RalfJung:miri-snapshot, r=eddyb
bors [Sun, 23 Sep 2018 12:33:54 +0000 (12:33 +0000)]
Auto merge of #54380 - RalfJung:miri-snapshot, r=eddyb

move CTFE engine snapshot state out of miri engine into CTFE machine instance

It still lives in the `interpret` module as it needs access to all sorts of private stuff. Also rename a thing to make @eddyb happy :D

The goal was not to change any behavior.

5 years agoOnly annotate if borrow is returned.
David Wood [Wed, 19 Sep 2018 00:48:47 +0000 (02:48 +0200)]
Only annotate if borrow is returned.

Error now correctly checks whether the borrow that does not live
long enough is being returned before annotating the error with the
arguments and return type from the signature - as this would not be
relevant if the borrow was not being returned.

5 years agoCorrectly handle named lifetimes.
David Wood [Tue, 18 Sep 2018 19:28:06 +0000 (21:28 +0200)]
Correctly handle named lifetimes.

Enhances annotation logic to properly consider named lifetimes where
lifetime elision rules that were previously implemented would not apply.

Further, adds new help and note messages to diagnostics and highlights
only lifetime when dealing with named lifetimes.

5 years agoRenamed ppaux highlight region hook.
David Wood [Tue, 18 Sep 2018 19:26:45 +0000 (21:26 +0200)]
Renamed ppaux highlight region hook.

Changed `highlight_region_with_region` function(s) to
`highlight_region_with_bound_region` to be more specific and less
ambigious.

5 years agoAdded note about dangling references.
David Wood [Mon, 17 Sep 2018 18:49:21 +0000 (20:49 +0200)]
Added note about dangling references.

This error can only occur within a function when a borrow of data owned
within the function is returned; and when there are arguments that could
have been returned instead. Therefore, it is always applicable to add a
specific note that links to the relevant rust documentation about
dangling references.

5 years agoFixed off-by-one span.
David Wood [Mon, 17 Sep 2018 17:39:37 +0000 (19:39 +0200)]
Fixed off-by-one span.

Fixes the off-by-one span issue where closure argument spans were
pointing to the token after the argument.

5 years agoAdded multiple parameter closure test.
David Wood [Mon, 17 Sep 2018 08:48:44 +0000 (10:48 +0200)]
Added multiple parameter closure test.

New test has multiple parameters in a closure with longer names in order
to clarify the issues relating to odd spans.

5 years agoImprove 'dropped here' note.
David Wood [Fri, 14 Sep 2018 21:13:24 +0000 (23:13 +0200)]
Improve 'dropped here' note.

Start mentioning function name that the variable is valid within in
notes to provide context.

5 years agoImprove borrow errors for closures.
David Wood [Fri, 14 Sep 2018 13:44:45 +0000 (15:44 +0200)]
Improve borrow errors for closures.

Adds improved messages for closures where returned type
does not match the inferred return lifetime of the closure.

5 years agoImprove non-closure, reference in-and-out errors.
David Wood [Tue, 11 Sep 2018 15:57:58 +0000 (17:57 +0200)]
Improve non-closure, reference in-and-out errors.

For cases where there are references in the parameters and in the the
outputs that do not match, and where no closures are involved, this
commit introduces an improved error that mentions (or synthesizes)
a name for the regions involved to better illustrate why the borrow
does not live long enough.

5 years agoRefactor MirBorrowckCtxt to take infcx instead of tcx.
David Wood [Tue, 11 Sep 2018 14:38:35 +0000 (16:38 +0200)]
Refactor MirBorrowckCtxt to take infcx instead of tcx.

5 years agoRefactor region naming for control of diagnostics.
David Wood [Tue, 11 Sep 2018 11:27:39 +0000 (13:27 +0200)]
Refactor region naming for control of diagnostics.

Previously, region naming would always highlight the source of the
region name it found. Now, region naming returns the name as part
of a larger structure that encodes the source of the region naming
such that a region name can be optionally added to the diagnostic.

5 years agoRefactor explain_borrow to return explanation.
David Wood [Sun, 9 Sep 2018 17:34:39 +0000 (19:34 +0200)]
Refactor explain_borrow to return explanation.

Previously, explain_borrow would emit an error with the explanation of
the a borrow. Now, it returns a enum with what the explanation for the
borrow is and any relevant spans or information such that the calling
code can choose to emit the same note/suggestion as before by calling
the emit method on the new enum.

5 years agoAuto merge of #54339 - cramertj:no-cx, r=aturon
bors [Sun, 23 Sep 2018 10:09:22 +0000 (10:09 +0000)]
Auto merge of #54339 - cramertj:no-cx, r=aturon

Remove spawning from task::Context

r? @aturon

cc https://github.com/rust-lang-nursery/wg-net/issues/56

5 years agoAuto merge of #54325 - michaelwoerister:incr-thinlto-tests, r=alexcrichton
bors [Sun, 23 Sep 2018 07:38:17 +0000 (07:38 +0000)]
Auto merge of #54325 - michaelwoerister:incr-thinlto-tests, r=alexcrichton

incr.comp.: Allow for more fine-grained testing of CGU reuse and use it to test incremental ThinLTO.

This adds some tests specifically targeted at incremental ThinLTO, plus the infrastructure for tracking the kind of cache hit/miss we had for a given CGU. @alexcrichton, let me know if you can think of any more tests to add. ThinLTO works rather reliably for small functions, so we should be able to test it in a robust way.

I think after this lands it might time for a "Help us test incremental ThinLTO" post on irlo.

r? @alexcrichton

5 years agoMake the `Vec::dedup` method use `slice::partition_dedup` internally
Clément Renault [Sun, 16 Sep 2018 21:32:16 +0000 (23:32 +0200)]
Make the `Vec::dedup` method use `slice::partition_dedup` internally

5 years agoIntroduce the partition_dedup/by/by_key methods for slices
Clément Renault [Sat, 8 Sep 2018 13:33:02 +0000 (15:33 +0200)]
Introduce the partition_dedup/by/by_key methods for slices

5 years agoand llvm has https now
Sylvestre Ledru [Sun, 23 Sep 2018 06:27:39 +0000 (08:27 +0200)]
and llvm has https now

5 years agoThe project moved under the Mozilla umbrella
Sylvestre Ledru [Sun, 23 Sep 2018 06:26:34 +0000 (08:26 +0200)]
The project moved under the Mozilla umbrella

5 years agoAuto merge of #54310 - pnkfelix:issue-52059-report-borrow-drop-conflict, r=nikomatsakis
bors [Sun, 23 Sep 2018 04:06:15 +0000 (04:06 +0000)]
Auto merge of #54310 - pnkfelix:issue-52059-report-borrow-drop-conflict, r=nikomatsakis

Report when borrow could cause `&mut` aliasing during Drop

We were already issuing an error for the cases where this cropped up, so this is not fixing any soundness holes. The previous diagnostic just wasn't accurately describing the problem in the user's code.

Fix #52059

5 years agoImprove error message for E0424
Julian Kulesh [Sun, 23 Sep 2018 02:35:42 +0000 (05:35 +0300)]
Improve error message for E0424

5 years agoAuto merge of #54262 - matthewjasper:explain-in-typeck, r=nikomatsakis
bors [Sun, 23 Sep 2018 01:39:54 +0000 (01:39 +0000)]
Auto merge of #54262 - matthewjasper:explain-in-typeck, r=nikomatsakis

[NLL] Record more infomation on free region constraints in typeck

Changes:

* Makes the span of the MIR return place point to the return type
* Don't try to use a path to a type alias as a path to the adt it aliases (fixes an ICE)
* Don't claim that `self` is declared outside of the function. [see this test](https://github.com/rust-lang/rust/commit/f2995d5b1ad0401a80ac4579ebc89295818c3eed#diff-0c9e6b1b204f42129b481df9ce459d44)
* Remove boring/interesting distinction and instead add a `ConstraintCategory` to the constraint.
* Add categories for implicit `Sized` and `Copy` requirements, for closure bounds, for user type annotations and `impl Trait`.
* Don't use the span of the first statement for Locations::All bounds (even if it happens to work on the tests we have)

Future work:

* Fine tuning the heuristic used to choose the place the report the error.
* Reporting multiple places (behind a flag)
* Better closure bounds reporting. This probably requires some discussion.

r? @nikomatsakis

5 years agoupdate rls to 32d457717ce37babef199fe4984b1e20d4e108d4
Matthias Krüger [Sat, 22 Sep 2018 21:58:03 +0000 (23:58 +0200)]
update rls to 32d457717ce37babef199fe4984b1e20d4e108d4

5 years agostabilize pattern_parentheses feature
Alex Stokes [Sun, 23 Sep 2018 00:07:56 +0000 (17:07 -0700)]
stabilize pattern_parentheses feature