]> git.lizzy.rs Git - rust.git/log
rust.git
3 years agoMove const tests for `Option` to `library\core`
Christiaan Dirkx [Thu, 3 Sep 2020 22:13:25 +0000 (00:13 +0200)]
Move const tests for `Option` to `library\core`

Part of #76268

3 years agoStabilize some Option methods as const
CDirkx [Mon, 31 Aug 2020 00:11:48 +0000 (02:11 +0200)]
Stabilize some Option methods as const

Stabilize the following methods of `Option` as const:
 - `is_some`
 - `is_none`
 - `as_ref`

Possible because of stabilization of #49146 (Allow if and match in constants).

3 years agoAuto merge of #76975 - RalfJung:rollup-s2wiuqr, r=RalfJung
bors [Sun, 20 Sep 2020 15:12:40 +0000 (15:12 +0000)]
Auto merge of #76975 - RalfJung:rollup-s2wiuqr, r=RalfJung

Rollup of 15 pull requests

Successful merges:

 - #76732 (Add docs for `BasicBlock`)
 - #76832 (Let backends define custom targets)
 - #76866 (Remove unused feature gates from library/ crates)
 - #76875 (Move to intra-doc links in library/alloc/src/collections/binary_heap.rs)
 - #76876 (Move to intra-doc links in collections/btree/map.rs and collections/linked_list.rs)
 - #76877 (Move to intra-doc links in collections/vec_deque.rs and collections/vec_deque/drain.rs)
 - #76878 (Move the version number to a plaintext file)
 - #76883 (README.md: Remove prompts from code blocks)
 - #76887 (Add missing examples on HashSet iter types)
 - #76890 (use matches!() macro for simple if let conditions)
 - #76891 (don't take `TyCtxt` by reference)
 - #76910 (transmute: use diagnostic item)
 - #76924 (Add tracking issue for feature(unix_socket_peek))
 - #76926 (BTreeMap: code readability tweaks)
 - #76940 (Don't allow implementing trait directly on type-alias-impl-trait)

Failed merges:

r? `@ghost`

3 years agoRollup merge of #76940 - Aaron1011:fix/trait-on-tait, r=oli-obk
Ralf Jung [Sun, 20 Sep 2020 13:52:09 +0000 (15:52 +0200)]
Rollup merge of #76940 - Aaron1011:fix/trait-on-tait, r=oli-obk

Don't allow implementing trait directly on type-alias-impl-trait

This is specifically disallowed by the RFC, but we never added a check
for it.

Fixes #76202

3 years agoRollup merge of #76926 - ssomers:btree_cleanup_1, r=Mark-Simulacrum
Ralf Jung [Sun, 20 Sep 2020 13:52:07 +0000 (15:52 +0200)]
Rollup merge of #76926 - ssomers:btree_cleanup_1, r=Mark-Simulacrum

BTreeMap: code readability tweaks

Gathered over the past months

r? @Mark-Simulacrum

3 years agoRollup merge of #76924 - rijenkii:patch-1, r=oli-obk
Ralf Jung [Sun, 20 Sep 2020 13:52:06 +0000 (15:52 +0200)]
Rollup merge of #76924 - rijenkii:patch-1, r=oli-obk

Add tracking issue for feature(unix_socket_peek)

Feature was added in #73761

3 years agoRollup merge of #76910 - lcnr:foreign-item-like, r=oli-obk
Ralf Jung [Sun, 20 Sep 2020 13:52:04 +0000 (15:52 +0200)]
Rollup merge of #76910 - lcnr:foreign-item-like, r=oli-obk

transmute: use diagnostic item

closes #66075, we now have no remaining uses of `match_def_path`  in the compiler while some uses still remain in `clippy`.

cc @RalfJung

3 years agoRollup merge of #76891 - lcnr:less-ref, r=ecstatic-morse
Ralf Jung [Sun, 20 Sep 2020 13:52:03 +0000 (15:52 +0200)]
Rollup merge of #76891 - lcnr:less-ref, r=ecstatic-morse

don't take `TyCtxt` by reference

small cleanup

3 years agoRollup merge of #76890 - matthiaskrgr:matches_simpl, r=lcnr
Ralf Jung [Sun, 20 Sep 2020 13:52:01 +0000 (15:52 +0200)]
Rollup merge of #76890 - matthiaskrgr:matches_simpl, r=lcnr

use matches!() macro for simple if let conditions

3 years agoRollup merge of #76887 - GuillaumeGomez:hashset-iter-types-examples, r=Dylan-DPC
Ralf Jung [Sun, 20 Sep 2020 13:51:59 +0000 (15:51 +0200)]
Rollup merge of #76887 - GuillaumeGomez:hashset-iter-types-examples, r=Dylan-DPC

Add missing examples on HashSet iter types

3 years agoRollup merge of #76883 - qlcom:master, r=Mark-Simulacrum
Ralf Jung [Sun, 20 Sep 2020 13:51:58 +0000 (15:51 +0200)]
Rollup merge of #76883 - qlcom:master, r=Mark-Simulacrum

README.md: Remove prompts from code blocks

https://github.com/rust-lang/rust/issues/76863

3 years agoRollup merge of #76878 - pietroalbini:version, r=Mark-Simulacrum
Ralf Jung [Sun, 20 Sep 2020 13:51:56 +0000 (15:51 +0200)]
Rollup merge of #76878 - pietroalbini:version, r=Mark-Simulacrum

