]> git.lizzy.rs Git - rust.git/log
rust.git
6 years agoAdd a link to the rustc docs
mark [Wed, 4 Jul 2018 22:24:43 +0000 (17:24 -0500)]
Add a link to the rustc docs

6 years agoAuto merge of #51611 - QuietMisdreavus:slippery-macros, r=ollie27
bors [Wed, 4 Jul 2018 18:15:14 +0000 (18:15 +0000)]
Auto merge of #51611 - QuietMisdreavus:slippery-macros, r=ollie27

rustdoc: import cross-crate macros alongside everything else

The thrilling conclusion of the cross-crate macro saga in rustdoc! After https://github.com/rust-lang/rust/pull/51425 made sure we saw all the namespaces of an import (and prevented us from losing the `vec!` macro in std's documentation), here is the PR to handle cross-crate macro re-exports at the same time as everything else. This way, attributes like `#[doc(hidden)]` and `#[doc(no_inline)]` can be used to control how the documentation for these macros is seen, rather than rustdoc inlining every macro every time.

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

6 years agoAuto merge of #51395 - SimonSapin:repr-transparent, r=SimonSapin
bors [Wed, 4 Jul 2018 16:21:42 +0000 (16:21 +0000)]
Auto merge of #51395 - SimonSapin:repr-transparent, r=SimonSapin

Add #[repr(transparent)] to some libcore types

* `UnsafeCell`
* `Cell`
* `NonZero*`
* `NonNull`
* `Unique`

CC https://github.com/rust-lang/rust/issues/43036

6 years agoAuto merge of #51870 - nnethercote:reuse-DefsUsesVisitor, r=nikomatsakis
bors [Wed, 4 Jul 2018 14:12:14 +0000 (14:12 +0000)]
Auto merge of #51870 - nnethercote:reuse-DefsUsesVisitor, r=nikomatsakis

Reuse the `DefsUsesVisitor` in `simulate_block()`.

This avoids a bunch of allocations for the bitsets within it,
speeding up a number of NLL benchmarks, the best by 1%.

r? @nikomatsakis

6 years agoAuto merge of #51935 - cramertj:unpin-references, r=withoutboats
bors [Wed, 4 Jul 2018 11:32:40 +0000 (11:32 +0000)]
Auto merge of #51935 - cramertj:unpin-references, r=withoutboats

Unpin references

I also considered adding an impl for raw pointers as well, but that makes it easy to accidentally have unsound owning-collections that might otherwise be able to project pinned-ness (e.g. `Box`).

cc @RalfJung

r? @withoutboats

6 years agoAuto merge of #51895 - nikomatsakis:move-self-trait-predicate-to-items, r=scalexm
bors [Wed, 4 Jul 2018 09:33:33 +0000 (09:33 +0000)]
Auto merge of #51895 - nikomatsakis:move-self-trait-predicate-to-items, r=scalexm

Move self trait predicate to items

This is a "reimagination" of @tmandry's PR #50183. The main effect is described in this comment from one of the commits:

---

Before we had the following results for `predicates_of`:

```rust
trait Foo { // predicates_of: Self: Foo
  fn bar(); // predicates_of: Self: Foo (inherited from trait)
}
```

Now we have removed the `Self: Foo` from the trait. However, we still
add it to the trait ITEM. This is because when people do things like
`<T as Foo>::bar()`, they still need to prove that `T: Foo`, and
having it in the `predicates_of` seems to be the cleanest way to
ensure that happens right now (otherwise, we'd need special case code
in various places):

```rust
trait Foo { // predicates_of: []
  fn bar(); // predicates_of: Self: Foo
}
```

However, we sometimes want to get the list of *just* the predicates
truly defined on a trait item (e.g., for chalk, but also for a few
other bits of code). For that, we define `predicates_defined_on`,
which does not contain the `Self: Foo` predicate yet, and we plumb
that through metadata and so forth.

---

I'm assigning @eddyb as the main reviewer, but I thought I might delegate to scalexm for this one in any case. I also want to post an alternative that I'll leave in the comments; it occurred to me as I was writing. =)

r? @eddyb
cc @scalexm @tmandry @leodasvacas

6 years agoReuse the `DefsUsesVisitor` in `simulate_block()`.
Nicholas Nethercote [Thu, 28 Jun 2018 06:30:33 +0000 (16:30 +1000)]
Reuse the `DefsUsesVisitor` in `simulate_block()`.

This avoids a bunch of allocations for the bitsets within it,
speeding up a number of NLL benchmarks, the best by 1%.

6 years agoAuto merge of #51926 - matthewjasper:Initialization-span, r=nikomatsakis
bors [Tue, 3 Jul 2018 23:54:25 +0000 (23:54 +0000)]
Auto merge of #51926 - matthewjasper:Initialization-span, r=nikomatsakis

[NLL] Use better span for initializing a variable twice

Closes #51217

When assigning to a (projection from a) local immutable local which starts initialised (everything except `let PATTERN;`):

* Point to the declaration of that local
* Make the error message refer to the local, rather than the projection.

r? @nikomatsakis

6 years agoAuto merge of #51900 - PramodBisht:51813_b, r=nikomatsakis
bors [Tue, 3 Jul 2018 21:48:37 +0000 (21:48 +0000)]
Auto merge of #51900 - PramodBisht:51813_b, r=nikomatsakis

introduce dirty list to dataflow

