]> git.lizzy.rs Git - rust.git/log
rust.git
4 years agoRollup merge of #67255 - tuxillo:remove-i686-unknown-dragonfly, r=alexcrichton
Mazdak Farrokhzad [Sun, 15 Dec 2019 04:57:21 +0000 (05:57 +0100)]
Rollup merge of #67255 - tuxillo:remove-i686-unknown-dragonfly, r=alexcrichton

Remove i686-unknown-dragonfly target

DragonFly BSD removed support for i386 a while ago. It only supports x86_64 right now.

4 years agoAuto merge of #67216 - ecstatic-morse:const-loop, r=oli-obk
bors [Sun, 15 Dec 2019 01:28:28 +0000 (01:28 +0000)]
Auto merge of #67216 - ecstatic-morse:const-loop, r=oli-obk

Enable `loop` and `while` in constants behind a feature flag

This PR is an initial implementation of #52000. It adds a `const_loop` feature gate, which allows `while` and `loop` expressions through both HIR and MIR const-checkers if enabled. `for` expressions remain forbidden by the HIR const-checker, since they desugar to a call to `IntoIterator::into_iter`, which will be rejected anyways.

`while` loops also require [`#![feature(const_if_match)]`](https://github.com/rust-lang/rust/pull/66507), since they have a conditional built into them. The diagnostics from the HIR const checker will suggest this to the user.

r? @oli-obk
cc @rust-lang/wg-const-eval

4 years agoAuto merge of #67224 - nikomatsakis:revert-stabilization-of-never-type, r=centril
bors [Sat, 14 Dec 2019 22:02:59 +0000 (22:02 +0000)]
Auto merge of #67224 - nikomatsakis:revert-stabilization-of-never-type, r=centril

Revert stabilization of never type

Fixes https://github.com/rust-lang/rust/issues/66757

I decided to keep the separate `never-type-fallback` feature gate, but tried to otherwise revert https://github.com/rust-lang/rust/pull/65355. Seemed pretty clean.

( cc @Centril, author of #65355, you may want to check this over briefly )

4 years agoupdate reference
Niko Matsakis [Sat, 14 Dec 2019 20:41:36 +0000 (15:41 -0500)]
update reference

4 years agoupdate clippy to the rustc-pr-67224 branch
Niko Matsakis [Sat, 14 Dec 2019 13:55:49 +0000 (08:55 -0500)]
update clippy to the rustc-pr-67224 branch

Actually to commit <69f99e74ac2266dff4b5adc7c59b35236f0abef1>.

4 years ago[WIP] fix tests after rebase
Niko Matsakis [Sat, 14 Dec 2019 13:17:09 +0000 (08:17 -0500)]
[WIP] fix tests after rebase

4 years agoadd `#![feature(never_type)]` to tests as needed
Niko Matsakis [Wed, 11 Dec 2019 16:46:56 +0000 (11:46 -0500)]
add `#![feature(never_type)]` to tests as needed

4 years agoAdd regression test for #66757
Niko Matsakis [Wed, 11 Dec 2019 15:09:40 +0000 (10:09 -0500)]
Add regression test for #66757

4 years agoRevert "Stabilize the `never_type`, written `!`."
Niko Matsakis [Wed, 11 Dec 2019 14:55:29 +0000 (09:55 -0500)]
Revert "Stabilize the `never_type`, written `!`."

This reverts commit 15c30ddd69d6cc3fffe6d304c6dc968a5ed046f1.

4 years agoRevert "Remove `#![feature(never_type)]` from tests."
Niko Matsakis [Wed, 11 Dec 2019 14:51:28 +0000 (09:51 -0500)]
Revert "Remove `#![feature(never_type)]` from tests."

This reverts commit 8f6197f39f7d468dfc5b2bd41dae4769992a2f83.

4 years agoRevert "Redefine `core::convert::Infallible` as `!`."
Niko Matsakis [Wed, 11 Dec 2019 14:49:29 +0000 (09:49 -0500)]
Revert "Redefine `core::convert::Infallible` as `!`."

This reverts commit 089229a1935fa9795cfdefa518c8f8c3beb66db8.

4 years agoAuto merge of #67136 - oli-obk:const_stability, r=Centril
bors [Sat, 14 Dec 2019 10:21:32 +0000 (10:21 +0000)]
Auto merge of #67136 - oli-obk:const_stability, r=Centril

Require stable/unstable annotations for the constness of all stable fns with a const modifier

r? @RalfJung @Centril

Every `#[stable]` const fn now needs either a `#[rustc_const_unstable]` attribute or a `#[rustc_const_stable]` attribute. You can't silently stabilize the constness of a function anymore.

4 years agoAuto merge of #67084 - Pagten:feature/print-msg-from-elf-entrypoint, r=Amanieu
bors [Sat, 14 Dec 2019 04:08:50 +0000 (04:08 +0000)]
Auto merge of #67084 - Pagten:feature/print-msg-from-elf-entrypoint, r=Amanieu

SGX: Change ELF entrypoint

This fixes [rust-sgx issue #148](https://github.com/fortanix/rust-sgx/issues/148).

A new entry point is created for the ELF file generated by `rustc`, separate from the enclave entry point. When the ELF file is executed as a Linux binary, the error message below is written to stderr.

> Error: This file is an SGX enclave which cannot be executed as a standard Linux binary.
> See the installation guide at https://edp.fortanix.com/docs/installation/guide/ on how to use 'cargo run' or follow the steps at https://edp.fortanix.com/docs/tasks/deployment/ for manual deployment.

When the ELF file is converted to an SGXS using `elf2sgxs`, the old entry point is still set as the enclave entry point. In a future pull request in the rust-sgx repository, `elf2sgxs` will be modified to remove the code in the ELF entry point, since this code is not needed in the enclave.

4 years agoAuto merge of #65951 - estebank:type-inference-error, r=nikomatsakis
bors [Fri, 13 Dec 2019 22:56:27 +0000 (22:56 +0000)]
Auto merge of #65951 - estebank:type-inference-error, r=nikomatsakis

Point at method call when type annotations are needed

- Point at method call instead of whole expression when type annotations are needed.
- Suggest use of turbofish on function and methods.

Fix #49391, fix #46333, fix #48089. CC #58517, #63502, #63082.

Fixes https://github.com/rust-lang/rust/issues/40015

r? @nikomatsakis

4 years agoAuto merge of #67284 - Centril:rollup-ghiukob, r=Centril
bors [Fri, 13 Dec 2019 19:39:20 +0000 (19:39 +0000)]
Auto merge of #67284 - Centril:rollup-ghiukob, r=Centril

Rollup of 7 pull requests

Successful merges:

 - #67026 (Improve diagnostics and code for exhaustiveness of empty matches)
 - #67235 (VecDeque: drop remaining items on destructor panic)
 - #67254 (dont ICE in case of invalid drop fn)
 - #67256 (Reduce allocs for validation errors)
 - #67274 (be explicit that mem::uninitialized is the same as MaybeUninit::uninit().assume_init())
 - #67278 (`coerce_inner`: use initial `expected_ty`)
 - #67280 (docs: std::convert::From: Fix typo)

Failed merges:

r? @ghost

4 years agoRollup merge of #67280 - shalzz:patch-1, r=jonas-schievink
Mazdak Farrokhzad [Fri, 13 Dec 2019 19:35:37 +0000 (20:35 +0100)]
Rollup merge of #67280 - shalzz:patch-1, r=jonas-schievink

docs: std::convert::From: Fix typo

Fix a minor typo

4 years agoRollup merge of #67278 - Centril:67273, r=oli-obk
Mazdak Farrokhzad [Fri, 13 Dec 2019 19:35:36 +0000 (20:35 +0100)]
Rollup merge of #67278 - Centril:67273, r=oli-obk

`coerce_inner`: use initial `expected_ty`

Fixes #67273.
Follow-up to #59439.

r? @oli-obk

4 years agoRollup merge of #67274 - RalfJung:uninit, r=Centril
Mazdak Farrokhzad [Fri, 13 Dec 2019 19:35:34 +0000 (20:35 +0100)]
Rollup merge of #67274 - RalfJung:uninit, r=Centril

be explicit that mem::uninitialized is the same as MaybeUninit::uninit().assume_init()

Cc @Centril @nikomatsakis

4 years agoRollup merge of #67256 - RalfJung:reduce-allocs, r=oli-obk
Mazdak Farrokhzad [Fri, 13 Dec 2019 19:35:33 +0000 (20:35 +0100)]
Rollup merge of #67256 - RalfJung:reduce-allocs, r=oli-obk

Reduce allocs for validation errors

This probably doesn't really matter, but I just felt like I had to do this...

r? @oli-obk

4 years agoRollup merge of #67254 - RalfJung:vtable-ice, r=oli-obk
Mazdak Farrokhzad [Fri, 13 Dec 2019 19:35:31 +0000 (20:35 +0100)]
Rollup merge of #67254 - RalfJung:vtable-ice, r=oli-obk

dont ICE in case of invalid drop fn

Fixes https://github.com/rust-lang/miri/issues/1112

r? @oli-obk

4 years agoRollup merge of #67235 - jonas-schievink:vecdeque-leak, r=KodrAus
Mazdak Farrokhzad [Fri, 13 Dec 2019 19:35:30 +0000 (20:35 +0100)]
Rollup merge of #67235 - jonas-schievink:vecdeque-leak, r=KodrAus

VecDeque: drop remaining items on destructor panic

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

4 years agoRollup merge of #67026 - Nadrieril:improve-usefulness-empty, r=varkor,Centril,estebank
Mazdak Farrokhzad [Fri, 13 Dec 2019 19:35:28 +0000 (20:35 +0100)]
Rollup merge of #67026 - Nadrieril:improve-usefulness-empty, r=varkor,Centril,estebank

Improve diagnostics and code for exhaustiveness of empty matches

There was a completely separate check and diagnostics for the case of an empty match. This led to slightly different error messages and duplicated code.
This improves code reuse and generally clarifies what happens for empty matches. This also clarifies the action of the `exhaustive_patterns` feature, and ensures that this feature doesn't change diagnostics in places it doesn't need to.

4 years agoCorrectly mark things as `min_const_fn`
Dylan MacKenzie [Fri, 13 Dec 2019 18:44:38 +0000 (10:44 -0800)]
Correctly mark things as `min_const_fn`

4 years agoDocument `Features::enabled`
ecstatic-morse [Thu, 12 Dec 2019 19:10:21 +0000 (11:10 -0800)]
Document `Features::enabled`

Co-Authored-By: Mazdak Farrokhzad <twingoow@gmail.com>
4 years agoUse correct nightly version for feature
Dylan MacKenzie [Wed, 11 Dec 2019 22:15:56 +0000 (14:15 -0800)]
Use correct nightly version for feature

4 years agoEnsure test actually uses dataflow, not simulation
Dylan MacKenzie [Wed, 11 Dec 2019 21:09:20 +0000 (13:09 -0800)]
Ensure test actually uses dataflow, not simulation

4 years agoUse better name for local containing required feature gates
Dylan MacKenzie [Wed, 11 Dec 2019 18:26:06 +0000 (10:26 -0800)]
Use better name for local containing required feature gates

4 years agoReplace `Index` impl with `enabled` method
Dylan MacKenzie [Wed, 11 Dec 2019 18:24:40 +0000 (10:24 -0800)]
Replace `Index` impl with `enabled` method

4 years agoApply suggestions from review
Dylan MacKenzie [Wed, 11 Dec 2019 18:20:50 +0000 (10:20 -0800)]
Apply suggestions from review

4 years agoFix grammar in test description
ecstatic-morse [Wed, 11 Dec 2019 18:16:12 +0000 (10:16 -0800)]
Fix grammar in test description

Co-Authored-By: Mazdak Farrokhzad <twingoow@gmail.com>
4 years agoLook for "unstable feature" error code in test
Dylan MacKenzie [Wed, 11 Dec 2019 18:09:10 +0000 (10:09 -0800)]
Look for "unstable feature" error code in test

Conditionals and loops now have unstable features, and `feature_err` has
its own error code. I think that `feature_err` should take an error code
as a parameter, but don't have the energy to make this change throughout
the codebase. Also, the error code system may be torn out entirely.

4 years agoImprove comment
Dylan MacKenzie [Wed, 11 Dec 2019 06:24:10 +0000 (22:24 -0800)]
Improve comment

4 years agoImprove message when active feature indexing panics
Dylan MacKenzie [Wed, 11 Dec 2019 06:20:44 +0000 (22:20 -0800)]
Improve message when active feature indexing panics

4 years agoBless modified tests
Dylan MacKenzie [Wed, 11 Dec 2019 05:11:53 +0000 (21:11 -0800)]
Bless modified tests

4 years agoBless unrelated tests with new help message
Dylan MacKenzie [Wed, 11 Dec 2019 05:27:53 +0000 (21:27 -0800)]
Bless unrelated tests with new help message

4 years agoAdd qualif smoke tests for const loops
Dylan MacKenzie [Wed, 11 Dec 2019 05:24:46 +0000 (21:24 -0800)]
Add qualif smoke tests for const loops

4 years agoExtend control flow basics tests with loops
Dylan MacKenzie [Wed, 11 Dec 2019 05:10:48 +0000 (21:10 -0800)]
Extend control flow basics tests with loops

4 years agoRestructue HIR const-checker to handle features with multiple gates
Dylan MacKenzie [Tue, 10 Dec 2019 20:43:15 +0000 (12:43 -0800)]
Restructue HIR const-checker to handle features with multiple gates

4 years agoPut MIR checks for loops behind the feature flag
Dylan MacKenzie [Tue, 10 Dec 2019 20:42:50 +0000 (12:42 -0800)]
Put MIR checks for loops behind the feature flag

4 years agoAdd feature gate for `const_loop`
Dylan MacKenzie [Tue, 10 Dec 2019 20:41:58 +0000 (12:41 -0800)]
Add feature gate for `const_loop`

4 years agoGet active features dynamically by their `Symbol`
Dylan MacKenzie [Tue, 10 Dec 2019 20:41:27 +0000 (12:41 -0800)]
Get active features dynamically by their `Symbol`

4 years agodocs: std::convert::From: Fix typo
Shaleen Jain [Fri, 13 Dec 2019 17:50:02 +0000 (23:20 +0530)]
docs: std::convert::From: Fix typo

Fix a minor typo

4 years agoAuto merge of #62359 - euclio:remove-serialize, r=Dylan-DPC
bors [Fri, 13 Dec 2019 16:14:47 +0000 (16:14 +0000)]
Auto merge of #62359 - euclio:remove-serialize, r=Dylan-DPC

replace serialize with serde in rustdoc

This is a slightly less aggressive version of #61028.

r? @GuillaumeGomez

4 years agocoerce_inner: use initial expected_ty
Mazdak Farrokhzad [Fri, 13 Dec 2019 14:52:51 +0000 (15:52 +0100)]
coerce_inner: use initial expected_ty

4 years agoThe constness of 128 bit atomics will be stabilized together with the atomics
Oliver Scherer [Fri, 13 Dec 2019 12:28:55 +0000 (13:28 +0100)]
The constness of 128 bit atomics will be stabilized together with the atomics

4 years agobe explicit that mem::uninitialized is the same as MaybeUninit::uninit().assume_init()
Ralf Jung [Fri, 13 Dec 2019 12:13:37 +0000 (13:13 +0100)]
be explicit that mem::uninitialized is the same as MaybeUninit::uninit().assume_init()

4 years agoAddress review comments
Oliver Scherer [Thu, 12 Dec 2019 09:51:42 +0000 (10:51 +0100)]
Address review comments

4 years agoConsistently name `min_const_fn`
Oliver Scherer [Thu, 12 Dec 2019 09:11:18 +0000 (10:11 +0100)]
Consistently name `min_const_fn`

4 years agoChange the const stab default for internal const fns
Oliver Scherer [Sun, 8 Dec 2019 11:58:41 +0000 (12:58 +0100)]
Change the const stab default for internal const fns

4 years agoFix rustdoc test
Oliver Scherer [Sun, 8 Dec 2019 11:53:27 +0000 (12:53 +0100)]
Fix rustdoc test

4 years agoElaborate internal const fn comment
Oliver Scherer [Sun, 8 Dec 2019 08:34:34 +0000 (09:34 +0100)]
Elaborate internal const fn comment

4 years agoCompiler internal error codes need no documentation
Oliver Scherer [Sun, 8 Dec 2019 08:33:06 +0000 (09:33 +0100)]
Compiler internal error codes need no documentation

4 years agoRequire stable/unstable annotations for the constness of all stable functions with...
Oliver Scherer [Sun, 8 Dec 2019 00:43:10 +0000 (01:43 +0100)]
Require stable/unstable annotations for the constness of all stable functions with a `const` modifier

4 years agoReuse the `staged_api` feature for `rustc_const_unstable`
Oliver Scherer [Wed, 4 Dec 2019 21:00:28 +0000 (22:00 +0100)]
Reuse the `staged_api` feature for `rustc_const_unstable`

4 years agoAuto merge of #67077 - Aaron1011:build-llvm-in-binary, r=alexcrichton
bors [Fri, 13 Dec 2019 10:07:38 +0000 (10:07 +0000)]
Auto merge of #67077 - Aaron1011:build-llvm-in-binary, r=alexcrichton

rustc: Link LLVM directly into rustc again (take two)

This is a continuation of PR https://github.com/rust-lang/rust/pull/65703

4 years agoAuto merge of #66405 - nnethercote:tweak-ObligForest-NodeStates, r=nikomatsakis
bors [Fri, 13 Dec 2019 06:51:28 +0000 (06:51 +0000)]
Auto merge of #66405 - nnethercote:tweak-ObligForest-NodeStates, r=nikomatsakis

Remove `NodeState::{Waiting,Done}`

An optimization, and then some clean-ups.

r? @nikomatsakis

4 years agoAuto merge of #67271 - Centril:rollup-i71iqkv, r=Centril
bors [Fri, 13 Dec 2019 03:22:20 +0000 (03:22 +0000)]
Auto merge of #67271 - Centril:rollup-i71iqkv, r=Centril

Rollup of 6 pull requests

Successful merges:

 - #66341 (Match `VecDeque::extend` to `Vec::extend_desugared`)
 - #67243 (LinkedList: drop remaining items when drop panics)
 - #67247 (Don't suggest wrong snippet in closure)
 - #67250 (Remove the `DelimSpan` from `NamedMatch::MatchedSeq`.)
 - #67251 (Require `allow_internal_unstable` for stable min_const_fn using unsta…)
 - #67269 (parser: recover on `&'lifetime mut? $pat`.)

Failed merges:

r? @ghost

4 years agoRollup merge of #67269 - Centril:recover-lt-deref-pat, r=estebank
Mazdak Farrokhzad [Fri, 13 Dec 2019 03:21:34 +0000 (04:21 +0100)]
Rollup merge of #67269 - Centril:recover-lt-deref-pat, r=estebank

parser: recover on `&'lifetime mut? $pat`.

r? @estebank

4 years agoRollup merge of #67251 - oli-obk:stability_sieve, r=Centril
Mazdak Farrokhzad [Fri, 13 Dec 2019 03:21:33 +0000 (04:21 +0100)]
Rollup merge of #67251 - oli-obk:stability_sieve, r=Centril

Require `allow_internal_unstable` for stable min_const_fn using unsta…

…ble features

r? @Centril

cc @ecstatic-morse @RalfJung

4 years agoRollup merge of #67250 - nnethercote:rm-DelimSpan-from-NamedMatch-MatchedSeq, r=Centril
Mazdak Farrokhzad [Fri, 13 Dec 2019 03:21:31 +0000 (04:21 +0100)]
Rollup merge of #67250 - nnethercote:rm-DelimSpan-from-NamedMatch-MatchedSeq, r=Centril

Remove the `DelimSpan` from `NamedMatch::MatchedSeq`.

Because it's unused. This then allows the removal of
`MatcherPos::sp_open`. It's a tiny perf win, reducing instruction counts
by 0.1% - 0.2% on a few benchmarks.

r? @Centril

4 years agoRollup merge of #67247 - JohnTitor:fix-sugg, r=estebank
Mazdak Farrokhzad [Fri, 13 Dec 2019 03:21:30 +0000 (04:21 +0100)]
Rollup merge of #67247 - JohnTitor:fix-sugg, r=estebank

Don't suggest wrong snippet in closure

Fixes #67190

r? @estebank

4 years agoRollup merge of #67243 - jonas-schievink:linkedlist-drop, r=KodrAus
Mazdak Farrokhzad [Fri, 13 Dec 2019 03:21:27 +0000 (04:21 +0100)]
Rollup merge of #67243 - jonas-schievink:linkedlist-drop, r=KodrAus

LinkedList: drop remaining items when drop panics

https://github.com/rust-lang/rust/pull/67235, but for `LinkedList`, which has the same issue.

I've also copied over the other drop-related tests from `VecDeque` since AFAICT `LinkedList` didn't have any.

4 years agoRollup merge of #66341 - crgl:vec-deque-extend, r=Amanieu
Mazdak Farrokhzad [Fri, 13 Dec 2019 03:21:22 +0000 (04:21 +0100)]
Rollup merge of #66341 - crgl:vec-deque-extend, r=Amanieu

Match `VecDeque::extend` to `Vec::extend_desugared`

Currently, `VecDeque::extend` [does not reserve at all](https://github.com/rust-lang/rust/pull/65069#discussion_r333166522). This implementation still runs a check every iteration of the loop, but should reallocate at most once for the common cases where the `size_hint` lower bound is exact. Further optimizations in the future could improve this for some common cases, but given the complexity of the `Vec::extend` implementation it's not immediately clear that this would be worthwhile.

4 years agoparser: recover on `&'lifetime mut $pat`.
Mazdak Farrokhzad [Thu, 12 Dec 2019 23:59:33 +0000 (00:59 +0100)]
parser: recover on `&'lifetime mut $pat`.

4 years agoAvoid re-processing nodes in `find_cycles_from_node`.
Nicholas Nethercote [Mon, 9 Dec 2019 03:51:59 +0000 (14:51 +1100)]
Avoid re-processing nodes in `find_cycles_from_node`.

4 years agoRemove an unnecessary local variable.
Nicholas Nethercote [Fri, 6 Dec 2019 02:41:07 +0000 (13:41 +1100)]
Remove an unnecessary local variable.

4 years agoRemove some `debug!` statements.
Nicholas Nethercote [Fri, 6 Dec 2019 02:37:35 +0000 (13:37 +1100)]
Remove some `debug!` statements.

Because I am tired of looking at them.

4 years agoMove functions around.
Nicholas Nethercote [Fri, 6 Dec 2019 02:31:40 +0000 (13:31 +1100)]
Move functions around.

In particular, it has bugged me for some time that `process_cycles` is
currently located before `mark_still_waiting_nodes` despite being called
afterwards.

4 years agoRemove `NodeState::{Waiting,Done}`.
Nicholas Nethercote [Tue, 12 Nov 2019 21:35:52 +0000 (08:35 +1100)]
Remove `NodeState::{Waiting,Done}`.

`NodeState` has two states, `Success` and `Done`, that are only used
within `ObligationForest` methods. This commit removes them, and renames
the existing `Waiting` state as `Success`.

We are left with three states: `Pending`, `Success`, and `Error`.
`Success` is augmented with a new `WaitingState`, which indicates when
(if ever) it was last waiting on one or more `Pending` nodes. This
notion of "when" requires adding a "process generation" to
`ObligationForest`; it is incremented on each call to
`process_obligtions`.

This commit is a performance win.

- Most of the benefit comes from `mark_as_waiting` (which the commit
  renames as `mark_still_waiting_nodes`). This function used to do two
  things: (a) change all `Waiting` nodes to `Success`, and (b) mark all
  nodes that depend on a pending node as `Waiting`. In practice, many
  nodes went from `Waiting` to `Success` and then immediately back to
  `Waiting`. The use of generations lets us skip step (a).

- A smaller benefit comes from not having to change nodes to the `Done`
  state in `process_cycles`.

4 years agoreplace serialize with serde in rustdoc
Andy Russell [Sat, 29 Jun 2019 17:30:45 +0000 (13:30 -0400)]
replace serialize with serde in rustdoc

4 years agoAuto merge of #67172 - jethrogb:jb/bootstrap-linker, r=alexcrichton
bors [Thu, 12 Dec 2019 19:52:27 +0000 (19:52 +0000)]
Auto merge of #67172 - jethrogb:jb/bootstrap-linker, r=alexcrichton

Bootstrap: change logic for choosing linker and rpath

This is a follow-up from #66957 and #67023. Apparently there was one more location with a hard-coded list of targets to influence linking.

I've filed #67171 to track this madness.

r? @alexcrichton

4 years agoRemove i686-unknown-dragonfly target
Antonio Huete Jimenez [Thu, 12 Dec 2019 15:19:37 +0000 (16:19 +0100)]
Remove i686-unknown-dragonfly target

4 years agoFix weird implicit dependency between rustllvm and rustc_codegen_llvm
Aaron Hill [Thu, 12 Dec 2019 15:51:19 +0000 (10:51 -0500)]
Fix weird implicit dependency between rustllvm and rustc_codegen_llvm

rustllvm relies on the `LLVMRustStringWriteImpl` symbol existing, but
this symbol was previously defined in a *downstream* crate
(rustc_codegen_llvm, which depends on rustc_llvm.

While this somehow worked under the old 'separate bootstrap step for
codegen' scheme, it meant that rustc_llvm could not actually be built by
itself, since it relied linking to the downstream rustc_codegen_llvm
crate.

Now that librustc_codegen_llvm is just a normal crate, we actually try
to build a standalone rustc_llvm when we run tests. This commit moves
`LLVMRustStringWriteImpl` into rustc_llvm (technically the rustllvm
directory, which has its contents built by rustc_llvm). This ensures
that we can build each crate in the graph by itself, without requiring
that any downstream crates be linked in as well.

4 years agoavoid more intermediate allocations in validation errors
Ralf Jung [Thu, 12 Dec 2019 15:48:46 +0000 (16:48 +0100)]
avoid more intermediate allocations in validation errors

4 years agovalidation: avoid some intermediate allocations
Ralf Jung [Thu, 12 Dec 2019 14:23:46 +0000 (15:23 +0100)]
validation: avoid some intermediate allocations

4 years agoAuto merge of #66886 - mark-i-m:simplify-borrow_check-2, r=matthewjasper
bors [Thu, 12 Dec 2019 15:04:36 +0000 (15:04 +0000)]
Auto merge of #66886 - mark-i-m:simplify-borrow_check-2, r=matthewjasper

Remove the borrow check::nll submodule

NLL is the only borrow checker now, so no need to have a separate submodule.

@rustbot modify labels: +S-blocked

Waiting on #66815

4 years agodont ICE in case of invalid drop fn
Ralf Jung [Thu, 12 Dec 2019 14:23:27 +0000 (15:23 +0100)]
dont ICE in case of invalid drop fn

4 years agoAuto merge of #67079 - nnethercote:optimize-shallow_resolve_changed, r=nikomatsakis
bors [Thu, 12 Dec 2019 11:51:26 +0000 (11:51 +0000)]
Auto merge of #67079 - nnethercote:optimize-shallow_resolve_changed, r=nikomatsakis

Optimize `shallow_resolve_changed`

r? @nikomatsakis

4 years agoRequire `allow_internal_unstable` for stable min_const_fn using unstable features
Oliver Scherer [Thu, 12 Dec 2019 09:22:09 +0000 (10:22 +0100)]
Require `allow_internal_unstable` for stable min_const_fn using unstable features

4 years agoRemove the `DelimSpan` from `NamedMatch::MatchedSeq`.
Nicholas Nethercote [Thu, 12 Dec 2019 04:48:30 +0000 (15:48 +1100)]
Remove the `DelimSpan` from `NamedMatch::MatchedSeq`.

Because it's unused. This then allows the removal of
`MatcherPos::sp_open`. It's a tiny perf win, reducing instruction counts
by 0.1% - 0.2% on a few benchmarks.

4 years agofix imports after rebase
Mark Mansi [Mon, 9 Dec 2019 18:24:47 +0000 (12:24 -0600)]
fix imports after rebase

4 years agomore private
Mark Mansi [Fri, 6 Dec 2019 16:02:48 +0000 (10:02 -0600)]
more private

4 years agofix imports
Mark Mansi [Thu, 5 Dec 2019 18:00:40 +0000 (12:00 -0600)]
fix imports

4 years agotidy
Mark Mansi [Sat, 30 Nov 2019 02:05:29 +0000 (20:05 -0600)]
tidy

4 years agofix imports
Mark Mansi [Sat, 30 Nov 2019 01:48:29 +0000 (19:48 -0600)]
fix imports

4 years agoget rid of nll submod
Mark Mansi [Sat, 30 Nov 2019 01:05:44 +0000 (19:05 -0600)]
get rid of nll submod

4 years agoDon't suggest wrong snippet in closure
Yuki Okushi [Wed, 11 Dec 2019 14:04:29 +0000 (23:04 +0900)]
Don't suggest wrong snippet in closure

4 years agoAuto merge of #67246 - JohnTitor:rollup-nfa7skn, r=JohnTitor
bors [Thu, 12 Dec 2019 02:11:31 +0000 (02:11 +0000)]
Auto merge of #67246 - JohnTitor:rollup-nfa7skn, r=JohnTitor

Rollup of 8 pull requests

Successful merges:

 - #62514 (Clarify `Box<T>` representation and its use in FFI)
 - #66983 (Fix `unused_parens` triggers on macro by example code)
 - #67215 (Fix `-Z print-type-sizes`'s handling of zero-sized fields.)
 - #67230 (Remove irelevant comment on `register_dtor`)
 - #67236 (resolve: Always resolve visibilities on impl items)
 - #67237 (Some small readability improvements)
 - #67238 (Small std::borrow::Cow improvements)
 - #67239 (Make TinyList::remove iterate instead of recurse)

Failed merges:

r? @ghost

4 years agoAdd more context for type parameters
Esteban Küber [Thu, 12 Dec 2019 01:06:24 +0000 (17:06 -0800)]
Add more context for type parameters

4 years agoRollup merge of #67239 - llogiq:tiny-list-iterative-remove, r=Mark-Simulacrum
Yuki Okushi [Thu, 12 Dec 2019 01:09:29 +0000 (10:09 +0900)]
Rollup merge of #67239 - llogiq:tiny-list-iterative-remove, r=Mark-Simulacrum

Make TinyList::remove iterate instead of recurse

Most of the diff is from from rustfmt, the actual change is in line 91..79 (or 79..89 in the "after" diff).

I had converted the other methods to iterate instead of recurse already, so this is the last recursive function on `TinyList`.

4 years agoRollup merge of #67238 - llogiq:moo-and-improved, r=Dylan-DPC
Yuki Okushi [Thu, 12 Dec 2019 01:09:28 +0000 (10:09 +0900)]
Rollup merge of #67238 - llogiq:moo-and-improved, r=Dylan-DPC

Small std::borrow::Cow improvements

This is a small set of improvements (+ one more tested code path) for `Cow`.

4 years agoRollup merge of #67237 - llogiq:improve-str, r=Dylan-DPC
Yuki Okushi [Thu, 12 Dec 2019 01:09:26 +0000 (10:09 +0900)]
Rollup merge of #67237 - llogiq:improve-str, r=Dylan-DPC

Some small readability improvements

4 years agoRollup merge of #67236 - petrochenkov:docerr2, r=matthewjasper
Yuki Okushi [Thu, 12 Dec 2019 01:09:24 +0000 (10:09 +0900)]
Rollup merge of #67236 - petrochenkov:docerr2, r=matthewjasper

resolve: Always resolve visibilities on impl items

Fixes https://github.com/rust-lang/rust/issues/64705.

Similarly to https://github.com/rust-lang/rust/pull/67106 this was an issue with visitor discipline.
Impl items were visited as a part of visiting `ast::ItemKind::Impl`, but they should be visit-able in isolation  from their parents as well, because that's how they are visited when they are expanded from macros.

I've checked that all the remaining `resolve_visibility` calls are used correctly.

r? @matthewjasper

4 years agoRollup merge of #67230 - chansuke:remove-irrelevant-passage, r=Dylan-DPC
Yuki Okushi [Thu, 12 Dec 2019 01:09:23 +0000 (10:09 +0900)]
Rollup merge of #67230 - chansuke:remove-irrelevant-passage, r=Dylan-DPC

Remove irelevant comment on `register_dtor`

Fixes #66572.

4 years agoRollup merge of #67215 - nnethercote:fix-Zprint-type-size-zero-sized-fields, r=pnkfelix
Yuki Okushi [Thu, 12 Dec 2019 01:09:21 +0000 (10:09 +0900)]
Rollup merge of #67215 - nnethercote:fix-Zprint-type-size-zero-sized-fields, r=pnkfelix

Fix `-Z print-type-sizes`'s handling of zero-sized fields.

Currently, the type `struct S { x: u32, y: u32, tag: () }` is
incorrectly described like this:
```
print-type-size type: `S`: 8 bytes, alignment: 4 bytes
print-type-size     field `.x`: 4 bytes
print-type-size     field `.tag`: 0 bytes, offset: 0 bytes, alignment: 1 bytes
print-type-size     padding: 4 bytes
print-type-size     field `.y`: 4 bytes, alignment: 4 bytes
```
Specifically:
- The `padding` line is wrong. (There is no padding.)
- The `offset` and `alignment` on the `.tag` line shouldn't be printed.

The problem is that multiple fields can end up with the same offset, and
the printing code doesn't handle this correctly.

This commit fixes it by adjusting the field sorting so that zero-sized fields
are dealt with before non-zero-sized fields. With that in place, the
printing code works correctly.

The commit also corrects the "something is very wrong" comment.

The new output looks like this:
```
print-type-size type: `S`: 8 bytes, alignment: 4 bytes
print-type-size     field `.tag`: 0 bytes
print-type-size     field `.x`: 4 bytes
print-type-size     field `.y`: 4 bytes
```
r? @pnkfelix

4 years agoRollup merge of #66983 - weiznich:bugfix/issue_66295, r=estebank
Yuki Okushi [Thu, 12 Dec 2019 01:09:19 +0000 (10:09 +0900)]
Rollup merge of #66983 - weiznich:bugfix/issue_66295, r=estebank

Fix `unused_parens` triggers on macro by example code

Fix #66295

Unfortunately this does also break [an existing test](https://github.com/rust-lang/rust/blob/4787e97475de6be9487e3d9255a9c2d3c0bf9252/src/test/ui/lint/issue-47775-nested-macro-unnecessary-parens-arg.rs#L22). I'm not sure how to handle that, because that seems to be quite similar to the allowed cases

If this gets accepted it would be great to backport this fix to beta.

4 years agoRollup merge of #62514 - stephaneyfx:box-ffi, r=nikomatsakis
Yuki Okushi [Thu, 12 Dec 2019 01:09:15 +0000 (10:09 +0900)]
Rollup merge of #62514 - stephaneyfx:box-ffi, r=nikomatsakis

Clarify `Box<T>` representation and its use in FFI

This officializes what was only shown as a code example in [the unsafe code guidelines](https://rust-lang.github.io/unsafe-code-guidelines/layout/function-pointers.html?highlight=box#use) and follows [the discussion](https://github.com/rust-lang/unsafe-code-guidelines/issues/157) in the corresponding repository.

It is also related to [the issue](https://github.com/rust-lang/rust/issues/52976) regarding marking `Box<T>` `#[repr(transparent)]`.

If the statement this PR adds is incorrect or a more in-depth discussion is warranted, I apologize. Should it be the case, the example in the unsafe code guidelines should be amended and some document should make it clear that it is not sound/supported.

4 years agoAdd comment to `Dropper`
Jonas Schievink [Wed, 11 Dec 2019 23:39:29 +0000 (00:39 +0100)]
Add comment to `Dropper`

4 years agoReuse existing HirId → DefId table
Esteban Küber [Wed, 11 Dec 2019 23:33:45 +0000 (15:33 -0800)]
Reuse existing HirId → DefId table

4 years agoLinkedList: drop remaining items when drop panics
Jonas Schievink [Wed, 11 Dec 2019 23:14:09 +0000 (00:14 +0100)]
LinkedList: drop remaining items when drop panics