]> git.lizzy.rs Git - rust.git/log
rust.git
5 years agoAuto merge of #54561 - matthiaskrgr:clippy_up, r=kennytm
bors [Wed, 26 Sep 2018 20:47:45 +0000 (20:47 +0000)]
Auto merge of #54561 - matthiaskrgr:clippy_up, r=kennytm

update clippy submodule to a72e786c

5 years agoAuto merge of #54453 - nikomatsakis:nll-issue-53121-shred-outlives, r=pnkfelix
bors [Wed, 26 Sep 2018 18:16:55 +0000 (18:16 +0000)]
Auto merge of #54453 - nikomatsakis:nll-issue-53121-shred-outlives, r=pnkfelix

rework how we handle outlives relationships

When we encounter an outlives relationship involving a projection, we use to over-constrain in some cases with region constraints. We also used to evaluate whether the where-clauses in the environment might apply **before** running inference.

We now avoid doing both of those things:

- If there are where-clauses in the environment that might be useful, we add no constraints.
- After inference is done, we check if we wound up inferring values compatible with the where-clause, and make use of them if so.

I realize now that this PR includes some meandering commits and refactorings from when I expected to go in a different direction. If desired, I could try to remove some of those.

Fixes #53121
Fixes #53789

r? @pnkfelix

5 years agoupdate clippy submodule to a72e786c
Matthias Krรผger [Tue, 25 Sep 2018 15:42:47 +0000 (17:42 +0200)]
update clippy submodule to a72e786c

Fixes clippy build.

5 years agoAuto merge of #51946 - japaric:emit-stack-sizes, r=nikomatsakis
bors [Wed, 26 Sep 2018 15:40:37 +0000 (15:40 +0000)]
Auto merge of #51946 - japaric:emit-stack-sizes, r=nikomatsakis

[eRFC] add -Z emit-stack-sizes

# What

This PR exposes LLVM's ability to report the stack usage of each function through the unstable /
experimental `-Z emit-stack-sizes` flag.

# Motivation

The end goal is to enable whole program analysis of stack usage to prove absence of stack overflows
at compile time. Such property is important in systems that lack a MMU / MPU and where stack
overflows can corrupt memory. And in systems that have protection against stack overflows such proof
can be used to opt out of runtime checks (e.g. stack probes or the MPU).

Such analysis requires the call graph of the program, which can be obtained from MIR, and the stack
usage of each function in the program. Precise information about the later later can only be
obtained from LLVM as it depends on the optimization level and optimization options like LTO.

This PR does **not** attempt to add the ability to perform such whole program analysis to rustc;
it simply does the minimal amount of work to enable such analysis to be implemented out of tree.

# Implementation

This PR exposes a way to set LLVM's `EmitStackSizeSection` option from the command line. The option
is documented [here]; the documentation is copied below for convenience and posteriority:

[here]: https://llvm.org/docs/CodeGenerator.html#emitting-function-stack-size-information

> A section containing metadata on function stack sizes will be emitted when
> TargetLoweringObjectFile::StackSizesSection is not null, and TargetOptions::EmitStackSizeSection
> is set (-stack-size-section). The section will contain an array of pairs of function symbol values
> (pointer size) and stack sizes (unsigned LEB128). The stack size values only include the space
> allocated in the function prologue. Functions with dynamic stack allocations are not included.

Where the LLVM feature is not available (e.g. LLVM version < 6.0) or can't be applied (e.g. the
output format doesn't support sections e.g. .wasm files) the flag does nothing -- i.e. no error or
warning is emitted.

# Example usage

``` console
$ cargo new --bin hello && cd $_

$ cat >src/main.rs <<'EOF'
use std::{mem, ptr};

fn main() {
    registers();
    stack();
}

#[inline(never)]
fn registers() {
    unsafe {
        // values loaded into registers
        ptr::read_volatile(&(0u64, 1u64));
    }
}

#[inline(never)]
fn stack() {
    unsafe {
        // array allocated on the stack
        let array: [i32; 4] = mem::uninitialized();
        for elem in &array {
            ptr::read_volatile(&elem);
        }
    }
}
EOF

$ # we need a custom linking step to preserve the .stack_sizes section
$ # (see unresolved questions for a solution that doesn't require custom linking)
$ cat > keep-stack-sizes.x <<'EOF'
SECTIONS
{
  .stack_sizes :
  {
    KEEP(*(.stack_sizes));
  }
}
EOF

$ cargo rustc --release -- \
    -Z emit-stack-sizes \
    -C link-arg=-Wl,-Tkeep-stack-sizes.x \
    -C link-arg=-N

$ size -A target/release/hello | grep stack_sizes
.stack_sizes    117   185136
```

