]> git.lizzy.rs Git - rust.git/log
rust.git
3 years agoAdd #[cold] to `abort` and `handle_alloc_error`
Benoît du Garreau [Wed, 18 Nov 2020 17:15:03 +0000 (18:15 +0100)]
Add #[cold] to `abort` and `handle_alloc_error`

3 years agoAuto merge of #79159 - pietroalbini:woops, r=pietroalbini
bors [Wed, 18 Nov 2020 10:39:02 +0000 (10:39 +0000)]
Auto merge of #79159 - pietroalbini:woops, r=pietroalbini

Revert #79132

The beta promotion release was mistakenly landed on master instead of beta. Ugh.

r? `@ghost`
cc `@rust-lang/release`

3 years agoRevert "Auto merge of #79132 - pietroalbini:beta-next, r=Mark-Simulacrum"
Pietro Albini [Wed, 18 Nov 2020 10:18:40 +0000 (11:18 +0100)]
Revert "Auto merge of #79132 - pietroalbini:beta-next, r=Mark-Simulacrum"

This was landed on master instead of beta!

3 years agoAuto merge of #77820 - jyn514:from-inner, r=petrochenkov
bors [Wed, 18 Nov 2020 03:56:18 +0000 (03:56 +0000)]
Auto merge of #77820 - jyn514:from-inner, r=petrochenkov

Add `Item::from_def_id_and_kind` to reduce duplication in rustdoc

This makes it harder to make typos, and also makes it much more clear what's intentionally different rather than a typo (look for `what_rustc_thinks`).

Found this while working on https://github.com/rust-lang/rust/issues/76998, I really didn't want to add `const_visibility` in 20 different places.

r? `@GuillaumeGomez`

3 years agoAuto merge of #79132 - pietroalbini:beta-next, r=Mark-Simulacrum
bors [Wed, 18 Nov 2020 01:34:32 +0000 (01:34 +0000)]
Auto merge of #79132 - pietroalbini:beta-next, r=Mark-Simulacrum

Prepare beta 1.49.0

This PR sets everything up for beta 1.49.0, and backports the following PRs to it:

* #79107 - build-manifest: strip newline from rustc version
* #78986 - Avoid installing external LLVM dylibs
* #79074 - Install CI llvm into the library directory
* #78364 - Update RELEASES.md for 1.48.0
* #77939 - Ensure that the source code display is working with DOS backline

r? `@ghost`
cc `@rust-lang/release`

3 years agoIgnore failures of RLS on aarch64 Windows
Mark Rousskov [Tue, 17 Nov 2020 21:00:41 +0000 (16:00 -0500)]
Ignore failures of RLS on aarch64 Windows

3 years agoRemove dead code in rustdoc::doctree
Joshua Nelson [Sat, 14 Nov 2020 23:27:06 +0000 (18:27 -0500)]
Remove dead code in rustdoc::doctree

It was completely unused.

3 years agoAdd `from_def_id_and_kind` reducing duplication in rustdoc
Joshua Nelson [Sun, 15 Nov 2020 19:09:26 +0000 (14:09 -0500)]
Add `from_def_id_and_kind` reducing duplication in rustdoc

- Add `Item::from_hir_id_and_kind` convenience wrapper
- Make name parameter mandatory

  `tcx.opt_item_name` doesn't handle renames, so this is necessary
  for any item that could be renamed, which is almost all of them.

- Override visibilities to be `Inherited` for enum variants

  `tcx.visibility` returns the effective visibility, not the visibility
  that was written in the source code. `pub enum E { A, B }` always has
  public variants `A` and `B`, so there's no sense printing `pub` again.

- Don't duplicate handling of `Visibility::Crate`

  Instead, represent it as just another `Restricted` path.

3 years agoFix broken handling of `MacroDef` in `Map::attrs`
Joshua Nelson [Sun, 15 Nov 2020 13:07:47 +0000 (08:07 -0500)]
Fix broken handling of `MacroDef` in `Map::attrs`

This also uses an exhaustive match to avoid future similar bugs.

3 years agoUse DefPath for clean::Visibility, not clean::Path
Joshua Nelson [Sat, 14 Nov 2020 06:51:05 +0000 (01:51 -0500)]
Use DefPath for clean::Visibility, not clean::Path

Visibility needs much less information than a full path, since modules
can never have generics. This allows constructing a Visibility from only
a DefId.

Note that this means that paths are now normalized to their DefPath.
In other words, `pub(self)` or `pub(super)` now always shows `pub(in
path)` instead of preserving the original text.

3 years agoUpdate fulldeps test
Mark Rousskov [Wed, 7 Oct 2020 02:36:12 +0000 (22:36 -0400)]
Update fulldeps test

3 years agoAuto merge of #79138 - m-ou-se:rollup-owel5ld, r=m-ou-se
bors [Tue, 17 Nov 2020 15:27:29 +0000 (15:27 +0000)]
Auto merge of #79138 - m-ou-se:rollup-owel5ld, r=m-ou-se

Rollup of 8 pull requests

Successful merges:

 - #74293 (Rustdoc test compiler output color)
 - #78702 ([self-profiling] Include the estimated size of each cgu in the profile)
 - #79069 (Get rid of `highlight::Class::None`)
 - #79072 (Fix exhaustiveness in case a byte string literal is used at slice type)
 - #79120 (update rustfmt to v1.4.27)
 - #79125 (Get rid of clean::{Method, TyMethod})
 - #79126 (Remove duplicate `Trait::auto` field)
 - #79130 (extend macro braces test)