@nikomatsakis my naive implementation never worked, So, I decided to implement using `work_queue` data structure. This PR also includes your commits from `nll-liveness-dirty-list` branch. Those commits should not visible once your branch is merged.

r? @nikomatsakis

6 years agoAuto merge of #51450 - estebank:inner-fn-test, r=@pnkfelix
bors [Tue, 3 Jul 2018 18:00:16 +0000 (18:00 +0000)]
Auto merge of #51450 - estebank:inner-fn-test, r=@pnkfelix

Add lint warning for inner function marked as `#[test]`

Fix #36629.

6 years agotest for renaming re-exported macros
QuietMisdreavus [Tue, 3 Jul 2018 15:40:11 +0000 (10:40 -0500)]
test for renaming re-exported macros

6 years agoAuto merge of #52014 - pietroalbini:rollup, r=pietroalbini
bors [Tue, 3 Jul 2018 12:26:14 +0000 (12:26 +0000)]
Auto merge of #52014 - pietroalbini:rollup, r=pietroalbini

Rollup of 13 pull requests

Successful merges:

 - #51548 (Initialize LLVM's AMDGPU target machine, if available.)
 - #51809 (Add read_exact_at and write_all_at methods to FileExt on unix)
 - #51914 (add outlives annotations to `BTreeMap`)
 - #51958 (Show known meta items in unknown meta items error)
 - #51973 (Make Stdio handle UnwindSafe)
 - #51977 (bootstrap: tests should use rustc from config.toml)
 - #51978 (Do not suggest changes to str literal if it isn't one)
 - #51979 (Get rid of `TyImplTraitExistential`)
 - #51980 (Emit column info in debuginfo for non msvc like targets)
 - #51982 (incr.comp.: Take names of children into account when computing the ICH of a module's HIR.)
 - #51997 (add entry for cargo-metadata feature to RELEASES)
 - #52004 (toolstate: Fixed detection of changed submodule, and other fixes.)
 - #52006 ( Change --keep-stage to apply more often)

Failed merges:

r? @ghost

6 years agoRollup merge of #52006 - Mark-Simulacrum:keep-stage-fix, r=alexcrichton
Pietro Albini [Tue, 3 Jul 2018 09:31:13 +0000 (11:31 +0200)]
Rollup merge of #52006 - Mark-Simulacrum:keep-stage-fix, r=alexcrichton

 Change --keep-stage to apply more often

Previously, the --keep-stage argument would only function for compilers
that were depended on by future stages. For example, if trying to build
a stage 1 compiler you could --keep-stage 0 to avoid re-building the
stage 0 compiler. However, this is often not what users want in
practice.

The new implementation essentially skips builds all higher stages of the
compiler, so an argument of 1 to keep-stage will skip rebuilds of the
libraries, just linking them into the sysroot. This is unlikely to work
well in cases where metadata or similar changes have been made, but is
likely fine otherwise.

This change is somewhat untested, but since it shouldn't have any effect
except with --keep-stage, I don't see that as a large problem.

r? @alexcrichton
cc @nikomatsakis - I believe you wanted this functionality

6 years agoRollup merge of #52004 - kennytm:toolstate-fixes, r=Mark-Simulacrum
Pietro Albini [Tue, 3 Jul 2018 09:31:12 +0000 (11:31 +0200)]
Rollup merge of #52004 - kennytm:toolstate-fixes, r=Mark-Simulacrum

toolstate: Fixed detection of changed submodule, and other fixes.

1. Make sure that if a submodule is updated but failed to test-pass, we'll block the merge.
2. Make sure failure on external docs (nomicon/RBE/etc) are properly checked.
3. If the commit message starts with "Update RLS" (or clippy etc), automatically run the "tools" job on the PR, so that we could know if the update failed before merging.

6 years agoRollup merge of #51997 - euclio:release-notes, r=Aaronepower
Pietro Albini [Tue, 3 Jul 2018 09:31:11 +0000 (11:31 +0200)]
Rollup merge of #51997 - euclio:release-notes, r=Aaronepower

add entry for cargo-metadata feature to RELEASES

6 years agoRollup merge of #51982 - michaelwoerister:hash-modules-properly, r=nikomatsakis
Pietro Albini [Tue, 3 Jul 2018 09:31:10 +0000 (11:31 +0200)]
Rollup merge of #51982 - michaelwoerister:hash-modules-properly, r=nikomatsakis

incr.comp.: Take names of children into account when computing the ICH of a module's HIR.

Fixes #40876. Red-green tracking does not make this a problem anymore. We should verify this via a perf-run though.

r? @nikomatsakis

6 years agoRollup merge of #51980 - est31:columns, r=alexcrichton
Pietro Albini [Tue, 3 Jul 2018 09:31:09 +0000 (11:31 +0200)]
Rollup merge of #51980 - est31:columns, r=alexcrichton

Emit column info in debuginfo for non msvc like targets

Fixes #42921 everywhere except MSVC. This mimics clang behaviour.

6 years agoRollup merge of #51979 - oli-obk:lowering_cleanups4, r=nikomatsakis
Pietro Albini [Tue, 3 Jul 2018 09:31:07 +0000 (11:31 +0200)]
Rollup merge of #51979 - oli-obk:lowering_cleanups4, r=nikomatsakis

Get rid of `TyImplTraitExistential`

cc @eddyb

r? @nikomatsakis

6 years agoRollup merge of #51978 - estebank:issue-48364, r=oli-obk
Pietro Albini [Tue, 3 Jul 2018 09:31:06 +0000 (11:31 +0200)]
Rollup merge of #51978 - estebank:issue-48364, r=oli-obk

