]> git.lizzy.rs Git - rust.git/log
rust.git
5 years agoAdd test of current behavior (infer free region within closure body) previously not...
Felix S. Klock II [Mon, 10 Dec 2018 11:53:46 +0000 (12:53 +0100)]
Add test of current behavior (infer free region within closure body) previously not in test suite.

5 years agospecialize: remove Boxes used by Children::insert
ljedrz [Wed, 12 Dec 2018 14:07:13 +0000 (15:07 +0100)]
specialize: remove Boxes used by Children::insert

5 years agoAuto merge of #56092 - alexcrichton:no-more-std-subodules, r=Mark-Simulacrum
bors [Wed, 12 Dec 2018 13:05:59 +0000 (13:05 +0000)]
Auto merge of #56092 - alexcrichton:no-more-std-subodules, r=Mark-Simulacrum

std: Depend directly on crates.io crates

Ever since we added a Cargo-based build system for the compiler the
standard library has always been a little special, it's never been able
to depend on crates.io crates for runtime dependencies. This has been a
result of various limitations, namely that Cargo doesn't understand that
crates from crates.io depend on libcore, so Cargo tries to build crates
before libcore is finished.

I had an idea this afternoon, however, which lifts the strategy
from #52919 to directly depend on crates.io crates from the standard
library. After all is said and done this removes a whopping three
submodules that we need to manage!

The basic idea here is that for any crate `std` depends on it adds an
*optional* dependency on an empty crate on crates.io, in this case named
`rustc-std-workspace-core`. This crate is overridden via `[patch]` in
this repository to point to a local crate we write, and *that* has a
`path` dependency on libcore.

Note that all `no_std` crates also depend on `compiler_builtins`, but if
we're not using submodules we can publish `compiler_builtins` to
crates.io and all crates can depend on it anyway! The basic strategy
then looks like:

* The standard library (or some transitive dep) decides to depend on a
  crate `foo`.
* The standard library adds

  ```toml
  [dependencies]
  foo = { version = "0.1", features = ['rustc-dep-of-std'] }
  ```
* The crate `foo` has an optional dependency on `rustc-std-workspace-core`
* The crate `foo` has an optional dependency on `compiler_builtins`
* The crate `foo` has a feature `rustc-dep-of-std` which activates these
  crates and any other necessary infrastructure in the crate.

A sample commit for `dlmalloc` [turns out to be quite simple][commit].
After that all `no_std` crates should largely build "as is" and still be
publishable on crates.io! Notably they should be able to continue to use
stable Rust if necessary, since the `rename-dependency` feature of Cargo
is soon stabilizing.

As a proof of concept, this commit removes the `dlmalloc`,
`libcompiler_builtins`, and `libc` submodules from this repository. Long
thorns in our side these are now gone for good and we can directly
depend on crates.io! It's hoped that in the long term we can bring in
other crates as necessary, but for now this is largely intended to
simply make it easier to manage these crates and remove submodules.

This should be a transparent non-breaking change for all users, but one
possible stickler is that this almost for sure breaks out-of-tree
`std`-building tools like `xargo` and `cargo-xbuild`. I think it should
be relatively easy to get them working, however, as all that's needed is
an entry in the `[patch]` section used to build the standard library.
Hopefully we can work with these tools to solve this problem!

[commit]: https://github.com/alexcrichton/dlmalloc-rs/commit/28ee12db813a3b650a7c25d1c36d2c17dcb88ae3

5 years agoAuto merge of #56039 - ljedrz:sorted_map_upgrades, r=matthewjasper
bors [Wed, 12 Dec 2018 10:44:32 +0000 (10:44 +0000)]
Auto merge of #56039 - ljedrz:sorted_map_upgrades, r=matthewjasper

SortedMap upgrades

- change the impl `From<Iterator<I>>` to `FromIterator<I>`
- make the impls of `Index` and `get` match the ones from `BTreeMap`
- add `is_empty` and `contains_key`
- readability/whitespace fixes
- add a proper `Iterator` implementation
- `impl IntoIterator for &SortedMap`

These changes make `SortedMap` almost a drop-in replacement for `BTreeMap`, at least to the point it is used by `rustc`; what is left is `Entry` API that I'd like to follow this PR with, and possibly implementing `ParallelIterator`.

5 years agoAuto merge of #56010 - euclio:intra-doc-spans, r=QuietMisdreavus
bors [Wed, 12 Dec 2018 08:18:13 +0000 (08:18 +0000)]
Auto merge of #56010 - euclio:intra-doc-spans, r=QuietMisdreavus

fix intra-link resolution spans in block comments

This commit improves the calculation of code spans for intra-doc
resolution failures. All sugared doc comments should now have the
correct spans, including those where the comment is longer than the
docs.