Then a tool like [`stack-sizes`] can be used to print the information in human readable format

[`stack-sizes`]: https://github.com/japaric/stack-sizes/#stack-sizes

``` console
$ stack-sizes target/release/hello
address                 size    name
0x000000000004b0        0       core::array::<impl core::iter::traits::IntoIterator for &'a [T; _]>::into_iter::ha50e6661c0ec84aa
0x000000000004c0        8       std::rt::lang_start::ha02aea783e0e1b3e
0x000000000004f0        8       std::rt::lang_start::{{closure}}::h5115b527d5244952
0x00000000000500        8       core::ops::function::FnOnce::call_once::h6bfa1076da82b0fb
0x00000000000510        0       core::ptr::drop_in_place::hb4de82e57787bc70
0x00000000000520        8       hello::main::h08bb6cec0556bd66
0x00000000000530        0       hello::registers::h9d058a5d765ec1d2
0x00000000000540        24      hello::stack::h88c8cb66adfdc6f3
0x00000000000580        8       main
0x000000000005b0        0       __rust_alloc
0x000000000005c0        0       __rust_dealloc
0x000000000005d0        0       __rust_realloc
0x000000000005e0        0       __rust_alloc_zeroed
```

# Stability

Like `-Z sanitize` this is a re-export of an LLVM feature. To me knowledge, we don't have a policy
about stabilization of such features as they are incompatible with, or demand extra implementation
effort from, alternative backends (e.g. cranelift). As such this feature will remain experimental /
unstable for the foreseeable future.

# Unresolved questions

## Section name

Should we rename the `.stack_sizes` section to `.debug_stacksizes`?

With the former name linkers will strip the section unless told otherwise using a linker script,
which means getting this information requires both knowledge about linker scripts and a custom
linker invocation (see example above).

If we use the `.debug_stacksizes` name (I believe) linkers will always keep the section, which means
`-Z emit-stack-sizes` is the only thing required to get the stack usage information.

# ~TODOs~

~Investigate why this doesn't work with the `thumb` targets. I get the LLVM error shown below:~

``` console
$ cargo new --lib foo && cd $_

$ echo '#![no_std] pub fn foo() {}' > src/lib.rs

$ cargo rustc --target thumbv7m-none-eabi -- -Z emit-stack-sizes
LLVM ERROR: unsupported relocation on symbol
```

~which sounds like it might be related to the `relocation-model` option. Maybe `relocation-model =
static` is not supported for some reason?~

This fixed itself after the LLVM upgrade.

---

r? @nikomatsakis
cc @rust-lang/compiler @perlindgren @whitequark

5 years agodon't run the test on macOS
Jorge Aparicio [Wed, 26 Sep 2018 14:22:52 +0000 (16:22 +0200)]
don't run the test on macOS

5 years agorustc_driver/test.rs: rustfmt
Niko Matsakis [Tue, 25 Sep 2018 17:58:32 +0000 (13:58 -0400)]
rustc_driver/test.rs: rustfmt

5 years agofix rustc_driver tests
Niko Matsakis [Tue, 25 Sep 2018 17:58:22 +0000 (13:58 -0400)]
fix rustc_driver tests

5 years agopacify the mercilous tidy.
Niko Matsakis [Tue, 25 Sep 2018 15:32:58 +0000 (11:32 -0400)]
pacify the mercilous tidy.

5 years agorustfmt `error_reporting/mod.rs` and `dropck.rs`
Niko Matsakis [Tue, 25 Sep 2018 15:32:39 +0000 (11:32 -0400)]
rustfmt `error_reporting/mod.rs` and `dropck.rs`

Pacify the mercilous tidy.

5 years agoupdate tests and add stderr files
Niko Matsakis [Mon, 24 Sep 2018 19:36:50 +0000 (15:36 -0400)]
update tests and add stderr files

5 years agoconvert from an `UnlessNll` flag to a `SuppressRegionErrors` flag
Niko Matsakis [Mon, 24 Sep 2018 17:05:10 +0000 (13:05 -0400)]
convert from an `UnlessNll` flag to a `SuppressRegionErrors` flag