Move the version number to a plaintext file

The Rust version number is currently embedded in bootstrap's source code, which makes it hard to update it automatically or access it outside of ./x.py (as you'd have to parse the source code).

This PR moves the version number to a standalone plaintext file, which makes accessing or updating it trivial.

r? @Mark-Simulacrum

3 years agoRollup merge of #76877 - denisvasilik:intra-doc-links-alloc-vec-deque, r=jyn514
Ralf Jung [Sun, 20 Sep 2020 13:51:54 +0000 (15:51 +0200)]
Rollup merge of #76877 - denisvasilik:intra-doc-links-alloc-vec-deque, r=jyn514

Move to intra-doc links in collections/vec_deque.rs and collections/vec_deque/drain.rs

Helps with #75080.

@rustbot modify labels: T-doc, A-intra-doc-links

3 years agoRollup merge of #76876 - denisvasilik:intra-doc-links-alloc, r=jyn514
Ralf Jung [Sun, 20 Sep 2020 13:51:53 +0000 (15:51 +0200)]
Rollup merge of #76876 - denisvasilik:intra-doc-links-alloc, r=jyn514

Move to intra-doc links in collections/btree/map.rs and collections/linked_list.rs

Helps with #75080.

@rustbot modify labels: T-doc, A-intra-doc-links

3 years agoRollup merge of #76875 - denisvasilik:intra-doc-links-alloc-binary-heap, r=jyn514
Ralf Jung [Sun, 20 Sep 2020 13:51:51 +0000 (15:51 +0200)]
Rollup merge of #76875 - denisvasilik:intra-doc-links-alloc-binary-heap, r=jyn514

Move to intra-doc links in library/alloc/src/collections/binary_heap.rs

Helps with #75080.

@rustbot modify labels: T-doc, A-intra-doc-links

3 years agoRollup merge of #76866 - est31:master, r=lcnr
Ralf Jung [Sun, 20 Sep 2020 13:51:50 +0000 (15:51 +0200)]
Rollup merge of #76866 - est31:master, r=lcnr

Remove unused feature gates from library/ crates

Removes some unused feature gates from library crates. It's likely not a complete list as I only tested a subset for which it's more likely that it is unused.

3 years agoRollup merge of #76832 - khyperia:backend_target_override, r=eddyb
Ralf Jung [Sun, 20 Sep 2020 13:51:48 +0000 (15:51 +0200)]
Rollup merge of #76832 - khyperia:backend_target_override, r=eddyb

Let backends define custom targets

Add a target_override hook that takes priority over builtin targets.

3 years agoRollup merge of #76732 - camelid:mir-basic-block-docs, r=RalfJung
Ralf Jung [Sun, 20 Sep 2020 13:51:46 +0000 (15:51 +0200)]
Rollup merge of #76732 - camelid:mir-basic-block-docs, r=RalfJung

Add docs for `BasicBlock`

Fixes #76715.

---

@rustbot modify labels: A-mir T-doc C-enhancement

3 years agoAuto merge of #76136 - CDirkx:const-result, r=dtolnay
bors [Sun, 20 Sep 2020 13:07:11 +0000 (13:07 +0000)]
Auto merge of #76136 - CDirkx:const-result, r=dtolnay

Stabilize some Result methods as const

Stabilize the following methods of Result as const:
 - `is_ok`
 - `is_err`
 - `as_ref`

A test is also included, analogous to the test for `const_option`.

