]> git.lizzy.rs Git - rust.git/log
rust.git
4 years agorustc_metadata: Privatize more entities
Vadim Petrochenkov [Sun, 3 Nov 2019 15:27:24 +0000 (18:27 +0300)]
rustc_metadata: Privatize more entities

4 years agorustc_metadata: Privatize everything in decoder
Vadim Petrochenkov [Sun, 3 Nov 2019 14:13:07 +0000 (17:13 +0300)]
rustc_metadata: Privatize everything in decoder

4 years agorustc_metadata: Move cstore_impl into mod decoder
Vadim Petrochenkov [Sun, 3 Nov 2019 14:36:16 +0000 (17:36 +0300)]
rustc_metadata: Move cstore_impl into mod decoder

4 years agorustc_metadata: Privatize everything in schema and schema/table
Vadim Petrochenkov [Sun, 3 Nov 2019 14:33:27 +0000 (17:33 +0300)]
rustc_metadata: Privatize everything in schema and schema/table

4 years agorustc_metadata: Move decoder/encoder/table into mod schema
Vadim Petrochenkov [Sun, 3 Nov 2019 12:56:11 +0000 (15:56 +0300)]
rustc_metadata: Move decoder/encoder/table into mod schema

4 years agoAuto merge of #66180 - Centril:rollup-c1ji943, r=Centril
bors [Thu, 7 Nov 2019 07:55:39 +0000 (07:55 +0000)]
Auto merge of #66180 - Centril:rollup-c1ji943, r=Centril

Rollup of 5 pull requests

Successful merges:

 - #59789 (Revert two unapproved changes to rustc_typeck.)
 - #65752 (Use structured suggestions for missing associated items)
 - #65884 (syntax: ABI-oblivious grammar)
 - #65974 (A scheme for more macro-matcher friendly pre-expansion gating)
 - #66017 (Add future incompatibility lint for `array.into_iter()`)

Failed merges:

 - #66056 (rustc_metadata: Some reorganization of the module structure)

r? @ghost

4 years agoRollup merge of #66017 - LukasKalbertodt:array-into-iter-lint, r=matthewjasper
Mazdak Farrokhzad [Thu, 7 Nov 2019 07:51:58 +0000 (08:51 +0100)]
Rollup merge of #66017 - LukasKalbertodt:array-into-iter-lint, r=matthewjasper

Add future incompatibility lint for `array.into_iter()`

This is for #65819. This lint warns when calling `into_iter` on an array directly. That's because today the method call resolves to `<&[T] as IntoIterator>::into_iter` but that would change when adding `IntoIterator` impls for arrays. This problem is discussed in detail in #65819.

We still haven't decided how to proceed exactly, but it seems like adding a lint is a good idea regardless?