Failed merges:

r? `@ghost`
`@rustbot` modify labels: rollup

3 years agoRollup merge of #79130 - lcnr:extend-tes, r=varkor
Mara Bos [Tue, 17 Nov 2020 15:14:00 +0000 (16:14 +0100)]
Rollup merge of #79130 - lcnr:extend-tes, r=varkor

extend macro braces test

r? `@varkor`

3 years agoRollup merge of #79126 - jyn514:auto, r=GuillaumeGomez
Mara Bos [Tue, 17 Nov 2020 15:13:58 +0000 (16:13 +0100)]
Rollup merge of #79126 - jyn514:auto, r=GuillaumeGomez

Remove duplicate `Trait::auto` field

It was exactly the same as `is_auto`.

I found this while working on #78082, but it's not required for that PR.

r? `@GuillaumeGomez`

3 years agoRollup merge of #79125 - jyn514:fewer-types, r=GuillaumeGomez
Mara Bos [Tue, 17 Nov 2020 15:13:57 +0000 (16:13 +0100)]
Rollup merge of #79125 - jyn514:fewer-types, r=GuillaumeGomez

Get rid of clean::{Method, TyMethod}

They're redundant and almost the same as `clean::Function`.

I needed this for https://github.com/rust-lang/rust/pull/78082, although I forget why.

r? `@GuillaumeGomez`

3 years agoRollup merge of #79120 - calebcartwright:update-rustfmt, r=Mark-Simulacrum
Mara Bos [Tue, 17 Nov 2020 15:13:55 +0000 (16:13 +0100)]
Rollup merge of #79120 - calebcartwright:update-rustfmt, r=Mark-Simulacrum

update rustfmt to v1.4.27

Fixes https://github.com/rust-lang/rustfmt/issues/4528

3 years agoRollup merge of #79072 - oli-obk:byte_str_pat, r=estebank
Mara Bos [Tue, 17 Nov 2020 15:13:53 +0000 (16:13 +0100)]
Rollup merge of #79072 - oli-obk:byte_str_pat, r=estebank

Fix exhaustiveness in case a byte string literal is used at slice type

fixes #79048

3 years agoRollup merge of #79069 - jyn514:class-none, r=GuillaumeGomez
Mara Bos [Tue, 17 Nov 2020 15:13:51 +0000 (16:13 +0100)]
Rollup merge of #79069 - jyn514:class-none, r=GuillaumeGomez

Get rid of `highlight::Class::None`

This is mostly me learning the codebase for https://github.com/rust-lang/rust/pull/77939, so feel free to close the PR.
It does have the small benefit that we statically know rustdoc isn't generating useless `span`s, though.

r? `@GuillaumeGomez`
cc `@matklad`

3 years agoRollup merge of #78702 - wesleywiser:self_profile_cgu_sizes, r=Mark-Simulacrum
Mara Bos [Tue, 17 Nov 2020 15:13:49 +0000 (16:13 +0100)]
Rollup merge of #78702 - wesleywiser:self_profile_cgu_sizes, r=Mark-Simulacrum

[self-profiling] Include the estimated size of each cgu in the profile

This is helpful when looking for CGUs where the size estimate isn't a
good indicator of compilation time.

I verified that moving the profiling timer call doesn't affect the
results.

Results:

<img width="297" alt="Screen Shot 2020-11-03 at 7 25 04 AM" src="https://user-images.githubusercontent.com/831192/97985503-5901d100-1da6-11eb-9f10-f3e399702952.png">

`measureme` doesn't have support for custom arg names yet so `arg0` is the CGU name and `arg1` is the estimated size.

3 years agoRollup merge of #74293 - GuillaumeGomez:rustdoc-test-compiler-output-color, r=jyn514
Mara Bos [Tue, 17 Nov 2020 15:13:46 +0000 (16:13 +0100)]
Rollup merge of #74293 - GuillaumeGomez:rustdoc-test-compiler-output-color, r=jyn514

Rustdoc test compiler output color

Fixes #72915

We just need to be sure it doesn't break rustdoc doctests' compilation checks. Maybe some other unforeseen consequences too?

r? `@ehuss`
cc `@rust-lang/rustdoc`

3 years agoAuto merge of #78779 - LeSeulArtichaut:ty-visitor-return, r=oli-obk
bors [Tue, 17 Nov 2020 12:24:34 +0000 (12:24 +0000)]
Auto merge of #78779 - LeSeulArtichaut:ty-visitor-return, r=oli-obk

Introduce `TypeVisitor::BreakTy`

Implements MCP rust-lang/compiler-team#383.
r? `@ghost`
cc `@lcnr` `@oli-obk`

~~Blocked on FCP in rust-lang/compiler-team#383.~~

3 years agoAdd test to ensure that no DOS backline (\r\n) doesn't create extra backline in sourc...
Guillaume Gomez [Sun, 15 Nov 2020 19:51:25 +0000 (20:51 +0100)]
Add test to ensure that no DOS backline (\r\n) doesn't create extra backline in source rendering

3 years agoEnsure that the source code display is working with DOS backline
Guillaume Gomez [Wed, 14 Oct 2020 15:02:04 +0000 (17:02 +0200)]
Ensure that the source code display is working with DOS backline

3 years agoUpdate RELEASES.md
XAMPPRocky [Thu, 12 Nov 2020 15:20:22 +0000 (16:20 +0100)]
Update RELEASES.md

3 years agoUpdate RELEASES.md
XAMPPRocky [Thu, 29 Oct 2020 15:28:17 +0000 (16:28 +0100)]
Update RELEASES.md