These methods are currently const under the unstable feature `const_result` (tracking issue: #67520).
I believe these methods to be eligible for stabilization because of the stabilization of #49146 (Allow if and match in constants) and the trivial implementations, see also: [PR#75463](https://github.com/rust-lang/rust/pull/75463) and [PR#76135](https://github.com/rust-lang/rust/pull/76135).

Note: these methods are the only methods currently under the `const_result` feature, thus this PR results in the removal of the feature.

Related: #76225

3 years agoAuto merge of #76964 - RalfJung:rollup-ybn06fs, r=RalfJung
bors [Sun, 20 Sep 2020 11:02:36 +0000 (11:02 +0000)]
Auto merge of #76964 - RalfJung:rollup-ybn06fs, r=RalfJung

Rollup of 15 pull requests

Successful merges:

 - #76722 (Test and fix Send and Sync traits of BTreeMap artefacts)
 - #76766 (Extract some intrinsics out of rustc_codegen_llvm)
 - #76800 (Don't generate bootstrap usage unless it's needed)
 - #76809 (simplfy condition in ItemLowerer::with_trait_impl_ref())
 - #76815 (Fix wording in mir doc)
 - #76818 (Don't compile regex at every function call.)
 - #76821 (Remove redundant nightly features)
 - #76823 (black_box: silence unused_mut warning when building with cfg(miri))
 - #76825 (use `array_windows` instead of `windows` in the compiler)
 - #76827 (fix array_windows docs)
 - #76828 (use strip_prefix over starts_with and manual slicing based on pattern length (clippy::manual_strip))
 - #76840 (Move to intra doc links in core/src/future)
 - #76845 (Use intra docs links in core::{ascii, option, str, pattern, hash::map})
 - #76853 (Use intra-doc links in library/core/src/task/wake.rs)
 - #76871 (support panic=abort in Miri)

Failed merges:

r? `@ghost`

3 years agoUpdate src/tools/clippy/clippy_lints/src/matches.rs
CDirkx [Sun, 20 Sep 2020 10:21:23 +0000 (12:21 +0200)]
Update src/tools/clippy/clippy_lints/src/matches.rs

Co-authored-by: Ralf Jung <post@ralfj.de>
3 years agoRollup merge of #76871 - RalfJung:miri-panic-abort, r=dtolnay
Ralf Jung [Sun, 20 Sep 2020 10:08:36 +0000 (12:08 +0200)]
Rollup merge of #76871 - RalfJung:miri-panic-abort, r=dtolnay

support panic=abort in Miri

This is needed for https://github.com/rust-lang/miri/issues/1058 on Windows: we cannot run the inline-assembly versions of `abort`, so fall back to the intrinsic (which Miri supports).

3 years agoRollup merge of #76853 - denisvasilik:intra-doc-links-core-wake, r=jyn514
Ralf Jung [Sun, 20 Sep 2020 10:08:34 +0000 (12:08 +0200)]
Rollup merge of #76853 - denisvasilik:intra-doc-links-core-wake, r=jyn514

Use intra-doc links in library/core/src/task/wake.rs

Helps with #75080.

@rustbot modify labels: T-doc, A-intra-doc-links

3 years agoRollup merge of #76845 - Amjad50:fix-intra-docs-links, r=jyn514
Ralf Jung [Sun, 20 Sep 2020 10:08:33 +0000 (12:08 +0200)]
Rollup merge of #76845 - Amjad50:fix-intra-docs-links, r=jyn514

Use intra docs links in core::{ascii, option, str, pattern, hash::map}

Partial fix for #75080

@rustbot modify labels: T-doc A-intra-doc-links

r? @jyn514

3 years agoRollup merge of #76840 - poliorcetics:intra-doc-core-sync-and-future, r=jyn514
Ralf Jung [Sun, 20 Sep 2020 10:08:31 +0000 (12:08 +0200)]
Rollup merge of #76840 - poliorcetics:intra-doc-core-sync-and-future, r=jyn514

Move to intra doc links in core/src/future

Helps with #75080.

@rustbot modify labels: T-doc A-intra-doc-links

r? @jyn514

3 years agoRollup merge of #76828 - matthiaskrgr:clippy_manual_strip, r=lcnr
Ralf Jung [Sun, 20 Sep 2020 10:08:29 +0000 (12:08 +0200)]
Rollup merge of #76828 - matthiaskrgr:clippy_manual_strip, r=lcnr

use strip_prefix over starts_with and manual slicing based on pattern length (clippy::manual_strip)

3 years agoRollup merge of #76827 - lcnr:array_windows-docs, r=jonas-schievink
Ralf Jung [Sun, 20 Sep 2020 10:08:27 +0000 (12:08 +0200)]
Rollup merge of #76827 - lcnr:array_windows-docs, r=jonas-schievink

fix array_windows docs

r? @Dylan-DPC

3 years agoRollup merge of #76825 - lcnr:array-windows-apply, r=varkor
Ralf Jung [Sun, 20 Sep 2020 10:08:26 +0000 (12:08 +0200)]
Rollup merge of #76825 - lcnr:array-windows-apply, r=varkor

use `array_windows` instead of `windows` in the compiler

I do think these changes are beautiful, but do have to admit that using type inference for the window length
can easily be confusing. This seems like a general issue with const generics, where inferring constants adds an additional
complexity which users have to learn and keep in mind.

3 years agoRollup merge of #76823 - RalfJung:black-box-warn, r=joshtriplett
Ralf Jung [Sun, 20 Sep 2020 10:08:24 +0000 (12:08 +0200)]
Rollup merge of #76823 - RalfJung:black-box-warn, r=joshtriplett

black_box: silence unused_mut warning when building with cfg(miri)

3 years agoRollup merge of #76821 - est31:remove_redundant_nightly_features, r=oli-obk,Mark...
Ralf Jung [Sun, 20 Sep 2020 10:08:22 +0000 (12:08 +0200)]
Rollup merge of #76821 - est31:remove_redundant_nightly_features, r=oli-obk,Mark-Simulacrum

Remove redundant nightly features

Removes a bunch of redundant/outdated nightly features. The first commit removes a `core_intrinsics` use for which a stable wrapper has been provided since. The second commit replaces the `const_generics` feature with `min_const_generics` which might get stabilized this year. The third commit is the result of a trial/error run of removing every single feature and then adding it back if compile failed. A bunch of unused features are the result that the third commit removes.

3 years agoRollup merge of #76818 - hbina:dont_compile_regex_all_the_time, r=ecstatic-morse
Ralf Jung [Sun, 20 Sep 2020 10:08:20 +0000 (12:08 +0200)]
Rollup merge of #76818 - hbina:dont_compile_regex_all_the_time, r=ecstatic-morse

Don't compile regex at every function call.

Use `SyncOnceCell` to only compile it once.
I believe this still adds some kind of locking mechanism?

Related issue: https://github.com/rust-lang/rust/issues/76817

3 years agoRollup merge of #76815 - pickfire:patch-6, r=jonas-schievink
Ralf Jung [Sun, 20 Sep 2020 10:08:19 +0000 (12:08 +0200)]
Rollup merge of #76815 - pickfire:patch-6, r=jonas-schievink

Fix wording in mir doc

3 years agoRollup merge of #76809 - matthiaskrgr:simplify_cond, r=varkor
Ralf Jung [Sun, 20 Sep 2020 10:08:17 +0000 (12:08 +0200)]
Rollup merge of #76809 - matthiaskrgr:simplify_cond, r=varkor

simplfy condition in ItemLowerer::with_trait_impl_ref()

3 years agoRollup merge of #76800 - jyn514:usage, r=Mark-Simulacrum
Ralf Jung [Sun, 20 Sep 2020 10:08:15 +0000 (12:08 +0200)]
Rollup merge of #76800 - jyn514:usage, r=Mark-Simulacrum

Don't generate bootstrap usage unless it's needed

Previously, `x.py` would unconditionally run `x.py build` to get the
help message. After https://github.com/rust-lang/rust/issues/76165,
when checking the CI stage was moved into `Config`, that would cause an
assertion failure (but only only in CI!):

```
thread 'main' panicked at 'assertion failed: `(left == right)`
  left: `1`,
 right: `2`', src/bootstrap/config.rs:619:49
```

This changes bootstrap to only generate a help message when it needs
to (when someone passes `--help`).

r? @Mark-Simulacrum
This should fix the CI failures in https://github.com/rust-lang/rust/pull/76797 and https://github.com/rust-lang/rust/pull/75991.

3 years agoRollup merge of #76766 - khyperia:generic_intrinsics, r=eddyb
Ralf Jung [Sun, 20 Sep 2020 10:08:13 +0000 (12:08 +0200)]
Rollup merge of #76766 - khyperia:generic_intrinsics, r=eddyb

Extract some intrinsics out of rustc_codegen_llvm

A significant amount of intrinsics do not actually need backend-specific behaviors to be implemented, instead relying on methods already in rustc_codegen_ssa. So, extract those methods out to rustc_codegen_ssa, so that each backend doesn't need to reimplement the same code.

Almost everything should be a pretty direct translation. A notable not-direct-translation is `add_with_overflow` and friends being changed to `bx.checked_binop`, but it's pretty simple.

I could have been a lot more aggressive here and pulled out way more methods, and add a few new methods in the rustc_codegen_ssa "API". However, because this is my second rustc PR, I thought that moving those to a follow-up PR and doing more incremental changes here would be better (and I guess ask if this work is even desired in the first place). I'm hoping to eventually remove the mess of intrinsic handling in the backend entirely, which would be hecking fantastic :sparkles:

3 years agoRollup merge of #76722 - ssomers:btree_send_sync, r=Mark-Simulacrum
Ralf Jung [Sun, 20 Sep 2020 10:08:12 +0000 (12:08 +0200)]
Rollup merge of #76722 - ssomers:btree_send_sync, r=Mark-Simulacrum

Test and fix Send and Sync traits of BTreeMap artefacts

Fixes #76686.

I'm not quite sure what all this implies. E.g. comparing with the definitions for `NodeRef` in node.rs,  maybe an extra bound `T: 'a` is useful for something. The test compiles on stable/beta (apart from `drain_filter`) so I bet `Sync` is equally desirable.

r? @Mark-Simulacrum

3 years agoAuto merge of #74949 - oli-obk:validate_const_eval_raw, r=RalfJung
bors [Sun, 20 Sep 2020 08:58:32 +0000 (08:58 +0000)]
Auto merge of #74949 - oli-obk:validate_const_eval_raw, r=RalfJung

Validate constants during `const_eval_raw`

This PR implements the groundwork for https://github.com/rust-lang/rust/issues/72396

* constants are now validated during `const_eval_raw`
* to prevent cycle errors, we do not validate references to statics anymore beyond the fact that they are not dangling
* the `const_eval` query ICEs if used on `static` items
* as a side effect promoteds are now evaluated to `ConstValue::Scalar` again (since they are just a reference to the actual promoted allocation in most cases).

3 years agoRemove `can_suggest` check for `is_ok` and `is_err`.
Christiaan Dirkx [Sun, 20 Sep 2020 08:46:30 +0000 (10:46 +0200)]
Remove `can_suggest` check for `is_ok` and `is_err`.

`is_ok` and `is_err` are stabilized as const and can thus always be suggested.

3 years agoMake codegen test bitwidth-independent
Oliver Scherer [Sun, 20 Sep 2020 07:09:56 +0000 (09:09 +0200)]
Make codegen test bitwidth-independent

3 years agoAuto merge of #76411 - RalfJung:promote-in-const-fn, r=ecstatic-morse
bors [Sun, 20 Sep 2020 06:20:16 +0000 (06:20 +0000)]
Auto merge of #76411 - RalfJung:promote-in-const-fn, r=ecstatic-morse

Some promotion cleanup

Based on top of both https://github.com/rust-lang/rust/pull/75502 and https://github.com/rust-lang/rust/pull/75585, this does some cleanup of the promotion code. The last 2 commits are new.

* Remove the remaining cases where `const fn` is treated different from `fn`. This means no longer promoting ptr-to-int casts, raw ptr operations, and union field accesses in `const fn` -- or anywhere, for that matter. These are all unstable in const-context so this should not break any stable code. Fixes https://github.com/rust-lang/rust/issues/75586.
* ~~Promote references to statics even outside statics (i.e., in functions) for consistency.~~
* Promote `&mut []` everywhere, not just in non-`const` functions, for consistency.
* Explain why we do not promote deref's of statics outside statics. ~~(This is the only remaining direct user of `const_kind`.)~~

This can only land once the other two PRs land; I am mostly putting this up already because I couldn't wait ;) and to get some feedback from `@rust-lang/wg-const-eval` .

3 years agoarray pattern
Bastian Kauschke [Thu, 17 Sep 2020 08:01:24 +0000 (10:01 +0200)]
array pattern

3 years agouse `array_windows` instead of `windows` in the compiler
Bastian Kauschke [Thu, 17 Sep 2020 07:28:14 +0000 (09:28 +0200)]
use `array_windows` instead of `windows` in the compiler

3 years agoAuto merge of #75346 - davidtwco:issue-69925-polymorphic-instancedef-fnptrshim, r...
bors [Sun, 20 Sep 2020 04:15:43 +0000 (04:15 +0000)]
Auto merge of #75346 - davidtwco:issue-69925-polymorphic-instancedef-fnptrshim, r=nikomatsakis

shim: monomorphic `FnPtrShim`s during construction

Fixes #69925.

This PR adjusts MIR shim construction so that substitutions are applied to function pointer shims during construction, rather than during codegen (as determined by `substs_for_mir_body`).

r? `@eddyb`

3 years agoRemove some unused features from alloc core and std
est31 [Fri, 18 Sep 2020 07:35:37 +0000 (09:35 +0200)]
Remove some unused features from alloc core and std

3 years agoAuto merge of #72632 - jonas-schievink:dest-prop, r=oli-obk
bors [Sun, 20 Sep 2020 01:38:26 +0000 (01:38 +0000)]
Auto merge of #72632 - jonas-schievink:dest-prop, r=oli-obk

Implement a generic Destination Propagation optimization on MIR

This takes the work that was originally started by `@eddyb` in https://github.com/rust-lang/rust/pull/47954, and then explored by me in https://github.com/rust-lang/rust/pull/71003, and implements it in a general (ie. not limited to acyclic CFGs) and dataflow-driven way (so that no additional infrastructure in rustc is needed).

The pass is configured to run at `mir-opt-level=2` and higher only. To enable it by default, some followup work on it is still needed:
* Performance needs to be evaluated. I did some light optimization work and tested against `tuple-stress`, which caused trouble in my last attempt, but didn't go much in depth here.
  * We can also enable the pass only at `opt-level=2` and higher, if it is too slow to run in debug mode, but fine when optimizations run anyways.
* Debuginfo needs to be fixed after locals are merged. I did not look into what is required for this.
* Live ranges of locals (aka `StorageLive` and `StorageDead`) are currently deleted. We either need to decide that this is fine, or if not, merge the variable's live ranges (or remove these statements entirely â€“ https://github.com/rust-lang/rust/issues/68622).

Some benchmarks of the pass were done in https://github.com/rust-lang/rust/pull/72635.

3 years agoUpdate Clippy testcases
Christiaan Dirkx [Sun, 20 Sep 2020 01:32:36 +0000 (03:32 +0200)]
Update Clippy testcases

Update the test `redundant_pattern_matching`: check if `is_ok` and `is_err` are suggested within const contexts.
Also removes the `redundant_pattern_matching_const_result` test, as it is no longer needed.

3 years agoUse intra-doc links
Denis Vasilik [Fri, 18 Sep 2020 09:05:26 +0000 (11:05 +0200)]
Use intra-doc links

3 years agoDon't allow implementing trait directly on type-alias-impl-trait
Aaron Hill [Sat, 19 Sep 2020 20:25:50 +0000 (16:25 -0400)]
Don't allow implementing trait directly on type-alias-impl-trait

This is specifically disallowed by the RFC, but we never added a check
for it.

Fixes #76202

3 years agofix some comments
Ralf Jung [Wed, 9 Sep 2020 10:57:36 +0000 (12:57 +0200)]
fix some comments

3 years agonever promote non-const operations; revert STATIC promotion change
Ralf Jung [Wed, 9 Sep 2020 08:00:23 +0000 (10:00 +0200)]
never promote non-const operations; revert STATIC promotion change

3 years agofix doc comment
Ralf Jung [Mon, 7 Sep 2020 11:22:59 +0000 (13:22 +0200)]
fix doc comment

3 years agocleanup promotion const_kind checks
Ralf Jung [Sun, 6 Sep 2020 14:06:39 +0000 (16:06 +0200)]
cleanup promotion const_kind checks

in particular allow a few more promotions for consistency when they were already allowed in other contexts

3 years agoAuto merge of #76929 - ssomers:btree_cleanup_2, r=Mark-Simulacrum
bors [Sat, 19 Sep 2020 19:15:06 +0000 (19:15 +0000)]
Auto merge of #76929 - ssomers:btree_cleanup_2, r=Mark-Simulacrum

BTreeMap: wrap node's raw parent pointer in NonNull

Now that the other `*const` (root) is gone, seemed like a small step forward.

r? `@Mark-Simulacrum`

3 years agoBTreeMap: wrap node's raw parent pointer in NonNull
Stein Somers [Sat, 19 Sep 2020 14:47:03 +0000 (16:47 +0200)]
BTreeMap: wrap node's raw parent pointer in NonNull

3 years agoAuto merge of #76327 - lzutao:split-core-num, r=SimonSapin
bors [Sat, 19 Sep 2020 16:13:26 +0000 (16:13 +0000)]
Auto merge of #76327 - lzutao:split-core-num, r=SimonSapin

Split `core/num/mod.rs` to smaller mods

Note for reviewer:
* I split to multiple commits for easier reviewing, but I could git squash them all to one if requested.
* Recommend pulling this change locally and using advanced git diff viewer or this command:
  ```
  git show --reverse --color-moved=dimmed-zebra master..
  ```

---

I split `core/num/mod.rs` to these modules:

* `error`: For error structs like `ParseIntError`.
* blanket `shells` dir: For dummy number type modules: std::i32, std::f32, and the likes. Why? See below.
* `int_macros` and `uint_macros`: Real implementation of all integer types via `int_impl` and `uint_impl`
* `nonzero`: For `NonZero*` types and their implementations.
* `wrapping`: For `Wrapping<T>` types.

3 years agoBTreeMap: code readability tweaks
Stein Somers [Sun, 16 Aug 2020 20:39:01 +0000 (22:39 +0200)]
BTreeMap: code readability tweaks

3 years agoRemove outdated ignored tidy comment
Lzu Tao [Fri, 4 Sep 2020 15:31:23 +0000 (15:31 +0000)]
Remove outdated ignored tidy comment

3 years agoMove (u)int_impl macros to their own files
Lzu Tao [Fri, 4 Sep 2020 14:20:01 +0000 (14:20 +0000)]
Move (u)int_impl macros to their own files

3 years agoAdd tracking issue for feature(unix_socket_peek)
rijenkii [Sat, 19 Sep 2020 14:55:01 +0000 (21:55 +0700)]
Add tracking issue for feature(unix_socket_peek)

3 years agoMove dummy integer modules (like core::u32) to shells dir
Lzu Tao [Fri, 4 Sep 2020 14:00:38 +0000 (14:00 +0000)]
Move dummy integer modules (like core::u32) to shells dir

3 years agoMove error structs to new mod
Lzu Tao [Fri, 4 Sep 2020 13:37:15 +0000 (13:37 +0000)]
Move error structs to new mod

3 years agoMove Wrapping<T> definition to wrapping mod
Lzu Tao [Fri, 4 Sep 2020 13:14:39 +0000 (13:14 +0000)]
Move Wrapping<T> definition to wrapping mod

3 years agoMove NonZero* to its file
Lzu Tao [Fri, 4 Sep 2020 13:07:03 +0000 (13:07 +0000)]
Move NonZero* to its file

3 years agoupdate docs
Bastian Kauschke [Sat, 19 Sep 2020 13:36:53 +0000 (15:36 +0200)]
update docs

3 years agoAuto merge of #76880 - shepmaster:cc-rs, r=Mark-Simulacrum
bors [Sat, 19 Sep 2020 13:31:23 +0000 (13:31 +0000)]
Auto merge of #76880 - shepmaster:cc-rs, r=Mark-Simulacrum

Update cc crate to 1.0.60 to understand aarch64-apple-darwin with clang

r? `@Mark-Simulacrum`

/cc `@alexcrichton`

3 years agoAuto merge of #76912 - RalfJung:rollup-q9ur56h, r=RalfJung
bors [Sat, 19 Sep 2020 11:29:00 +0000 (11:29 +0000)]
Auto merge of #76912 - RalfJung:rollup-q9ur56h, r=RalfJung

Rollup of 14 pull requests

Successful merges:

 - #73963 (deny(unsafe_op_in_unsafe_fn) in libstd/path.rs)
 - #75099 (lint/ty: move fns to avoid abstraction violation)
 - #75502 (Use implicit (not explicit) rules for promotability by default in `const fn`)
 - #75580 (Add test for checking duplicated branch or-patterns)
 - #76310 (Add `[T; N]: TryFrom<Vec<T>>` (insta-stable))
 - #76400 (Clean up vec benches bench_in_place style)
 - #76434 (do not inline black_box when building for Miri)
 - #76492 (Add associated constant `BITS` to all integer types)
 - #76525 (Add as_str() to string::Drain.)
 - #76636 (assert ScalarMaybeUninit size)
 - #76749 (give *even better* suggestion when matching a const range)
 - #76757 (don't convert types to the same type with try_into (clippy::useless_conversion))
 - #76796 (Give a better error message when x.py uses the wrong stage for CI)
 - #76798 (Build fixes for RISC-V 32-bit Linux support)

Failed merges:

r? `@ghost`

3 years agoRollup merge of #76798 - alistair23:alistair/rv32-linux, r=jyn514
Ralf Jung [Sat, 19 Sep 2020 09:47:56 +0000 (11:47 +0200)]
Rollup merge of #76798 - alistair23:alistair/rv32-linux, r=jyn514

Build fixes for RISC-V 32-bit Linux support

This fixes build issues with the 32-bit RISC-V port.

3 years agoRollup merge of #76796 - jyn514:wrong-stage, r=shepmaster
Ralf Jung [Sat, 19 Sep 2020 09:47:54 +0000 (11:47 +0200)]
Rollup merge of #76796 - jyn514:wrong-stage, r=shepmaster

Give a better error message when x.py uses the wrong stage for CI

r? @shepmaster

3 years agoRollup merge of #76757 - matthiaskrgr:clippy_try_into, r=lcnr
Ralf Jung [Sat, 19 Sep 2020 09:47:52 +0000 (11:47 +0200)]
Rollup merge of #76757 - matthiaskrgr:clippy_try_into, r=lcnr

don't convert types to the same type with try_into (clippy::useless_conversion)

3 years agoRollup merge of #76749 - guswynn:hir_ranges, r=estebank
Ralf Jung [Sat, 19 Sep 2020 09:47:50 +0000 (11:47 +0200)]
Rollup merge of #76749 - guswynn:hir_ranges, r=estebank

give *even better* suggestion when matching a const range

notice that the err already has "constant defined here"
so this is now *exceedingly clear*

extension to #76222

r? @estebank

3 years agoRollup merge of #76636 - RalfJung:miri-size-assert, r=oli-obk
Ralf Jung [Sat, 19 Sep 2020 09:47:49 +0000 (11:47 +0200)]
Rollup merge of #76636 - RalfJung:miri-size-assert, r=oli-obk

assert ScalarMaybeUninit size

I noticed most low-level Miri types have such an assert but `ScalarMaybeUninit` does not, so let's add that. Good t see that the `Option`-like optimization kicks in and this is no bigger than `Scalar`. :)

r? @oli-obk

3 years agoRollup merge of #76525 - fusion-engineering-forks:string-drain, r=dtolnay
Ralf Jung [Sat, 19 Sep 2020 09:47:47 +0000 (11:47 +0200)]
Rollup merge of #76525 - fusion-engineering-forks:string-drain, r=dtolnay

Add as_str() to string::Drain.

Vec's Drain recently [had its `.as_slice()` stabilized](https://github.com/rust-lang/rust/pull/72584), but String's Drain was still missing the analogous `.as_str()`. This adds that.

Also improves the Debug implementation, which now shows the remaining data instead of just `"Drain { .. }"`.

3 years agoRollup merge of #76492 - fusion-engineering-forks:int-bits, r=dtolnay
Ralf Jung [Sat, 19 Sep 2020 09:47:45 +0000 (11:47 +0200)]
Rollup merge of #76492 - fusion-engineering-forks:int-bits, r=dtolnay

Add associated constant `BITS` to all integer types

Recently I've regularly come across this snippet (in a few different crates, including `core` and `std`):
```rust
std::mem::size_of<usize>() * 8
```

I think it's time for a `usize::BITS`.

3 years agoRollup merge of #76434 - RalfJung:black-box, r=Mark-Simulacrum
Ralf Jung [Sat, 19 Sep 2020 09:47:43 +0000 (11:47 +0200)]
Rollup merge of #76434 - RalfJung:black-box, r=Mark-Simulacrum

do not inline black_box when building for Miri

We cannot do the assembly trick in Miri, but let's at least make sure MIR inlining does not circumvent the black_box.

Also use black_box instead of local optimization barriers in a few const tests.

3 years agoRollup merge of #76400 - pickfire:patch-5, r=dtolnay
Ralf Jung [Sat, 19 Sep 2020 09:47:41 +0000 (11:47 +0200)]
Rollup merge of #76400 - pickfire:patch-5, r=dtolnay

Clean up vec benches bench_in_place style

3 years agoRollup merge of #76310 - scottmcm:array-try_from-vec, r=dtolnay
Ralf Jung [Sat, 19 Sep 2020 09:47:39 +0000 (11:47 +0200)]
Rollup merge of #76310 - scottmcm:array-try_from-vec, r=dtolnay

Add `[T; N]: TryFrom<Vec<T>>` (insta-stable)

This is very similar to the [existing](https://doc.rust-lang.org/nightly/std/convert/trait.TryFrom.html#impl-TryFrom%3CBox%3C%5BT%5D%3E%3E) `Box<[T; N]>: TryFrom<Box<[T]>>`, but allows avoiding the `shrink_to_fit` if you have a vector and not a boxed slice.

Like the slice equivalents of this, it fails if the length of the vector is not exactly `N`.
This uses `Vec<T>` as the `Error` type to return the input, like how the `Rc<[T]> -> Rc<[T; N]>` (and Arc) ones also reflect the input directly in the error type.

```rust
#[stable(feature = "array_try_from_vec", since = "1.47.0")]
impl<T, const N: usize> TryFrom<Vec<T>> for [T; N] {
    type Error = Vec<T>;
    fn try_from(mut vec: Vec<T>) -> Result<[T; N], Vec<T>>;
}
```

Inspired by this zulip thread: https://rust-lang.zulipchat.com/#narrow/stream/219381-t-libs/topic/APIs.20for.20getting.20stuff.20from.20a.20Vec.20by.20owned/near/209048103

3 years agoRollup merge of #75580 - JulianKnodt:or_pattern, r=wesleywiser
Ralf Jung [Sat, 19 Sep 2020 09:47:37 +0000 (11:47 +0200)]
Rollup merge of #75580 - JulianKnodt:or_pattern, r=wesleywiser

Add test for checking duplicated branch or-patterns

This adds a regression test for checking `or-patterns` in MIR as shown in #75439.
This doesn't introduce a fix as I'm not sure where it would go(I suspect maybe here: src/librustc_mir_build/build/matches/mod.rs), and I'm not particularly able to fix it.

cc: @lzutao

3 years agoRollup merge of #75502 - ecstatic-morse:implicit-promotion-in-const-fn, r=RalfJung
Ralf Jung [Sat, 19 Sep 2020 09:47:35 +0000 (11:47 +0200)]
Rollup merge of #75502 - ecstatic-morse:implicit-promotion-in-const-fn, r=RalfJung

Use implicit (not explicit) rules for promotability by default in `const fn`

For crater run. See https://github.com/rust-lang/const-eval/pull/54#discussion_r469995552.

cc #75586

3 years agoRollup merge of #75099 - davidtwco:is-zst-abstraction-violation, r=eddyb
Ralf Jung [Sat, 19 Sep 2020 09:47:34 +0000 (11:47 +0200)]
Rollup merge of #75099 - davidtwco:is-zst-abstraction-violation, r=eddyb

lint/ty: move fns to avoid abstraction violation

This PR moves `transparent_newtype_field` and `is_zst` to `LateContext` where they are used, rather than being on the `VariantDef` and `TyS` types, hopefully addressing @eddyb's concern [from this comment](https://github.com/rust-lang/rust/pull/74340#discussion_r456534910).

3 years agoRollup merge of #73963 - hellow554:unsafe_path, r=Mark-Simulacrum
Ralf Jung [Sat, 19 Sep 2020 09:47:31 +0000 (11:47 +0200)]
Rollup merge of #73963 - hellow554:unsafe_path, r=Mark-Simulacrum

deny(unsafe_op_in_unsafe_fn) in libstd/path.rs

The libstd/path.rs part of #73904 . Wraps the two calls to an unsafe fn Initializer::nop() in an unsafe block.

3 years agowording
Bastian Kauschke [Sat, 19 Sep 2020 09:32:55 +0000 (11:32 +0200)]
wording

3 years agocfg bootstrap
Bastian Kauschke [Sat, 19 Sep 2020 09:17:44 +0000 (11:17 +0200)]
cfg bootstrap

3 years agotransmute: use diagnostic item
Bastian Kauschke [Sat, 19 Sep 2020 08:57:13 +0000 (10:57 +0200)]
transmute: use diagnostic item

3 years agoAuto merge of #76886 - Aaron1011:fix/ensure-stack-predicate, r=Mark-Simulacrum
bors [Sat, 19 Sep 2020 09:21:22 +0000 (09:21 +0000)]
Auto merge of #76886 - Aaron1011:fix/ensure-stack-predicate, r=Mark-Simulacrum

Wrap recursive predicate evaluation with `ensure_sufficient_stack`

I haven't been able to come up with a minimized test case for #76770,
but this fixes a stack overflow in rustc as well.

3 years agoReflect the "do not call this query directly" mentality in its name
Oliver Scherer [Sat, 19 Sep 2020 08:57:14 +0000 (10:57 +0200)]
Reflect the "do not call this query directly" mentality in its name

3 years agoUpdate incremental tests
Oliver Scherer [Wed, 9 Sep 2020 12:04:27 +0000 (14:04 +0200)]
Update incremental tests

3 years agoUpdate compile-fail tests
Oliver Scherer [Wed, 9 Sep 2020 10:25:55 +0000 (12:25 +0200)]
Update compile-fail tests

3 years agoRustfmt
Oliver Scherer [Wed, 9 Sep 2020 09:40:09 +0000 (11:40 +0200)]
Rustfmt

3 years agoAddress review comments
Oliver Scherer [Mon, 7 Sep 2020 15:30:38 +0000 (17:30 +0200)]
Address review comments

3 years agoFix rebase fallout and make the test work with debug info
Oliver Scherer [Fri, 21 Aug 2020 08:33:28 +0000 (10:33 +0200)]
Fix rebase fallout and make the test work with debug info

3 years agoUnify the names of const eval queries and their return types
Oliver Scherer [Thu, 20 Aug 2020 16:55:07 +0000 (18:55 +0200)]
Unify the names of const eval queries and their return types

3 years agoRename const eval queries to reflect the validation changes
Oliver Scherer [Mon, 10 Aug 2020 13:11:40 +0000 (15:11 +0200)]
Rename const eval queries to reflect the validation changes

3 years agoWe can make const eval sound, it's just super expensive
Oliver Scherer [Mon, 10 Aug 2020 10:40:29 +0000 (12:40 +0200)]
We can make const eval sound, it's just super expensive

3 years agoDo not call the `const_eval` query in mir interpretation except for caching of nulary...
Oliver Scherer [Mon, 10 Aug 2020 10:40:14 +0000 (12:40 +0200)]
Do not call the `const_eval` query in mir interpretation except for caching of nulary intrinsics

3 years agoClarify a statement in UB test
Oliver Scherer [Mon, 10 Aug 2020 10:08:52 +0000 (12:08 +0200)]
Clarify a statement in UB test

3 years agoReplace `and_then` `map_err` `and_then` chain with a match
Oliver Scherer [Mon, 10 Aug 2020 10:04:01 +0000 (12:04 +0200)]
Replace `and_then` `map_err` `and_then` chain with a match

3 years ago`turn_into_const` is infallible
Oliver Scherer [Mon, 10 Aug 2020 09:57:20 +0000 (11:57 +0200)]
`turn_into_const` is infallible

3 years agoDocument `op_to_const`'s purpose
Oliver Scherer [Mon, 10 Aug 2020 09:48:52 +0000 (11:48 +0200)]
Document `op_to_const`'s purpose

3 years agoUpdate codegen tests
Oliver Scherer [Fri, 31 Jul 2020 17:10:37 +0000 (19:10 +0200)]
Update codegen tests

3 years agoStop using the `const_eval` query for initializers of statics
Oliver Scherer [Fri, 31 Jul 2020 11:27:54 +0000 (13:27 +0200)]
Stop using the `const_eval` query for initializers of statics

As a side effect, we now represent most promoteds as `ConstValue::Scalar` again. This is useful because all implict promoteds are just references anyway and most explicit promoteds are numeric arguments to `asm!` or SIMD instructions.