]> git.lizzy.rs Git - rust.git/log
rust.git
6 years agoAuto merge of #45761 - gnzlbg:xsave_feature, r=alexcrichton
bors [Thu, 9 Nov 2017 23:17:13 +0000 (23:17 +0000)]
Auto merge of #45761 - gnzlbg:xsave_feature, r=alexcrichton

[xsave] whitelist xsave target feature

Required for https://github.com/rust-lang-nursery/stdsimd/issues/171

6 years agoAuto merge of #45757 - mikhail-m1:change-mir-dump-filename, r=nikomatsakis
bors [Thu, 9 Nov 2017 20:46:39 +0000 (20:46 +0000)]
Auto merge of #45757 - mikhail-m1:change-mir-dump-filename, r=nikomatsakis

change MIR dump filenames from `rustc.nodeN...` to `rustc.<DefPath>`

r? @nikomatsakis

6 years agoAuto merge of #45725 - alexcrichton:std-less-rand, r=dtolnay
bors [Thu, 9 Nov 2017 18:14:48 +0000 (18:14 +0000)]
Auto merge of #45725 - alexcrichton:std-less-rand, r=dtolnay

Working towards a libc-less (wasm32) libstd

This is a series of commits I was able to extract from prepare to comiple libstd on a "bare libc-less" target, notably wasm32. The actual wasm32 bits I intend to send in a PR later, this is just some internal refactorings required for libstd to work with a `libc` that's empty and a few other assorted refactorings.

No functional change should be included in this PR for users of libstd, this is intended to just be internal refactorings.

6 years agostd: Avoid use of `libc` in portable modules
Alex Crichton [Wed, 1 Nov 2017 20:04:03 +0000 (13:04 -0700)]
std: Avoid use of `libc` in portable modules

This commit removes usage of the `libc` crate in "portable" modules like
those at the top level and `sys_common`. Instead common types like `*mut
u8` or `u32` are used instead of `*mut c_void` or `c_int` as well as
switching to platform-specific functions like `sys::strlen` instead of
`libc::strlen`.

6 years agoAuto merge of #45741 - oli-obk:refactor_suggestions, r=estebank
bors [Thu, 9 Nov 2017 15:42:26 +0000 (15:42 +0000)]
Auto merge of #45741 - oli-obk:refactor_suggestions, r=estebank

Refactor internal suggestion API

~~The only functional change is that whitespace, which is suggested to be added, also gets `^^^^` under it. An example is shown in the tests (the only test that changed).~~

Continuation of #41876

r? @nagisa