It also fixes an issue where the spans were calculated incorrectly for
certain unsugared doc comments. The diagnostic will now always use the
span of the attributes, as originally intended.

Fixes #55964.

r? @QuietMisdreavus

5 years agoFix private_no_mangle_fns message grammar
Steve Loveless [Wed, 12 Dec 2018 05:42:23 +0000 (21:42 -0800)]
Fix private_no_mangle_fns message grammar

5 years agoRemove some env vars for rustdoc invocations.
Nicholas Nethercote [Wed, 12 Dec 2018 05:28:43 +0000 (16:28 +1100)]
Remove some env vars for rustdoc invocations.

In an attempt to avoid "thread '<unnamed>' panicked at 'failed to
acquire jobserver token: Bad file descriptor" errors.

5 years agostd: Depend directly on crates.io crates
Alex Crichton [Tue, 20 Nov 2018 05:52:50 +0000 (21:52 -0800)]
std: Depend directly on crates.io crates

Ever since we added a Cargo-based build system for the compiler the
standard library has always been a little special, it's never been able
to depend on crates.io crates for runtime dependencies. This has been a
result of various limitations, namely that Cargo doesn't understand that
crates from crates.io depend on libcore, so Cargo tries to build crates
before libcore is finished.

I had an idea this afternoon, however, which lifts the strategy
from #52919 to directly depend on crates.io crates from the standard
library. After all is said and done this removes a whopping three
submodules that we need to manage!

The basic idea here is that for any crate `std` depends on it adds an
*optional* dependency on an empty crate on crates.io, in this case named
`rustc-std-workspace-core`. This crate is overridden via `[patch]` in
this repository to point to a local crate we write, and *that* has a
`path` dependency on libcore.

Note that all `no_std` crates also depend on `compiler_builtins`, but if
we're not using submodules we can publish `compiler_builtins` to
crates.io and all crates can depend on it anyway! The basic strategy
then looks like:

* The standard library (or some transitive dep) decides to depend on a
  crate `foo`.
* The standard library adds

  ```toml
  [dependencies]
  foo = { version = "0.1", features = ['rustc-dep-of-std'] }
  ```
* The crate `foo` has an optional dependency on `rustc-std-workspace-core`
* The crate `foo` has an optional dependency on `compiler_builtins`
* The crate `foo` has a feature `rustc-dep-of-std` which activates these
  crates and any other necessary infrastructure in the crate.

A sample commit for `dlmalloc` [turns out to be quite simple][commit].
After that all `no_std` crates should largely build "as is" and still be
publishable on crates.io! Notably they should be able to continue to use
stable Rust if necessary, since the `rename-dependency` feature of Cargo
is soon stabilizing.

As a proof of concept, this commit removes the `dlmalloc`,
`libcompiler_builtins`, and `libc` submodules from this repository. Long
thorns in our side these are now gone for good and we can directly
depend on crates.io! It's hoped that in the long term we can bring in
other crates as necessary, but for now this is largely intended to
simply make it easier to manage these crates and remove submodules.

This should be a transparent non-breaking change for all users, but one
possible stickler is that this almost for sure breaks out-of-tree
`std`-building tools like `xargo` and `cargo-xbuild`. I think it should
be relatively easy to get them working, however, as all that's needed is
an entry in the `[patch]` section used to build the standard library.
Hopefully we can work with these tools to solve this problem!

[commit]: https://github.com/alexcrichton/dlmalloc-rs/commit/28ee12db813a3b650a7c25d1c36d2c17dcb88ae3

5 years agoFix gpg signing in manifest builder
Mark Rousskov [Wed, 12 Dec 2018 02:10:45 +0000 (19:10 -0700)]
Fix gpg signing in manifest builder

GPG versions 2.x+ require that --batch be passed if --passphrase-fd is
to be accepted.

5 years agoReplace `FileSearch::for_each_lib_search_path` with `search_paths`.
Nicholas Nethercote [Fri, 23 Nov 2018 02:36:41 +0000 (13:36 +1100)]
Replace `FileSearch::for_each_lib_search_path` with `search_paths`.

Returning an iterator leads to nicer code all around.

5 years agoAvoid regenerating the `Vec<PathBuf>` in `FileSearch::search()`.
Nicholas Nethercote [Tue, 20 Nov 2018 00:06:45 +0000 (11:06 +1100)]
Avoid regenerating the `Vec<PathBuf>` in `FileSearch::search()`.

`FileSearch::search()` traverses one or more directories. For each
directory it generates a `Vec<PathBuf>` containing one element per file
in that directory.

In some benchmarks this occurs enough that the allocations done for the
`PathBuf`s are significant, and in practice a small number of
directories are being traversed over and over again. For example, when
compiling the `tokio-webpush-simple` benchmark, two directories are
traversed 58 times each. Each of these directories have more than 100
files.