Also: this is the first time I implement a lint, so there are probably a lot of things I can improve. I used a different strategy than @scottmcm describes [here](https://github.com/rust-lang/rust/pull/65819#issuecomment-548667847) since I already started implementing this before they commented.

### TODO

- [x] Decide if we want this lint -> apparently [we want](https://github.com/rust-lang/rust/pull/65819#issuecomment-548964818)
- [x] Open a lint-tracking-issue and add the correct issue number in the code -> https://github.com/rust-lang/rust/issues/66145

4 years agoRollup merge of #65974 - Centril:matcher-friendly-gating, r=petrochenkov
Mazdak Farrokhzad [Thu, 7 Nov 2019 07:51:57 +0000 (08:51 +0100)]
Rollup merge of #65974 - Centril:matcher-friendly-gating, r=petrochenkov

A scheme for more macro-matcher friendly pre-expansion gating

Pre-expansion gating will now avoid gating macro matchers that did not result in `Success(...)`. That is, the following is now OK despite `box 42` being a valid `expr` and that form being pre-expansion gated:

```rust
macro_rules! m {
    ($e:expr) => { 0 }; // This fails on the input below due to `, foo`.
    (box $e:expr, foo) => { 1 }; // Successful matcher, we should get `2`.
}

fn main() {
    assert_eq!(1, m!(box 42, foo));
}
```

Closes https://github.com/rust-lang/rust/issues/65846.

r? @petrochenkov
cc @Mark-Simulacrum

4 years agoRollup merge of #65884 - Centril:non-hardcoded-abis, r=petrochenkov
Mazdak Farrokhzad [Thu, 7 Nov 2019 07:51:55 +0000 (08:51 +0100)]
Rollup merge of #65884 - Centril:non-hardcoded-abis, r=petrochenkov

syntax: ABI-oblivious grammar

This PR has the following effects:

1. `extern $lit` is now legal where `$lit:literal` and `$lit` is substituted for a string literal.

2. `extern "abi_that_does_not_exist"` is now *syntactically* legal whereas before, the set of ABI strings was hard-coded into the grammar of the language. With this PR, the set of ABIs are instead validated and translated during lowering. That seems more appropriate.

3. `ast::FloatTy` is now distinct from `rustc_target::abi::FloatTy`. The former is used substantially more and the translation between them is only necessary in a single place.

4. As a result of 2-3, libsyntax no longer depends on librustc_target, which should improve pipe-lining somewhat.

cc @rust-lang/lang -- the points 1-2 slightly change the definition of the language but in a way which seems consistent with our general principles (in particular wrt. the discussions of turning things into semantic errors). I expect this to be uncontroversial but it's worth letting y'all know. :)

r? @varkor

4 years agoRollup merge of #65752 - estebank:sugg, r=Centril
Mazdak Farrokhzad [Thu, 7 Nov 2019 07:51:54 +0000 (08:51 +0100)]
Rollup merge of #65752 - estebank:sugg, r=Centril

Use structured suggestions for missing associated items

When encountering an `impl` that is missing associated items required by its `trait`, use structured suggestions at an appropriate place in the `impl`.

4 years agoRollup merge of #59789 - eddyb:typeck-reverts, r=nikomatsakis
Mazdak Farrokhzad [Thu, 7 Nov 2019 07:51:52 +0000 (08:51 +0100)]
Rollup merge of #59789 - eddyb:typeck-reverts, r=nikomatsakis

Revert two unapproved changes to rustc_typeck.

There was a breakdown in process (https://github.com/rust-lang/rust/pull/59004#issuecomment-477600735, https://github.com/rust-lang/rust/pull/58894#discussion_r272795560) and two changes were made to `rustc_typeck`'s "collect" queries, for rustdoc, that were neither needed *nor* correct.
I'm reverting them here, and will fix up rustdoc *somehow*, if necessary.

cc @rust-lang/compiler How do we ensure this doesn't happen again?

r? @nikomatsakis or @oli-obk

4 years agosyntax: use distinct FloatTy from rustc_target.
Mazdak Farrokhzad [Mon, 28 Oct 2019 02:46:22 +0000 (03:46 +0100)]
syntax: use distinct FloatTy from rustc_target.

We also sever syntax's dependency on rustc_target as a result.
This should slightly improve pipe-lining.

Moreover, some cleanup is done in related code.

4 years agotest that extern lits accept raw strings annd escapes
Mazdak Farrokhzad [Wed, 30 Oct 2019 12:53:53 +0000 (13:53 +0100)]
test that extern lits accept raw strings annd escapes

4 years agotest that parser is oblivious to set of ABIs
Mazdak Farrokhzad [Mon, 28 Oct 2019 03:13:38 +0000 (04:13 +0100)]
test that parser is oblivious to set of ABIs

4 years agoparser: allow ABIs from literal macro fragments
Mazdak Farrokhzad [Sun, 27 Oct 2019 23:29:23 +0000 (00:29 +0100)]
parser: allow ABIs from literal macro fragments

4 years agocleanup can_begin_const_arg
Mazdak Farrokhzad [Sun, 27 Oct 2019 22:22:59 +0000 (23:22 +0100)]
cleanup can_begin_const_arg

4 years agoparser: don't hardcode ABIs into grammar
Mazdak Farrokhzad [Sun, 27 Oct 2019 22:14:35 +0000 (23:14 +0100)]
parser: don't hardcode ABIs into grammar

4 years agoAuto merge of #66175 - JohnTitor:rollup-ihqk5vn, r=JohnTitor
bors [Thu, 7 Nov 2019 03:54:25 +0000 (03:54 +0000)]
Auto merge of #66175 - JohnTitor:rollup-ihqk5vn, r=JohnTitor

Rollup of 12 pull requests

Successful merges:

 - #65794 (gate rustc_on_unimplemented under rustc_attrs)
 - #65945 (Optimize long-linker-command-line test)
 - #66044 (Improve uninit/zeroed lint)
 - #66076 (HIR docs: mention how to resolve method paths)
 - #66084 (Do not require extra LLVM backends for `x.py test` to pass)
 - #66111 (improve from_raw_parts docs)
 - #66114 (Improve std::thread::Result documentation)
 - #66117 (Fixed PhantomData markers in Arc and Rc)
 - #66146 (Remove unused parameters in `__thread_local_inner`)
 - #66147 (Miri: Refactor to_scalar_ptr out of existence)
 - #66162 (Fix broken link in README)
 - #66171 (Update link on CONTRIBUTING.md)

Failed merges:

r? @ghost

4 years agoRollup merge of #66171 - JohnTitor:update-link, r=ehuss
Yuki Okushi [Thu, 7 Nov 2019 00:20:49 +0000 (09:20 +0900)]
Rollup merge of #66171 - JohnTitor:update-link, r=ehuss

Update link on CONTRIBUTING.md

This is a lost article of #66162
Follow-up for rust-lang/rustc-guide#491

CC: @mark-i-m
4 years agoRollup merge of #66162 - Darksonn:master, r=ehuss
Yuki Okushi [Thu, 7 Nov 2019 00:20:48 +0000 (09:20 +0900)]
Rollup merge of #66162 - Darksonn:master, r=ehuss

Fix broken link in README

The link to the rustc guide on building and running the compiler is broken. It was broken in [rustc-guide#491](https://github.com/rust-lang/rustc-guide/pull/491).

4 years agoRollup merge of #66147 - RalfJung:no-scalar-ptr, r=oli-obk
Yuki Okushi [Thu, 7 Nov 2019 00:20:46 +0000 (09:20 +0900)]
Rollup merge of #66147 - RalfJung:no-scalar-ptr, r=oli-obk

Miri: Refactor to_scalar_ptr out of existence

`to_scalar_ptr` is somewhat subtle as it just throws away the 2nd component of a `ScalarPair` if there is one -- without any check if this is truly a pointer or so. And indeed we used it wrong on two occasions!

So I fixed those two, and then refactored things such that everyone calls `ref_to_mplace` instead (which they did anyway, I just moved up the calls), which is the only place that should interpret a `ScalarPair` as a wide ptr -- and it checks the type first. Thus we can remove `to_scalar_ptr` and `to_meta`.

r? @oli-obk

4 years agoRollup merge of #66146 - 3442853561:patch-2, r=Mark-Simulacrum
Yuki Okushi [Thu, 7 Nov 2019 00:20:45 +0000 (09:20 +0900)]
Rollup merge of #66146 - 3442853561:patch-2, r=Mark-Simulacrum

Remove unused parameters in `__thread_local_inner`

Fixes #65993.

4 years agoRollup merge of #66117 - olegnn:fixed_linked_list_marker, r=RalfJung
Yuki Okushi [Thu, 7 Nov 2019 00:20:44 +0000 (09:20 +0900)]
Rollup merge of #66117 - olegnn:fixed_linked_list_marker, r=RalfJung

Fixed PhantomData markers in Arc and Rc

Include owned internal structs in `PhantomData` markers in `Arc` (`PhantomData<T>` => `PhantomData<ArcInner<T>>`) and `Rc` (`PhantomData<T>` => `PhantomData<RcBox<T>>`).

4 years agoRollup merge of #66114 - golddranks:improve_thread_docs, r=Centril
Yuki Okushi [Thu, 7 Nov 2019 00:20:42 +0000 (09:20 +0900)]
Rollup merge of #66114 - golddranks:improve_thread_docs, r=Centril

Improve std::thread::Result documentation

Thanks to @dtolnay for pointing out the different premise of the contents of the `Err` variant in `std::thread::Result` WRT normal error handling.

4 years agoRollup merge of #66111 - RalfJung:from_raw_parts, r=Centril
Yuki Okushi [Thu, 7 Nov 2019 00:20:41 +0000 (09:20 +0900)]
Rollup merge of #66111 - RalfJung:from_raw_parts, r=Centril

improve from_raw_parts docs

Triggered by https://github.com/rust-lang/rfcs/pull/2806. Hopefully this helps clarify that joining slices across allocations is not possible in Rust currently.

r? @Centril

4 years agoRollup merge of #66084 - petrochenkov:x86arm, r=alexcrichton
Yuki Okushi [Thu, 7 Nov 2019 00:20:39 +0000 (09:20 +0900)]
Rollup merge of #66084 - petrochenkov:x86arm, r=alexcrichton

Do not require extra LLVM backends for `x.py test` to pass

For long time our testing passed with a partially built LLVM
```
[llvm]
targets = "X86;ARM"
```
, a [recent PR](https://github.com/rust-lang/rust/pull/65809) changed that.

4 years agoRollup merge of #66076 - RalfJung:qpath, r=davidtwco,oli-obk
Yuki Okushi [Thu, 7 Nov 2019 00:20:38 +0000 (09:20 +0900)]
Rollup merge of #66076 - RalfJung:qpath, r=davidtwco,oli-obk

HIR docs: mention how to resolve method paths

4 years agoRollup merge of #66044 - RalfJung:uninit-lint, r=oli-obk
Yuki Okushi [Thu, 7 Nov 2019 00:20:36 +0000 (09:20 +0900)]
Rollup merge of #66044 - RalfJung:uninit-lint, r=oli-obk

Improve uninit/zeroed lint

* Also warn when creating a raw pointer with a NULL vtable.
* Also identify `MaybeUninit::uninit().assume_init()` and `MaybeUninit::zeroed().assume_init()` as dangerous.

4 years agoRollup merge of #65945 - tmiasko:long-linker-command-line, r=alexcrichton
Yuki Okushi [Thu, 7 Nov 2019 00:20:34 +0000 (09:20 +0900)]
Rollup merge of #65945 - tmiasko:long-linker-command-line, r=alexcrichton

Optimize long-linker-command-line test

Replace O(n^3) text matching with inexpensive hash set lookups.

On my machine this reduces the total runtime of complete
run-make-fulldeps suite from roughly 75 seconds to 45 seconds.

4 years agoRollup merge of #65794 - Centril:unimpl-internal, r=varkor
Yuki Okushi [Thu, 7 Nov 2019 00:20:33 +0000 (09:20 +0900)]
Rollup merge of #65794 - Centril:unimpl-internal, r=varkor

gate rustc_on_unimplemented under rustc_attrs

Move `rustc_on_implemented` from the `on_implemented` gate to `rustc_attrs` as it is internal.

Closes #29628

r? @varkor

4 years agoAuto merge of #65750 - nnethercote:cheaper-doc-comments, r=petrochenkov
bors [Thu, 7 Nov 2019 00:10:52 +0000 (00:10 +0000)]
Auto merge of #65750 - nnethercote:cheaper-doc-comments, r=petrochenkov

Cheaper doc comments

This PR implements the idea from #60935: represent doc comments more cheaply, rather than converting them into `#[doc="..."]` attribute form. Unlike #60936 (which is about coalescing doc comments to reduce their number), this approach does not have any backwards compatibility concerns, and it eliminates about 80-90% of the current cost of doc comments (as estimated using the numbers in #60930, which eliminated the cost of doc comments entirely by treating them as normal comments).

r? @petrochenkov

4 years agoFix other broken link
Yuki Okushi [Wed, 6 Nov 2019 23:30:44 +0000 (08:30 +0900)]
Fix other broken link

4 years agoUpdate link on CONTRIBUTING.md
Yuki Okushi [Wed, 6 Nov 2019 21:48:28 +0000 (06:48 +0900)]
Update link on CONTRIBUTING.md

4 years agoAuto merge of #65728 - ecstatic-morse:promotion-const-proj, r=eddyb
bors [Wed, 6 Nov 2019 18:12:57 +0000 (18:12 +0000)]
Auto merge of #65728 - ecstatic-morse:promotion-const-proj, r=eddyb

Fix promotion in a `const` when projections are present

Resolves #65727.

This marks the entire local as "needs promotion" when only a projection of that local appears in a promotable context. This should only affect promotion in a `const` or `static`, not in a `fn` or `const fn`, which is handled in `promote_consts.rs`.

r? @eddyb

4 years agoreview comments
Esteban Küber [Wed, 30 Oct 2019 19:55:38 +0000 (12:55 -0700)]
review comments

4 years agoSuggest missing item from `trait` in `impl`
Esteban Küber [Thu, 24 Oct 2019 05:45:15 +0000 (22:45 -0700)]
Suggest missing item from `trait` in `impl`

4 years agoTry with crate::error::Error
Pyry Kontio [Wed, 6 Nov 2019 16:45:30 +0000 (01:45 +0900)]
Try with crate::error::Error

4 years agoFix broken link in README
Alice Ryhl [Wed, 6 Nov 2019 15:41:24 +0000 (16:41 +0100)]
Fix broken link in README

4 years agoReplace `array.into_iter()` with `iter()` in `libtest/tests.rs`
Lukas Kalbertodt [Fri, 1 Nov 2019 12:43:44 +0000 (13:43 +0100)]
Replace `array.into_iter()` with `iter()` in `libtest/tests.rs`

4 years agoAdd UI test for `array.into_iter()` lint
Lukas Kalbertodt [Fri, 1 Nov 2019 11:04:31 +0000 (12:04 +0100)]
Add UI test for `array.into_iter()` lint

4 years agoAdd future incompatibility lint for `array.into_iter()`
Lukas Kalbertodt [Fri, 1 Nov 2019 11:04:18 +0000 (12:04 +0100)]
Add future incompatibility lint for `array.into_iter()`

As we might want to add `IntoIterator` impls for arrays in the future,
and since that introduces a breaking change, this lint warns and
suggests using `iter()` instead (which is shorter and more explicit).

4 years agoAuto merge of #65134 - davidtwco:issue-19834-improper-ctypes-in-extern-C-fn, r=rkruppe
bors [Wed, 6 Nov 2019 12:45:35 +0000 (12:45 +0000)]
Auto merge of #65134 - davidtwco:issue-19834-improper-ctypes-in-extern-C-fn, r=rkruppe

improper_ctypes: `extern "C"` fns

cc #19834. Fixes #65867.

This pull request implements the change [described in this comment](https://github.com/rust-lang/rust/issues/19834#issuecomment-466671572).

cc @rkruppe @varkor @shepmaster

4 years agoMake doc comments cheaper with `AttrKind`.
Nicholas Nethercote [Wed, 23 Oct 2019 19:33:12 +0000 (06:33 +1100)]
Make doc comments cheaper with `AttrKind`.

`AttrKind` is a new type with two variants, `Normal` and `DocComment`. It's a
big performance win (over 10% in some cases) because `DocComment` lets doc
comments (which are common) be represented very cheaply.

`Attribute` gets some new helper methods to ease the transition:
- `has_name()`: check if the attribute name matches a single `Symbol`; for
  `DocComment` variants it succeeds if the symbol is `sym::doc`.
- `is_doc_comment()`: check if it has a `DocComment` kind.
- `{get,unwrap}_normal_item()`: extract the item from a `Normal` variant;
  panic otherwise.

Fixes #60935.

4 years agoRemove unnecessary `Deref` impl for `Attribute`.
Nicholas Nethercote [Wed, 23 Oct 2019 19:40:35 +0000 (06:40 +1100)]
Remove unnecessary `Deref` impl for `Attribute`.

This kind of thing just makes the code harder to read.

4 years agorollback gating for failing macro matchers
Mazdak Farrokhzad [Wed, 30 Oct 2019 16:34:00 +0000 (17:34 +0100)]
rollback gating for failing macro matchers

4 years agorevamp pre-expansion gating infra
Mazdak Farrokhzad [Wed, 30 Oct 2019 15:38:16 +0000 (16:38 +0100)]
revamp pre-expansion gating infra

4 years agoFix markdown link
Ralf Jung [Wed, 6 Nov 2019 10:15:30 +0000 (11:15 +0100)]
Fix markdown link

Co-Authored-By: Oliver Scherer <github35764891676564198441@oli-obk.de>
4 years agoAuto merge of #65830 - Quantumplation:master, r=davidtwco,estebank
bors [Wed, 6 Nov 2019 09:35:27 +0000 (09:35 +0000)]
Auto merge of #65830 - Quantumplation:master, r=davidtwco,estebank

Use ident.span instead of def_span in dead-code pass

Hello! First time contributor! :)

This should fix #58729.

According to @estebank in the duplicate #63064, def_span scans forward on the line until it finds a {,
and if it can't find one, falls back to the span for the whole item. This
was apparently written before the identifier span was explicitly tracked on
each node.

This means that if an unused function signature spans multiple lines, the
entire function (potentially hundreds of lines) gets flagged as dead code.
This could, for example, cause IDEs to add error squiggly's to the whole
function.

By using the span from the ident instead, we narrow the scope of this in
most cases. In a wider sense, it's probably safe to use ident.span
instead of def_span in most locations throughout the whole code base,
but since this is my first contribution, I kept it small.

Some interesting points that came up while I was working on this:
- I reorganized the tests a bit to bring some of the dead code ones all
into the same location
- A few tests were for things unrelated to dead code (like the
path-lookahead for parens), so I added #![allow(dead_code)] and
cleaned up the stderr file to reduce noise in the future
- The same fix doesn't apply to const and static declarations. I tried
adding these cases to the match expression, but that created a much
wider change to tests and error messages, so I left it off until I
could get some code review to validate the approach.

4 years ago--bless
Ralf Jung [Wed, 6 Nov 2019 08:52:11 +0000 (09:52 +0100)]
--bless

4 years agoimprove a comment
Ralf Jung [Wed, 6 Nov 2019 07:45:50 +0000 (08:45 +0100)]
improve a comment

4 years agoremvoe to_scalar_ptr and use ref_to_mplace everywhere
Ralf Jung [Wed, 6 Nov 2019 07:44:15 +0000 (08:44 +0100)]
remvoe to_scalar_ptr and use ref_to_mplace everywhere

4 years agomiri cast: avoid unnecessary to_scalar_ptr
Ralf Jung [Tue, 5 Nov 2019 22:04:17 +0000 (23:04 +0100)]
miri cast: avoid unnecessary to_scalar_ptr

4 years agoUpdate local.rs
3442853561 [Wed, 6 Nov 2019 08:39:48 +0000 (16:39 +0800)]
Update local.rs

Removed parameters not used in the macro

4 years agoFix the Error linking.
Pyry Kontio [Wed, 6 Nov 2019 07:57:59 +0000 (16:57 +0900)]
Fix the Error linking.

4 years agogate rustc_on_unimplemented under rustc_attrs
Mazdak Farrokhzad [Fri, 25 Oct 2019 05:19:07 +0000 (07:19 +0200)]
gate rustc_on_unimplemented under rustc_attrs

4 years agoAuto merge of #66143 - Centril:rollup-qmzuex0, r=Centril
bors [Wed, 6 Nov 2019 06:14:03 +0000 (06:14 +0000)]
Auto merge of #66143 - Centril:rollup-qmzuex0, r=Centril

Rollup of 9 pull requests

Successful merges:

 - #65776 (Rename `LocalInternedString` and more)
 - #65973 (caller_location: point to macro invocation sites, like file!/line!, and use in core::panic!.)
 - #66015 (librustc_lexer: Refactor the module)
 - #66062 (Configure LLVM module PIC level)
 - #66086 (bump smallvec to 1.0)
 - #66092 (Use KERN_ARND syscall for random numbers on NetBSD, same as FreeBSD.)
 - #66103 (Add target thumbv7neon-unknown-linux-musleabihf)
 - #66133 (Update the bundled `wasi-libc` repository)
 - #66139 (use American spelling for `pluralize!`)

Failed merges:

r? @ghost

4 years agoRollup merge of #66139 - euclio:pluralize, r=nagisa
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:14 +0000 (07:03 +0100)]
Rollup merge of #66139 - euclio:pluralize, r=nagisa

use American spelling for `pluralize!`

4 years agoRollup merge of #66133 - alexcrichton:update-wasi-libc, r=Mark-Simulacrum
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:12 +0000 (07:03 +0100)]
Rollup merge of #66133 - alexcrichton:update-wasi-libc, r=Mark-Simulacrum

Update the bundled `wasi-libc` repository

This updates the libc that the `wasm32-wasi` target links against to the
latest revision, mostly just bringing in minor bug fixes and minor wasm
size improvements.

4 years agoRollup merge of #66103 - smaeul:patch/thumb-musl, r=nagisa
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:11 +0000 (07:03 +0100)]
Rollup merge of #66103 - smaeul:patch/thumb-musl, r=nagisa

Add target thumbv7neon-unknown-linux-musleabihf

This is a copy of thumbv7neon-unknown-linux-gnueabihf with musl changes
merged from armv7-unknown-linux-musleabihf. This appears to have been
missed when adding the other ARMv7-A thumb targets.

4 years agoRollup merge of #66092 - niacat:master, r=nagisa
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:09 +0000 (07:03 +0100)]
Rollup merge of #66092 - niacat:master, r=nagisa

