]> git.lizzy.rs Git - rust.git/log
rust.git
5 years agostd: Start implementing wasm32 atomics
Alex Crichton [Wed, 15 Aug 2018 17:51:24 +0000 (10:51 -0700)]
std: Start implementing wasm32 atomics

This commit is an initial start at implementing the standard library for
wasm32-unknown-unknown with the experimental `atomics` feature enabled. None of
these changes will be visible to users of the wasm32-unknown-unknown target
because they all require recompiling the standard library. The hope with this is
that we can get this support into the standard library and start iterating on it
in-tree to enable experimentation.

Currently there's a few components in this PR:

* Atomic fences are disabled on wasm as there's no corresponding atomic op and
  it's not clear yet what the convention should be, but this will change in the
  future!
* Implementations of `Mutex`, `Condvar`, and `RwLock` were all added based on
  the atomic intrinsics that wasm has.
* The `ReentrantMutex` and thread-local-storage implementations panic currently
  as there's no great way to get a handle on the current thread's "id" yet.

Right now the wasm32 target with atomics is unfortunately pretty unusable,
requiring a lot of manual things here and there to actually get it operational.
This will likely continue to evolve as the story for atomics and wasm unfolds,
but we also need more LLVM support for some operations like custom `global`
directives for this to work best.

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

Deny the `overflowing_literals` lint for the 2018 edition

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

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

update rls to 32d457717ce37babef199fe4984b1e20d4e108d4

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

Should fix rls and toolstate.

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

Improve error message for E0424

Resolves #54369

r? @estebank

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

avoid loading constructor attributes in AdtDef decoding

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

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

r? @eddyb & cc @nnethercote

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

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

Fixes #52534.

r? @nikomatsakis

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

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

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

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

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

The goal was not to change any behavior.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Remove spawning from task::Context

r? @aturon

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

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

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

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

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

r? @alexcrichton

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

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

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

Fix #52059

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

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

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

Changes:

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

Future work:

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

r? @nikomatsakis

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

5 years agoAuto merge of #53508 - japaric:maybe-uninit, r=RalfJung
bors [Sat, 22 Sep 2018 23:08:03 +0000 (23:08 +0000)]
Auto merge of #53508 - japaric:maybe-uninit, r=RalfJung

Implement `MaybeUninit`

This PR:

- Adds `MaybeUninit` (see #53491) to `{core,std}::mem`.
- Makes `mem::{uninitialized,zeroed}` panic when they are used to instantiate an uninhabited type.
- Does *not* deprecate `mem::{uninitialized,zeroed}` just yet. As per https://github.com/rust-lang/rust/issues/53491#issuecomment-414147666, we should not deprecate them until `MaybeUninit` is stabilized.
- It replaces uses of `mem::{uninitialized,zeroed}` in core and alloc with `MaybeUninit`.

There are still several instances of `mem::{uninitialized,zeroed}` in `std` that *this* PR doesn't address.

r? @RalfJung
cc @eddyb you may want to look at the new panicking logic

5 years agoallow dead_code
Jorge Aparicio [Sat, 22 Sep 2018 22:37:08 +0000 (00:37 +0200)]
allow dead_code

5 years agoAuto merge of #54188 - lqd:fallout-53695, r=nikomatsakis
bors [Sat, 22 Sep 2018 20:38:19 +0000 (20:38 +0000)]
Auto merge of #54188 - lqd:fallout-53695, r=nikomatsakis

NLL: disallow creation of immediately unusable variables

Fix #53695

Original description follows

----

This WIP PR is for discussing the impact of fixing #53695 by injecting a fake read in let patterns.

(Travis will fail, at least the `mir-opt` suite is failing in its current state)

5 years agothe test requires unwinding so we don't run it on the wasm32-bare target
Jorge Aparicio [Fri, 21 Sep 2018 21:40:00 +0000 (23:40 +0200)]
the test requires unwinding so we don't run it on the wasm32-bare target

5 years agoadd codegen test
Jorge Aparicio [Thu, 20 Sep 2018 18:57:25 +0000 (20:57 +0200)]
add codegen test

5 years agofix tidy
Jorge Aparicio [Sat, 1 Sep 2018 19:44:35 +0000 (21:44 +0200)]
fix tidy

5 years agomake the nil-enum test work again
Jorge Aparicio [Sat, 1 Sep 2018 18:13:13 +0000 (20:13 +0200)]
make the nil-enum test work again

5 years agogdb_rust_pretty_printing: adapt to the changes in the layout of btree::LeafNode
Jorge Aparicio [Sat, 1 Sep 2018 17:58:04 +0000 (19:58 +0200)]
gdb_rust_pretty_printing: adapt to the changes in the layout of btree::LeafNode

5 years agoaddress RalfJung's comment
Jorge Aparicio [Thu, 23 Aug 2018 14:52:05 +0000 (16:52 +0200)]
address RalfJung's comment

5 years agoadd empty enum to the test cases
Jorge Aparicio [Thu, 23 Aug 2018 14:49:35 +0000 (16:49 +0200)]
add empty enum to the test cases

5 years agoimprove the run-pass test
Jorge Aparicio [Thu, 23 Aug 2018 14:49:00 +0000 (16:49 +0200)]
improve the run-pass test

5 years agomove our check to reuse a previous computation
Jorge Aparicio [Thu, 23 Aug 2018 14:39:03 +0000 (16:39 +0200)]
move our check to reuse a previous computation

5 years agoimprove panic message
Jorge Aparicio [Thu, 23 Aug 2018 14:36:51 +0000 (16:36 +0200)]
improve panic message

5 years agouse is_uninhabited in more places
Jorge Aparicio [Thu, 23 Aug 2018 14:34:38 +0000 (16:34 +0200)]
use is_uninhabited in more places

5 years agoaddress Mark-Simulacrum comments
Jorge Aparicio [Thu, 23 Aug 2018 14:29:01 +0000 (16:29 +0200)]
address Mark-Simulacrum comments

5 years agoadapt to change in Session API
Jorge Aparicio [Thu, 23 Aug 2018 14:18:28 +0000 (16:18 +0200)]
adapt to change in Session API

5 years agodon't deprecate mem::{uninitialized,zeroed} just yet
Jorge Aparicio [Sun, 19 Aug 2018 19:59:21 +0000 (21:59 +0200)]
don't deprecate mem::{uninitialized,zeroed} just yet

5 years agoalloc: fix deprecated warnings
Jorge Aparicio [Sun, 19 Aug 2018 19:56:49 +0000 (21:56 +0200)]
alloc: fix deprecated warnings

5 years agopanic when instantiating an uninhabited type via mem::{uninitialized,zeroed}
Jorge Aparicio [Sun, 19 Aug 2018 15:36:04 +0000 (17:36 +0200)]
panic when instantiating an uninhabited type via mem::{uninitialized,zeroed}

5 years agocore: fix deprecated warnings
Jorge Aparicio [Sun, 19 Aug 2018 15:45:31 +0000 (17:45 +0200)]
core: fix deprecated warnings

5 years agoadd MaybeUninit and deprecate mem::{uninitialized,zeroed}
Jorge Aparicio [Sun, 19 Aug 2018 13:51:35 +0000 (15:51 +0200)]
add MaybeUninit and deprecate mem::{uninitialized,zeroed}

5 years agoavoid loading constructor attributes in AdtDef decoding
Ariel Ben-Yehuda [Sat, 22 Sep 2018 18:53:58 +0000 (21:53 +0300)]
avoid loading constructor attributes in AdtDef decoding

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

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

5 years agoAuto merge of #54457 - pietroalbini:rollup, r=pietroalbini
bors [Sat, 22 Sep 2018 14:26:15 +0000 (14:26 +0000)]
Auto merge of #54457 - pietroalbini:rollup, r=pietroalbini

Rollup of 16 pull requests

Successful merges:

 - #53652 (define copy_within on slices)
 - #54261 (Make `dyn` a keyword in the 2018 edition)
 - #54280 (remove (more) CAS API from Atomic* types where not natively supported)
 - #54323 (rustbuild: drop color handling)
 - #54350 (Support specifying edition in doc test)
 - #54370 (Improve handling of type bounds in `bit_set.rs`.)
 - #54371 (add -Zui-testing to rustdoc)
 - #54374 (Make 'proc_macro::MultiSpan' public.)
 - #54402 (Use no_default_libraries for all NetBSD flavors)
 - #54409 (Detect `for _ in in bar {}` typo)
 - #54412 (add applicability to span_suggestion call)
 - #54413 (Add UI test for deref recursion limit printing twice)
 - #54415 (parser: Tweak function parameter parsing to avoid rollback on succesfull path)
 - #54420 (Compress `Liveness` data some more.)
 - #54422 (Simplify slice's first(_mut) and last(_mut) with get)
 - #54446 (Unify christianpoveda's emails)

Failed merges:

 - #54058 (Introduce the partition_dedup/by/by_key methods for slices)

r? @ghost

5 years agoAuto merge of #54265 - arielb1:civilize-proc-macros, r=alexcrichton
bors [Sat, 22 Sep 2018 11:56:08 +0000 (11:56 +0000)]
Auto merge of #54265 - arielb1:civilize-proc-macros, r=alexcrichton

avoid leaking host details in proc macro metadata decoding

proc macro crates are essentially implemented as dynamic libraries using
a dlopen-based ABI. They are also Rust crates, so they have 2 worlds -
the "host" world in which they are defined, and the "target" world in
which they are used.

For all the "target" world knows, the proc macro crate might not even
be implemented in Rust, so leaks of details from the host to the target
must be avoided for correctness.

Because the "host" DefId space is different from the "target" DefId
space, any leak involving a DefId will have a nonsensical or
out-of-bounds DefKey, and will cause all sorts of crashes.

This PR fixes all leaks I have found in `decoder`. In particular, #54059
was caused by host native libraries leaking into the target, which feels
like it might even be a correctness issue if it doesn't cause an ICE.

Fixes #54059

5 years agoRollup merge of #54446 - christianpoveda:patch-1, r=cramertj
Pietro Albini [Sat, 22 Sep 2018 07:56:44 +0000 (09:56 +0200)]
Rollup merge of #54446 - christianpoveda:patch-1, r=cramertj

Unify christianpoveda's emails

5 years agoRollup merge of #54422 - ljedrz:simplify_first_last, r=Mark-Simulacrum
Pietro Albini [Sat, 22 Sep 2018 07:56:43 +0000 (09:56 +0200)]
Rollup merge of #54422 - ljedrz:simplify_first_last, r=Mark-Simulacrum

Simplify slice's first(_mut) and last(_mut) with get

This change makes these functions easier to read and interpret. I haven't detected any difference in performance locally.

r? @Mark-Simulacrum

5 years agoRollup merge of #54420 - nnethercote:PackedRWU-Vec, r=nikomatsakis
Pietro Albini [Sat, 22 Sep 2018 07:56:41 +0000 (09:56 +0200)]
Rollup merge of #54420 - nnethercote:PackedRWU-Vec, r=nikomatsakis

Compress `Liveness` data some more.

Profiling shows that the `(reader, writer, used)` triples used by
liveness analysis almost always have invalid `reader` and `writer`
fields. We can take advantage of this knowledge to use a compressed
representation for them, falling back to a secondary table for the
uncommon cases.

This change reduces instruction counts on numerous benchmarks, the best
by 16%. It also reduces max-rss on numerous benchmarks, the best by 38%.

The patch also renames these triples from `Users` to `RWU`, because it's
confusing having a type whose name is plural and then used within
vectors whose names are also plural.

r? @nikomatsakis

5 years agoRollup merge of #54415 - petrochenkov:norollback, r=estebank
Pietro Albini [Sat, 22 Sep 2018 07:56:40 +0000 (09:56 +0200)]
Rollup merge of #54415 - petrochenkov:norollback, r=estebank

parser: Tweak function parameter parsing to avoid rollback on succesfull path

Since rollback is not perfect and may e.g. leave non-fatal errors after it, we need to make sure compilation fails if it happens.
So in particular case of `fn parse_arg_general` we need to parse the "good" `TYPE` first and only then rollback and recover erroneous `PAT: TYPE` if necessary.
Found when working on https://github.com/rust-lang/rfcs/pull/2544#issuecomment-423293222.

r? @ghost

5 years agoRollup merge of #54413 - memoryruins:deref-error-twice, r=estebank
Pietro Albini [Sat, 22 Sep 2018 07:56:39 +0000 (09:56 +0200)]
Rollup merge of #54413 - memoryruins:deref-error-twice, r=estebank

Add UI test for deref recursion limit printing twice

Closes #38940

Does ``NOTE`` in the test need to be changed to ``HELP`` if its in the stderr?
``help: consider adding a `#![recursion_limit="20"]` attribute to your crate``

It doesn't appear to complaining locally that the line isn't set to ``HELP`` in the test, and the guide says
 > HELP and SUGGESTION*
> * Note: SUGGESTION must follow immediately after HELP.

yet there's no concrete suggestion emitted.

r? @estebank

5 years agoRollup merge of #54412 - jcpst:replace_span_suggestion, r=estebank
Pietro Albini [Sat, 22 Sep 2018 07:56:38 +0000 (09:56 +0200)]
Rollup merge of #54412 - jcpst:replace_span_suggestion, r=estebank

add applicability to span_suggestion call

Found another `span_suggestion` call. Issue #50723

r? @estebank

5 years agoRollup merge of #54409 - estebank:remove-in, r=pnkfelix
Pietro Albini [Sat, 22 Sep 2018 07:56:37 +0000 (09:56 +0200)]
Rollup merge of #54409 - estebank:remove-in, r=pnkfelix

Detect `for _ in in bar {}` typo

Fix #36611, #52964, without modifying the parsing of emplacement `in` to avoid further problems like #50832.

5 years agoRollup merge of #54402 - bgermann:master, r=alexcrichton
Pietro Albini [Sat, 22 Sep 2018 07:56:35 +0000 (09:56 +0200)]
Rollup merge of #54402 - bgermann:master, r=alexcrichton

Use no_default_libraries for all NetBSD flavors

The no_default_libraries was introduced in #28578 because the
NetBSD-based rumprun needed to disable the link flag.
This moves the definition to be used by all NetBSD linker flavors to
close #49627.

A different solution would be adding -lc but as there is no platform
with explicit -lc, this approach is used.

5 years agoRollup merge of #54374 - SergioBenitez:pub-multispan, r=alexcrichton
Pietro Albini [Sat, 22 Sep 2018 07:56:34 +0000 (09:56 +0200)]
Rollup merge of #54374 - SergioBenitez:pub-multispan, r=alexcrichton

Make 'proc_macro::MultiSpan' public.

Oversight from #52896.

5 years agoRollup merge of #54371 - QuietMisdreavus:rustdoc-ui-testing, r=GuillaumeGomez
Pietro Albini [Sat, 22 Sep 2018 07:56:33 +0000 (09:56 +0200)]
Rollup merge of #54371 - QuietMisdreavus:rustdoc-ui-testing, r=GuillaumeGomez

add -Zui-testing to rustdoc

Before we depend on the `rustdoc-ui` tests some more, let's make rustdoc act the same as the compiler when they're actually being executed.

5 years agoRollup merge of #54370 - nnethercote:better-domain_size, r=nikomatsakis
Pietro Albini [Sat, 22 Sep 2018 07:56:32 +0000 (09:56 +0200)]
Rollup merge of #54370 - nnethercote:better-domain_size, r=nikomatsakis

Improve handling of type bounds in `bit_set.rs`.

Currently, `BitSet` doesn't actually know its own domain size; it just
knows how many words it contains. We can make it better.

5 years agoRollup merge of #54350 - Munksgaard:support-edition-in-doc-test, r=steveklabnik
Pietro Albini [Sat, 22 Sep 2018 07:56:30 +0000 (09:56 +0200)]
Rollup merge of #54350 - Munksgaard:support-edition-in-doc-test, r=steveklabnik

Support specifying edition in doc test

Fixes #52623

r? @QuietMisdreavus

5 years agoRollup merge of #54323 - Keruspe:rustc-color, r=Mark-Simulacrum
Pietro Albini [Sat, 22 Sep 2018 07:56:29 +0000 (09:56 +0200)]
Rollup merge of #54323 - Keruspe:rustc-color, r=Mark-Simulacrum

rustbuild: drop color handling

Let cargo handle that for us

Fixes #54322

Needs a beta backport

5 years agoRollup merge of #54280 - japaric:no-cas-for-thumbv6, r=alexcrichton
Pietro Albini [Sat, 22 Sep 2018 07:56:28 +0000 (09:56 +0200)]
Rollup merge of #54280 - japaric:no-cas-for-thumbv6, r=alexcrichton

remove (more) CAS API from Atomic* types where not natively supported

closes #54276

In PR #51953 I made the Atomic* types available on targets like thumbv6m and
msp430 with the intention of *only* exposing the load and store API on those
types -- the rest of the API doesn't work on those targets because the are no
native instructions to implement CAS loops.

Unfortunately, it seems I didn't properly cfg away all the CAS API on those
targets, as evidenced in #54276. This PR amends the issue by removing the rest
of the CAS API.

This is technically a breaking change because *libraries* that were using this
API and were being compiled for e.g. thumbv6m-none-eabi will stop compiling.
However, using those libraries (before this change) in programs (binaries) would
lead to linking errors when compiled for e.g. thumbv6m so this change
effectively shifts a linker error in binaries to a compiler error in libraries.

On a side note: extending the Atomic API is a bit error prone because of these
non-cas targets. Unless the author of the change is aware of these targets and
properly uses `#[cfg(atomic = "cas")]` they could end up exposing new CAS API on
these targets. I can't think of a test to check that an API is not present on
some target, but we could extend the `tidy` tool to check that *all* newly added
atomic API has the `#[cfg(atomic = "cas")]` attribute unless it's whitelisted in
`tidy` then the author of the change would have to verify if the API can be used
on non-cas targets.

In any case, I'd like to plug this hole ASAP. We can revisit testing in a
follow-up issue / PR.

r? @alexcrichton
cc @mvirkkunen

5 years agoRollup merge of #54261 - varkor:dyn-keyword-2018, r=petrochenkov
Pietro Albini [Sat, 22 Sep 2018 07:56:27 +0000 (09:56 +0200)]
Rollup merge of #54261 - varkor:dyn-keyword-2018, r=petrochenkov

Make `dyn` a keyword in the 2018 edition

Proposed in https://github.com/rust-lang/rust/issues/44662#issuecomment-421596088.

5 years agoRollup merge of #53652 - oconnor663:copy_in_place, r=alexcrichton
Pietro Albini [Sat, 22 Sep 2018 07:56:24 +0000 (09:56 +0200)]
Rollup merge of #53652 - oconnor663:copy_in_place, r=alexcrichton

define copy_within on slices

This is a safe wrapper around `ptr::copy`, for regions within a single slice. Previously, safe in-place copying was only available as a side effect of `Vec::drain`.

I've wanted this API a couple times in the past, and I figured I'd just whip up a PR to help discuss it. It's possible something like this exists elsewhere and I just missed it. It might also be a big enough addition to warrant an RFC, I'm not sure.

5 years agoAuto merge of #54403 - eddyb:oopsie-daisy-stabilize, r=alexcrichton
bors [Sat, 22 Sep 2018 07:06:11 +0000 (07:06 +0000)]
Auto merge of #54403 - eddyb:oopsie-daisy-stabilize, r=alexcrichton

Stabilize crate_in_paths, extern_absolute_paths and extern_prelude on all editions.

Needed for beta, path-related migrations to Rust 2018 don't work on RC1 without these stabilizations.

r? @aturon cc @nikomatsakis @Centril @alexcrichton

5 years agoStabilize crate_in_paths, extern_absolute_paths and extern_prelude on all editions.
Eduard-Mihai Burtescu [Thu, 20 Sep 2018 17:39:46 +0000 (20:39 +0300)]
Stabilize crate_in_paths, extern_absolute_paths and extern_prelude on all editions.

5 years agoAuto merge of #54334 - steveklabnik:update-cargo, r=alexcrichton
bors [Sat, 22 Sep 2018 02:18:17 +0000 (02:18 +0000)]
Auto merge of #54334 - steveklabnik:update-cargo, r=alexcrichton

update cargo

This pulls in https://github.com/rust-lang/cargo/pull/6052, which is needed for the edition preview, and will be backported to beta as well.

5 years agoAuto merge of #54223 - pnkfelix:issue-53764-uiify-run-pass, r=nikomatsakis
bors [Fri, 21 Sep 2018 20:54:57 +0000 (20:54 +0000)]
Auto merge of #54223 - pnkfelix:issue-53764-uiify-run-pass, r=nikomatsakis

`ui`ify run-pass

This addresses the remainder of #53764 by first converting `src/test/run-pass` into another `ui`-style test suite, and then turning on `compare-mode=nll` for that new suite.

After this lands, we can address #54047 for the short term by moving all the `src/test/ui/run-pass` tests back to `src/test/run-pass`.

(Longer term, the compiler team's current (hypothetical sketch of a) plan (see [1][], [2][]) is unify all the tests by embedding these meta-properties like "// run-pass` into their headers explicitly and dropping the significance of their location on the file system.)

[1]: https://rust-lang.zulipchat.com/#narrow/stream/131828-t-compiler/subject/weekly.20meeting.202018-09-13/near/133889370
[2]: https://github.com/rust-lang/rust/issues/54047#issuecomment-421030356

5 years agoUpdate .mailmap
Christian Poveda [Fri, 21 Sep 2018 19:02:45 +0000 (14:02 -0500)]
Update .mailmap

5 years agoUpdate Cargo
Alex Crichton [Thu, 20 Sep 2018 21:37:53 +0000 (14:37 -0700)]
Update Cargo

This commit brings in a few Cargo updates

* Updates Cargo with experimental HTTP/2 support - a post on the forums
  will be made about testing this when available.
* Bumps Cargo's own version number

5 years agoIgnore new test on Windows
Alex Crichton [Fri, 21 Sep 2018 17:05:23 +0000 (10:05 -0700)]
Ignore new test on Windows

5 years agofix comment
Ralf Jung [Fri, 21 Sep 2018 14:25:33 +0000 (16:25 +0200)]
fix comment

5 years agoAllow unused_imports lint on test where lint only fires on non-linux targets...
Felix S. Klock II [Fri, 21 Sep 2018 10:45:23 +0000 (12:45 +0200)]
Allow unused_imports lint on test where lint only fires on non-linux targets...

5 years agoAllow dead_code lint on some tests where the lint only fires on non-x86 targets...
Felix S. Klock II [Wed, 19 Sep 2018 14:28:06 +0000 (16:28 +0200)]
Allow dead_code lint on some tests where the lint only fires on non-x86 targets...

5 years agoAdded comment above `Mode::RunPass` noting that it now behaves like `Mode::Ui`.
Felix S. Klock II [Wed, 19 Sep 2018 09:21:28 +0000 (11:21 +0200)]
Added comment above `Mode::RunPass` noting that it now behaves like `Mode::Ui`.

5 years agoMake the `// skip-codegen` property apply to ui tests too.
Felix S. Klock II [Wed, 19 Sep 2018 09:17:43 +0000 (11:17 +0200)]
Make the `// skip-codegen` property apply to ui tests too.

5 years agoAdded expected (compile-time) outputs.
Felix S. Klock II [Mon, 17 Sep 2018 09:54:33 +0000 (11:54 +0200)]
Added expected (compile-time) outputs.

* In the case of `derive-same-struct`, it seemed cleaner to add the
  output than to try to modify the macro itself (which is where the
  output is coming from).

* In the case of `custom-derive-partial-eq`, it was just easier to add
  the output than to attempt to port the test to use a procedural
  macro.

5 years agoAdd `Rustc` prefixes to `derive(Decodable, Encodable)`.
Felix S. Klock II [Mon, 17 Sep 2018 09:48:20 +0000 (11:48 +0200)]
Add `Rustc` prefixes to `derive(Decodable, Encodable)`.

As a bit of a hack, make `rustc_serialize` an alias of the private
`serialize` crate, just so the new derive continues working.

Fix #54287.

5 years agoAllow various lints in `src/test/run-pass-fulldeps/` so that it can continue under...
Felix S. Klock II [Mon, 17 Sep 2018 09:18:35 +0000 (11:18 +0200)]
Allow various lints in `src/test/run-pass-fulldeps/` so that it can continue under ui test mode.

(One of them led me to file rust-lang/rust#54288.)

5 years agoyou can have `// compile-pass` markers in headers of `compile-fail/` tests.
Felix S. Klock II [Mon, 17 Sep 2018 08:43:05 +0000 (10:43 +0200)]
you can have `// compile-pass` markers in headers of `compile-fail/` tests.

(It seems only `compile-fail-fulldeps/` exercises this functionality,
unfortunately.)

5 years agoSimilar to above, failed to notice that `Mode::Incremental` delegates to `run_{rpass...
Felix S. Klock II [Sat, 15 Sep 2018 05:01:47 +0000 (07:01 +0200)]
Similar to above, failed to notice that `Mode::Incremental` delegates to `run_{rpass,rfail,cfail}_test`.

(Also, maybe we should revise the names to make it clear that sometimes "cfail" means "cpass"...)

5 years agoMark `ParseFail` as tests that are not expected to compile.
Felix S. Klock II [Sat, 15 Sep 2018 04:52:18 +0000 (06:52 +0200)]
Mark `ParseFail` as tests that are not expected to compile.

(I did not notice earlier that `ParseFail` delegates to `fn run_cfail_test`.)

5 years agoRun the newly `ui`-ified run-pass tests under `compare-mode=nll` as well.
Felix S. Klock II [Fri, 14 Sep 2018 11:18:02 +0000 (13:18 +0200)]
Run the newly `ui`-ified run-pass tests under `compare-mode=nll` as well.

Fix #53764.

5 years agoAdd expected output for compiler to tests of optimization-fuel-{0,1}.rs.
Felix S. Klock II [Fri, 14 Sep 2018 11:11:14 +0000 (13:11 +0200)]
Add expected output for compiler to tests of optimization-fuel-{0,1}.rs.

5 years agoIgnore the output itself on `rustc-rust-log.rs` (added in rust-lang/rust#42737).
Felix S. Klock II [Fri, 14 Sep 2018 11:10:36 +0000 (13:10 +0200)]
Ignore the output itself on `rustc-rust-log.rs` (added in rust-lang/rust#42737).

5 years agoWorkaround rust-lang/rust#54222 by just ignoring the warning about the linker flag.
Felix S. Klock II [Fri, 14 Sep 2018 10:57:42 +0000 (12:57 +0200)]
Workaround rust-lang/rust#54222 by just ignoring the warning about the linker flag.

5 years agoAllow various lints as part of ui-ifying `src/test/run-pass` suite.
Felix S. Klock II [Fri, 14 Sep 2018 10:20:28 +0000 (12:20 +0200)]
Allow various lints as part of ui-ifying `src/test/run-pass` suite.

5 years agoProvide way for ui tests to opt out of having their output checked.
Felix S. Klock II [Fri, 14 Sep 2018 10:18:02 +0000 (12:18 +0200)]
Provide way for ui tests to opt out of having their output checked.

Namely, this adds support for:

 * `// dont-check-compiler-stdout`, and
 * `// dont-check-compiler-stderr`.

Obviously almost all ui tests wont want to opt into these, since the whole point
of a ui test is to check the compiler ui. However, since this PR is converting
run-pass into (another set of) ui tests, these header options make sense in that
context.

(Also this puts us into a better position for eventually turning
*every* test suite into a ui test suite, by making ui-ness the default
and forcing tests to opt out explicitly.)

5 years agoSupport `// skip-codegen` in header of ui tests
Felix S. Klock II [Fri, 14 Sep 2018 10:17:30 +0000 (12:17 +0200)]
Support `// skip-codegen` in header of ui tests

(just like how they behaved under previous run-pass semantics)

5 years agoMake `src/test/run-pass/` act like an alternative `ui` test suite.
Felix S. Klock II [Fri, 14 Sep 2018 09:42:32 +0000 (11:42 +0200)]
Make `src/test/run-pass/` act like an alternative `ui` test suite.

5 years agoSimplify slice's first(_mut) and last(_mut) with get
ljedrz [Fri, 21 Sep 2018 11:06:44 +0000 (13:06 +0200)]
Simplify slice's first(_mut) and last(_mut) with get

5 years agoCompress `Liveness` data some more.
Nicholas Nethercote [Fri, 21 Sep 2018 10:42:49 +0000 (20:42 +1000)]
Compress `Liveness` data some more.

Profiling shows that the `(reader, writer, used)` triples used by
liveness analysis almost always have invalid `reader` and `writer`
fields. We can take advantage of this knowledge to use a compressed
representation for them, falling back to a secondary table for the
uncommon cases.

This change reduces instruction counts on numerous benchmarks, the best
by 16%. It also reduces max-rss on numerous benchmarks, the best by 38%.

The patch also renames these triples from `Users` to `RWU`, because it's
confusing having a type whose name is plural and then used within
vectors whose names are also plural.

5 years agoAuto merge of #54399 - alexcrichton:fix-bug, r=steveklabnik
bors [Fri, 21 Sep 2018 10:30:24 +0000 (10:30 +0000)]
Auto merge of #54399 - alexcrichton:fix-bug, r=steveklabnik

std: Check for overflow in `str::repeat`

This commit fixes a buffer overflow issue in the standard library
discovered by Scott McMurray where if a large number was passed to
`str::repeat` it may cause and out of bounds write to the buffer of a `Vec`.
This bug was accidentally introduced in #48657 when optimizing the
`str::repeat` function. The bug affects stable Rust releases 1.26.0 to
1.29.0. We plan on backporting this fix to create a 1.29.1 release, and
the 1.30.0 release onwards will include this fix.

The fix in this commit is to introduce a deterministic panic in the case of
capacity overflow. When repeating a slice where the resulting length is larger
than the address space, there’s no way it can succeed anyway!

The standard library and surrounding libraries were briefly checked to see if
there were othere instances of preallocating a vector with a calculation that
may overflow. No instances of this bug (out of bounds write due to a calculation
overflow) were found at this time.

Note that this commit is the first steps towards fixing this issue,
we'll be making a formal post to the Rust security list once these
commits have been merged.

5 years agoDetect `for _ in in bar {}` typo
Esteban Küber [Wed, 19 Sep 2018 23:23:21 +0000 (16:23 -0700)]
Detect `for _ in in bar {}` typo

5 years agoadd applicability to span suggestion call
Joseph Post [Fri, 21 Sep 2018 01:06:03 +0000 (20:06 -0500)]
add applicability to span suggestion call

5 years agoRemove incidental notes
memoryruins [Fri, 21 Sep 2018 02:07:57 +0000 (22:07 -0400)]
Remove incidental notes

5 years agoparser: Tweak function parameter parsing to avoid rollback on succesfull path
Vadim Petrochenkov [Fri, 21 Sep 2018 01:26:36 +0000 (04:26 +0300)]
parser: Tweak function parameter parsing to avoid rollback on succesfull path