3 years agoUpdate RELEASES.md
XAMPPRocky [Tue, 27 Oct 2020 12:07:14 +0000 (13:07 +0100)]
Update RELEASES.md

3 years agoUpdate RELEASES.md
XAMPPRocky [Tue, 27 Oct 2020 12:04:05 +0000 (13:04 +0100)]
Update RELEASES.md

3 years agoUpdate RELEASES.md
XAMPPRocky [Tue, 27 Oct 2020 10:00:07 +0000 (11:00 +0100)]
Update RELEASES.md

3 years agoUpdate RELEASES.md
XAMPPRocky [Mon, 26 Oct 2020 10:30:23 +0000 (11:30 +0100)]
Update RELEASES.md

3 years agoUpdate RELEASES.md
XAMPPRocky [Mon, 26 Oct 2020 10:24:31 +0000 (11:24 +0100)]
Update RELEASES.md

3 years agoUpdate RELEASES.md
XAMPPRocky [Mon, 26 Oct 2020 10:23:54 +0000 (11:23 +0100)]
Update RELEASES.md

3 years agoApply suggestions from code review
XAMPPRocky [Mon, 26 Oct 2020 06:11:03 +0000 (07:11 +0100)]
Apply suggestions from code review

Co-authored-by: Camelid <camelidcamel@gmail.com>
Co-authored-by: Mark Rousskov <mark.simulacrum@gmail.com>
3 years agoApply suggestions from code review
XAMPPRocky [Sun, 25 Oct 2020 19:43:44 +0000 (20:43 +0100)]
Apply suggestions from code review

Co-authored-by: Vadim Petrochenkov <vadim.petrochenkov@gmail.com>
Co-authored-by: Jonas Schievink <jonasschievink@gmail.com>
Co-authored-by: Yuki Okushi <huyuumi.dev@gmail.com>
3 years agoUpdate RELEASES.md
XAMPPRocky [Sun, 25 Oct 2020 19:43:00 +0000 (20:43 +0100)]
Update RELEASES.md

Co-authored-by: Vadim Petrochenkov <vadim.petrochenkov@gmail.com>
3 years agoUpdate RELEASES.md
XAMPPRocky [Sun, 25 Oct 2020 17:12:40 +0000 (18:12 +0100)]
Update RELEASES.md

3 years agoUpdate RELEASES.md for 1.48.0
Erin Power [Sun, 25 Oct 2020 17:09:28 +0000 (18:09 +0100)]
Update RELEASES.md for 1.48.0

3 years agoInstall CI llvm into the library directory
Mark Rousskov [Sun, 15 Nov 2020 13:59:53 +0000 (08:59 -0500)]
Install CI llvm into the library directory

3 years agoAvoid installing external LLVM dylibs
Mark Rousskov [Thu, 12 Nov 2020 14:49:45 +0000 (09:49 -0500)]
Avoid installing external LLVM dylibs