the changes are probably best viewed [without whitespace](https://github.com/rust-lang/rust/pull/45741/files?w=1)

6 years agochange separator from `.` to `-`
Mikhail Modin [Sun, 5 Nov 2017 08:14:00 +0000 (11:14 +0300)]
change separator from `.` to `-`

6 years agochange MIR dump filenames from `nodeN` to `DefPath`
Mikhail Modin [Sat, 4 Nov 2017 11:27:08 +0000 (14:27 +0300)]
change MIR dump filenames from `nodeN` to `DefPath`

6 years agostd: Move the `cmath` module into the `sys` module
Alex Crichton [Wed, 1 Nov 2017 19:59:40 +0000 (12:59 -0700)]
std: Move the `cmath` module into the `sys` module

This commit moves the `f32::cmath` and `f64::cmath` modules into the
`sys` module. Note that these are not publicly exported modules, simply
implementation details. These modules are already platform-specific with
shims on MSVC and this is mostly just a reflection of that reality. This
should also help cut down on `#[cfg]` traffic if platforms are brought on
which don't directly support these functions.

6 years agostd: Change how EBADF is handled in `sys`
Alex Crichton [Wed, 1 Nov 2017 19:50:13 +0000 (12:50 -0700)]
std: Change how EBADF is handled in `sys`

This commit removes the reexport of `EBADF_ERR` as a constant from
libstd's portability facade, instead opting for a platform-specific
function that specifically queries an `io::Error`. Not all platforms may
have a constant for this, so it makes the intent a little more clear
that a code need not be supplied, just an answer to a query.

6 years agostd: Remove `rand` crate and module
Alex Crichton [Wed, 1 Nov 2017 19:32:13 +0000 (12:32 -0700)]
std: Remove `rand` crate and module

This commit removes the `rand` crate from the standard library facade as
well as the `__rand` module in the standard library. Neither of these
were used in any meaningful way in the standard library itself. The only
need for randomness in libstd is to initialize the thread-local keys of
a `HashMap`, and that unconditionally used `OsRng` defined in the
standard library anyway.

The cruft of the `rand` crate and the extra `rand` support in the
standard library makes libstd slightly more difficult to port to new
platforms, namely WebAssembly which doesn't have any randomness at all
(without interfacing with JS). The purpose of this commit is to clarify
and streamline randomness in libstd, focusing on how it's only required
in one location, hashmap seeds.

Note that the `rand` crate out of tree has almost always been a drop-in
replacement for the `rand` crate in-tree, so any usage (accidental or
purposeful) of the crate in-tree should switch to the `rand` crate on
crates.io. This then also has the further benefit of avoiding
duplication (mostly) between the two crates!

6 years agoAuto merge of #45736 - oli-obk:rvalue_promotable_map, r=nikomatsakis
bors [Thu, 9 Nov 2017 04:14:28 +0000 (04:14 +0000)]
Auto merge of #45736 - oli-obk:rvalue_promotable_map, r=nikomatsakis

Use a `Set<T>` instead of a `Map<T, bool>`

r? @nikomatsakis

introduced in #44501

6 years agoAuto merge of #45688 - Gankro:layout-tests, r=alexcrichton
bors [Thu, 9 Nov 2017 00:50:56 +0000 (00:50 +0000)]
Auto merge of #45688 - Gankro:layout-tests, r=alexcrichton

Add reftest that checks the layout of repr(int) on non-c-like enums

This verifies the first layout specified in https://github.com/rust-lang/rfcs/pull/2195

The second (`repr(C)`) layout isn't included here because it doesn't actually exist today. However if/when that's implemented a second test could be fairly easily derived from this one.

CC @eddyb

6 years agoAuto merge of #45867 - michaelwoerister:check-ich-stability, r=nikomatsakis
bors [Wed, 8 Nov 2017 22:27:06 +0000 (22:27 +0000)]
Auto merge of #45867 - michaelwoerister:check-ich-stability, r=nikomatsakis

incr.comp.: Verify stability of incr. comp. hashes and clean up various other things.

The main contribution of this PR is that it adds the `-Z incremental-verify-ich` functionality. Normally, when the red-green tracking system determines that a certain query result has not changed, it does not re-compute the incr. comp. hash (ICH) for that query result because that hash is already known. `-Z incremental-verify-ich` tells the compiler to re-hash the query result and compare the new hash against the cached hash. This is a rather thorough way of
- testing hashing implementation stability,
- finding missing `[input]` annotations on `DepNodes`, and
- finding missing read-edges,

since both a missed read and a missing `[input]` annotation can lead to something being marked as green instead of red and thus will have a different hash than it should have.

Case in point, implementing this verification logic and activating it for all `src/test/incremental` tests has revealed several such oversights, all of which are fixed in this PR.

r? @nikomatsakis

6 years agoAuto merge of #45452 - estebank:colon-typo, r=nikomatsakis
bors [Wed, 8 Nov 2017 20:00:41 +0000 (20:00 +0000)]
Auto merge of #45452 - estebank:colon-typo, r=nikomatsakis

Detect `=` -> `:` typo in let bindings

When encountering a let binding type error, attempt to parse as
initializer instead. If successful, it is likely just a typo:

```rust
fn main() {
    let x: Vec::with_capacity(10);
}
```

```
error: expected type, found `10`
 --> file.rs:3:31
  |
3 |     let x: Vec::with_capacity(10, 20);
  |         --                    ^^
  |         ||
  |         |help: did you mean assign here?: `=`
  |         while parsing the type for `x`
```

Fix #43703.

6 years agoAdd reftest that checks the layout of repr(int) on non-c-like enums
Alexis Beingessner [Wed, 1 Nov 2017 15:46:17 +0000 (11:46 -0400)]
Add reftest that checks the layout of repr(int) on non-c-like enums

This verifies the layout specified in rfc #2195

6 years agoAuto merge of #45205 - rkruppe:saturating-casts, r=eddyb
bors [Wed, 8 Nov 2017 17:27:56 +0000 (17:27 +0000)]
Auto merge of #45205 - rkruppe:saturating-casts, r=eddyb

Saturating casts between integers and floats

Introduces a new flag, `-Z saturating-float-casts`, which makes code generation for int->float and float->int casts safe (`undef`-free), implementing [the saturating semantics laid out by](https://github.com/rust-lang/rust/issues/10184#issuecomment-299229143) @jorendorff for float->int casts and overflowing to infinity for `u128::MAX` -> `f32`.
Constant evaluation in trans was changed to behave like HIR const eval already did, i.e., saturate for u128->f32 and report an error for problematic float->int casts.

Many thanks to @eddyb, whose APFloat port simplified many parts of this patch, and made HIR constant evaluation recognize dangerous float casts as mentioned above.
Also thanks to @ActuallyaDeviloper whose branchless implementation served as inspiration for this implementation.

cc #10184 #41799
fixes #45134

6 years agoAuto merge of #45866 - JohnColanduoni:issue-45731, r=alexcrichton
bors [Wed, 8 Nov 2017 14:54:03 +0000 (14:54 +0000)]
Auto merge of #45866 - JohnColanduoni:issue-45731, r=alexcrichton

Disable `mmap`  in `libbacktrace` on Apple platforms

Fixes #45731

libbacktrace uses mmap if available to map ranges of the files containing debug information. On macOS `mmap` will succeed even if the mapped range does not exist, and a SIGBUS (with an unusual EXC_BAD_ACCESS code 10) will occur when the program attempts to page in the memory. To combat this we force `libbacktrace` to be built with the simple `read` based fallback on Apple platforms.

6 years agoDisable u128 <-> float tests on emscripten
Robin Kruppe [Wed, 8 Nov 2017 13:54:03 +0000 (14:54 +0100)]
Disable u128 <-> float tests on emscripten

6 years agoincr.comp.: Provide session to some more decoding contexts.
Michael Woerister [Wed, 8 Nov 2017 13:52:00 +0000 (14:52 +0100)]
incr.comp.: Provide session to some more decoding contexts.

6 years agoAuto merge of #45575 - michaelwoerister:tweak-inline-trans-items, r=nikomatsakis
bors [Wed, 8 Nov 2017 12:23:34 +0000 (12:23 +0000)]
Auto merge of #45575 - michaelwoerister:tweak-inline-trans-items, r=nikomatsakis

Only instantiate inline- and const-fns if they are referenced (again).

It seems that we have regressed on not translating `#[inline]` functions unless they are actually used. This should bring back this optimization. I also added a regression test this time so it doesn't happen again accidentally.

Fixes #40392.

r? @alexcrichton

UPDATE & PSA
---------------------
This patch **makes translation very lazy** -- in general this is a good thing (we don't want the compiler to do unnecessary work) but it has two consequences:
1. Some error messages are only generated when an item is actually translated. Consequently, this patch will lead to more cases where the compiler will only start emitting errors when the erroneous function is actually used. This has always been true to some extend (e.g. when passing generic values to an intrinsic) but since this is something user-facing it's worth mentioning.
2. When writing tests, one has to make sure that the functions in question are actually generated. In other words, it must not be dead code. This can usually  be achieved by either
    1. making sure the function is exported from the resulting binary or
    2. by making sure the function is called from something that is exported (or `main()`).

Note that it depends on the crate type what functions are exported:
   1. For rlibs and dylibs everything that is reachable from the outside is exported.
   2. For executables, cdylibs, and staticlibs, items are only exported if they are additionally `#[no_mangle]` or have an `#[export_name]`.

The commits in this PR contain many examples of how tests can be updated to comply to the new requirements.

6 years agoincr.comp.: Remove unused DepKind::WorkProduct.
Michael Woerister [Wed, 8 Nov 2017 10:44:55 +0000 (11:44 +0100)]
incr.comp.: Remove unused DepKind::WorkProduct.

6 years agoincr.comp.: Remove outdated comment about TraitSelect dep-node.
Michael Woerister [Wed, 8 Nov 2017 10:34:09 +0000 (11:34 +0100)]
incr.comp.: Remove outdated comment about TraitSelect dep-node.

6 years agoincr.comp.: Always verify incr. comp. hashes when running incremental tests.
Michael Woerister [Wed, 8 Nov 2017 10:33:06 +0000 (11:33 +0100)]
incr.comp.: Always verify incr. comp. hashes when running incremental tests.

6 years agoincr.comp.: Adapt nested_items test to new HIR hashing rules.
Michael Woerister [Wed, 8 Nov 2017 10:32:16 +0000 (11:32 +0100)]
incr.comp.: Adapt nested_items test to new HIR hashing rules.

6 years agoincr.comp.: Add some missing reads in HIR map.
Michael Woerister [Wed, 8 Nov 2017 10:31:15 +0000 (11:31 +0100)]
incr.comp.: Add some missing reads in HIR map.

6 years agoincr.comp.: Make DefSpan an input dep-node so it is not affected by the existing...
Michael Woerister [Wed, 8 Nov 2017 10:30:14 +0000 (11:30 +0100)]
incr.comp.: Make DefSpan an input dep-node so it is not affected by the existing Span/HIR hashing hack.

6 years agoDisable `mmap` in `libbacktrace` on Apple platforms
John Colanduoni [Wed, 8 Nov 2017 10:28:17 +0000 (02:28 -0800)]
Disable `mmap`  in `libbacktrace` on Apple platforms

Fixes #45731

libbacktrace uses mmap if available to map ranges of the files containing debug information. On macOS `mmap` will succeed even if the mapped range does not exist, and a SIGBUS (with an unusual EXC_BAD_ACCESS code 10) will occur when the program attempts to page in the memory. To combat this we force `libbacktrace` to be built with the simple `read` based fallback on Apple platforms.

6 years agoUpdate fastcall-inreg codegen test so that functions actually get instantiated.
Michael Woerister [Wed, 8 Nov 2017 10:09:48 +0000 (11:09 +0100)]
Update fastcall-inreg codegen test so that functions actually get instantiated.

6 years agoAuto merge of #45862 - GuillaumeGomez:rollup, r=GuillaumeGomez
bors [Wed, 8 Nov 2017 09:43:27 +0000 (09:43 +0000)]
Auto merge of #45862 - GuillaumeGomez:rollup, r=GuillaumeGomez

Rollup of 4 pull requests

- Successful merges: #45582, #45766, #45830, #45849
- Failed merges:

6 years agoRollup merge of #45849 - GuillaumeGomez:more-shortcut, r=QuietMisdreavus
Guillaume Gomez [Wed, 8 Nov 2017 09:09:18 +0000 (10:09 +0100)]
Rollup merge of #45849 - GuillaumeGomez:more-shortcut, r=QuietMisdreavus

Add "-" shortcut

Fixes #45847.

r? @Havvy

6 years agoRollup merge of #45830 - pornel:dosglobs, r=dtolnay
Guillaume Gomez [Wed, 8 Nov 2017 09:09:17 +0000 (10:09 +0100)]
Rollup merge of #45830 - pornel:dosglobs, r=dtolnay

Warn about lack of args glob expansion in Windows shell

Because all shells on Linux/macOS expand globs, and even MinGW on Windows emulates this behavior, it's easy to forget that Windows by itself doesn't support glob expansion. This PR documents this cross-platform difference.

6 years agoRollup merge of #45766 - GuillaumeGomez:trait-methods-list, r=QuietMisdreavus
Guillaume Gomez [Wed, 8 Nov 2017 09:09:16 +0000 (10:09 +0100)]
Rollup merge of #45766 - GuillaumeGomez:trait-methods-list, r=QuietMisdreavus

Add more elements in the sidebar

Fixes #45740.

r? @rust-lang/docs

6 years agoRollup merge of #45582 - GuillaumeGomez:doc-unix-missing-links, r=frewsxcv
Guillaume Gomez [Wed, 8 Nov 2017 09:09:15 +0000 (10:09 +0100)]
Rollup merge of #45582 - GuillaumeGomez:doc-unix-missing-links, r=frewsxcv

Add missing links and examples

r? @rust-lang/docs

6 years agoAuto merge of #45735 - tirr-c:issue-45730, r=arielb1
bors [Wed, 8 Nov 2017 07:12:15 +0000 (07:12 +0000)]
Auto merge of #45735 - tirr-c:issue-45730, r=arielb1

Forbid casting to/from a pointer of unknown kind

Fixes #45730.

Before, it ICE'd when `pointer_kind` encountered `TyInfer`.

6 years agoAuto merge of #45379 - cuviper:unit_from_iter, r=alexcrichton
bors [Wed, 8 Nov 2017 01:32:12 +0000 (01:32 +0000)]
Auto merge of #45379 - cuviper:unit_from_iter, r=alexcrichton

impl FromIterator<()> for ()

This just collapses all unit items from an iterator into one.  This is
more useful when combined with higher-level abstractions, like
collecting to a `Result<(), E>` where you only care about errors:

```rust
use std::io::*;
data = vec![1, 2, 3, 4, 5];
let res: Result<()> = data.iter()
    .map(|x| writeln!(stdout(), "{}", x))
    .collect();
assert!(res.is_ok());
```

6 years agoAdd more elements in the sidebar
Guillaume Gomez [Sat, 4 Nov 2017 19:45:12 +0000 (20:45 +0100)]
Add more elements in the sidebar

6 years agoAdd "-" shortcut
Guillaume Gomez [Tue, 7 Nov 2017 21:44:18 +0000 (22:44 +0100)]
Add "-" shortcut

6 years agoAuto merge of #44932 - cuviper:unsized-ptr-is_null, r=alexcrichton
bors [Tue, 7 Nov 2017 20:55:01 +0000 (20:55 +0000)]
Auto merge of #44932 - cuviper:unsized-ptr-is_null, r=alexcrichton

Remove `T: Sized` on pointer `as_ref()` and `as_mut()`

`NonZero::is_zero()` was already casting all pointers to thin `*mut u8` to check for null.  The same test on unsized fat pointers can also be used with `as_ref()` and `as_mut()` to get fat references.

(This PR formerly changed `is_null()` too, but checking just the data pointer is not obviously correct for trait objects, especially if `*const self` sorts of methods are ever allowed.)

6 years agoAdd missing links and examples
Guillaume Gomez [Fri, 27 Oct 2017 20:01:50 +0000 (22:01 +0200)]
Add missing links and examples

6 years agoClean up
Robin Kruppe [Sat, 28 Oct 2017 14:43:08 +0000 (16:43 +0200)]
Clean up

6 years agoImplement more efficient saturation
Robin Kruppe [Tue, 17 Oct 2017 14:42:10 +0000 (16:42 +0200)]
Implement more efficient saturation

6 years agoMake trans const eval error on overflow and NaN, matching HIR const eval.
Robin Kruppe [Sun, 15 Oct 2017 20:28:49 +0000 (22:28 +0200)]
Make trans const eval error on overflow and NaN, matching  HIR const eval.

6 years agoExtract (f32::MAX + 0.5 ULP) constant
Robin Kruppe [Sun, 15 Oct 2017 19:37:09 +0000 (21:37 +0200)]
Extract (f32::MAX + 0.5 ULP) constant

6 years agoFix bug in rustc_apfloat
Robin Kruppe [Sun, 15 Oct 2017 18:10:42 +0000 (20:10 +0200)]
Fix bug in rustc_apfloat

6 years agoSaturating casts between integers and floats (both directions).
Robin Kruppe [Mon, 9 Oct 2017 00:14:00 +0000 (02:14 +0200)]
Saturating casts between integers and floats (both directions).

This affects regular code generation as well as constant evaluation in trans,
but not the HIR constant evaluator because that one returns an error for
overflowing casts and NaN-to-int casts. That error is conservatively
correct and we should be careful to not accept more code in constant
expressions.
The changes to code generation are guarded by a new -Z flag, to be able
to evaluate the performance impact. The trans constant evaluation changes
are unconditional because they have no run time impact and don't affect
type checking either.

6 years agoAuto merge of #45822 - kennytm:rollup, r=kennytm
bors [Tue, 7 Nov 2017 18:04:33 +0000 (18:04 +0000)]
Auto merge of #45822 - kennytm:rollup, r=kennytm

Rollup of 9 pull requests

- Successful merges: #45470, #45588, #45682, #45714, #45751, #45764, #45778, #45782, #45784
- Failed merges:

6 years agoWarn about non-portability of glob patterns
Kornel [Tue, 7 Nov 2017 12:17:04 +0000 (12:17 +0000)]
Warn about non-portability of glob patterns

6 years agoAlways treat #[rustc_std_internal_symbol]s as root TransItems.
Michael Woerister [Tue, 7 Nov 2017 15:41:42 +0000 (16:41 +0100)]
Always treat #[rustc_std_internal_symbol]s as root TransItems.

6 years agoincr.comp.: Acknowledge the fact that shift operations can panic at runtime.
Michael Woerister [Tue, 7 Nov 2017 14:49:51 +0000 (15:49 +0100)]
incr.comp.: Acknowledge the fact that shift operations can panic at runtime.

6 years agoRollup merge of #45784 - harpocrates:fix/print-parens-cast-lt, r=kennytm
kennytm [Tue, 7 Nov 2017 07:52:15 +0000 (15:52 +0800)]
Rollup merge of #45784 - harpocrates:fix/print-parens-cast-lt, r=kennytm

Pretty print parens around casts on the LHS of `<`/`<<`

When pretty printing a cast expression occuring on the LHS of a `<` or `<<` expression, we should add parens around the cast. Otherwise, the `<`/`<<` gets interpreted as the beginning of the generics for the type on the RHS of the cast.

Consider:

    $ cat parens_cast.rs
    macro_rules! negative {
        ($e:expr) => { $e < 0 }
    }

    fn main() {
        negative!(1 as i32);
    }

Before this PR, the output of the following is not valid Rust:

    $ rustc -Z unstable-options --pretty=expanded parens_cast.rs
    #![feature(prelude_import)]
    #![no_std]
    #[prelude_import]
    use std::prelude::v1::*;
    #[macro_use]
    extern crate std as std;
    macro_rules! negative(( $ e : expr ) => { $ e < 0 });

    fn main() { 1 as i32 < 0; }

After this PR, the output of the following is valid Rust:

    $ rustc -Z unstable-options --pretty=expanded parens_cast.rs
    #![feature(prelude_import)]
    #![no_std]
    #[prelude_import]
    use std::prelude::v1::*;
    #[macro_use]
    extern crate std as std;
    macro_rules! negative(( $ e : expr ) => { $ e < 0 });

    fn main() { (1 as i32) < 0; }

I've gone through several README/wiki style documents but I'm still not sure where to test this though. I'm not even sure if this sort of thing is tested...

6 years agoRollup merge of #45782 - frewsxcv:frewsxcv-shorthands-helpers, r=manishearth
kennytm [Tue, 7 Nov 2017 07:52:14 +0000 (15:52 +0800)]
Rollup merge of #45782 - frewsxcv:frewsxcv-shorthands-helpers, r=manishearth

Display all emission types in error msg if user inputs invalid option.

before:

```
> rustc --emit foo
error: unknown emission type: `foo`
```

after:

```
> rustc --emit foo
error: unknown emission type: `foo` - expected one of: `llvm-bc`, `asm`, `llvm-ir`, `mir`, `obj`, `metadata`, `link`, `dep-info`
```

6 years agoRollup merge of #45778 - Havvy:patch-1, r=steveklabnik
kennytm [Tue, 7 Nov 2017 07:52:13 +0000 (15:52 +0800)]
Rollup merge of #45778 - Havvy:patch-1, r=steveklabnik

Update reference link in doc's 404

It's currently linking to a page that says it's on the page I'm changing the link too.

6 years agoRollup merge of #45764 - QuietMisdreavus:rustdoc-doctest-lints, r=GuillaumeGomez
kennytm [Tue, 7 Nov 2017 07:52:12 +0000 (15:52 +0800)]
Rollup merge of #45764 - QuietMisdreavus:rustdoc-doctest-lints, r=GuillaumeGomez

rustdoc: add #[allow(unused)] to every doctest

More information in #45750 - this is behavior that was documented but not actually implemented.

I also reordered how outer attributes are applied to doctests. Previously, attributes from `#![doc(test(attr(...)))]` would be applied *after* attributes from within the test itself, meaning if a doctest tried to override lints that would be set crate-wide, it wouldn't work at all. This gives a better scope of how lints can be applied.

Closes #45750

6 years agoRollup merge of #45751 - estebank:issue-44684, r=nikomatsakis
kennytm [Tue, 7 Nov 2017 07:52:11 +0000 (15:52 +0800)]
Rollup merge of #45751 - estebank:issue-44684, r=nikomatsakis

Handle anon lifetime arg being returned with named lifetime return type

When there's a lifetime mismatch between an argument with an anonymous
lifetime being returned in a method with a return type that has a named
lifetime, show specialized lifetime error pointing at argument with a
hint to give it an explicit lifetime matching the return type.

```
error[E0621]: explicit lifetime required in the type of `other`
  --> file2.rs:21:21
   |
17 |     fn bar(&self, other: Foo) -> Foo<'a> {
   |                   ----- consider changing the type of `other` to `Foo<'a>`
...
21 |                     other
   |                     ^^^^^ lifetime `'a` required
```

Follow up to #44124 and #42669. Fix #44684.

6 years agoRollup merge of #45714 - sdroege:thread-panic-docs, r=dtolnay
kennytm [Tue, 7 Nov 2017 07:52:11 +0000 (15:52 +0800)]
Rollup merge of #45714 - sdroege:thread-panic-docs, r=dtolnay

Update the std::thread docs and clarify that panics can nowadays be caught

6 years agoRollup merge of #45682 - RalfJung:rwlock-guards, r=alexcrichton
kennytm [Tue, 7 Nov 2017 07:52:10 +0000 (15:52 +0800)]
Rollup merge of #45682 - RalfJung:rwlock-guards, r=alexcrichton

RwLock guards are Sync if T is

Currently, the compiler requires `T` to also be `Send`.  There is no reason for
that.  `&Rw{Read,Write}LockGuard` only provides a shared referenced to `T`, sending
that across threads is safe if `T` is `Sync`.

Cc @oconnor663

6 years agoRollup merge of #45588 - Keruspe:master, r=alexcrichton
kennytm [Tue, 7 Nov 2017 07:52:09 +0000 (15:52 +0800)]
Rollup merge of #45588 - Keruspe:master, r=alexcrichton

rustbuild: don't try to install rls if ToolState is not Testing

We already do that for the Dist Step so we would end up trying to install something that we didn't dist.

6 years agoRollup merge of #45470 - GuillaumeGomez:unix-metadata-ext, r=QuietMisdreavus
kennytm [Tue, 7 Nov 2017 07:52:08 +0000 (15:52 +0800)]
Rollup merge of #45470 - GuillaumeGomez:unix-metadata-ext, r=QuietMisdreavus

add missing docs for MetadataExt

r? @rust-lang/docs

6 years agoAuto merge of #45666 - Amanieu:tls-model, r=alexcrichton
bors [Tue, 7 Nov 2017 14:24:15 +0000 (14:24 +0000)]
Auto merge of #45666 - Amanieu:tls-model, r=alexcrichton

Allow overriding the TLS model

This PR adds the ability to override the default "global-dynamic" TLS model with a more specific one through a target json option or a command-line option. This allows for better code generation in certain situations.

This is similar to the `-ftls-model=` option in GCC and Clang.

6 years agoincr.comp.: Add -Zincremental-verify-ich, which allows to perform a consistency check...
Michael Woerister [Tue, 7 Nov 2017 14:22:29 +0000 (15:22 +0100)]
incr.comp.: Add -Zincremental-verify-ich, which allows to perform a consistency check for stored query result fingerprints.

6 years agoincr.comp.: Don't filter out StmtDecls from hir::Block during hashing as these make...
Michael Woerister [Tue, 7 Nov 2017 14:18:00 +0000 (15:18 +0100)]
incr.comp.: Don't filter out StmtDecls from hir::Block during hashing as these make a difference for the RegionScopeTree.

6 years agoincr.comp.: Sort exported symbols list in order to achieve stable incr. comp. hash.
Michael Woerister [Tue, 7 Nov 2017 14:15:45 +0000 (15:15 +0100)]
incr.comp.: Sort exported symbols list in order to achieve stable incr. comp. hash.

6 years agoincr.comp.: Always require Session when decoding Spans (as to avoid silently wrong...
Michael Woerister [Tue, 7 Nov 2017 14:14:32 +0000 (15:14 +0100)]
incr.comp.: Always require Session when decoding Spans (as to avoid silently wrong results).

6 years agoincr.comp.: Make assertion in try_mark_green() more targeted.
Michael Woerister [Tue, 7 Nov 2017 14:04:10 +0000 (15:04 +0100)]
incr.comp.: Make assertion in try_mark_green() more targeted.

6 years agoincr.comp.: Mark more input nodes as inputs.
Michael Woerister [Tue, 7 Nov 2017 13:54:07 +0000 (14:54 +0100)]
incr.comp.: Mark more input nodes as inputs.

6 years agoincr.comp.: Allow for forcing input nodes lazily.
Michael Woerister [Tue, 7 Nov 2017 13:53:21 +0000 (14:53 +0100)]
incr.comp.: Allow for forcing input nodes lazily.

6 years agoFix some rebasing fallout.
Michael Woerister [Mon, 6 Nov 2017 09:35:52 +0000 (10:35 +0100)]
Fix some rebasing fallout.

6 years agoDon't duplicate logic of when an Instance requests to be inlined.
Michael Woerister [Mon, 30 Oct 2017 17:49:56 +0000 (18:49 +0100)]
Don't duplicate logic of when an Instance requests to be inlined.

6 years agoUpdate run-make tests.
Michael Woerister [Mon, 30 Oct 2017 17:21:06 +0000 (18:21 +0100)]
Update run-make tests.

6 years agoUpdate mir-opt tests.
Michael Woerister [Mon, 30 Oct 2017 17:20:07 +0000 (18:20 +0100)]
Update mir-opt tests.

6 years agoUpdate compile-fail tests.
Michael Woerister [Mon, 30 Oct 2017 17:19:31 +0000 (18:19 +0100)]
Update compile-fail tests.

6 years agoUpdate codegen tests.
Michael Woerister [Mon, 30 Oct 2017 17:18:00 +0000 (18:18 +0100)]
Update codegen tests.

6 years agoFix incremental tests after change to instantiation strategy.
Michael Woerister [Fri, 27 Oct 2017 16:57:15 +0000 (18:57 +0200)]
Fix incremental tests after change to instantiation strategy.

6 years agoincr.comp.: Improve error message for unknown fingerprint.
Michael Woerister [Fri, 27 Oct 2017 16:56:29 +0000 (18:56 +0200)]
incr.comp.: Improve error message for unknown fingerprint.

6 years agoUpdate invalid inline arg test.
Michael Woerister [Fri, 27 Oct 2017 14:15:23 +0000 (16:15 +0200)]
Update invalid inline arg test.

6 years agoAdd regression tests for non-instantiation of inline and const fns.
Michael Woerister [Fri, 27 Oct 2017 12:32:26 +0000 (14:32 +0200)]
Add regression tests for non-instantiation of inline and const fns.

6 years agoUpdate codegen-unit tests.
Michael Woerister [Fri, 27 Oct 2017 12:31:18 +0000 (14:31 +0200)]
Update codegen-unit tests.

6 years agoFix translation item collection for inline and const fns.
Michael Woerister [Fri, 27 Oct 2017 12:30:34 +0000 (14:30 +0200)]
Fix translation item collection for inline and const fns.

6 years agoAuto merge of #45620 - ollie27:rustdoc_impl_generic_dupe, r=QuietMisdreavus
bors [Tue, 7 Nov 2017 07:24:13 +0000 (07:24 +0000)]
Auto merge of #45620 - ollie27:rustdoc_impl_generic_dupe, r=QuietMisdreavus

rustdoc: Fix duplicated impls with generics

The same type can appear multiple times in impls so we need to use a set
to avoid adding it multiple times.

Fixes: #45584
6 years agoUpdate comments in cast-lt.pp
Alec Theriault [Tue, 7 Nov 2017 06:18:14 +0000 (22:18 -0800)]
Update comments in cast-lt.pp

6 years agoreview comments
Esteban Küber [Tue, 7 Nov 2017 05:02:31 +0000 (21:02 -0800)]
review comments

6 years agoAuto merge of #45571 - zackmdavis:regenerate_char_private, r=alexcrichton
bors [Tue, 7 Nov 2017 02:07:34 +0000 (02:07 +0000)]
Auto merge of #45571 - zackmdavis:regenerate_char_private, r=alexcrichton

regenerate libcore/char_private.rs

(filed separately from the work in #45569, because of this matter of the updated Unicode data; see also #45567)

char_private.rs is generated programmatically by char_private.py, using data retrieved from the Unicode Consortium's website.

The motivation here was to make `is_printable` crate-visible (with `pub(crate)`), but it would seem that the Unicode data has changed slightly since char_private.rs was last generated.

6 years agoDisplay all emission types in error msg if user inputs invalid option.
Corey Farwell [Sun, 5 Nov 2017 14:20:59 +0000 (09:20 -0500)]
Display all emission types in error msg if user inputs invalid option.

before:

```
> rustc --emit foo
error: unknown emission type: `foo`
```

after:

```
> rustc --emit foo
error: unknown emission type: `foo` - expected one of: `llvm-bc`, `asm`, `llvm-ir`, `mir`, `obj`, `metadata`, `link`, `dep-info`
```

6 years agoAuto merge of #45668 - nikomatsakis:nll-free-region, r=arielb1
bors [Mon, 6 Nov 2017 23:30:57 +0000 (23:30 +0000)]
Auto merge of #45668 - nikomatsakis:nll-free-region, r=arielb1

extend NLL with preliminary support for free regions on functions

This PR extends https://github.com/rust-lang/rust/pull/45538 with support for free regions. This is pretty preliminary and will no doubt want to change in various ways, particularly as we add support for closures, but it's enough to get the basic idea in place:

- We now create specific regions to represent each named lifetime declared on the function.
- Region values can contain references to these regions (represented for now as a `BTreeSet<RegionIndex>`).
- If we wind up trying to infer that `'a: 'b` must hold, but no such relationship was declared, we report an error.

It also does a number of drive-by refactorings.

r? @arielb1

cc @spastorino

6 years agoMove tls-model to a -Z option since it is unstable
Amanieu d'Antras [Mon, 6 Nov 2017 21:10:49 +0000 (21:10 +0000)]
Move tls-model to a -Z option since it is unstable

6 years agoAuto merge of #45811 - DSpeckhals:update-rustfmt-rls, r=nikomatsakis
bors [Mon, 6 Nov 2017 20:43:46 +0000 (20:43 +0000)]
Auto merge of #45811 - DSpeckhals:update-rustfmt-rls, r=nikomatsakis

tools: Fix rustfmt and the RLS

These tools have been corrected in their upstream repo's, and the submodules have been updated here to reflect that. I also had to update Cargo to match what the RLS is expecting.

The tool states for `rustfmt` and `rls` where both changed from "Broken" to "Testing" in this commit, thus enabling testing and distribution again.

6 years agoAuto merge of #45322 - infinity0:master, r=alexcrichton
bors [Mon, 6 Nov 2017 18:04:13 +0000 (18:04 +0000)]
Auto merge of #45322 - infinity0:master, r=alexcrichton

When cross-compiling, also build target-arch tarballs for libstd. (Closes: #42320)

Half of the logic is actually in there already in install.rs:install_std but it fails with an error like:

sh: 0: Can't open /<<BUILDDIR>>/rustc-1.21.0+dfsg1/build/tmp/dist/rust-std-1.21.0-powerpc64le-unknown-linux-gnu/install.sh

because the target-arch dist tarball wasn't built as well. This commit fixes that so the overall install works.

There is one minor bug in the existing code which this commit doesn't fix - the install.log from multiple runs of the installer gets clobbered, which seems like it might interfere with the uninstall process (I didn't look very deeply into this, because it doesn't affect what I need to do.) The actual installed files under DESTDIR seem fine though - either they are installed under an arch-specific path, or the multiple runs will clobber the same path with the same arch-independent file.

6 years agotools: Fix rustfmt and the RLS
Dustin Speckhals [Mon, 6 Nov 2017 17:59:33 +0000 (12:59 -0500)]
tools: Fix rustfmt and the RLS

These tools have been corrected in their upstream repo's, and the
submodules have been updated here to reflect that. I also had to update
Cargo to match what the RLS is expecting.

The tool states for `rustfmt` and `rls` where both changed from "Broken"
to "Testing" in this commit, thus enabling testing and distribution
again.

6 years agoForbid casting to/from a pointer of unknown kind
Wonwoo Choi [Fri, 3 Nov 2017 07:58:01 +0000 (16:58 +0900)]
Forbid casting to/from a pointer of unknown kind

6 years agoAuto merge of #45369 - fintelia:patch-1, r=BurntSushi
bors [Mon, 6 Nov 2017 15:19:48 +0000 (15:19 +0000)]
Auto merge of #45369 - fintelia:patch-1, r=BurntSushi

Implement is_empty() for BufReader

Simple implementation of `is_empty` method for BufReader so it is possible to tell whether there is any data in its buffer.

I didn't know correct stability annotation to place on the function. Presumably there is no reason to place this feature behind a feature flag, but I wasn't sure how to tag it as an unstable feature without that.

CC: #45323
6 years agoAuto merge of #45737 - oli-obk:json, r=petrochenkov
bors [Mon, 6 Nov 2017 12:18:12 +0000 (12:18 +0000)]
Auto merge of #45737 - oli-obk:json, r=petrochenkov

Pretty print json in ui tests

I found the json output in one line to not be useful for reviewing

r? @petrochenkov

6 years agoEnsure dist::Std for every libstd target. (Closes: #42320)
Ximin Luo [Mon, 6 Nov 2017 10:34:18 +0000 (11:34 +0100)]
Ensure dist::Std for every libstd target. (Closes: #42320)

This fixes cross-compile installation. Half of the logic is actually in there
already in install.rs:install_std but it fails with an error like:

sh: 0: Can't open /<<BUILDDIR>>/rustc-1.21.0+dfsg1/build/tmp/dist/rust-std-1.21.0-powerpc64le-unknown-linux-gnu/install.sh

because the target-arch dist tarball wasn't built as well.

6 years agoAdjust json errors to byte changes
Oliver Schneider [Mon, 6 Nov 2017 09:34:23 +0000 (10:34 +0100)]
Adjust json errors to byte changes

6 years agoDo not highlight surrounding whitespace
Oliver Schneider [Mon, 6 Nov 2017 08:58:53 +0000 (09:58 +0100)]
Do not highlight surrounding whitespace

6 years agoAuto merge of #45798 - nrc:rls-bugs-3, r=eddyb
bors [Mon, 6 Nov 2017 08:48:11 +0000 (08:48 +0000)]
Auto merge of #45798 - nrc:rls-bugs-3, r=eddyb

A couple more save-analysis fixes

r? @eddyb

6 years agoAuto merge of #45758 - nzig:explain-span-ctxt, r=petrochenkov
bors [Mon, 6 Nov 2017 05:16:15 +0000 (05:16 +0000)]
Auto merge of #45758 - nzig:explain-span-ctxt, r=petrochenkov

Add comment explaining the ctxt field in Span

As discussed in #45747.

r? @petrochenkov

6 years agoFix comments
Alec Theriault [Mon, 6 Nov 2017 04:53:46 +0000 (20:53 -0800)]
Fix comments

6 years agosave-analysis: fix bugs in method chains
Nick Cameron [Mon, 6 Nov 2017 02:52:42 +0000 (15:52 +1300)]
save-analysis: fix bugs in method chains

Use the span we save in the PathSegment for a method call, rather than searching for it in the text.

Fixes https://github.com/nrc/rls-analysis/issues/111

6 years agoAuto merge of #45756 - topecongiro:fix-typos/librustc_typeck, r=kennytm
bors [Mon, 6 Nov 2017 02:02:11 +0000 (02:02 +0000)]
Auto merge of #45756 - topecongiro:fix-typos/librustc_typeck, r=kennytm

Fix typos in README.md

This nitpicky PR fixes few typos I found while reading `README.md`s.

6 years agosave-analysis: give better info for Unions
Nick Cameron [Mon, 6 Nov 2017 01:56:43 +0000 (14:56 +1300)]
save-analysis: give better info for Unions