Use KERN_ARND syscall for random numbers on NetBSD, same as FreeBSD.

This system call is present on all supported NetBSD versions and provides an endless stream of non-blocking random data from the kernel's ChaCha20-based CSPRNG. It doesn't require a file like `/dev/urandom` to be opened.

The system call is documented here (under kern.arandom):
https://netbsd.gw.com/cgi-bin/man-cgi?sysctl+7+NetBSD-7.0

And defined here:
https://nxr.netbsd.org/xref/src/sys/sys/sysctl.h#273

The semantics are the same as FreeBSD so reading 256 bytes per call is fine.

Similar change for getrandom crate: rust-random/getrandom#115

4 years agoRollup merge of #66086 - RalfJung:smallvec, r=nagisa
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:08 +0000 (07:03 +0100)]
Rollup merge of #66086 - RalfJung:smallvec, r=nagisa

bump smallvec to 1.0

This includes https://github.com/servo/rust-smallvec/pull/162, fixing an unsoundness in smallvec.

See https://github.com/servo/rust-smallvec/pull/175 for the 1.0 release announcement.

Cc @mbrubeck @emilio

4 years agoRollup merge of #66062 - smaeul:patch/pic-level, r=estebank
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:06 +0000 (07:03 +0100)]
Rollup merge of #66062 - smaeul:patch/pic-level, r=estebank

