]> git.lizzy.rs Git - rust.git/log
rust.git
5 years agoadd MaybeUninit
Jorge Aparicio [Sun, 19 Aug 2018 13:51:35 +0000 (15:51 +0200)]
add MaybeUninit

5 years agoRevert "Auto merge of #53508 - japaric:maybe-uninit, r=RalfJung"
Ralf Jung [Tue, 25 Sep 2018 13:07:27 +0000 (15:07 +0200)]
Revert "Auto merge of #53508 - japaric:maybe-uninit, r=RalfJung"

This reverts commit c6e3d7fa3113aaa64602507f39d4627c427742ff, reversing
changes made to 4591a245c7eec9f70d668982b1383cd2a6854af5.

5 years agoAuto merge of #54278 - eddyb:spanned-generic-predicates, r=nikomatsakis
bors [Sat, 29 Sep 2018 03:42:38 +0000 (03:42 +0000)]
Auto merge of #54278 - eddyb:spanned-generic-predicates, r=nikomatsakis

rustc: keep a Span for each predicate in ty::GenericPredicates.

This should allow finer-grained diagnostics, including migration suggestions for #54090.
(Note that I haven't changed most of the users of `predicates_of` to use the new spans)

r? @nikomatsakis

5 years agoAuto merge of #53013 - zackmdavis:infer_outlints, r=nikomatsakis
bors [Sat, 29 Sep 2018 01:09:07 +0000 (01:09 +0000)]
Auto merge of #53013 - zackmdavis:infer_outlints, r=nikomatsakis

in which inferable outlives-requirements are linted

RFC 2093 (tracking issue #44493) lets us leave off these
commonsensically inferable `T: 'a` outlives requirements. (A separate
feature-gate was split off for the case of 'static lifetimes, for
which questions still remain.) Detecting these was requested as an
idioms-2018 lint.

Resolves #52042, an item under the fabulous metaïssue #52047.

It's plausible that this shouldn't land until after `infer_outlives_requirements` has been stabilized ([final comment period started](https://github.com/rust-lang/rust/issues/44493#issuecomment-408852946) 4 days ago), but I think there's also a strong case to not-wait in order to maximize the time that [Edition Preview 2](https://internals.rust-lang.org/t/rust-2018-release-schedule-and-extended-beta/8076) users have to kick at it. (It's allow by default, so there's no impact unless you explicitly turn it or the rust-2018-idioms group up to `warn` or higher.)

Questions—

 * Is `explicit-outlives-requirements` a good name? (I chose it as an [RFC 344](https://github.com/rust-lang/rfcs/blob/master/text/0344-conventions-galore.md#lints)-compliant "inversion" of the feature-gate name, `infer_outlives_requirements`, but I could imagine someone arguing that the word `struct` should be part of the name somewhere, for specificity.)

 * Are there any false-positives or false-negatives? @nikomatsakis [said that](https://github.com/rust-lang/rust/issues/52042#issuecomment-406409795) getting this right would be "fairly hard", which makes me nervous that I'm missing something. The UI test in the initial submission of this pull request just exercises the examples [given in the Edition Guide](https://rust-lang-nursery.github.io/edition-guide/2018/transitioning/ownership-and-lifetimes/struct-inference.html).

![infer_outlints](https://user-images.githubusercontent.com/1076988/43625740-6bf43dca-96a3-11e8-9dcf-793ac83d424d.png)

r? @alexcrichton

5 years agoAuto merge of #54643 - Xanewok:fix-rls, r=kennytm
bors [Fri, 28 Sep 2018 20:30:17 +0000 (20:30 +0000)]
Auto merge of #54643 - Xanewok:fix-rls, r=kennytm

Fix RLS toolstate after #54356 merge

Fixes toolstate regression caused by https://github.com/rust-lang/rust/pull/54356.

The `save::process_crate` now needs to be passed an additional `&Input`, this change contains the RLS equivalent of [this](https://github.com/rust-lang/rust/pull/54356/files#diff-707a0eda6b2f1a0537abc3d23133748cR983).

r? @kennytm (or @nrc if you're not away yet)

5 years agoFix RLS toolstate after #54356 merge
Igor Matuszewski [Fri, 28 Sep 2018 14:39:24 +0000 (16:39 +0200)]
Fix RLS toolstate after #54356 merge

5 years agorustc: keep a Span for each predicate in ty::GenericPredicates.
Eduard-Mihai Burtescu [Sun, 16 Sep 2018 17:15:49 +0000 (20:15 +0300)]
rustc: keep a Span for each predicate in ty::GenericPredicates.

5 years agoAuto merge of #54356 - Xanewok:save-analysis-invocation, r=nrc
bors [Fri, 28 Sep 2018 11:48:48 +0000 (11:48 +0000)]
Auto merge of #54356 - Xanewok:save-analysis-invocation, r=nrc

Emit used rustc invocation in the save-analysis file

Blocked on https://github.com/nrc/rls-data/pull/19. (I'm guessing it won't pass CI due to an out-of-tree git dependency)

This should allow RLS to recreate a Rust compilation build plan from the save-analysis files alone, which should be useful when fetching those from external build systems, most notably Buck now.

Also this includes some more potentially useful compilation-specific options (e.g. sysroot or the actual path to extern crates) but that's not required for the build plan bits.

cc @jsgf @alexcrichton

r? @nrc

5 years agoAuto merge of #54568 - levex:issue-54130, r=nagisa
bors [Fri, 28 Sep 2018 09:17:28 +0000 (09:17 +0000)]
Auto merge of #54568 - levex:issue-54130, r=nagisa

codegen_llvm: check inline assembly constraints with LLVM

---%<---
Hey all,

As issue #54130 highlights, constraints are not checked and passing bad constraints to LLVM can crash it since a `Verify()` call is placed inside an assertion (see: `src/llvm/lib/IR/InlineAsm.cpp:39`).

As this is my first PR to the Rust compiler (woot! :tada:), there might be better ways of achieving this result. In particular, I am not too happy about generating an error in codegen; it would be much nicer if we did it earlier. However, @rkruppe [noted on IRC](https://botbot.me/mozilla/rustc/2018-09-25/?msg=104791581&page=1) that this should be fine for an unstable feature and a much better solution than the _status quo_, which is an ICE.

Thanks!
--->%---

LLVM provides a way of checking whether the constraints and the actual
inline assembly make sense. This commit introduces a check before
emitting code for the inline assembly. If LLVM rejects the inline
assembly (or its constraints), then the compiler emits an error E0668
("malformed inline assembly").

Fixes: #54130
Signed-off-by: Levente Kurusa \<lkurusa@acm.org\>
5 years agoAuto merge of #54338 - orium:fix-macro-inc-comp, r=nrc
bors [Fri, 28 Sep 2018 06:40:32 +0000 (06:40 +0000)]
Auto merge of #54338 - orium:fix-macro-inc-comp, r=nrc

Use full name to identify a macro in a `FileName`.

Before this two macros with same name would be indistinguishable inside a `FileName`.  This caused a bug in incremental compilation (see #53097) since two different macros would map out to the same `StableFilemapId`.

Fixes #53097.

r? @nrc

5 years agoin which inferable outlives-requirements are linted
Zack M. Davis [Sun, 26 Aug 2018 19:22:04 +0000 (12:22 -0700)]
in which inferable outlives-requirements are linted

RFC 2093 (tracking issue #44493) lets us leave off
commonsensically inferable `T: 'a` outlives requirements. (A separate
feature-gate was split off for the case of 'static lifetimes, for
which questions still remain.) Detecting these was requested as an
idioms-2018 lint.

It turns out that issuing a correct, autofixable suggestion here is
somewhat subtle in the presence of other bounds and generic
parameters. Basically, we want to handle these three cases:

 • One outlives-bound. We want to drop the bound altogether, including
   the colon—

   MyStruct<'a, T: 'a>
                 ^^^^ help: remove this bound

 • An outlives bound first, followed by a trait bound. We want to
   delete the outlives bound and the following plus sign (and
   hopefully get the whitespace right, too)—

   MyStruct<'a, T: 'a + MyTrait>
                   ^^^^^ help: remove this bound

 • An outlives bound after a trait bound. We want to delete the
   outlives lifetime and the preceding plus sign—

   MyStruct<'a, T: MyTrait + 'a>
                          ^^^^^ help: remove this bound

This gets (slightly) even more complicated in the case of where
clauses, where we want to drop the where clause altogether if there's
just the one bound. Hopefully the comments are enough to explain
what's going on!

A script (in Python, sorry) was used to generate the
hopefully-sufficiently-exhaustive UI test input. Some of these are
split off into a different file because rust-lang-nursery/rustfix#141
(and, causally upstream of that, #53934) prevents them from being
`run-rustfix`-tested.

We also make sure to include a UI test of a case (copied from RFC
2093) where the outlives-bound can't be inferred. Special thanks to
Niko Matsakis for pointing out the `inferred_outlives_of` query,
rather than blindly stripping outlives requirements as if we weren't a
production compiler and didn't care.

This concerns #52042.

5 years agoAuto merge of #54547 - AstralSorcerer:issue-54028, r=eddyb
bors [Fri, 28 Sep 2018 02:28:25 +0000 (02:28 +0000)]
Auto merge of #54547 - AstralSorcerer:issue-54028, r=eddyb

Rely only on base alignment and offset for computing field alignment

Fix #54028
r? @eddyb

5 years agoUse rls-data 0.18.1
Igor Matuszewski [Tue, 25 Sep 2018 06:32:49 +0000 (08:32 +0200)]
Use rls-data 0.18.1

5 years agoAlso remap absolute source names in save-analysis
Igor Matuszewski [Mon, 24 Sep 2018 14:53:49 +0000 (16:53 +0200)]
Also remap absolute source names in save-analysis

5 years agoMinimize final diff
Igor Matuszewski [Mon, 24 Sep 2018 14:38:54 +0000 (16:38 +0200)]
Minimize final diff

5 years agoRemap only source files in the command line
Igor Matuszewski [Mon, 24 Sep 2018 14:28:53 +0000 (16:28 +0200)]
Remap only source files in the command line

5 years agoEmit only necessary compilation options in save-analysis
Igor Matuszewski [Sat, 22 Sep 2018 21:19:39 +0000 (23:19 +0200)]
Emit only necessary compilation options in save-analysis

This is `command`, `directory` and `output` file.

5 years agoMove `filename_for_metadata` to codegen_utils
Igor Matuszewski [Sat, 22 Sep 2018 20:24:32 +0000 (22:24 +0200)]
Move `filename_for_metadata` to codegen_utils

This function isn't strictly tied to LLVM (it's more of a utility) and
it's now near an analogous, almost identical `filename_for_input` (for
rlibs and so forth).
Also this means not depending on the backend when one wants to know the
accurate .rmeta output filename.

5 years agoEmit used rustc invocation in the save-analysis file
Igor Matuszewski [Tue, 11 Sep 2018 14:39:07 +0000 (16:39 +0200)]
Emit used rustc invocation in the save-analysis file

5 years agoAuto merge of #54530 - pnkfelix:issue-54047-migrate-ui-run-pass-back-to-run-pass...
bors [Thu, 27 Sep 2018 23:46:21 +0000 (23:46 +0000)]
Auto merge of #54530 - pnkfelix:issue-54047-migrate-ui-run-pass-back-to-run-pass, r=alexcrichton

Migrate `src/test/ui/run-pass/*` back to `src/test/run-pass/`.

Moves all the tests from `src/test/ui/run-pass/**` back to `src/test/run-pass/`.

This should have no impact on our overall testing completeness due to PR #54223

Fix #54047

5 years agoAuto merge of #54468 - matthewjasper:fix-polonius, r=nikomatsakis
bors [Thu, 27 Sep 2018 19:26:59 +0000 (19:26 +0000)]
Auto merge of #54468 - matthewjasper:fix-polonius, r=nikomatsakis

[NLL] Get Polonius borrow check to work in simple cases

* Restores the generation of outlives facts from subtyping.
* Restore liveness facts.
* Generate invalidates facts at the start point of each location,
  where we check for errors.
* Add a small test for simple cases (previously these cases have compiled, and more recently ICEd).

Closes #54212
cc #53142 (will need test)

### Known limitations

* Two phase borrows aren't implemented for Polonius yet
* Invalidation facts haven't been updated for some of the recent changes to make `Drop` terminators access fewer things.
* Fact generation is not as optimized as it could be.
* Around 30 tests fail in compare mode, often tests that are ignored in nll compare mode

r? @nikomatsakis

5 years agoAllow `unused_variables` lint to placate test failure exposed by macos builders.
Felix S. Klock II [Thu, 27 Sep 2018 19:00:21 +0000 (21:00 +0200)]
Allow `unused_variables` lint to placate test failure exposed by macos builders.

5 years agoAuto merge of #54533 - ljedrz:cleanup_librustc_typeck_check, r=davidtwco
bors [Thu, 27 Sep 2018 16:54:28 +0000 (16:54 +0000)]
Auto merge of #54533 - ljedrz:cleanup_librustc_typeck_check, r=davidtwco

A few cleanups and minor improvements to typeck/check

- turn a `loop` into a `while let`
- turn a `push_back` loop into an `extend`
- turn a few `push` loops into collected iterators
- prefer `vec![x; n]` to `(0..n).map(|_| x).collect()`
- combine two loops doing the same thing on 2 data sets using `chain`
- use `unwrap_or` where applicable and readable
- add a `potentially_plural_count` helper function to simplify several `format!()` calls
- prefer `to_owned` to `to_string` for string literals
- change `match` to `if let` where only one branch matters
- a few other minor improvements
- whitespace fixes

5 years agoAuto merge of #54355 - pnkfelix:issue-22323-regression-test, r=davidtwco
bors [Thu, 27 Sep 2018 12:35:36 +0000 (12:35 +0000)]
Auto merge of #54355 - pnkfelix:issue-22323-regression-test, r=davidtwco

NLL: regression test for "dropck: track order of destruction for r-value temporaries"

Once this lands, we can remove the E-needstest from #22323.

(We shouldn't close the bug itself, however, because we are leaving the NLL-fixed-by-NLL bugs open until NLL is turned on by default.)

5 years agoAllow more lints that signalled on the arm-android test run.
Felix S. Klock II [Thu, 27 Sep 2018 11:06:16 +0000 (13:06 +0200)]
Allow more lints that signalled on the arm-android test run.

5 years agoAuto merge of #52319 - tinco:issue_12590, r=pnkfelix
bors [Thu, 27 Sep 2018 09:51:12 +0000 (09:51 +0000)]
Auto merge of #52319 - tinco:issue_12590, r=pnkfelix

Track whether module declarations are inline (fixes #12590)

To track whether module declarations are inline I added a field `inline: bool` to `ast::Mod`. The main use case is for pretty to know whether it should render the items associated with the module, but perhaps there are use cases for this information to not be forgotten in the AST.

5 years agoA few cleanups and minor improvements to typeck
ljedrz [Wed, 19 Sep 2018 11:51:51 +0000 (13:51 +0200)]
A few cleanups and minor improvements to typeck

5 years agoAllow some lints that only fired on 32-bit and/or Windows.
Felix S. Klock II [Thu, 27 Sep 2018 08:14:57 +0000 (10:14 +0200)]
Allow some lints that only fired on 32-bit and/or Windows.

5 years agoAuto merge of #54581 - petrochenkov:cfgattr, r=alexcrichton
bors [Thu, 27 Sep 2018 07:16:27 +0000 (07:16 +0000)]
Auto merge of #54581 - petrochenkov:cfgattr, r=alexcrichton

Accept trailing comma in `cfg_attr`

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

5 years agoAuto merge of #54526 - nnethercote:shrink-StatementKind, r=nagisa
bors [Wed, 26 Sep 2018 23:22:48 +0000 (23:22 +0000)]
Auto merge of #54526 - nnethercote:shrink-StatementKind, r=nagisa

Shrink `StatementKind`

`StatementKind` occurs in significant amounts in Massif profiles.

5 years agoGet Polonius borrow check to work in simple cases
Matthew Jasper [Wed, 26 Sep 2018 19:41:14 +0000 (20:41 +0100)]
Get Polonius borrow check to work in simple cases

* Restores the generation of outlives facts from subtyping.
* Restore liveness facts.
* Generate invalidates facts at the start point of each location,
  where we check for errors.
* Add a small test for simple cases.

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 agofixup! codegen_llvm: check inline assembly constraints with LLVM
Levente Kurusa [Wed, 26 Sep 2018 14:23:10 +0000 (16:23 +0200)]
fixup! codegen_llvm: check inline assembly constraints with LLVM

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 agoAdd `#[allow(unused_mut)]` for various cases that arise only in compare-mode=nll.
Felix S. Klock II [Wed, 26 Sep 2018 11:04:07 +0000 (13:04 +0200)]
Add `#[allow(unused_mut)]` for various cases that arise only in compare-mode=nll.

5 years agoAdd `#![allow(..)]` as necessary to get re-migrated run-pass tests compiling with...
Felix S. Klock II [Tue, 25 Sep 2018 21:51:35 +0000 (23:51 +0200)]
Add `#![allow(..)]` as necessary to get re-migrated run-pass tests compiling with clean stderr again.

Most were added mechanically.

5 years agoMigrate `src/test/ui/run-pass/*` back to `src/test/run-pass/`.
Felix S. Klock II [Mon, 24 Sep 2018 13:05:45 +0000 (15:05 +0200)]
Migrate `src/test/ui/run-pass/*` back to `src/test/run-pass/`.

Fix #54047

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 agofixup! codegen_llvm: check inline assembly constraints with LLVM
Levente Kurusa [Wed, 26 Sep 2018 08:19:09 +0000 (10:19 +0200)]
fixup! codegen_llvm: check inline assembly constraints with LLVM

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 agofixup! codegen_llvm: check inline assembly constraints with LLVM
Levente Kurusa [Wed, 26 Sep 2018 06:44:19 +0000 (08:44 +0200)]
fixup! codegen_llvm: check inline assembly constraints with LLVM

5 years agofixup! codegen_llvm: check inline assembly constraints with LLVM
Levente Kurusa [Wed, 26 Sep 2018 04:43:19 +0000 (06:43 +0200)]
fixup! codegen_llvm: check inline assembly constraints with LLVM

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 agoAccept trailing comma in `cfg_attr`
Vadim Petrochenkov [Wed, 26 Sep 2018 00:07:59 +0000 (03:07 +0300)]
Accept trailing comma in `cfg_attr`

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