This commit changes things so that all the `Vec<PathBuf>`s that will be
needed by a `Session` are precomputed when that `Session` is created;
they are stored in `SearchPath`. `FileSearch` gets a reference to the
necessary `SearchPath`s. This reduces instruction counts on several
benchmarks by 1--5%.

The commit also removes the barely-used `visited_dirs` hash in
`for_each_lib_searchPath`. It only detects if `tlib_path` is the same as
one of the previously seen paths, which is unlikely.

5 years agoIntroduce `SearchPath` and replace `SearchPaths` with `Vec<SearchPath>`.
Nicholas Nethercote [Thu, 22 Nov 2018 05:33:07 +0000 (16:33 +1100)]
Introduce `SearchPath` and replace `SearchPaths` with `Vec<SearchPath>`.

It's more idiomatic, makes the code shorter, and will help with the next
commit.

5 years agoRemove `Session::sysroot()`.
Nicholas Nethercote [Thu, 22 Nov 2018 04:49:48 +0000 (15:49 +1100)]
Remove `Session::sysroot()`.

Instead of maybe storing its own sysroot and maybe deferring to the one
in `Session::opts`, just clone the latter when necessary so one is
always directly available. This removes the need for the getter.

5 years agoAvoid a useless `FxHashSet::insert` in `FileSearch::for_each_lib_search_path`.
Nicholas Nethercote [Wed, 21 Nov 2018 11:03:59 +0000 (22:03 +1100)]
Avoid a useless `FxHashSet::insert` in `FileSearch::for_each_lib_search_path`.

5 years agoAdd missing urls in ffi module docs
Guillaume Gomez [Tue, 11 Dec 2018 22:54:41 +0000 (23:54 +0100)]
Add missing urls in ffi module docs

5 years agoDocumentation for impl From for AtomicBool and other Atomic types
Son [Tue, 11 Dec 2018 22:41:12 +0000 (09:41 +1100)]
Documentation for impl From for AtomicBool and other Atomic types

5 years agoUse a `newtype_index!` within `Symbol`.
Nicholas Nethercote [Mon, 10 Dec 2018 22:06:51 +0000 (09:06 +1100)]
Use a `newtype_index!` within `Symbol`.

This shrinks `Option<Symbol>` from 8 bytes to 4 bytes, which shrinks
`Token` from 24 bytes to 16 bytes. This reduces instruction counts by up
to 1% across a range of benchmarks.

5 years agobump backtrace version to get prettier pretty-printing
Ralf Jung [Tue, 11 Dec 2018 21:36:24 +0000 (22:36 +0100)]
bump backtrace version to get prettier pretty-printing

5 years agoRemove unneeded extra chars to reduce search-index size
Guillaume Gomez [Tue, 11 Dec 2018 09:57:45 +0000 (10:57 +0100)]
Remove unneeded extra chars to reduce search-index size

5 years agoUse iterators instead of raw offsets in Windows argument parser
Michael Howell [Tue, 11 Dec 2018 18:55:02 +0000 (11:55 -0700)]
Use iterators instead of raw offsets in Windows argument parser

5 years agofix rust-lang/rust issue #50583
Piers Finlayson [Tue, 11 Dec 2018 20:02:16 +0000 (20:02 +0000)]
fix rust-lang/rust issue #50583

5 years agoAuto merge of #53497 - fukatani:test-debuginfo-function-call, r=tromey
bors [Tue, 11 Dec 2018 16:27:49 +0000 (16:27 +0000)]
Auto merge of #53497 - fukatani:test-debuginfo-function-call, r=tromey

Test with gdb8.2 and add debuginfo printing function call test

As far as I can see, `print function()` is not tested. It is important feature for debugging.

5 years agomiri: use backtrace crate printing instead of rolling our own
Ralf Jung [Tue, 11 Dec 2018 14:53:35 +0000 (15:53 +0100)]
miri: use backtrace crate printing instead of rolling our own

5 years agoAlways set the RDRAND and RDSEED features on SGX
Jethro Beekman [Tue, 11 Dec 2018 12:34:33 +0000 (18:04 +0530)]
Always set the RDRAND and RDSEED features on SGX

5 years agoTest capacity of ZST vector
Konrad Borowski [Tue, 11 Dec 2018 14:07:07 +0000 (15:07 +0100)]
Test capacity of ZST vector

Initially, #50233 accidentally changed the capacity of empty ZST. This
was pointed out during code review. This commit adds a test to prevent
capacity of ZST vectors from accidentally changing to prevent that
from happening again.

5 years agoAuto merge of #56243 - RalfJung:test-deterministic, r=alexcrichton
bors [Tue, 11 Dec 2018 14:04:15 +0000 (14:04 +0000)]
Auto merge of #56243 - RalfJung:test-deterministic, r=alexcrichton