Configure LLVM module PIC level

As of LLVM 9, this is required for 32-bit PowerPC to properly generate
PLT references. Previously, only BigPIC was supported; now LLVM supports
both BigPIC and SmallPIC, and there is no default value provided.

4 years agoRollup merge of #66015 - popzxc:refactor-librustc_parser, r=matklad
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:05 +0000 (07:03 +0100)]
Rollup merge of #66015 - popzxc:refactor-librustc_parser, r=matklad

librustc_lexer: Refactor the module

This PR introduces a refactoring of the `librustc_lexer` in order to improve readability.

All the changes performed are only cosmetic and do not introduce any changes the lexer logic or performance.

Newly introduced modules `literal`, `token` and `utils` are just copy-pasted from the `lib.rs` and do not contain even cosmetic changes (I decided to do so so it'll be easier to review changes looking only on diff).

r? @petrochenkov

cc @Centril @matklad

4 years agoRollup merge of #65973 - eddyb:caller-location-panic, r=petrochenkov
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:03 +0000 (07:03 +0100)]
Rollup merge of #65973 - eddyb:caller-location-panic, r=petrochenkov

caller_location: point to macro invocation sites, like file!/line!, and use in core::panic!.

The main change here is to `core::panic!`, trying to fix this remaining regression: https://github.com/rust-lang/rust/pull/65927#issuecomment-547625147