If the LLVM was externally provided, then we don't currently copy artifacts into
the sysroot. This is not necessarily the right choice (in particular, it will
require the LLVM dylib to be in the linker's load path at runtime), but the
common use case for external LLVMs is distribution provided LLVMs, and in that
case they're usually in the standard search path (e.g., /usr/lib) and copying
them here is going to cause problems as we may end up with the wrong files and
isn't what distributions want.

This behavior may be revisited in the future though.

3 years agobuild-manifest: strip newline from rustc version
Pietro Albini [Mon, 16 Nov 2020 13:36:49 +0000 (14:36 +0100)]
build-manifest: strip newline from rustc version

3 years agothis is beta 1.49.0
Pietro Albini [Tue, 17 Nov 2020 11:33:49 +0000 (12:33 +0100)]
this is beta 1.49.0

3 years agoRemove unused import
Guillaume Gomez [Sun, 15 Nov 2020 20:06:53 +0000 (21:06 +0100)]
Remove unused import

3 years agoAdd comment explaining why we can't split on `error[{}]: ` because of the color escap...
Guillaume Gomez [Fri, 13 Nov 2020 10:19:39 +0000 (11:19 +0100)]
Add comment explaining why we can't split on `error[{}]: ` because of the color escape characters

3 years agoCorrectly detect color support
Guillaume Gomez [Thu, 12 Nov 2020 21:32:42 +0000 (22:32 +0100)]
Correctly detect color support

3 years agoUpdate doctest tests
Guillaume Gomez [Wed, 11 Nov 2020 19:27:24 +0000 (20:27 +0100)]
Update doctest tests

3 years agoSimplfy color availability check
Guillaume Gomez [Wed, 11 Nov 2020 15:44:02 +0000 (16:44 +0100)]
Simplfy color availability check

3 years agoUpdate lock file
Guillaume Gomez [Thu, 16 Jul 2020 14:46:30 +0000 (16:46 +0200)]
Update lock file

3 years agoAdd check to get windows console type to decide to use colors or not
Guillaume Gomez [Thu, 16 Jul 2020 14:36:25 +0000 (16:36 +0200)]
Add check to get windows console type to decide to use colors or not

3 years agoUpdate error code detection in compile_fail doctests
Guillaume Gomez [Tue, 14 Jul 2020 12:44:12 +0000 (14:44 +0200)]
Update error code detection in compile_fail doctests

3 years agoAdd color in rustdoc --test output
Guillaume Gomez [Mon, 13 Jul 2020 13:34:38 +0000 (15:34 +0200)]
Add color in rustdoc --test output

3 years agoAuto merge of #79128 - m-ou-se:rollup-lzz1dym, r=m-ou-se
bors [Tue, 17 Nov 2020 09:19:55 +0000 (09:19 +0000)]
Auto merge of #79128 - m-ou-se:rollup-lzz1dym, r=m-ou-se

Rollup of 9 pull requests

Successful merges:

 - #77939 (Ensure that the source code display is working with DOS backline)
 - #78138 (Upgrade dlmalloc to version 0.2)
 - #78967 (Make codegen tests compatible with extra inlining)
 - #79027 (Limit storage duration of inlined always live locals)
 - #79077 (document that __rust_alloc is also magic to our LLVM fork)
 - #79088 (clarify `span_label` documentation)
 - #79097 (Code block invalid html tag lint)
 - #79105 (std: Fix test `symlink_hard_link` on Windows)
 - #79107 (build-manifest: strip newline from rustc version)

Failed merges:

r? `@ghost`
`@rustbot` modify labels: rollup

3 years agoextend macro braces test
Bastian Kauschke [Tue, 17 Nov 2020 09:18:27 +0000 (10:18 +0100)]
extend macro braces test

3 years agoFix exhaustiveness in case a byte string literal is used at slice type
oli [Sun, 15 Nov 2020 13:04:30 +0000 (13:04 +0000)]
Fix exhaustiveness in case a byte string literal is used at slice type

3 years agoRollup merge of #79107 - pietroalbini:build-manifest-newline, r=Mark-Simulacrum
Mara Bos [Tue, 17 Nov 2020 09:06:31 +0000 (10:06 +0100)]
Rollup merge of #79107 - pietroalbini:build-manifest-newline, r=Mark-Simulacrum

build-manifest: strip newline from rustc version

Backport of https://github.com/rust-lang/rust/pull/79096 on the master branch. This will also need to be included in the beta bump tomorrow.

r? `@Mark-Simulacrum`
`@rustbot` modify labels: beta-nominated beta-accepted T-infra

3 years agoRollup merge of #79105 - petrochenkov:winlink, r=shepmaster
Mara Bos [Tue, 17 Nov 2020 09:06:29 +0000 (10:06 +0100)]
Rollup merge of #79105 - petrochenkov:winlink, r=shepmaster

std: Fix test `symlink_hard_link` on Windows

The test was introduced in https://github.com/rust-lang/rust/pull/78026 and fails depending on Windows version and admin rights.
Other similar tests check for symlink creation permissions before doing anything, this PR performs the same check for `symlink_hard_link` as well.

3 years agoRollup merge of #79097 - GuillaumeGomez:code-block-invalid-html-tag-lint, r=jyn514
Mara Bos [Tue, 17 Nov 2020 09:06:27 +0000 (10:06 +0100)]
Rollup merge of #79097 - GuillaumeGomez:code-block-invalid-html-tag-lint, r=jyn514

Code block invalid html tag lint

Fixes #79095

r? ``@jyn514``

3 years agoRollup merge of #79088 - euclio:span-label-doc, r=estebank
Mara Bos [Tue, 17 Nov 2020 09:06:25 +0000 (10:06 +0100)]
Rollup merge of #79088 - euclio:span-label-doc, r=estebank

clarify `span_label` documentation

Fixes #71857.

r? ``@estebank``

cc ``@RalfJung``

3 years agoRollup merge of #79077 - RalfJung:llvm-magic, r=Mark-Simulacrum
Mara Bos [Tue, 17 Nov 2020 09:06:23 +0000 (10:06 +0100)]
Rollup merge of #79077 - RalfJung:llvm-magic, r=Mark-Simulacrum

document that __rust_alloc is also magic to our LLVM fork

Based on [comments](https://github.com/rust-lang/rust/pull/79045#discussion_r523442198) by ````@tmiasko```` and ````@bjorn3.````

3 years agoRollup merge of #79027 - tmiasko:inline-always-live-locals, r=oli-obk
Mara Bos [Tue, 17 Nov 2020 09:06:21 +0000 (10:06 +0100)]
Rollup merge of #79027 - tmiasko:inline-always-live-locals, r=oli-obk

Limit storage duration of inlined always live locals

Closes #76375.

3 years agoRollup merge of #78967 - tmiasko:codegen-tests, r=cuviper
Mara Bos [Tue, 17 Nov 2020 09:06:19 +0000 (10:06 +0100)]
Rollup merge of #78967 - tmiasko:codegen-tests, r=cuviper

Make codegen tests compatible with extra inlining

3 years agoRollup merge of #78138 - fortanix:raoul/dlmalloc0.2, r=Mark-Simulacrum
Mara Bos [Tue, 17 Nov 2020 09:06:16 +0000 (10:06 +0100)]
Rollup merge of #78138 - fortanix:raoul/dlmalloc0.2, r=Mark-Simulacrum

Upgrade dlmalloc to version 0.2

In preparation of adding dynamic memory management support for SGXv2-enabled platforms, the dlmalloc crate has been refactored. More specifically, support has been added to implement platform specification outside of the dlmalloc crate. (see https://github.com/alexcrichton/dlmalloc-rs/pull/15)

This PR upgrades dlmalloc to version 0.2 for the `wasm` and `sgx` targets.

As the dlmalloc changes have received a positive review, but have not been merged yet, this PR contains a commit to prevent tidy from aborting CI prematurely.

cc: `@jethrogb`

3 years agoRollup merge of #77939 - GuillaumeGomez:fix-source-code-dos-backline, r=jyn514
Mara Bos [Tue, 17 Nov 2020 09:06:13 +0000 (10:06 +0100)]
Rollup merge of #77939 - GuillaumeGomez:fix-source-code-dos-backline, r=jyn514

Ensure that the source code display is working with DOS backline

Fixes #76361.

cc ````@lzutao````
r? ````@jyn514````

3 years agoAuto merge of #78924 - bjorn3:less_sysroot_build_scripts, r=Mark-Simulacrum
bors [Tue, 17 Nov 2020 06:37:59 +0000 (06:37 +0000)]
Auto merge of #78924 - bjorn3:less_sysroot_build_scripts, r=Mark-Simulacrum

Make the libstd build script smaller

Of all sysroot crates currently only compiler_builtins, miniz_oxide and std require a build script. compiler_builtins uses to conditionally enable certain features and possibly compile a C version ([source](https://github.com/rust-lang/compiler-builtins/blob/63ccaf11f08fb5d0b39cc33884c5a1a63f547ace/build.rs)), miniz_oxide only uses it to detect if liballoc is supported as the MSRV is 1.34.0 instead of the 1.36.0 which stabilized liballoc ([source](https://github.com/Frommi/miniz_oxide/blob/28514ec09f0b1ce74bfb2d561de52a6652ce377a/miniz_oxide/build.rs)). std now only uses it to enable `freebsd12` when the `RUST_STD_FREEBSD_12_ABI` env var is set, to determine if `restricted-std` should be set, to set the `STD_ENV_ARCH` env var identical to `CARGO_CFG_TARGET_ARCH`, and to unconditionally enable `backtrace_in_libstd`.

If all build scripts were to be removed, it would be possible for rustc to completely compile it's own sysroot. It currently requires a rustc version that already has an available libstd to compile the build scripts. If rustc can completely compile it's own sysroot, rustbuild could be simplified to not forcefully use the bootstrap compiler for build scripts.

`@rustbot` modify labels: +T-compiler +libs-impl

3 years agoRemove duplicate `Trait::auto` field
Joshua Nelson [Tue, 17 Nov 2020 05:34:38 +0000 (00:34 -0500)]
Remove duplicate `Trait::auto` field

It was exactly the same as `is_auto`.

3 years agoGet rid of clean::Method
Joshua Nelson [Tue, 17 Nov 2020 04:19:58 +0000 (23:19 -0500)]
Get rid of clean::Method

Replace it instead with `(clean::Function, Option<hir::Defaultness>)`.

3 years agoAuto merge of #78801 - sexxi-goose:min_capture, r=nikomatsakis
bors [Tue, 17 Nov 2020 03:56:03 +0000 (03:56 +0000)]
Auto merge of #78801 - sexxi-goose:min_capture, r=nikomatsakis

RFC-2229: Implement Precise Capture Analysis

### This PR introduces
- Feature gate for RFC-2229 (incomplete) `capture_disjoint_field`
- Rustc Attribute to print out the capture analysis `rustc_capture_analysis`
- Precise capture analysis

### Description of the analysis
1. If the feature gate is not set then all variables that are not local to the closure will be added to the list of captures. (This is for backcompat)
2. The rest of the analysis is based entirely on how the captured `Place`s are used within the closure. Precise information (i.e. projections) about the `Place` is maintained throughout.
3. To reduce the amount of information we need to keep track of, we do a minimization step. In this step, we determine a list such that no Place within this list represents an ancestor path to another entry in the list.  Check rust-lang/project-rfc-2229#9 for more detailed examples.
4. To keep the compiler functional as before we implement a Bridge between the results of this new analysis to existing data structures used for closure captures. Note the new capture analysis results are only part of MaybeTypeckTables that is the information is only available during typeck-ing.

### Known issues
- Statements like `let _ = x` will make the compiler ICE when used within a closure with the feature enabled. More generally speaking the issue is caused by `let` statements that create no bindings and are init'ed using a Place expression.

### Testing
We removed the code that would handle the case where the feature gate is not set, to enable the feature as default and did a bors try and perf run. More information here: #78762

### Thanks
This has been slowly in the works for a while now.
I want to call out `@Azhng` `@ChrisPardy` `@null-sleep` `@jenniferwills` `@logmosier` `@roxelo` for working on this and the previous PRs that led up to this, `@nikomatsakis` for guiding us.

Closes rust-lang/project-rfc-2229#7
Closes rust-lang/project-rfc-2229#9
Closes rust-lang/project-rfc-2229#6
Closes rust-lang/project-rfc-2229#19

r? `@nikomatsakis`

3 years agoGet rid of clean::TyMethod
Joshua Nelson [Tue, 17 Nov 2020 03:53:10 +0000 (22:53 -0500)]
Get rid of clean::TyMethod

It's the same as clean::Function.

3 years agoupdate rustfmt to v1.4.27
Caleb Cartwright [Tue, 17 Nov 2020 01:30:21 +0000 (19:30 -0600)]
update rustfmt to v1.4.27

3 years agoAuto merge of #78313 - lcnr:somebody-fold-me, r=nikomatsakis
bors [Tue, 17 Nov 2020 01:14:54 +0000 (01:14 +0000)]
Auto merge of #78313 - lcnr:somebody-fold-me, r=nikomatsakis

TypeFoldable: take self by value

Implements https://github.com/rust-lang/compiler-team/issues/371 which is currently still in FCP.

r? `@nikomatsakis`

3 years agoclarify `span_label` documentation
Andy Russell [Mon, 16 Nov 2020 03:39:51 +0000 (22:39 -0500)]
clarify `span_label` documentation

3 years agoAuto merge of #79104 - m-ou-se:rollup-v74492y, r=m-ou-se
bors [Mon, 16 Nov 2020 22:32:40 +0000 (22:32 +0000)]
Auto merge of #79104 - m-ou-se:rollup-v74492y, r=m-ou-se

Rollup of 11 pull requests

Successful merges:

 - #74989 (Implement `Index` and `IndexMut` for arrays)
 - #76339 (Test structural matching for all range types)
 - #77691 (Rename/Deprecate LayoutErr in favor of LayoutError)
 - #78364 (Update RELEASES.md for 1.48.0)
 - #78678 (Add tests and improve rendering of cfgs on traits)
 - #78714 (Simplify output capturing)
 - #78769 (Remove unneeded lifetimes in array/mod.rs)
 - #78903 (BTreeMap: test chaotic ordering & other bits & bobs)
 - #79032 (improve type const mismatch errors)
 - #79061 (Make all rustdoc functions and structs crate-private)
 - #79087 (Update E0744 about control flow in `const` contexts to accurately describe when the error is triggered and why)

Failed merges:

r? `@ghost`
`@rustbot` modify labels: rollup

3 years agoupdate `cg_clif`
Bastian Kauschke [Wed, 28 Oct 2020 07:25:06 +0000 (08:25 +0100)]
update `cg_clif`

3 years agowords
lcnr [Sat, 24 Oct 2020 07:27:15 +0000 (09:27 +0200)]
words

3 years agoclippy: fold by value
Bastian Kauschke [Sat, 24 Oct 2020 00:21:27 +0000 (02:21 +0200)]
clippy: fold by value

3 years agocompiler: fold by value
Bastian Kauschke [Sat, 24 Oct 2020 00:21:18 +0000 (02:21 +0200)]
compiler: fold by value

3 years agoadd IdFunctor to rustc_data_structures
Bastian Kauschke [Sat, 24 Oct 2020 00:20:16 +0000 (02:20 +0200)]
add IdFunctor to rustc_data_structures

3 years agobuild-manifest: strip newline from rustc version
Pietro Albini [Mon, 16 Nov 2020 13:36:49 +0000 (14:36 +0100)]
build-manifest: strip newline from rustc version

3 years agostd: Fix test `got_symlink_permission` on Windows
Vadim Petrochenkov [Mon, 16 Nov 2020 18:09:26 +0000 (21:09 +0300)]
std: Fix test `got_symlink_permission` on Windows

3 years agoRollup merge of #79087 - ThePuzzlemaker:issue-79083-docfix, r=RalfJung
Mara Bos [Mon, 16 Nov 2020 16:26:38 +0000 (17:26 +0100)]
Rollup merge of #79087 - ThePuzzlemaker:issue-79083-docfix, r=RalfJung

Update E0744 about control flow in `const` contexts to accurately describe when the error is triggered and why

This PR fixes #79083. `const fn` currently supports `if`, `match`, `loop`, and `while` in terms of control flow. The error relating to control flow in `const` contexts currently states that those control flow constructs are not allowed in `const` contexts. That is no longer true, as RFC 2342 and 2344 were [stabilized](https://github.com/rust-lang/rust/pull/72437). `for` loops, however, as well as `?` and `.await` are still not allowed, so I changed the error message to be more descriptive of the error as it is not just control flow that could trigger this error. I also added links to tracking issues that mark things that are blocking the usage of these expressions.

3 years agoRollup merge of #79061 - jyn514:no-pub, r=GuillaumeGomez
Mara Bos [Mon, 16 Nov 2020 16:26:36 +0000 (17:26 +0100)]
Rollup merge of #79061 - jyn514:no-pub, r=GuillaumeGomez

Make all rustdoc functions and structs crate-private

This gives warnings when code is no longer used, which will be helpful when https://github.com/rust-lang/rust/pull/77820 and https://github.com/rust-lang/rust/pull/78082 land.

AFAIK no one is using this API.

r? ``@GuillaumeGomez``
cc ``@rust-lang/rustdoc``

3 years agoRollup merge of #79032 - lcnr:arg-count, r=varkor
Mara Bos [Mon, 16 Nov 2020 16:26:35 +0000 (17:26 +0100)]
Rollup merge of #79032 - lcnr:arg-count, r=varkor

improve type const mismatch errors

Doesn't completely remove `check_generic_arg_count` as that would have required some more complex changes but
instead checks type and const params in only one step. Also moved the help added by `@JulianKnodt` in #75611 to `generic_arg_mismatch_err`.

r? `@varkor` cc `@petrochenkov`

3 years agoRollup merge of #78903 - ssomers:btree_order_chaos_testing, r=Mark-Simulacrum
Mara Bos [Mon, 16 Nov 2020 16:26:33 +0000 (17:26 +0100)]
Rollup merge of #78903 - ssomers:btree_order_chaos_testing, r=Mark-Simulacrum

BTreeMap: test chaotic ordering & other bits & bobs

r? `@Mark-Simulacrum`

3 years agoRollup merge of #78769 - est31:remove_lifetimes, r=KodrAus
Mara Bos [Mon, 16 Nov 2020 16:26:29 +0000 (17:26 +0100)]
Rollup merge of #78769 - est31:remove_lifetimes, r=KodrAus

Remove unneeded lifetimes in array/mod.rs

3 years agoRollup merge of #78714 - m-ou-se:simplify-local-streams, r=KodrAus
Mara Bos [Mon, 16 Nov 2020 16:26:27 +0000 (17:26 +0100)]
Rollup merge of #78714 - m-ou-se:simplify-local-streams, r=KodrAus

Simplify output capturing

This is a sequence of incremental improvements to the unstable/internal `set_panic` and `set_print` mechanism used by the `test` crate:

1. Remove the `LocalOutput` trait and use `Arc<Mutex<dyn Write>>` instead of `Box<dyn LocalOutput>`. In practice, all implementations of `LocalOutput` were just `Arc<Mutex<..>>`. This simplifies some logic and removes all custom `Sink` implementations such as `library/test/src/helpers/sink.rs`. Also removes a layer of indirection, as the outermost `Box` is now gone. It also means that locking now happens per `write_fmt`, not per individual `write` within. (So `"{} {}\n"` now results in one `lock()`, not four or more.)

2. Since in all cases the `dyn Write`s were just `Vec<u8>`s, replace the type with `Arc<Mutex<Vec<u8>>>`. This simplifies things more, as error handling and flushing can be removed now. This also removes the hack needed in the default panic handler to make this work with `::realstd`, as (unlike `Write`) `Vec<u8>` is from `alloc`, not `std`.

3. Replace the `RefCell`s by regular `Cell`s. The `RefCell`s were mostly used as `mem::replace(&mut *cell.borrow_mut(), something)`, which is just `Cell::replace`. This removes an unecessary bookkeeping and makes the code a bit easier to read.

4. Merge `set_panic` and `set_print` into a single `set_output_capture`. Neither the test crate nor rustc (the only users of this feature) have a use for using these separately. Merging them simplifies things even more. This uses a new function name and feature name, to make it clearer this is internal and not supposed to be used by other crates.

Might be easier to review per commit.

3 years agoRollup merge of #78678 - Nemo157:doc-cfg-w-traits, r=jyn514,GuillaumeGomez
Mara Bos [Mon, 16 Nov 2020 16:26:25 +0000 (17:26 +0100)]
Rollup merge of #78678 - Nemo157:doc-cfg-w-traits, r=jyn514,GuillaumeGomez

Add tests and improve rendering of cfgs on traits

Shows the additional features required to get the trait implementation, suppressing any already shown on the current page. One interesting effect from this is if you have a cfg-ed type, implementing a cfg-ed trait (so the implementation depends on both cfgs), you will get the inverted pair of cfgs shown on each page:

![image](https://user-images.githubusercontent.com/81079/97904671-207bdc00-1d41-11eb-8144-707e8017d2b6.png)

![image](https://user-images.githubusercontent.com/81079/97904700-27a2ea00-1d41-11eb-8b9f-e925ba339044.png)

The hidden items on the trait implementation also now get the correct cfgs displayed on them.

Tests are blocked on #78673.

fixes #68100
cc #43781

3 years agoRollup merge of #78364 - XAMPPRocky:relnote-1.48.0, r=pietroalbini
Mara Bos [Mon, 16 Nov 2020 16:26:21 +0000 (17:26 +0100)]
Rollup merge of #78364 - XAMPPRocky:relnote-1.48.0, r=pietroalbini

Update RELEASES.md for 1.48.0

### [Rendered](https://github.com/XAMPPRocky/rust/blob/relnote-1.48.0/RELEASES.md)

r? `@Mark-Simulacrum`
cc `@rust-lang/release`

3 years agoRollup merge of #77691 - exrook:rename-layouterr, r=KodrAus
Mara Bos [Mon, 16 Nov 2020 16:26:17 +0000 (17:26 +0100)]
Rollup merge of #77691 - exrook:rename-layouterr, r=KodrAus

Rename/Deprecate LayoutErr in favor of LayoutError

Implements rust-lang/wg-allocators#73.

This patch renames LayoutErr to LayoutError, and uses a type alias to support users using the old name.

The new name will be instantly stable in release 1.49 (current nightly), the type alias will become deprecated in release 1.51 (so that when the current nightly is 1.51, 1.49 will be stable).

This is the only error type in `std` that ends in `Err` rather than `Error`, if this PR lands all stdlib error types will end in `Error` :smiling_face_with_three_hearts:

3 years agoRollup merge of #76339 - CDirkx:structural-match-range, r=Mark-Simulacrum
Mara Bos [Mon, 16 Nov 2020 16:26:13 +0000 (17:26 +0100)]
Rollup merge of #76339 - CDirkx:structural-match-range, r=Mark-Simulacrum

Test structural matching for all range types

As of #70166 all range types (`core::ops::Range` etc.) can be structurally matched upon, and by extension used in const generics. In reference to the fact that this is a publicly observable property of these types, and thus falls under the Rust stability guarantees of the standard library, a regression test was added in #70283.

This regression test was implemented by me by testing for the ability to use the range types within const generics, but that is not the actual property the std guarantees now (const generics is still unstable). This PR addresses that situation by adding extra tests for the range types that directly test whether they can be structurally matched upon.

Note: also adds the otherwise unrelated test `test_range_to_inclusive` for completeness with the other range unit tests

3 years agoRollup merge of #74989 - pubfnbar:impl-array-indexing, r=KodrAus
Mara Bos [Mon, 16 Nov 2020 16:26:11 +0000 (17:26 +0100)]
Rollup merge of #74989 - pubfnbar:impl-array-indexing, r=KodrAus

Implement `Index` and `IndexMut` for arrays

Adds implementations of `Index` and `IndexMut` for arrays that simply forward to the slice indexing implementation in order to fix the following problem:

If you implement `Index<MyIndexType>` for an array, you lose all the other indexing functionality that used to be available to the array via its implicit coercion to a slice. An example of what I'm talking about:
```rust
use std::ops::Index;

pub enum MyIndexType {
    _0, _1, _2, _3, _4, _5, _6, _7,
}

impl<T> Index<MyIndexType> for [T; 8] {
    type Output = T;

    fn index(&self, index: MyIndexType) -> &T {
        unsafe { self.get_unchecked(index as usize) }
    }
}

fn main() {
    let array = [11u8; 8];

    println!("{:?}", array[MyIndexType::_0]); // OK

    println!("{:?}", array[0usize]); // error[E0277]
    //               ^^^^^^^^^^^^^ `[u8; 8]` cannot be indexed by `usize`
}
```

3 years agoAdd test to ensure that "invalid HTML tag" lint isn't fired in code blocks
Guillaume Gomez [Mon, 16 Nov 2020 14:32:26 +0000 (15:32 +0100)]
Add test to ensure that "invalid HTML tag" lint isn't fired in code blocks

3 years agoUpdate E0744 about control flow in `const` contexts to reflect the current status...
James [Mon, 16 Nov 2020 02:34:16 +0000 (20:34 -0600)]
Update E0744 about control flow in `const` contexts to reflect the current status of `const fn`.

This is a squash of these commits:
- Update E0744 about control flow in `const` contexts to reflect current status of `const fn`.
- E0744 isn't just about `for` loops or control flow
- Fix formatting on E0744 cause my editor decided to not copy it well
- Improve wording
- Fix a markdown formatting error
- Fix E0744's description as I interpreted some code wrong
- Fix a minor wording issue again
- Add a few more links to blocking issues
- Improve links to tracking issues

3 years agoimprove error message for const ty param mismatch
Bastian Kauschke [Fri, 13 Nov 2020 19:23:37 +0000 (20:23 +0100)]
improve error message for const ty param mismatch

3 years agoDon't warn about invalid HTML tags in code blocks
Guillaume Gomez [Mon, 16 Nov 2020 14:31:35 +0000 (15:31 +0100)]
Don't warn about invalid HTML tags in code blocks

3 years agoImplement Index[Mut] for arrays
pubfnbar [Fri, 31 Jul 2020 20:19:10 +0000 (23:19 +0300)]
Implement Index[Mut] for arrays

Adds implementations of `Index` and `IndexMut` for arrays that simply forward to the slice indexing implementation.

3 years agoAuto merge of #78631 - ssomers:btree-alias_for_underfull, r=Mark-Simulacrum
bors [Mon, 16 Nov 2020 03:22:10 +0000 (03:22 +0000)]
Auto merge of #78631 - ssomers:btree-alias_for_underfull, r=Mark-Simulacrum

BTreeMap: fix pointer provenance rules in underfullness

Continuing on #78480, and for readability, and possibly for performance: avoid aliasing when handling underfull nodes, and consolidate the code doing that. In particular:
- Avoid the rather explicit aliasing for internal nodes in `remove_kv_tracking`.
- Climb down to the root to handle underfull nodes using a reborrowed handle, rather than one copied with `ptr::read`, before resuming on the leaf level.
- Integrate the code tracking leaf edge position into the functions performing changes, rather than bolting it on.

r? `@Mark-Simulacrum`

3 years agoAuto merge of #79074 - Mark-Simulacrum:fix-ci-llvm, r=jyn514
bors [Mon, 16 Nov 2020 00:40:04 +0000 (00:40 +0000)]
Auto merge of #79074 - Mark-Simulacrum:fix-ci-llvm, r=jyn514

Install CI llvm into the library directory

In other words, my concern in https://github.com/rust-lang/rust/issues/78932#issuecomment-725781767 was perfectly justified by something we were already doing. For now just special case CI LLVM, but in the future we may want a more general fix.

Fixes #79071.

r? `@alexcrichton`

3 years agoIgnore doctest for capture analysis examples
Aman Arora [Sun, 15 Nov 2020 23:06:30 +0000 (18:06 -0500)]
Ignore doctest for capture analysis examples

3 years agoFix case when ExprUseVisitor is called after typeck writeback
Aman Arora [Sun, 15 Nov 2020 22:09:51 +0000 (17:09 -0500)]
Fix case when ExprUseVisitor is called after typeck writeback

Clippy uses `ExprUseVisitor` and atleast in some cases it runs
after writeback.

We currently don't writeback the min_capture results of closure
capture analysis since no place within the compiler itself uses it.

In the short term to fix clippy we add a fallback when walking captures
of a closure to check if closure_capture analysis has any entries in it.

Writeback for closure_min_captures will be implemented in
rust-lang/project-rfc-2229#18

3 years agoAdd test to ensure that no DOS backline (\r\n) doesn't create extra backline in sourc...
Guillaume Gomez [Sun, 15 Nov 2020 19:51:25 +0000 (20:51 +0100)]
Add test to ensure that no DOS backline (\r\n) doesn't create extra backline in source rendering

3 years agodocument that __rust_alloc is also magic to our LLVM fork
Ralf Jung [Sun, 15 Nov 2020 17:40:49 +0000 (18:40 +0100)]
document that __rust_alloc is also magic to our LLVM fork

3 years agoMake `Playground` public for error index generator
Joshua Nelson [Sun, 15 Nov 2020 11:44:23 +0000 (06:44 -0500)]
Make `Playground` public for error index generator