libtest: Use deterministic HashMap, avoid spawning thread if there is no concurrency

It seems desirable to make a test and bench runner deterministic, which this achieves by using a deterministic hasher. Also, we we only have 1 thread, we don't bother spawning one and just use the main thread.

The motivation for this is to be able to run the test harness in miri, where we can neither access the OS RNG, nor spawn threads.

5 years agoAdd function call test, Update gdb and test docker image install gdb by ppa.
Unknown [Sun, 19 Aug 2018 14:51:57 +0000 (23:51 +0900)]
Add function call test, Update gdb and test docker image install gdb by ppa.

5 years agoFix irrefutable matches on integer ranges
varkor [Mon, 10 Dec 2018 23:28:54 +0000 (23:28 +0000)]
Fix irrefutable matches on integer ranges

5 years agouse an enum instead of bool
Ralf Jung [Tue, 11 Dec 2018 10:02:23 +0000 (11:02 +0100)]
use an enum instead of bool

5 years agoProperly stage new feature gates
Oliver Scherer [Tue, 11 Dec 2018 09:43:40 +0000 (10:43 +0100)]
Properly stage new feature gates

5 years agoRemove some dead code from `sgx`
Oliver Scherer [Tue, 11 Dec 2018 09:33:17 +0000 (10:33 +0100)]
Remove some dead code from `sgx`

5 years agoRemove unnecessary feature gates from const fns
Oliver Scherer [Tue, 11 Dec 2018 09:32:39 +0000 (10:32 +0100)]
Remove unnecessary feature gates from const fns

5 years agoAuto merge of #56703 - alexcrichton:fix-tools, r=Mark-Simulacrum
bors [Tue, 11 Dec 2018 08:14:14 +0000 (08:14 +0000)]
Auto merge of #56703 - alexcrichton:fix-tools, r=Mark-Simulacrum

Fix build of the `build-manifest` tool

Accidentally broken in #56258!

5 years agoDiagnostics improvement!
Oliver Scherer [Tue, 11 Dec 2018 08:05:06 +0000 (09:05 +0100)]
Diagnostics improvement!

5 years agoBuild manifest tool on mingw-check builder
Mark Rousskov [Tue, 11 Dec 2018 03:40:04 +0000 (20:40 -0700)]
Build manifest tool on mingw-check builder

This builder is not really the correct place to put this, but it
definitely has the time budget and checking this tool builds on just one
platform is more than sufficient.

5 years agoFix build of the `build-manifest` tool
Alex Crichton [Tue, 11 Dec 2018 03:34:47 +0000 (19:34 -0800)]
Fix build of the `build-manifest` tool

Accidentally broken in #56258!

5 years ago[self-profiler] Add column for percent of total time
Wesley Wiser [Tue, 11 Dec 2018 02:16:19 +0000 (21:16 -0500)]
[self-profiler] Add column for percent of total time

5 years agoAuto merge of #56627 - alexcrichton:update-cargo, r=alexcrichton
bors [Tue, 11 Dec 2018 03:22:10 +0000 (03:22 +0000)]
Auto merge of #56627 - alexcrichton:update-cargo, r=alexcrichton

Update Cargo submodule and its dependencies

Hopefully just another routine update!

So far this starts to enable the `std::arch` in stage0 builds of rustc.
This means that we may need stage0/not(stage0) in stdsimd itself, but
more and more code is starting to use `std::arch` so I think it's time
to start shifting the balance of work here.

5 years agofix intra-link resolution spans in block comments
Andy Russell [Mon, 10 Dec 2018 17:24:39 +0000 (12:24 -0500)]
fix intra-link resolution spans in block comments

This commit improves the calculation of code spans for intra-doc
resolution failures. All sugared doc comments should now have the
correct spans, including those where the comment is longer than the
docs.

It also fixes an issue where the spans were calculated incorrectly for
certain unsugared doc comments. The diagnostic will now always use the
span of the attributes, as originally intended.

Fixes #55964.

5 years agoFix iterator nits
Michael Howell [Tue, 11 Dec 2018 01:31:53 +0000 (18:31 -0700)]
Fix iterator nits

5 years agoFix nit
Michael Howell [Mon, 10 Dec 2018 22:48:32 +0000 (15:48 -0700)]
Fix nit

Rewrite it to not use `if let`.

5 years agoAdd lint for stlib
aheart [Mon, 10 Dec 2018 21:20:28 +0000 (23:20 +0200)]
Add lint for stlib

5 years agoFix nits
Michael Howell [Mon, 10 Dec 2018 22:37:50 +0000 (15:37 -0700)]
Fix nits

Add comments explaining how we test this,
and use a slice for debugging instead of a clone of the iterator.

5 years agofix install broken link
misagh [Mon, 10 Dec 2018 22:28:55 +0000 (23:28 +0100)]
fix install broken link