However, in order for `caller_location` to be usable from macros the same way `file!()`/`line!()` are, it needs to have the same behavior (of extracting the macro invocation site `Span` and using that).

Arguably we would've had to do this at some point anyway, if we want to use `#[track_caller]` to replace the `file!()`/`line!()` uses from macros, but I'm not sure the RFC mentions this at all.

r? @petrochenkov cc @anp @nnethercote

4 years agoRollup merge of #65776 - nnethercote:rename-LocalInternedString-and-more, r=estebank
Mazdak Farrokhzad [Wed, 6 Nov 2019 06:03:01 +0000 (07:03 +0100)]
Rollup merge of #65776 - nnethercote:rename-LocalInternedString-and-more, r=estebank

Rename `LocalInternedString` and more

This PR renames `LocalInternedString` as `SymbolStr`, removes an unnecessary `impl` from it, improves comments, and cleans up some `SymbolStr` uses.

r? @estebank

4 years agoAddressed review comments.
Pyry Kontio [Wed, 6 Nov 2019 05:47:52 +0000 (14:47 +0900)]
Addressed review comments.

4 years agoAuto merge of #66141 - Centril:rollup-n2fcvp9, r=Centril
bors [Wed, 6 Nov 2019 02:29:21 +0000 (02:29 +0000)]
Auto merge of #66141 - Centril:rollup-n2fcvp9, r=Centril