Do not suggest changes to str literal if it isn't one

Fix #48364.

6 years agoRollup merge of #51977 - mnd:fix-bootstrap-test-with-local-stage0, r=simulacrum
Pietro Albini [Tue, 3 Jul 2018 09:31:04 +0000 (11:31 +0200)]
Rollup merge of #51977 - mnd:fix-bootstrap-test-with-local-stage0, r=simulacrum

bootstrap: tests should use rustc from config.toml

Tests should always use "rustc" and "cargo" from config.toml instead of assuming that stage0 binaries was downloaded to build directory.

Without this change `./x.py test src/bootstrap` will always try to use `build/ARCH/stage0/bin/rustc` file as compiler, but when we use local compiler to bootstrap this file does not exist.

6 years agoRollup merge of #51973 - estk:master, r=abonander
Pietro Albini [Tue, 3 Jul 2018 09:31:03 +0000 (11:31 +0200)]
Rollup merge of #51973 - estk:master, r=abonander

Make Stdio handle UnwindSafe

Closes  #51863

This is my first compiler PR. Thanks Niko for the mentor help!

r? @nikomatsakis

6 years agoRollup merge of #51958 - euclio:attr-refactor, r=petrochenkov
Pietro Albini [Tue, 3 Jul 2018 09:31:01 +0000 (11:31 +0200)]
Rollup merge of #51958 - euclio:attr-refactor, r=petrochenkov

Show known meta items in unknown meta items error

This PR adds a label to E0541. It also factors built-in attribute parsing into a submodule of `attr` for ease of future refactoring.

Fixes #51469.

6 years agoRollup merge of #51914 - nikomatsakis:nll-fix-issue-issue-btreemap-annotations, r...
Pietro Albini [Tue, 3 Jul 2018 09:31:00 +0000 (11:31 +0200)]
Rollup merge of #51914 - nikomatsakis:nll-fix-issue-issue-btreemap-annotations, r=gankro

add outlives annotations to `BTreeMap`

NLL requires these annotations, I believe because of <https://github.com/rust-lang/rust/issues/29149>.

Fixes #48224

r? @Gankro
cc @lqd

6 years agoRollup merge of #51809 - drrlvn:rw_exact_all_at, r=alexcrichton
Pietro Albini [Tue, 3 Jul 2018 09:30:59 +0000 (11:30 +0200)]
Rollup merge of #51809 - drrlvn:rw_exact_all_at, r=alexcrichton

Add read_exact_at and write_all_at methods to FileExt on unix

This PR adds `FileExt::read_exact_at()` and `FileExt::write_all_at()`, which are to `read_at()` and `write_at()` as `read_exact()` and `write_all()` are to `read()` and `write()`. This allows the user to not have to deal with `ErrorKind::Interrupted` and calling the functions in a loop.

I was unsure as to how to mark these new methods so I marked them `unstable`, please let me know if I should have done it differently.

I asked in Discord and was told that as this change is small it does not require an RFC.

6 years agoRollup merge of #51548 - DiamondLovesYou:amdgpu-target-machine, r=alexcrichton
Pietro Albini [Tue, 3 Jul 2018 09:30:57 +0000 (11:30 +0200)]
Rollup merge of #51548 - DiamondLovesYou:amdgpu-target-machine, r=alexcrichton

Initialize LLVM's AMDGPU target machine, if available.

Note this isn't useful, yet. More changes will be necessary to be able to
actually codegen for this machine. As such, it is not enabled by default.

This patch is on its own for the benefit of the reviewers.

6 years agoAvoid sorting the item_ids array the StableHash impl of hir::Mod.
Michael Woerister [Tue, 3 Jul 2018 09:16:38 +0000 (11:16 +0200)]
Avoid sorting the item_ids array the StableHash impl of hir::Mod.

6 years agoAuto merge of #51889 - spastorino:make-causal-tracking-lazy, r=nikomatsakis
bors [Tue, 3 Jul 2018 09:08:58 +0000 (09:08 +0000)]
Auto merge of #51889 - spastorino:make-causal-tracking-lazy, r=nikomatsakis

Make causal tracking lazy

Closes #51710

r? @nikomatsakis

6 years agoAuto merge of #51695 - est31:stdsimd_update, r=alexcrichton
bors [Tue, 3 Jul 2018 07:06:46 +0000 (07:06 +0000)]
Auto merge of #51695 - est31:stdsimd_update, r=alexcrichton

Update stdsimd

Closes #51691

6 years agoAuto merge of #51564 - SimonSapin:try-int, r=alexcrichton
bors [Tue, 3 Jul 2018 04:08:02 +0000 (04:08 +0000)]
Auto merge of #51564 - SimonSapin:try-int, r=alexcrichton

Implement always-fallible TryFrom for usize/isize conversions that are infallible on some platforms

This reverts commit 837d6c70233715a0ae8e15c703d40e3046a2f36a "Remove TryFrom impls that might become conditionally-infallible with a portability lint".

This fixes #49415 by adding (restoring) missing `TryFrom` impls for integer conversions to or from `usize` or `isize`, by making them always fallible at the type system level (that is, with `Error=TryFromIntError`) even though they happen to be infallible on some platforms (for some values of `size_of::<usize>()`).