5 years agoUpdate Cargo submodule and its dependencies
Alex Crichton [Sat, 8 Dec 2018 11:06:54 +0000 (03:06 -0800)]
Update Cargo submodule and its dependencies

Hopefully just another routine update!

So far this starts to enable the `std::arch` in stage0 builds of rustc.
This means that we may need stage0/not(stage0) in stdsimd itself, but
more and more code is starting to use `std::arch` so I think it's time
to start shifting the balance of work here.

5 years agoAuto merge of #56688 - GuillaumeGomez:rollup, r=GuillaumeGomez
bors [Mon, 10 Dec 2018 21:42:20 +0000 (21:42 +0000)]
Auto merge of #56688 - GuillaumeGomez:rollup, r=GuillaumeGomez

Rollup of 5 pull requests

Successful merges:

 - #56491 (emit error with span for empty asserts)
 - #56633 (Fix right arrow size for crate filter)
 - #56641 (fix span for invalid number of parameters in trait method)
 - #56656 (Fix typo)
 - #56661 (Add regression test for ICE)

Failed merges:

r? @ghost

5 years agoFix poorly-transcribed test case
Michael Howell [Mon, 10 Dec 2018 21:33:03 +0000 (14:33 -0700)]
Fix poorly-transcribed test case

5 years agoRollup merge of #56661 - aelred:issue-55846, r=Mark-Simulacrum
Guillaume Gomez [Mon, 10 Dec 2018 21:02:02 +0000 (22:02 +0100)]
Rollup merge of #56661 - aelred:issue-55846, r=Mark-Simulacrum

Add regression test for ICE

Fixes #55846 with a minimal (or as best as I can manage) test case. I tested this against 1.30.0 manually to confirm it crashes.

The issue seemed to have something to do with associated types. It's possible someone with more knowledge can shrink the test case down further, or make it clearer.

5 years agoRollup merge of #56656 - BeatButton:liballoc_string_typo, r=Centril
Guillaume Gomez [Mon, 10 Dec 2018 21:02:01 +0000 (22:02 +0100)]
Rollup merge of #56656 - BeatButton:liballoc_string_typo, r=Centril

Fix typo

5 years agoRollup merge of #56641 - GuillaumeGomez:span-trait-method-invalid-nb-parameters,...
Guillaume Gomez [Mon, 10 Dec 2018 21:02:00 +0000 (22:02 +0100)]
Rollup merge of #56641 - GuillaumeGomez:span-trait-method-invalid-nb-parameters, r=estebank

fix span for invalid number of parameters in trait method

Fixes #56582.

5 years agoRollup merge of #56633 - GuillaumeGomez:fix-right-arrow-display, r=QuietMisdreavus
Guillaume Gomez [Mon, 10 Dec 2018 21:01:58 +0000 (22:01 +0100)]
Rollup merge of #56633 - GuillaumeGomez:fix-right-arrow-display, r=QuietMisdreavus

Fix right arrow size for crate filter

This bug only appears when a crate has a long name:

<img width="1440" alt="screenshot 2018-12-08 at 16 36 21" src="https://user-images.githubusercontent.com/3050060/49687728-7de06180-fb07-11e8-8554-d32597351fac.png">

With this fix, it goes back to normal, whatever the size:

<img width="1440" alt="screenshot 2018-12-08 at 16 36 05" src="https://user-images.githubusercontent.com/3050060/49687730-8769c980-fb07-11e8-91b7-b5e1961211a2.png">

r? @QuietMisdreavus

5 years agoRollup merge of #56491 - euclio:assert-error, r=estebank
Guillaume Gomez [Mon, 10 Dec 2018 21:01:57 +0000 (22:01 +0100)]
Rollup merge of #56491 - euclio:assert-error, r=estebank

emit error with span for empty asserts

Fixes #55547.

5 years agoFix nitpicks
Michael Howell [Mon, 10 Dec 2018 20:12:47 +0000 (13:12 -0700)]
Fix nitpicks

Switch to vec::IntoIter as our backing double-ended iterator.

Fix incorrect comment.

5 years agoUpdate the stdsimd submodule
Alex Crichton [Mon, 10 Dec 2018 20:05:33 +0000 (12:05 -0800)]
Update the stdsimd submodule

Includes some new stabilized intrinsics for the wasm32 target!

Closes #56292

5 years agoRemove dependency on shell32.dll #56510
Michael Howell [Thu, 6 Dec 2018 18:26:11 +0000 (11:26 -0700)]
Remove dependency on shell32.dll #56510

5 years agoimprove diagnostics for invalid external docs
Andy Russell [Wed, 28 Nov 2018 19:54:08 +0000 (14:54 -0500)]
improve diagnostics for invalid external docs