Rollup of 11 pull requests

Successful merges:

 - #65892 (Remove `PartialEq` and `Eq` from the `SpecialDerives`.)
 - #66014 (Show type parameter name and definition in type mismatch error messages )
 - #66027 (Move has_panic_handler to query)
 - #66054 (syntax: Avoid span arithmetic for delimiter tokens)
 - #66068 (use silent emitter for rustdoc highlighting pass)
 - #66081 (let caller of check_ptr_access_align control the error message)
 - #66093 (Do not ICE with a precision flag in formatting str and no format arguments)
 - #66098 (Detect `::` -> `:` typo when involving turbofish)
 - #66101 (Tweak type mismatch caused by break on tail expr)
 - #66106 (Fix typo in explanation of `E0080`)
 - #66115 (rustc: remove "GlobalMetaData" dead code from hir::map::definitions.)

Failed merges:

r? @ghost

4 years agoRollup merge of #66115 - eddyb:global-meta-what, r=michaelwoerister
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:20 +0000 (03:28 +0100)]
Rollup merge of #66115 - eddyb:global-meta-what, r=michaelwoerister

rustc: remove "GlobalMetaData" dead code from hir::map::definitions.

Spotted while refactoring uses of `DefIndex` and/or `LocalDefId`.

r? @michaelwoerister

4 years agoRollup merge of #66106 - JOE1994:master, r=GuillaumeGomez
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:19 +0000 (03:28 +0100)]
Rollup merge of #66106 - JOE1994:master, r=GuillaumeGomez

Fix typo in explanation of `E0080`

Handling issue #66105 in Rust repo.
`evaluate an constant expression` to `evaluate a constant expression`

4 years agoRollup merge of #66101 - estebank:break-tail-e0308, r=Centril
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:17 +0000 (03:28 +0100)]
Rollup merge of #66101 - estebank:break-tail-e0308, r=Centril

Tweak type mismatch caused by break on tail expr

When `break;` has a type mismatch because the `Destination` points at a tail
expression with an obligation flowing from a return type, point at the
return type.

Fix #39968.

4 years agoRollup merge of #66098 - estebank:path-asciption-typo, r=Centril
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:15 +0000 (03:28 +0100)]
Rollup merge of #66098 - estebank:path-asciption-typo, r=Centril

Detect `::` -> `:` typo when involving turbofish

Fix #65569.

4 years agoRollup merge of #66093 - estebank:fmt-ice, r=Centril
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:14 +0000 (03:28 +0100)]
Rollup merge of #66093 - estebank:fmt-ice, r=Centril

Do not ICE with a precision flag in formatting str and no format arguments

Fix #66065.

4 years agoRollup merge of #66081 - RalfJung:ptr-offset, r=zackmdavis
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:12 +0000 (03:28 +0100)]
Rollup merge of #66081 - RalfJung:ptr-offset, r=zackmdavis

let caller of check_ptr_access_align control the error message

This is needed for https://github.com/rust-lang/miri/pull/1031

4 years agoRollup merge of #66068 - euclio:null-emitter, r=estebank
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:11 +0000 (03:28 +0100)]
Rollup merge of #66068 - euclio:null-emitter, r=estebank