They had been removed to allow the possibility to conditionally having some of them be infallible `From` impls instead, depending on the platforms, and have the [portability lint](https://github.com/rust-lang/rfcs/pull/1868) warn when they are used in code that is not already opting into non-portability. For example `#[allow(some_lint)] usize::from(x: u64)` would be valid on code that only targets 64-bit platforms.

This PR gives up on this possiblity for two reasons:

* Based on discussion with @aturon, it seems that the portability lint is not happening any time soon. It’s better to have the conversions be available *at all* than keep blocking them for so long. Portability-lint-gated platform-specific APIs can always be added separately later.

* For code that is fine with fallibility, the alternative would force it to opt into "non-portability" even though there would be no real portability issue.

6 years agoAuto merge of #51428 - alexreg:uninitialized-statics-simplification, r=oli-obk
bors [Tue, 3 Jul 2018 02:01:49 +0000 (02:01 +0000)]
Auto merge of #51428 - alexreg:uninitialized-statics-simplification, r=oli-obk

Removed `uninitialized_statics` field from `Memory` struct in miri

based on #51110

r? @oli-obk

CC @eddyb

6 years agoAuto merge of #51991 - oli-obk:clippy, r=kennytm
bors [Mon, 2 Jul 2018 23:50:13 +0000 (23:50 +0000)]
Auto merge of #51991 - oli-obk:clippy, r=kennytm

Update the clippy submodule

nth time is the charm? `x.py test src/tools/clippy` passes locally

r? @kennytm

6 years agoChange --keep-stage to apply more
Mark Rousskov [Mon, 2 Jul 2018 22:04:58 +0000 (16:04 -0600)]
Change --keep-stage to apply more

Previously, the --keep-stage argument would only function for compilers
that were depended on by future stages. For example, if trying to build
a stage 1 compiler you could --keep-stage 0 to avoid re-building the
stage 0 compiler. However, this is often not what users want in
practice.

The new implementation essentially skips builds all higher stages of the
compiler, so an argument of 1 to keep-stage will skip rebuilds of the
libraries, just linking them into the sysroot. This is unlikely to work
well in cases where metadata or similar changes have been made, but is
likely fine otherwise.

This change is somewhat untested, but since it shouldn't have any effect
except with --keep-stage, I don't see that as a large problem.

6 years agoRun "tools" job on PR when commit message starts with "Update RLS/miri/..."
kennytm [Mon, 2 Jul 2018 22:01:58 +0000 (06:01 +0800)]
Run "tools" job on PR when commit message starts with "Update RLS/miri/..."

6 years agoFixed detection of test-fail for doctests.
kennytm [Mon, 2 Jul 2018 21:53:18 +0000 (05:53 +0800)]
Fixed detection of test-fail for doctests.

6 years agoFix the tool's path in toolstate verification.
kennytm [Mon, 2 Jul 2018 20:49:42 +0000 (04:49 +0800)]
Fix the tool's path in toolstate verification.

This ensure we do block the tools when they are broken during an update.

6 years agoMake explicit that assemble is not run from CLI
Mark Rousskov [Mon, 2 Jul 2018 20:46:40 +0000 (14:46 -0600)]
Make explicit that assemble is not run from CLI

6 years agoAddress #51813
Pramod Bisht [Mon, 2 Jul 2018 18:48:54 +0000 (00:18 +0530)]
Address #51813

6 years agoAuto merge of #51944 - MajorBreakfast:generic-future-obj, r=cramertj
bors [Mon, 2 Jul 2018 20:12:00 +0000 (20:12 +0000)]
Auto merge of #51944 - MajorBreakfast:generic-future-obj, r=cramertj

Make custom trait object for `Future` generic

- `TaskObj` -> `FutureObj<'static, ()>`
- The `impl From<...> for FutureObj<'a, T>` impls are impossible because of the type parameter `T`. The impl has to live in libstd, but `FutureObj<'a, T>` is from libcore. Therefore `Into<FutureObj<'a, T>>` was implemented instead. Edit: This didn‘t compile without warnings. I am now using non-generic Form impls.

See https://github.com/rust-lang-nursery/futures-rs/issues/1058

r? @cramertj

Edit: Added lifetime

6 years agoMake Stdio handle UnwindSafe
Evan Simmons [Sun, 1 Jul 2018 21:30:16 +0000 (14:30 -0700)]
Make Stdio handle UnwindSafe

6 years agoAuto merge of #51896 - nikomatsakis:nll-liveness-dirty-list, r=Zoxc
bors [Mon, 2 Jul 2018 18:09:20 +0000 (18:09 +0000)]
Auto merge of #51896 - nikomatsakis:nll-liveness-dirty-list, r=Zoxc

introduce dirty list to liveness, eliminate `ins` vector

At least in my measurements, this seems to knock much of the liveness computation off the profile.

r? @Zoxc
cc @nnethercote

6 years agoadd entry for cargo-metadata feature to RELEASES
Andy Russell [Mon, 2 Jul 2018 17:47:51 +0000 (13:47 -0400)]
add entry for cargo-metadata feature to RELEASES

6 years agoImplemented `UnsafeFutureObj` on `Box`
Josef Reinhard Brandl [Mon, 2 Jul 2018 17:21:32 +0000 (19:21 +0200)]
Implemented `UnsafeFutureObj` on `Box`

6 years agoImplement `UnsafeFutureObj` for `&mut Future`
Josef Reinhard Brandl [Mon, 2 Jul 2018 17:07:59 +0000 (19:07 +0200)]
Implement `UnsafeFutureObj` for `&mut Future`

6 years agoUpdate the clippy submodule
Oliver Schneider [Mon, 2 Jul 2018 17:07:35 +0000 (19:07 +0200)]
Update the clippy submodule

6 years agoRemove unnecessary `PhantomData` field
Josef Reinhard Brandl [Mon, 2 Jul 2018 16:57:58 +0000 (18:57 +0200)]
Remove unnecessary `PhantomData` field

6 years agoAdd explanation for custom trait object
Josef Reinhard Brandl [Mon, 2 Jul 2018 16:55:42 +0000 (18:55 +0200)]
Add explanation for custom trait object

6 years agobootstrap: tests should use rustc from config.toml
Nikolai Merinov [Sun, 1 Jul 2018 20:45:35 +0000 (01:45 +0500)]
bootstrap: tests should use rustc from config.toml

Tests should always use "rustc" and "cargo" from config.toml instead
of assuming that stage0 binaries was downloaded to build directory.

6 years agoAdd some more additional functions to the shim
est31 [Mon, 2 Jul 2018 09:55:52 +0000 (11:55 +0200)]
Add some more additional functions to the shim

They are all needed now due to the stdsimd update.

6 years agoUpdated miri submodule.
Alexander Regueiro [Mon, 2 Jul 2018 16:18:38 +0000 (17:18 +0100)]
Updated miri submodule.

6 years agoFix naming convention issue
Josef Reinhard Brandl [Mon, 2 Jul 2018 16:16:36 +0000 (18:16 +0200)]
Fix naming convention issue

6 years agoAuto merge of #51321 - zackmdavis:hiridification_generations, r=eddyb
bors [Mon, 2 Jul 2018 16:04:54 +0000 (16:04 +0000)]
Auto merge of #51321 - zackmdavis:hiridification_generations, r=eddyb

HirId-ification, continued

Another incremental step towards the vision of #50928 (previously: #50929).

r? @michaelwoerister

6 years agoadd outlives annotations to `BTreeMap`
Niko Matsakis [Tue, 20 Feb 2018 15:26:48 +0000 (10:26 -0500)]
add outlives annotations to `BTreeMap`

nll requires these annotations, I believe because of
https://github.com/rust-lang/rust/issues/29149

6 years agoimprove comments
Niko Matsakis [Mon, 2 Jul 2018 15:40:49 +0000 (11:40 -0400)]
improve comments

6 years agointroduce `predicates_defined_on` for traits
Niko Matsakis [Mon, 2 Jul 2018 14:35:30 +0000 (10:35 -0400)]
introduce `predicates_defined_on` for traits

This new query returns only the predicates *directly defined* on an
item (in contrast to the more common `predicates_of`, which returns
the predicates that must be proven to reference an item). These two
sets are almost always identical except for traits, where
`predicates_of` includes an artificial `Self: Trait<...>` predicate
(basically saying that you cannot use a trait item without proving
that the trait is implemented for the type parameters).

This new query is only used in chalk lowering, where this artificial
`Self: Trait` predicate is problematic. We encode it in metadata but
only where needed since it is kind of repetitive with existing
information.

Co-authored-by: Tyler Mandry <tmandry@gmail.com>
6 years agoadd `is_trait(DefId)` helper to `TyCtxt`
Niko Matsakis [Mon, 2 Jul 2018 14:34:19 +0000 (10:34 -0400)]
add `is_trait(DefId)` helper to `TyCtxt`

Co-authored-by: Tyler Mandry <tmandry@gmail.com>
6 years agodrive-by nits and debug
Niko Matsakis [Mon, 2 Jul 2018 14:33:18 +0000 (10:33 -0400)]
drive-by nits and debug

Co-authored-by: Tyler Mandry <tmandry@gmail.com>
6 years agouse `ty::TraitRef::identity` where possible
Niko Matsakis [Fri, 29 Jun 2018 10:59:00 +0000 (06:59 -0400)]
use `ty::TraitRef::identity` where possible

Co-authored-by: Tyler Mandry <tmandry@gmail.com>
6 years agoprove defaults meet WF requirements, not that they are WF
Niko Matsakis [Fri, 29 Jun 2018 09:31:59 +0000 (05:31 -0400)]
prove defaults meet WF requirements, not that they are WF

If we have

```rust
struct Foo<T: Copy = String> { .. }
```

the old code would have proven that `String: Copy` was WF -- this,
incidentally, also proved that `String: Copy`. The new code just
proves `String: Copy` directly.

Co-authored-by: Tyler Mandry <tmandry@gmail.com>
6 years agoFill in tracking issue number for read_exact_at/write_all_at
Dror Levin [Mon, 2 Jul 2018 14:38:15 +0000 (17:38 +0300)]
Fill in tracking issue number for read_exact_at/write_all_at

6 years agoincr.comp.: Take names of children into account when computing the ICH of a module...
Michael Woerister [Mon, 2 Jul 2018 14:21:34 +0000 (16:21 +0200)]
incr.comp.: Take names of children into account when computing the ICH of a module's HIR.

6 years agoRemoved `uninitialized_statics` field from `Memory` struct in miri.
Alexander Regueiro [Fri, 8 Jun 2018 02:47:26 +0000 (03:47 +0100)]
Removed `uninitialized_statics` field from `Memory` struct in miri.

Refactored code accordingly.

6 years agoAuto merge of #51122 - oli-obk:clippy, r=Mark-Simulacrum
bors [Mon, 2 Jul 2018 14:04:26 +0000 (14:04 +0000)]
Auto merge of #51122 - oli-obk:clippy, r=Mark-Simulacrum

Did you mean to block nightlies on clippy?

Discussion: https://gitter.im/rust-lang/WG-clippy?at=5b073b6597a0361fb760cdc2

r? @alexcrichton

did I forget anything?

cc @nrc @Manishearth

6 years agoMake `drop` method for `PinMut`'s `UnsafeFutureObj` impl empty
Josef Reinhard Brandl [Sun, 1 Jul 2018 13:27:53 +0000 (15:27 +0200)]
Make `drop` method for `PinMut`'s `UnsafeFutureObj` impl empty

6 years agoImprove doc comments for `FutureObj`
Josef Reinhard Brandl [Sun, 1 Jul 2018 12:58:40 +0000 (14:58 +0200)]
Improve doc comments for `FutureObj`

6 years ago`UnsafeFutureObj` impl for `PinMut`
Josef Reinhard Brandl [Sun, 1 Jul 2018 07:28:16 +0000 (09:28 +0200)]
`UnsafeFutureObj` impl for `PinMut`

6 years agoAdd lifetime to `FutureObj`
Josef Reinhard Brandl [Sat, 30 Jun 2018 19:16:44 +0000 (21:16 +0200)]
Add lifetime to `FutureObj`

6 years agoUse `From` impls for `FutureObj<()>`
Josef Reinhard Brandl [Sat, 30 Jun 2018 17:37:28 +0000 (19:37 +0200)]
Use `From` impls for `FutureObj<()>`

6 years agoMake custom trait object for `Future` generic
Josef Reinhard Brandl [Sat, 30 Jun 2018 15:26:38 +0000 (17:26 +0200)]
Make custom trait object for `Future` generic

6 years agoAuto merge of #51645 - marco-c:error_when_incremental_and_profile, r=michaelwoerister
bors [Mon, 2 Jul 2018 11:58:45 +0000 (11:58 +0000)]
Auto merge of #51645 - marco-c:error_when_incremental_and_profile, r=michaelwoerister

Raise an error if gcov profiling and incremental compilation are both enabled

Fixes #50203.

6 years agoClippy tool also has only a single LICENSE file
Oliver Schneider [Mon, 2 Jul 2018 11:57:29 +0000 (13:57 +0200)]
Clippy tool also has only a single LICENSE file

6 years agoUpdate stdsimd
est31 [Fri, 22 Jun 2018 00:02:51 +0000 (02:02 +0200)]
Update stdsimd

6 years agoEmit column info in debuginfo for non msvc like targets
est31 [Mon, 2 Jul 2018 09:40:32 +0000 (11:40 +0200)]
Emit column info in debuginfo for non msvc like targets

6 years agoUpdate rustdoc
Oliver Schneider [Mon, 2 Jul 2018 08:37:49 +0000 (10:37 +0200)]
Update rustdoc

6 years agoMake sure clippy does not duplicate depenencies
Oliver Schneider [Mon, 2 Jul 2018 08:36:07 +0000 (10:36 +0200)]
Make sure clippy does not duplicate depenencies

6 years agoAuto merge of #51893 - nnethercote:BTreeMap-clone-noalloc, r=nnethercote
bors [Mon, 2 Jul 2018 08:28:12 +0000 (08:28 +0000)]
Auto merge of #51893 - nnethercote:BTreeMap-clone-noalloc, r=nnethercote

Make `BTreeMap::clone()` not allocate when cloning an empty tree.

r? @Gankro

CC @porglezomp

6 years agoGet rid of `TyImplTraitExistential`
Oliver Schneider [Fri, 29 Jun 2018 08:58:17 +0000 (10:58 +0200)]
Get rid of `TyImplTraitExistential`

6 years agoAuto merge of #51931 - cramertj:rm-libbacktrace, r=alexcrichton
bors [Mon, 2 Jul 2018 06:32:16 +0000 (06:32 +0000)]
Auto merge of #51931 - cramertj:rm-libbacktrace, r=alexcrichton

Use in-tree libbacktrace on Fuchsia

cc @abarth

r? @alexcrichton
(welcome back! :smile: )

6 years agoadd FIXMEs pleading for post-@ edit of commentary on mem_categorization
Zack M. Davis [Sat, 2 Jun 2018 23:49:34 +0000 (16:49 -0700)]
add FIXMEs pleading for post-@ edit of commentary on mem_categorization

(The present author fears not being knowledgeable enough to rewrite the
comments unilaterally; merely calling it out is a lazy half-measure, but
at least doesn't actively make things worse the way an ill-informed
rewrite would.)

6 years agouse HirId in middle::mem_categorization::cmt_, and consequences of that
Zack M. Davis [Sun, 3 Jun 2018 01:50:40 +0000 (18:50 -0700)]
use HirId in middle::mem_categorization::cmt_, and consequences of that

For the HirIdification initiative #50928.

6 years agoAuto merge of #51866 - zackmdavis:hir_making_each_day_of_the_year, r=petrochenkov
bors [Mon, 2 Jul 2018 03:18:49 +0000 (03:18 +0000)]
Auto merge of #51866 - zackmdavis:hir_making_each_day_of_the_year, r=petrochenkov

add modifier keyword spans to hir::Visibility; improve unreachable-pub, private-no-mangle lint suggestions

#50455 pointed out that the unreachable-pub suggestion for brace-grouped `use`s was bogus; #50476 partially ameliorated this by marking the suggestion as `Applicability::MaybeIncorrect`, but this is the actual fix.

Meanwhile, another application of having spans available in `hir::Visibility` is found in the private-no-mangle lints, where we can now issue a suggestion to use `pub` if the item has a more restricted visibility marker (this seems much less likely to come up in practice than not having any visibility keyword at all, but thoroughness is a virtue). While we're there, we can also add a helpful note if the item does have a `pub` (but triggered the lint presumably because enclosing modules were private).

![hir_vis](https://user-images.githubusercontent.com/1076988/42018064-ca830290-7a65-11e8-9c4c-48bc846f861f.png)

r? @nrc
cc @Manishearth

6 years agoDo not suggest changes to str literal if it isn't one
Esteban Küber [Mon, 2 Jul 2018 03:03:35 +0000 (20:03 -0700)]
Do not suggest changes to str literal if it isn't one

6 years agoMake `BTreeMap::clone()` not allocate when cloning an empty tree.
Nicholas Nethercote [Fri, 29 Jun 2018 07:02:38 +0000 (17:02 +1000)]
Make `BTreeMap::clone()` not allocate when cloning an empty tree.

6 years agoAuto merge of #51864 - est31:libc_update, r=alexcrichton
bors [Mon, 2 Jul 2018 01:16:13 +0000 (01:16 +0000)]
Auto merge of #51864 - est31:libc_update, r=alexcrichton

Update liblibc

This updates the libc submodule

6 years agoRun rustfmt
Santiago Pastorino [Thu, 28 Jun 2018 23:45:08 +0000 (20:45 -0300)]
Run rustfmt

6 years agoMake causal tracking lazy
Santiago Pastorino [Sun, 1 Jul 2018 22:43:01 +0000 (19:43 -0300)]
Make causal tracking lazy

6 years agoMove find_use stuff to it's own file
Santiago Pastorino [Wed, 27 Jun 2018 19:13:33 +0000 (16:13 -0300)]
Move find_use stuff to it's own file

6 years agolet add_element return by itself
Santiago Pastorino [Tue, 26 Jun 2018 17:24:54 +0000 (14:24 -0300)]
let add_element return by itself

6 years agoAuto merge of #51110 - alexreg:new-static-eval-rules, r=eddyb
bors [Sun, 1 Jul 2018 23:00:27 +0000 (23:00 +0000)]
Auto merge of #51110 - alexreg:new-static-eval-rules, r=eddyb

Loosened rules involving statics mentioning other statics

Before this PR, trying to mention a static in any way other than taking a reference to it caused a compile-time error. So, while

```rust
static A: u32 = 42;
static B: &u32 = &A;
```

compiles successfully,

```rust
static A: u32 = 42;
static B: u32 = A; // error
```

and

```rust
static A: u32 = 42;
static B: u32 = *&A; // error
```

are not possible to express in Rust. On the other hand, introducing an intermediate `const fn` can presently allow one to do just that:

```rust
static A: u32 = 42;
static B: u32 = foo(&A); // success!

const fn foo(a: &u32) -> u32 {
    *a
}
```

Preventing `const fn` from allowing to work around the ban on reading from statics would cripple `const fn` almost into uselessness.
Additionally, the limitation for reading from statics comes from the old const evaluator(s) and is not shared by `miri`.

This PR loosens the rules around use of statics to allow statics to evaluate other statics by value, allowing all of the above examples to compile and run successfully.
Reads from extern (foreign) statics are however still disallowed by miri, because there is no compile-time value to be read.

```rust
extern static A: u32;

static B: u32 = A; // error
```

This opens up a new avenue of potential issues, as a static can now not just refer to other statics or read from other statics, but even contain references that point into itself.
While it might seem like this could cause subtle bugs like allowing a static to be initialized by its own value, this is inherently impossible in miri.
Reading from a static causes the `const_eval` query for that static to be invoked. Calling the `const_eval` query for a static while already inside the `const_eval` query of said static will cause cycle errors.
It is not possible to accidentally create a bug in miri that would enable initializing a static with itself, because the memory of the static *does not exist* while being initialized.
The memory is not uninitialized, it is not there. Thus any change that would accidentally allow reading from a not yet initialized static would cause ICEs.

Tests have been modified according to the new rules, and new tests have been added for writing to `static mut`s within definitions of statics (which needs to fail), and incremental compilation with complex/interlinking static definitions.
Note that incremental compilation did not need to be adjusted, because all of this was already possible before with workarounds (like intermediate `const fn`s) and the encoding/decoding already supports all the possible cases.

r? @eddyb

6 years agoAuto merge of #51969 - pietroalbini:rollup, r=pietroalbini
bors [Sun, 1 Jul 2018 20:48:57 +0000 (20:48 +0000)]
Auto merge of #51969 - pietroalbini:rollup, r=pietroalbini

Rollup of 7 pull requests

Successful merges:

 - #51511 (Stabilize Iterator::flatten in 1.29, fixes #48213.)
 - #51853 (Fix some doc links)
 - #51890 (Fix inconsequential typo in GlobalAlloc doc example)
 - #51920 (use literal span for concrete type suggestion)
 - #51921 (improve the error message when `#[panic_implementation]` is missing)
 - #51922 (rename the llvm-tools component to llvm-tools-preview and tweak its image)
 - #51961 (Fix typo in /src/librustc_resolve/lib.rs)

Failed merges:

r? @ghost

6 years agoRollup merge of #51961 - 11Takanori:fix-typo, r=petrochenkov
Pietro Albini [Sun, 1 Jul 2018 19:18:51 +0000 (21:18 +0200)]
Rollup merge of #51961 - 11Takanori:fix-typo, r=petrochenkov

Fix typo in /src/librustc_resolve/lib.rs

absoluate -> absolute

6 years agoRollup merge of #51922 - japaric:llvm-tools-preview, r=alexcrichton
Pietro Albini [Sun, 1 Jul 2018 19:18:50 +0000 (21:18 +0200)]
Rollup merge of #51922 - japaric:llvm-tools-preview, r=alexcrichton

rename the llvm-tools component to llvm-tools-preview and tweak its image

as per https://github.com/rust-lang/rust/issues/49584#issuecomment-401217483

r? @alexcrichton or @Mark-Simulacrum

6 years agoRollup merge of #51921 - japaric:panic-impl-error, r=nagisa
Pietro Albini [Sun, 1 Jul 2018 19:18:49 +0000 (21:18 +0200)]
Rollup merge of #51921 - japaric:panic-impl-error, r=nagisa

improve the error message when `#[panic_implementation]` is missing

closes #51341

r? @nagisa
cc @phil-opp

6 years agoRollup merge of #51920 - euclio:concrete-type-suggestion, r=estebank
Pietro Albini [Sun, 1 Jul 2018 19:18:47 +0000 (21:18 +0200)]
Rollup merge of #51920 - euclio:concrete-type-suggestion, r=estebank

use literal span for concrete type suggestion

Fixes #51874.

r? @estebank

6 years agoRollup merge of #51890 - Ixrec:patch-3, r=alexcrichton
Pietro Albini [Sun, 1 Jul 2018 19:18:46 +0000 (21:18 +0200)]
Rollup merge of #51890 - Ixrec:patch-3, r=alexcrichton

Fix inconsequential typo in GlobalAlloc doc example

6 years agoRollup merge of #51853 - MajorBreakfast:fix-doc-links, r=cramertj
Pietro Albini [Sun, 1 Jul 2018 19:18:45 +0000 (21:18 +0200)]
Rollup merge of #51853 - MajorBreakfast:fix-doc-links, r=cramertj

Fix some doc links

The futures crate CI always fails because of these intra doc links. I hope that this will fix this issue.

r? @steveklabnik
@cramertj

Edit: I added @steveklabnik as reviewer because this PR also adjusts a link in `src/libstd/error.rs`

6 years agoRollup merge of #51511 - Centril:feature/stabilize_iterator_flatten, r=SimonSapin
Pietro Albini [Sun, 1 Jul 2018 19:18:43 +0000 (21:18 +0200)]
Rollup merge of #51511 - Centril:feature/stabilize_iterator_flatten, r=SimonSapin

Stabilize Iterator::flatten in 1.29, fixes #48213.

This PR stabilizes [`Iterator::flatten`](https://doc.rust-lang.org/nightly/std/iter/trait.Iterator.html#method.flatten) in *version 1.29* (1.28 goes to beta in 10 days, I don't think there's enough time to land it in that time, but let's see...).

Tracking issue is:  #48213.

cc @bluss re. itertools.
r? @SimonSapin
ping @pietroalbini -- let's do a crater run when this passes CI :)

6 years agoAuto merge of #51833 - wesleywiser:faster_large_constant_arrays, r=oli-obk
bors [Sun, 1 Jul 2018 18:43:41 +0000 (18:43 +0000)]
Auto merge of #51833 - wesleywiser:faster_large_constant_arrays, r=oli-obk

Speed up compilation of large constant arrays

This is a different approach to #51672 as suggested by @oli-obk. Rather
than write each repeated value one-by-one, we write the first one and
then copy its value directly into the remaining memory.

With this change, the [toy program](https://github.com/rust-lang/rust/blob/c2f4744d2db4e162df824d0bd0b093ba4b351545/src/test/run-pass/mir_heavy_promoted.rs) goes from 63 seconds to 19 seconds on my machine.

Edit: Inlining `Size::bytes()` saves an additional 6 seconds dropping the total time to 13 seconds on my machine.

Edit2: Now down to 2.8 seconds.

r? @oli-obk

cc @nnethercote @eddyb

6 years agoUpdate liblibc
est31 [Thu, 28 Jun 2018 05:26:01 +0000 (07:26 +0200)]
Update liblibc

6 years agocall it `hir::VisibilityKind` instead of `hir::Visibility_:*`
Zack M. Davis [Sun, 1 Jul 2018 18:05:10 +0000 (11:05 -0700)]
call it `hir::VisibilityKind` instead of `hir::Visibility_:*`

It was pointed out in review that the glob-exported
underscore-suffixed convention for `Spanned` HIR nodes is no longer
preferred: see February 2016's #31487 for AST's migration away from
this style towards properly namespaced NodeKind enums.

This concerns #51968.

6 years agoAuto merge of #51536 - davidtwco:nll-dyn-trait-underscore-error-improvements, r=nikom...
bors [Sun, 1 Jul 2018 15:49:48 +0000 (15:49 +0000)]
Auto merge of #51536 - davidtwco:nll-dyn-trait-underscore-error-improvements, r=nikomatsakis

NLL: bad error message when converting anonymous lifetime to `'static`

Contributes to #46983. This PR doesn't introduce fantastic errors, but it should hopefully lay some groundwork for diagnostic improvements.
r? @nikomatsakis