5 years agoreject invalid external doc attributes
Andy Russell [Wed, 28 Nov 2018 17:11:45 +0000 (12:11 -0500)]
reject invalid external doc attributes

Also, provide a suggestion for the correct syntax.

5 years agoAdd a few more tests of edge cases
Oliver Scherer [Fri, 7 Dec 2018 18:06:22 +0000 (19:06 +0100)]
Add a few more tests of edge cases

5 years agoDocument and simplify pattern matching with constants as patterns
Oliver Scherer [Fri, 7 Dec 2018 17:56:05 +0000 (18:56 +0100)]
Document and simplify pattern matching with constants as patterns

5 years agoDon't depend on `Allocation` sizes for pattern length
Oliver Scherer [Wed, 5 Dec 2018 17:31:49 +0000 (18:31 +0100)]
Don't depend on `Allocation` sizes for pattern length

5 years agoAdd trailing newline
Felix Chapman [Mon, 10 Dec 2018 15:05:54 +0000 (15:05 +0000)]
Add trailing newline

5 years agoAdd #[must_use] attribute to stdlib traits
Felix Chapman [Mon, 10 Dec 2018 14:45:26 +0000 (14:45 +0000)]
Add #[must_use] attribute to stdlib traits

5 years agoAdd test to check library traits have #[must_use] attribute
Felix Chapman [Mon, 10 Dec 2018 14:44:16 +0000 (14:44 +0000)]
Add test to check library traits have #[must_use] attribute

5 years agoAuto merge of #56666 - Xanewok:rustfmt, r=kennytm
bors [Mon, 10 Dec 2018 14:40:41 +0000 (14:40 +0000)]
Auto merge of #56666 - Xanewok:rustfmt, r=kennytm

Update Rustfmt and RLS

Supersedes #56652, hopefully fixes toolstate.

r? @SimonSapin

5 years agosorted_map: add contains_key function
ljedrz [Sun, 18 Nov 2018 18:00:22 +0000 (19:00 +0100)]
sorted_map: add contains_key function

5 years agosorted_map: readability/whitespace fixes
ljedrz [Sun, 18 Nov 2018 09:44:49 +0000 (10:44 +0100)]
sorted_map: readability/whitespace fixes

5 years agosorted_map: add is_empty
ljedrz [Sun, 18 Nov 2018 09:44:25 +0000 (10:44 +0100)]
sorted_map: add is_empty

5 years agosorted_map: make the impls of Index and get match ones from BTreeMap
ljedrz [Sun, 18 Nov 2018 09:43:50 +0000 (10:43 +0100)]
sorted_map: make the impls of Index and get match ones from BTreeMap

5 years agosorted_map: change From<Iterator<I>> to FromIterator<I>
ljedrz [Sun, 18 Nov 2018 09:41:40 +0000 (10:41 +0100)]
sorted_map: change From<Iterator<I>> to FromIterator<I>

5 years agobootstrap: fix edition
ljedrz [Fri, 7 Dec 2018 12:21:05 +0000 (13:21 +0100)]
bootstrap: fix edition

5 years agoAuto merge of #56157 - RalfJung:park, r=nagisa
bors [Mon, 10 Dec 2018 12:19:47 +0000 (12:19 +0000)]
Auto merge of #56157 - RalfJung:park, r=nagisa

expand thread::park explanation

Cc @carllerche @parched @stjepang

5 years agoAuto merge of #56624 - RalfJung:miri, r=oli-obk
bors [Mon, 10 Dec 2018 09:58:22 +0000 (09:58 +0000)]
Auto merge of #56624 - RalfJung:miri, r=oli-obk

update miri

r? @oli-obk

5 years agoBump failure to 0.1.3
Igor Matuszewski [Mon, 10 Dec 2018 09:57:43 +0000 (10:57 +0100)]
Bump failure to 0.1.3

We use failure_derive 0.1.3, try to work around
```
error[E0433]: failed to resolve: could not find `AsFail` in `failure`
```

5 years agoUpdate in-tree rustfmt to 1.0.1 to dedup versions
Igor Matuszewski [Mon, 10 Dec 2018 08:05:37 +0000 (09:05 +0100)]
Update in-tree rustfmt to 1.0.1 to dedup versions

5 years agoUpdate RLS
Igor Matuszewski [Mon, 10 Dec 2018 07:58:08 +0000 (08:58 +0100)]
Update RLS

5 years agoUpdate rustfmt
Simon Sapin [Sun, 9 Dec 2018 18:14:49 +0000 (19:14 +0100)]
Update rustfmt

Pick up https://github.com/rust-lang/rustfmt/pull/3236

5 years agoAuto merge of #56369 - nnethercote:rm-Delimited, r=petrochenkov
bors [Mon, 10 Dec 2018 03:33:17 +0000 (03:33 +0000)]
Auto merge of #56369 - nnethercote:rm-Delimited, r=petrochenkov