use silent emitter for rustdoc highlighting pass

Partially addresses #63284.

4 years agoRollup merge of #66054 - petrochenkov:delspan, r=estebank
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:09 +0000 (03:28 +0100)]
Rollup merge of #66054 - petrochenkov:delspan, r=estebank

syntax: Avoid span arithmetic for delimiter tokens

The +/-1 logic is from the time where the whole group had a single span and the delimiter spans had to be calculated from it.
Now the delimiters have their own spans which are constructed by lexer or proc macro API and can be used directly.
If those spans are not perfect, then it should be fixed by tweaking the corresponding lexer logic rather than by trying to add or substract `1` from the span boundaries.

Fixes https://github.com/rust-lang/rust/issues/62524
r? @estebank

4 years agoRollup merge of #66027 - Mark-Simulacrum:panic-handler-query, r=alexcrichton
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:08 +0000 (03:28 +0100)]
Rollup merge of #66027 - Mark-Simulacrum:panic-handler-query, r=alexcrichton

Move has_panic_handler to query

Moves us off of a global Once instead re-querying the lang item each time. The conditions on when we set it to true change a little (previously we'd make sure a few more lang items were `Some`) but I think they in practice don't matter, we won't compile later on if we don't have them.

4 years agoRollup merge of #66014 - dkadashev:47319-type-param-def-location, r=estebank
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:06 +0000 (03:28 +0100)]
Rollup merge of #66014 - dkadashev:47319-type-param-def-location, r=estebank

Show type parameter name and definition in type mismatch error messages

Fixes #47319

r? estebank

4 years agoRollup merge of #65892 - pnkfelix:trim-special-derives, r=petrochenkov
Mazdak Farrokhzad [Wed, 6 Nov 2019 02:28:05 +0000 (03:28 +0100)]
Rollup merge of #65892 - pnkfelix:trim-special-derives, r=petrochenkov

Remove `PartialEq` and `Eq` from the `SpecialDerives`.

Now that PR #65519 landed, this is the follow-on work of removing `PartialEq` and `Eq` from the set of `SpecialDerives` .

4 years agoUse source_callee().is_some() to detect macros
Pi Lanningham [Tue, 5 Nov 2019 23:49:46 +0000 (23:49 +0000)]
Use source_callee().is_some() to detect macros

macro_backtrace() allocates a vector, whereas source_callee() doesn't
but indicates the same thing.  Suggested by @estebank

4 years agoTweak type mismatch caused by break on tail expr
Esteban Küber [Tue, 5 Nov 2019 02:47:02 +0000 (18:47 -0800)]
Tweak type mismatch caused by break on tail expr

When `break;` has a type mismatch because the `Destination` points at a tail
expression with an obligation flowing from a return type, point at the
return type.

Fix #39968.

4 years agoFixed libcore/cell.rs example
Oleg Nosov [Tue, 5 Nov 2019 22:03:31 +0000 (01:03 +0300)]
Fixed libcore/cell.rs example

4 years agoApply suggestions from code review
Ralf Jung [Tue, 5 Nov 2019 20:50:55 +0000 (21:50 +0100)]
Apply suggestions from code review

Co-Authored-By: Mazdak Farrokhzad <twingoow@gmail.com>
4 years agoReverted PhantomData in LinkedList, fixed PhantomData markers in Rc and Arc
Oleg Nosov [Tue, 5 Nov 2019 20:34:54 +0000 (23:34 +0300)]
Reverted PhantomData in LinkedList, fixed PhantomData markers in Rc and Arc

4 years agoAuto merge of #66121 - pietroalbini:rollup-8zrwe7l, r=pietroalbini
bors [Tue, 5 Nov 2019 20:22:27 +0000 (20:22 +0000)]
Auto merge of #66121 - pietroalbini:rollup-8zrwe7l, r=pietroalbini

Rollup of 8 pull requests

Successful merges:

 - #65948 (Improve MaybeUninit::get_{ref,mut} documentation)
 - #65953 (Allow specifying LLVM's MCTargetOptions::ABIName in target specification files)
 - #66012 (De-querify `trivial_dropck_outlives`.)
 - #66025 (`Span` cannot represent `span.hi < span.lo`)
 - #66047 (Don't double-count `simd_shuffle` promotion candidates)
 - #66053 (when Miri tests are not passing, do not add Miri component)
 - #66082 (clean highlightSourceLines code)
 - #66091 (Implemented the home_dir for VxWorks)

Failed merges:

r? @ghost

4 years agouse American spelling for `pluralize!`
Andy Russell [Tue, 5 Nov 2019 20:10:24 +0000 (15:10 -0500)]
use American spelling for `pluralize!`

4 years agoUpdate the bundled `wasi-libc` repository
Alex Crichton [Tue, 5 Nov 2019 19:49:23 +0000 (11:49 -0800)]
Update the bundled `wasi-libc` repository

This updates the libc that the `wasm32-wasi` target links against to the
latest revision, mostly just bringing in minor bug fixes and minor wasm
size improvements.

4 years agoDo not ICE whith a precision flag in formatting str and no format arguments
Esteban Küber [Mon, 4 Nov 2019 18:57:41 +0000 (10:57 -0800)]
Do not ICE whith a precision flag in formatting str and no format arguments

4 years agorustc: remove "GlobalMetaData" dead code from hir::map::definitions.
Eduard-Mihai Burtescu [Tue, 5 Nov 2019 11:49:36 +0000 (13:49 +0200)]
rustc: remove "GlobalMetaData" dead code from hir::map::definitions.