Hopefully this will help clarify the behavior in the various borrowck
modes

5 years agomake NLL handle `IfEq` bounds by using SCC normalization
Niko Matsakis [Fri, 21 Sep 2018 23:26:24 +0000 (19:26 -0400)]
make NLL handle `IfEq` bounds by using SCC normalization

5 years agoswitch to use `VerifyBound` instead of `RegionTest`
Niko Matsakis [Fri, 21 Sep 2018 19:27:53 +0000 (15:27 -0400)]
switch to use `VerifyBound` instead of `RegionTest`

5 years agoregion_infer: rustfmt
Niko Matsakis [Fri, 21 Sep 2018 19:25:42 +0000 (15:25 -0400)]
region_infer: rustfmt

5 years agouse `IfEq` to defer equality comparison around `where` clauses`
Niko Matsakis [Wed, 19 Sep 2018 20:12:00 +0000 (16:12 -0400)]
use `IfEq` to defer equality comparison around `where` clauses`

5 years agorefactor away `AnyRegions` and `AllRegions`
Niko Matsakis [Wed, 19 Sep 2018 19:58:47 +0000 (15:58 -0400)]
refactor away `AnyRegions` and `AllRegions`

It's a bit cleaner to just have `AnyBound` and `AllBound`, after all.

5 years agointroduce `VerifyBound::IfEq` (presently unused)
Niko Matsakis [Wed, 19 Sep 2018 16:52:17 +0000 (12:52 -0400)]
introduce `VerifyBound::IfEq` (presently unused)

5 years agochange to use impl Trait a bit
Niko Matsakis [Wed, 19 Sep 2018 18:45:02 +0000 (14:45 -0400)]
change to use impl Trait a bit

5 years agoremove handling of verify from taintset
Niko Matsakis [Wed, 19 Sep 2018 16:44:38 +0000 (12:44 -0400)]
remove handling of verify from taintset

This lets us remove `for_each_region` and makes things simpler.

5 years agomake `normalize` work on any type-foldable
Niko Matsakis [Wed, 19 Sep 2018 16:15:40 +0000 (12:15 -0400)]
make `normalize` work on any type-foldable

5 years agolexical_region_resolve: rustfmt
Niko Matsakis [Wed, 19 Sep 2018 16:11:58 +0000 (12:11 -0400)]
lexical_region_resolve: rustfmt

5 years agoencapsulate `infcx` too into the delegate
Niko Matsakis [Mon, 17 Sep 2018 20:57:41 +0000 (16:57 -0400)]
encapsulate `infcx` too into the delegate

5 years agoextract out NLL-specific code from relate-tys into a delegate
Niko Matsakis [Mon, 17 Sep 2018 20:36:59 +0000 (16:36 -0400)]
extract out NLL-specific code from relate-tys into a delegate

No functional change.

5 years agorefactor NLL relate_tys to use Region internally, not RegionVid
Niko Matsakis [Mon, 17 Sep 2018 20:25:26 +0000 (16:25 -0400)]
refactor NLL relate_tys to use Region internally, not RegionVid

No functional change.

5 years agouse approx. bounds to decide whether to add outlives obligations
Niko Matsakis [Mon, 17 Sep 2018 18:00:33 +0000 (14:00 -0400)]
use approx. bounds to decide whether to add outlives obligations

Before, if we had a projection like `<T as Foo<'0>>::Bar: 'x` and a
where clause like `<T as Foo<'a>>::Bar: 'a`, we considered those to
have nothing to do with one another. Therefore, we would use the
"overconstrained" path of adding `T: 'x` and `'0: 'x` requirements. We
now do a "fuzzy" match where we erase regions first and hence we see
the env bound `'a`.

5 years agopropagate the `compare_ty` fn further up
Niko Matsakis [Mon, 17 Sep 2018 17:44:20 +0000 (13:44 -0400)]
propagate the `compare_ty` fn further up

5 years agointroduce the idea of an "approximate match"
Niko Matsakis [Mon, 17 Sep 2018 17:28:19 +0000 (13:28 -0400)]
introduce the idea of an "approximate match"

In fact, however, we currently always give back the same exact answers
as ever. But we don't rely on them being exact anymore.