Remove `tokenstream::Delimited`.

Because it's an extra type layer that doesn't really help; in a couple
of places it actively gets in the way, and overall removing it makes the
code nicer. It does, however, move `tokenstream::TokenTree` further away
from the `TokenTree` in `quote.rs`.

More importantly, this change reduces the size of `TokenStream` from 48
bytes to 40 bytes on x86-64, which is enough to slightly reduce
instruction counts on numerous benchmarks, the best by 1.5%.

Note that `open_tt` and `close_tt` have gone from being methods on
`Delimited` to associated methods of `TokenTree`.

5 years agoAdd regression test for issue #55846
Felix Chapman [Mon, 10 Dec 2018 02:49:19 +0000 (02:49 +0000)]
Add regression test for issue #55846

5 years agoRemove `tokenstream::Delimited`.
Nicholas Nethercote [Thu, 29 Nov 2018 23:02:04 +0000 (10:02 +1100)]
Remove `tokenstream::Delimited`.

Because it's an extra type layer that doesn't really help; in a couple
of places it actively gets in the way, and overall removing it makes the
code nicer. It does, however, move `tokenstream::TokenTree` further away
from the `TokenTree` in `quote.rs`.

More importantly, this change reduces the size of `TokenStream` from 48
bytes to 40 bytes on x86-64, which is enough to slightly reduce
instruction counts on numerous benchmarks, the best by 1.5%.

Note that `open_tt` and `close_tt` have gone from being methods on
`Delimited` to associated methods of `TokenTree`.

5 years agoAuto merge of #56269 - nnethercote:_match-Matrix-SmallVec, r=simulacrum
bors [Mon, 10 Dec 2018 01:08:05 +0000 (01:08 +0000)]
Auto merge of #56269 - nnethercote:_match-Matrix-SmallVec, r=simulacrum

Use a `SmallVec` within `_match::Matrix`.

This avoids allocations.

5 years agoUse a `SmallVec` within `_match::Matrix`.
Nicholas Nethercote [Wed, 28 Nov 2018 02:38:46 +0000 (13:38 +1100)]
Use a `SmallVec` within `_match::Matrix`.

This commit also fixes up lifetimes a bit:

- Renames `'a` as `'p` when used with `Matrix` and `Pattern`, for
  consistency.

- Removes some unnecessary `'p` lifetimes on some function arguments.

- Adds some missing lifetime parameters.

5 years agoAdd missing, non-panicking `maybe_new_parser_from_file` variant
Igor Matuszewski [Sun, 9 Dec 2018 21:53:00 +0000 (22:53 +0100)]
Add missing, non-panicking `maybe_new_parser_from_file` variant

5 years agoAuto merge of #56463 - ljedrz:slice_concat_join, r=nikic
bors [Sun, 9 Dec 2018 22:39:44 +0000 (22:39 +0000)]
Auto merge of #56463 - ljedrz:slice_concat_join, r=nikic

slice: tweak concat & join

- use `sum` instead of `fold` (readability)
- adjust the capacity for `join` - the number of separators is `n - 1`, not `n`; proof:
```
fn main() {
    let a = [[1, 2], [4, 5]];
    let v = a.join(&3);

    assert_ne!(v.len(), v.capacity()); // len is 5, capacity is 6
}
```

5 years agoUpgrade `smallvec` to 0.6.7 and use the new `may_dangle` feature.
Nicholas Nethercote [Wed, 28 Nov 2018 21:52:22 +0000 (08:52 +1100)]
Upgrade `smallvec` to 0.6.7 and use the new `may_dangle` feature.

5 years agoFix typo
BeatButton [Sun, 9 Dec 2018 21:10:20 +0000 (14:10 -0700)]
Fix typo

5 years agoAdd lint for items deprecated in future
aheart [Sun, 9 Dec 2018 16:17:50 +0000 (18:17 +0200)]
Add lint for items deprecated in future

5 years agoAuto merge of #56444 - petrochenkov:uifull, r=davidtwco
bors [Sun, 9 Dec 2018 18:49:12 +0000 (18:49 +0000)]
Auto merge of #56444 - petrochenkov:uifull, r=davidtwco

Move compile-fail-fulldeps tests to UI

cc https://github.com/rust-lang/rust/issues/53353

r? @davidtwco

5 years agoFix rebase + Add missing `// force-host`
Vadim Petrochenkov [Fri, 7 Dec 2018 21:53:15 +0000 (00:53 +0300)]
Fix rebase + Add missing `// force-host`

5 years agoRemove compile-fail-fulldeps test suite
Vadim Petrochenkov [Sun, 2 Dec 2018 20:07:22 +0000 (23:07 +0300)]
Remove compile-fail-fulldeps test suite