4 years agoAccount for typo in turbofish and suggest `::`
Esteban Küber [Tue, 5 Nov 2019 18:29:54 +0000 (10:29 -0800)]
Account for typo in turbofish and suggest `::`

4 years agoDetect if item.span is in a macro, and fall back
Pi Lanningham [Tue, 5 Nov 2019 15:42:34 +0000 (15:42 +0000)]
Detect if item.span is in a macro, and fall back

If item.span is part of a macro invocation, this has several downstream
implications.  To name two that were found while working on this:

 - The dead-code error gets annotated with a "in this macro invocation"
 - Some errors get canceled if they refer to remote crates

Ideally, we should annotate item.ident.span with the same macro info,
but this is a larger change (see: #66095), so for now we just fall
back to the old behavior if this item was generated by a macro.

I use span.macro_backtrace().len() to detect if it's part of a macro,
because that (among other things) is what is used by the code which
adds the "in this macro invocation" annotations mentioned above.

4 years agoReview feedback: alpha-rename field from `copy_derives` to `containers_derving_copy`.
Felix S. Klock II [Mon, 4 Nov 2019 09:09:58 +0000 (10:09 +0100)]
Review feedback: alpha-rename field from `copy_derives` to `containers_derving_copy`.

4 years agoReview feedback: Remove more stuff! Simplify simplify simplify!
Felix S. Klock II [Wed, 30 Oct 2019 10:13:00 +0000 (11:13 +0100)]
Review feedback: Remove more stuff! Simplify simplify simplify!

4 years agoRemove `PartialEq` and `Eq` from the `SpecialDerives`.
Felix S. Klock II [Mon, 28 Oct 2019 11:40:12 +0000 (12:40 +0100)]
Remove `PartialEq` and `Eq` from the `SpecialDerives`.

4 years agoRollup merge of #66091 - Wind-River:master_xyz, r=cramertj
Pietro Albini [Tue, 5 Nov 2019 13:37:08 +0000 (14:37 +0100)]
Rollup merge of #66091 - Wind-River:master_xyz, r=cramertj

Implemented the home_dir for VxWorks

Use HOME's value if it is set;
otherwise return NONE.

4 years agoRollup merge of #66082 - GuillaumeGomez:cleanup-highlightsourcelines, r=kinnison
Pietro Albini [Tue, 5 Nov 2019 13:37:07 +0000 (14:37 +0100)]
Rollup merge of #66082 - GuillaumeGomez:cleanup-highlightsourcelines, r=kinnison

clean highlightSourceLines code

This is the first part of https://github.com/rust-lang/rust/issues/66046. Now that I've splitted the hashchange stuff and the source code lines highlighting, I'll be able to fix the whole issue once and for all.

r? @kinnison

4 years agoRollup merge of #66053 - RalfJung:miri-toolstate, r=pietroalbini
Pietro Albini [Tue, 5 Nov 2019 13:37:05 +0000 (14:37 +0100)]
Rollup merge of #66053 - RalfJung:miri-toolstate, r=pietroalbini

when Miri tests are not passing, do not add Miri component

Second attempt, this time based on the JSON files that exist since https://github.com/rust-lang/rust/pull/65274.

Fixes https://github.com/rust-lang/rust/issues/60301
r? @pietroalbini @alexcrichton

4 years agoRollup merge of #66047 - ecstatic-morse:issue-66016, r=eddyb
Pietro Albini [Tue, 5 Nov 2019 13:37:03 +0000 (14:37 +0100)]
Rollup merge of #66047 - ecstatic-morse:issue-66016, r=eddyb

Don't double-count `simd_shuffle` promotion candidates

Resolves #66016.

The `#[rustc_args_required_const]` attribute was added to `simd_shuffle*` in rust-lang/stdarch#825. This caused `promote_consts` to double-count its second argument when recording promotion candidates, which caused the promotion candidate compatibility check to fail.

Once `stdarch` is updated in-tree to include rust-lang/stdarch#825, all special logic around `simd_shuffle` can and should be removed.

4 years agoRollup merge of #66025 - petrochenkov:lohi, r=eddyb
Pietro Albini [Tue, 5 Nov 2019 13:37:01 +0000 (14:37 +0100)]
Rollup merge of #66025 - petrochenkov:lohi, r=eddyb

`Span` cannot represent `span.hi < span.lo`

So we can remove the corresponding checks from various code

4 years agoRollup merge of #66012 - nnethercote:dequery-trivial_dropck_outlives, r=michaelwoerister
Pietro Albini [Tue, 5 Nov 2019 13:36:59 +0000 (14:36 +0100)]
Rollup merge of #66012 - nnethercote:dequery-trivial_dropck_outlives, r=michaelwoerister

De-querify `trivial_dropck_outlives`.

It's sufficiently simple and fast that memoizing it is a slight
pessimization.

r? @michaelwoerister

4 years agoRollup merge of #65953 - keystone-enclave:llvm_abiname, r=alexcrichton
Pietro Albini [Tue, 5 Nov 2019 13:36:57 +0000 (14:36 +0100)]
Rollup merge of #65953 - keystone-enclave:llvm_abiname, r=alexcrichton

Allow specifying LLVM's MCTargetOptions::ABIName in target specification files

This addresses #65024, as it allows RISC-V target specification files to set `"llvm-abiname": "lp64d"`.

Other languages (read: C) usually expose this codegen parameter under a compiler argument like `-mabi=<XYZ>`.