5 years agointroduce a "comparison fn" instead of always use `==`
Niko Matsakis [Mon, 17 Sep 2018 17:03:34 +0000 (13:03 -0400)]
introduce a "comparison fn" instead of always use `==`

5 years agosplit out getting the declared bounds from the env versus trait
Niko Matsakis [Mon, 17 Sep 2018 16:15:48 +0000 (12:15 -0400)]
split out getting the declared bounds from the env versus trait

Right now, we just concatenate them

5 years agobreak out the code that computes VerifyBounds
Niko Matsakis [Fri, 14 Sep 2018 21:13:27 +0000 (17:13 -0400)]
break out the code that computes VerifyBounds

Later, we'll defer this work until a separate phase.

5 years agoapply `process_registered_region_obligations` at the end of regionck
Niko Matsakis [Wed, 12 Sep 2018 21:48:51 +0000 (17:48 -0400)]
apply `process_registered_region_obligations` at the end of regionck

We used to apply it repeatedly as we went, relying on the current
value of the `region_bound_pairs_accum` vector. But now we save those
values into a map, so we can just process all the registered region
obligations at the end.

5 years agotype_check/mod.rs: rustfmt
Niko Matsakis [Wed, 12 Sep 2018 21:48:33 +0000 (17:48 -0400)]
type_check/mod.rs: rustfmt

5 years agouse `RegionBoundPairs` type alias
Niko Matsakis [Wed, 12 Sep 2018 21:45:00 +0000 (17:45 -0400)]
use `RegionBoundPairs` type alias

5 years agoauto_trait.rs: rustfmt
Niko Matsakis [Wed, 12 Sep 2018 21:34:08 +0000 (17:34 -0400)]
auto_trait.rs: rustfmt

5 years agochange `RegionObligation` to store a `SubregionOrigin`
Niko Matsakis [Wed, 12 Sep 2018 21:28:47 +0000 (17:28 -0400)]
change `RegionObligation` to store a `SubregionOrigin`

5 years agouse a `UnlessNll` flag to consolidate error reporting paths
Niko Matsakis [Wed, 12 Sep 2018 19:43:26 +0000 (15:43 -0400)]
use a `UnlessNll` flag to consolidate error reporting paths

5 years agobuild up a map of the region-bound pairs for each body-id
Niko Matsakis [Wed, 12 Sep 2018 19:11:53 +0000 (15:11 -0400)]
build up a map of the region-bound pairs for each body-id

Presently unused.

5 years agooutlives/env: rustfmt
Niko Matsakis [Wed, 12 Sep 2018 19:02:46 +0000 (15:02 -0400)]
outlives/env: rustfmt

5 years agoregionck: rustfmt
Niko Matsakis [Wed, 12 Sep 2018 18:47:57 +0000 (14:47 -0400)]
regionck: rustfmt

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 #54199 - nikomatsakis:predicate_may_hold-failure, r=eddyb
bors [Wed, 26 Sep 2018 12:39:20 +0000 (12:39 +0000)]
Auto merge of #54199 - nikomatsakis:predicate_may_hold-failure, r=eddyb

overlook overflows in rustdoc trait solving

Context:

The new rustdoc "auto trait" feature walks across impls and tries to run trait solving on them with a lot of unconstrained variables. This is prone to overflows. These overflows used to cause an ICE because of a caching bug (fixed in this PR). But even once that is fixed, it means that rustdoc causes an overflow rather than generating docs.

This PR therefore adds a new helper that propagates the overflow error out. This requires rustdoc to then decide what to do when it encounters such an overflow: technically, an overflow represents neither "yes" nor "no", but rather a failure to make a decision. I've decided to opt on the side of treating this as "yes, implemented", since rustdoc already takes an optimistic view. This may prove to include too many items, but I *suspect* not.

We could probably reduce the rate of overflows by unifying more of the parameters from the impl -- right now we only seem to consider the self type. Moreover, in the future, as we transition to Chalk, overflow errors are expected to just "go away" (in some cases, though, queries might return an ambiguous result).

Fixes #52873

cc @QuietMisdreavus -- this is the stuff we were talking about earlier
cc @GuillaumeGomez -- this supersedes #53687

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 agoadd regression test
Niko Matsakis [Tue, 25 Sep 2018 17:54:51 +0000 (13:54 -0400)]
add regression test

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?