5 years agoMove some tests from ui-fulldeps to ui
Vadim Petrochenkov [Sun, 2 Dec 2018 19:59:50 +0000 (22:59 +0300)]
Move some tests from ui-fulldeps to ui

5 years agoMove compile-fail-fulldeps tests to ui-fulldeps
Vadim Petrochenkov [Sun, 2 Dec 2018 19:42:43 +0000 (22:42 +0300)]
Move compile-fail-fulldeps tests to ui-fulldeps

5 years agoMove former compile-fail-fulldeps tests to ui
Vadim Petrochenkov [Sun, 2 Dec 2018 19:27:37 +0000 (22:27 +0300)]
Move former compile-fail-fulldeps tests to ui

5 years agoAuto merge of #56644 - jens1o:patch-1, r=pietroalbini
bors [Sun, 9 Dec 2018 16:15:32 +0000 (16:15 +0000)]
Auto merge of #56644 - jens1o:patch-1, r=pietroalbini

Fix security link in CONTRIBUTING to its new place

avoiding an 404

5 years agoFix security link in CONTRIBUTING to its new place
Jens Hausdorf [Sun, 9 Dec 2018 14:25:23 +0000 (15:25 +0100)]
Fix security link in CONTRIBUTING to its new place

avoiding an 404

5 years agoAuto merge of #56631 - matthiaskrgr:clippy, r=nikic
bors [Sun, 9 Dec 2018 11:56:32 +0000 (11:56 +0000)]
Auto merge of #56631 - matthiaskrgr:clippy, r=nikic

submodules: update clippy from 1df5766c to a3c77f6a

fixes clippy toolstate

Changes:
````
s/rustfmt-preview/rustfmt/
Swap if branches
Fix c_void false positive caused by libc refactoring
rustup https://github.com/rust-lang/rust/pull/56502 ( .hir -> .hir() )
typo: emum → enum
Fix format.
Add sysroot gettinh code to dogfood tests.
Add sysroot getting code to tests.
Don't try to determine sysroot. rustc_driver will use default value.
Fix suggestion for multiple derefs
Fix `clone_on_copy` not detecting derefs sometimes
````
r? @oli-obk

5 years agoAuto merge of #56630 - sinkuu:core_iter, r=kennytm
bors [Sun, 9 Dec 2018 00:18:34 +0000 (00:18 +0000)]
Auto merge of #56630 - sinkuu:core_iter, r=kennytm

Resolve FIXME in libcore/iter/mod.rs

and makes a few improvements.

5 years agoAuto merge of #56615 - integer32llc:update-book, r=GuillaumeGomez
bors [Sat, 8 Dec 2018 22:00:09 +0000 (22:00 +0000)]
Auto merge of #56615 - integer32llc:update-book, r=GuillaumeGomez

Update the book to fix some edition-related bugs

I'd love to have this included in a point release if one happens, but the changes aren't worth doing a point release on their own IMO. I'd definitely like to see this backported to beta.

The most urgent changes included here are:

- Chapter 19.6, on macros (including the macro changes that just stabilized), [is cut off](https://github.com/rust-lang/book/issues/1668) because of an ill-placed newline in a comment that [pulldown-cmark interprets incorrectly](https://github.com/raphlinus/pulldown-cmark/issues/124).
- [The `Cargo.toml` shown in the Guessing Game example in Chapter 2 (and one in Chapter 14) doesn't have `edition="2018"`](https://github.com/rust-lang/book/pull/1671), which can be confusing depending on whether the readers have it in theirs or not, think they should remove it if they have it, and the rest of the chapter assumes it's there and the code doesn't compile if you don't have it.
- The redirects implemented as part of only shipping the 2018 edition of the book sometimes lead to [having to click through 2 redirect pages](https://github.com/rust-lang/book/pull/1667) when it could be just one.

There are other small corrections included that were made since the last time the book was updated, but those aren't urgent.

cc @steveklabnik

5 years agoAuto merge of #56616 - estebank:issue-56539, r=davidtwco
bors [Sat, 8 Dec 2018 19:34:43 +0000 (19:34 +0000)]
Auto merge of #56616 - estebank:issue-56539, r=davidtwco

Encode `TraitAlias` as if they were `Trait`

Fix #56539.

5 years agofix span for invalid number of parameters in trait method
Guillaume Gomez [Sat, 8 Dec 2018 19:04:14 +0000 (20:04 +0100)]
fix span for invalid number of parameters in trait method

5 years agorustdoc: Fix local reexports of proc macros
Oliver Middleton [Sat, 8 Dec 2018 18:27:12 +0000 (18:27 +0000)]
rustdoc: Fix local reexports of proc macros

Filter out `ProcMacroStub`s to avoid an ICE during cleaning.

Also add proc macros to `cache().paths` so it can generate links.