From aff4cd5ce725602249c2554b04b1066d09acd31e Mon Sep 17 00:00:00 2001
From: Deadbeef
Date: Mon, 14 Jun 2021 01:49:37 +0800
Subject: [PATCH 01/24] Report Layout of enum variants
Followup of #83501, Fixes #86253.
---
src/librustdoc/html/render/print_item.rs | 36 +++++++++++++++++++++++-
src/test/rustdoc/type-layout.rs | 6 ++++
2 files changed, 41 insertions(+), 1 deletion(-)
diff --git a/src/librustdoc/html/render/print_item.rs b/src/librustdoc/html/render/print_item.rs
index 8f4857a693928..f362a288bcbf9 100644
--- a/src/librustdoc/html/render/print_item.rs
+++ b/src/librustdoc/html/render/print_item.rs
@@ -7,11 +7,13 @@ use rustc_data_structures::fx::FxHashMap;
use rustc_hir as hir;
use rustc_hir::def::CtorKind;
use rustc_hir::def_id::DefId;
+use rustc_middle::bug;
use rustc_middle::middle::stability;
use rustc_middle::ty::layout::LayoutError;
-use rustc_middle::ty::TyCtxt;
+use rustc_middle::ty::{Adt, TyCtxt};
use rustc_span::hygiene::MacroKind;
use rustc_span::symbol::{kw, sym, Symbol};
+use rustc_target::abi::Variants;
use super::{
collect_paths_for_type, document, ensure_trailing_slash, item_ty_to_strs, notable_traits_decl,
@@ -1636,6 +1638,38 @@ fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
pl = if bytes == 1 { "" } else { "s" },
);
}
+ if let Variants::Multiple { variants, .. } = &ty_layout.layout.variants {
+ if !variants.is_empty() {
+ w.write_str(
+ "\
+ Size for each variant:\
+
",
+ );
+
+ let adt = if let Adt(adt, _) = ty_layout.ty.kind() {
+ adt
+ } else {
+ bug!("not an adt")
+ };
+
+ for (index, layout) in variants.iter_enumerated() {
+ let ident = adt.variants[index].ident;
+ if layout.abi.is_unsized() {
+ writeln!(w, "{name}
(unsized) ", name = ident);
+ } else {
+ let bytes = layout.size.bytes();
+ writeln!(
+ w,
+ "{name}
: {size} byte{pl} ",
+ name = ident,
+ size = bytes,
+ pl = if bytes == 1 { "" } else { "s" },
+ );
+ }
+ }
+ w.write_str("
");
+ }
+ }
}
// This kind of layout error can occur with valid code, e.g. if you try to
// get the layout of a generic type such as `Vec`.
diff --git a/src/test/rustdoc/type-layout.rs b/src/test/rustdoc/type-layout.rs
index 272911de6815b..f398dd776d9c6 100644
--- a/src/test/rustdoc/type-layout.rs
+++ b/src/test/rustdoc/type-layout.rs
@@ -52,3 +52,9 @@ pub struct Unsized([u8]);
// @!has type_layout/trait.MyTrait.html 'Size: '
pub trait MyTrait {}
+
+// @has type_layout/enum.Variants.html '1 byte'
+pub enum Variants {
+ A,
+ B(u8),
+}
From c349b79029770e39963fadf5021cfa6a6cfe5472 Mon Sep 17 00:00:00 2001
From: Deadbeef
Date: Fri, 9 Jul 2021 22:25:46 +0800
Subject: [PATCH 02/24] Apply suggestions
---
src/librustdoc/html/render/print_item.rs | 44 ++++++++++--------------
1 file changed, 18 insertions(+), 26 deletions(-)
diff --git a/src/librustdoc/html/render/print_item.rs b/src/librustdoc/html/render/print_item.rs
index f362a288bcbf9..b25323c4e0a74 100644
--- a/src/librustdoc/html/render/print_item.rs
+++ b/src/librustdoc/html/render/print_item.rs
@@ -7,13 +7,13 @@ use rustc_data_structures::fx::FxHashMap;
use rustc_hir as hir;
use rustc_hir::def::CtorKind;
use rustc_hir::def_id::DefId;
-use rustc_middle::bug;
use rustc_middle::middle::stability;
+use rustc_middle::span_bug;
use rustc_middle::ty::layout::LayoutError;
use rustc_middle::ty::{Adt, TyCtxt};
use rustc_span::hygiene::MacroKind;
use rustc_span::symbol::{kw, sym, Symbol};
-use rustc_target::abi::Variants;
+use rustc_target::abi::{Layout, Variants};
use super::{
collect_paths_for_type, document, ensure_trailing_slash, item_ty_to_strs, notable_traits_decl,
@@ -1606,6 +1606,15 @@ fn document_non_exhaustive(w: &mut Buffer, item: &clean::Item) {
}
fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
+ fn write_size_of_layout(w: &mut Buffer, layout: &Layout) {
+ if layout.abi.is_unsized() {
+ write!(w, "(unsized)");
+ } else {
+ let bytes = layout.size.bytes();
+ write!(w, "{size} byte{pl}", size = bytes, pl = if bytes == 1 { "" } else { "s" },);
+ }
+ }
+
if !cx.shared.show_type_layout {
return;
}
@@ -1627,17 +1636,9 @@ fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
“Type Layout” \
chapter for details on type layout guarantees."
);
- if ty_layout.layout.abi.is_unsized() {
- writeln!(w, "Size: (unsized)
");
- } else {
- let bytes = ty_layout.layout.size.bytes();
- writeln!(
- w,
- "Size: {size} byte{pl}
",
- size = bytes,
- pl = if bytes == 1 { "" } else { "s" },
- );
- }
+ w.write_str("Size: ");
+ write_size_of_layout(w, ty_layout.layout);
+ writeln!(w, "
");
if let Variants::Multiple { variants, .. } = &ty_layout.layout.variants {
if !variants.is_empty() {
w.write_str(
@@ -1649,23 +1650,14 @@ fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
let adt = if let Adt(adt, _) = ty_layout.ty.kind() {
adt
} else {
- bug!("not an adt")
+ span_bug!(tcx.def_span(ty_def_id), "not an adt")
};
for (index, layout) in variants.iter_enumerated() {
let ident = adt.variants[index].ident;
- if layout.abi.is_unsized() {
- writeln!(w, "{name}
(unsized)", name = ident);
- } else {
- let bytes = layout.size.bytes();
- writeln!(
- w,
- "{name}
: {size} byte{pl}",
- name = ident,
- size = bytes,
- pl = if bytes == 1 { "" } else { "s" },
- );
- }
+ write!(w, "{name}
", name = ident);
+ write_size_of_layout(w, layout);
+ writeln!(w, "");
}
w.write_str("");
}
From 8096910b54920f4c3334de555ee9dd265ed6f49d Mon Sep 17 00:00:00 2001
From: Deadbeef
Date: Sat, 10 Jul 2021 21:35:40 +0800
Subject: [PATCH 03/24] Report variant size without the discriminant
---
src/librustdoc/html/render/print_item.rs | 20 +++++++++++++-------
src/test/rustdoc/type-layout.rs | 3 ++-
2 files changed, 15 insertions(+), 8 deletions(-)
diff --git a/src/librustdoc/html/render/print_item.rs b/src/librustdoc/html/render/print_item.rs
index b25323c4e0a74..4e90e611a16ae 100644
--- a/src/librustdoc/html/render/print_item.rs
+++ b/src/librustdoc/html/render/print_item.rs
@@ -13,7 +13,7 @@ use rustc_middle::ty::layout::LayoutError;
use rustc_middle::ty::{Adt, TyCtxt};
use rustc_span::hygiene::MacroKind;
use rustc_span::symbol::{kw, sym, Symbol};
-use rustc_target::abi::{Layout, Variants};
+use rustc_target::abi::{Layout, Primitive, Variants};
use super::{
collect_paths_for_type, document, ensure_trailing_slash, item_ty_to_strs, notable_traits_decl,
@@ -1606,11 +1606,11 @@ fn document_non_exhaustive(w: &mut Buffer, item: &clean::Item) {
}
fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
- fn write_size_of_layout(w: &mut Buffer, layout: &Layout) {
+ fn write_size_of_layout(w: &mut Buffer, layout: &Layout, tag_size: u64) {
if layout.abi.is_unsized() {
write!(w, "(unsized)");
} else {
- let bytes = layout.size.bytes();
+ let bytes = layout.size.bytes() - tag_size;
write!(w, "{size} byte{pl}", size = bytes, pl = if bytes == 1 { "" } else { "s" },);
}
}
@@ -1637,9 +1637,9 @@ fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
chapter for details on type layout guarantees."
);
w.write_str("Size: ");
- write_size_of_layout(w, ty_layout.layout);
+ write_size_of_layout(w, ty_layout.layout, 0);
writeln!(w, "
");
- if let Variants::Multiple { variants, .. } = &ty_layout.layout.variants {
+ if let Variants::Multiple { variants, tag, .. } = &ty_layout.layout.variants {
if !variants.is_empty() {
w.write_str(
"\
@@ -1653,10 +1653,16 @@ fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
span_bug!(tcx.def_span(ty_def_id), "not an adt")
};
+ let tag_size = if let Primitive::Int(i, _) = tag.value {
+ i.size().bytes()
+ } else {
+ span_bug!(tcx.def_span(ty_def_id), "tag is not int")
+ };
+
for (index, layout) in variants.iter_enumerated() {
let ident = adt.variants[index].ident;
- write!(w, "
{name}
", name = ident);
- write_size_of_layout(w, layout);
+ write!(w, "{name}
: ", name = ident);
+ write_size_of_layout(w, layout, tag_size);
writeln!(w, "");
}
w.write_str("");
diff --git a/src/test/rustdoc/type-layout.rs b/src/test/rustdoc/type-layout.rs
index f398dd776d9c6..bc1b65c46e24a 100644
--- a/src/test/rustdoc/type-layout.rs
+++ b/src/test/rustdoc/type-layout.rs
@@ -53,7 +53,8 @@ pub struct Unsized([u8]);
// @!has type_layout/trait.MyTrait.html 'Size: '
pub trait MyTrait {}
-// @has type_layout/enum.Variants.html '1 byte'
+// @has type_layout/enum.Variants.html 'A
: 0 bytes'
+// @has - 'B
: 1 byte'
pub enum Variants {
A,
B(u8),
From 5f1505e7f13fdea3f2d626059010cf26edfce4f8 Mon Sep 17 00:00:00 2001
From: Deadbeef
Date: Tue, 31 Aug 2021 05:24:08 +0000
Subject: [PATCH 04/24] Apply suggestions
---
src/librustdoc/html/render/print_item.rs | 5 ++---
src/test/rustdoc/type-layout.rs | 4 +++-
2 files changed, 5 insertions(+), 4 deletions(-)
diff --git a/src/librustdoc/html/render/print_item.rs b/src/librustdoc/html/render/print_item.rs
index 4e90e611a16ae..6054073bf79b2 100644
--- a/src/librustdoc/html/render/print_item.rs
+++ b/src/librustdoc/html/render/print_item.rs
@@ -1642,8 +1642,7 @@ fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
if let Variants::Multiple { variants, tag, .. } = &ty_layout.layout.variants {
if !variants.is_empty() {
w.write_str(
- "\
- Size for each variant:\
+ "
Size for each variant:
\
",
);
@@ -1665,7 +1664,7 @@ fn document_type_layout(w: &mut Buffer, cx: &Context<'_>, ty_def_id: DefId) {
write_size_of_layout(w, layout, tag_size);
writeln!(w, "");
}
- w.write_str("
");
+ w.write_str("");
}
}
}
diff --git a/src/test/rustdoc/type-layout.rs b/src/test/rustdoc/type-layout.rs
index bc1b65c46e24a..8c4f4f8fc98e6 100644
--- a/src/test/rustdoc/type-layout.rs
+++ b/src/test/rustdoc/type-layout.rs
@@ -53,7 +53,9 @@ pub struct Unsized([u8]);
// @!has type_layout/trait.MyTrait.html 'Size: '
pub trait MyTrait {}
-// @has type_layout/enum.Variants.html 'A
: 0 bytes'
+// @has type_layout/enum.Variants.html 'Size: '
+// @has - '2 bytes'
+// @has - 'A
: 0 bytes'
// @has - 'B
: 1 byte'
pub enum Variants {
A,
From 6cfe98f1962c442504a0b56f260620f1bccd7601 Mon Sep 17 00:00:00 2001
From: Theodore Luo Wang
Date: Tue, 31 Aug 2021 23:07:58 -0400
Subject: [PATCH 05/24] Improve error checking on unary plus
---
compiler/rustc_parse/src/parser/expr.rs | 12 +++
.../did_you_mean/issue-88276-unary-plus.fixed | 13 +++
.../ui/did_you_mean/issue-88276-unary-plus.rs | 13 +++
.../issue-88276-unary-plus.stderr | 83 +++++++++++++++++++
4 files changed, 121 insertions(+)
create mode 100644 src/test/ui/did_you_mean/issue-88276-unary-plus.fixed
create mode 100644 src/test/ui/did_you_mean/issue-88276-unary-plus.rs
create mode 100644 src/test/ui/did_you_mean/issue-88276-unary-plus.stderr
diff --git a/compiler/rustc_parse/src/parser/expr.rs b/compiler/rustc_parse/src/parser/expr.rs
index 326c8f81ffbf9..88dae48a9013d 100644
--- a/compiler/rustc_parse/src/parser/expr.rs
+++ b/compiler/rustc_parse/src/parser/expr.rs
@@ -23,6 +23,8 @@ use rustc_span::symbol::{kw, sym, Ident, Symbol};
use rustc_span::{BytePos, Pos};
use std::mem;
+use tracing::debug;
+
/// Possibly accepts an `token::Interpolated` expression (a pre-parsed expression
/// dropped into the token stream, which happens while parsing the result of
/// macro expansion). Placement of these is not as complex as I feared it would
@@ -355,6 +357,7 @@ impl<'a> Parser<'a> {
/// but the next token implies this should be parsed as an expression.
/// For example: `if let Some(x) = x { x } else { 0 } / 2`.
fn error_found_expr_would_be_stmt(&self, lhs: &Expr) {
+ debug!("error_found_expr_would_be_stmt(lhs: {:?})", lhs);
let mut err = self.struct_span_err(
self.token.span,
&format!("expected expression, found `{}`", pprust::token_to_string(&self.token),),
@@ -516,6 +519,15 @@ impl<'a> Parser<'a> {
token::BinOp(token::And) | token::AndAnd => {
make_it!(this, attrs, |this, _| this.parse_borrow_expr(lo))
}
+ token::BinOp(token::Plus) => {
+ this.struct_span_err(lo, "leading `+` is not supported")
+ .span_label(lo, "unexpected `+`")
+ .span_suggestion_short(lo, "remove the `+`", "".to_string(), Applicability::MachineApplicable)
+ .emit();
+ this.bump();
+
+ this.parse_prefix_expr(None)
+ } // `+expr`
token::Ident(..) if this.token.is_keyword(kw::Box) => {
make_it!(this, attrs, |this, _| this.parse_box_expr(lo))
}
diff --git a/src/test/ui/did_you_mean/issue-88276-unary-plus.fixed b/src/test/ui/did_you_mean/issue-88276-unary-plus.fixed
new file mode 100644
index 0000000000000..4bd248663b884
--- /dev/null
+++ b/src/test/ui/did_you_mean/issue-88276-unary-plus.fixed
@@ -0,0 +1,13 @@
+// run-rustfix
+#[allow(unused_parens)]
+fn main() {
+ let _ = 1; //~ ERROR leading `+` is not supported
+ let _ = -(1+2)*3; //~ ERROR leading `+` is not supported
+ let _ = -(1+2)*3; //~ ERROR leading `+` is not supported
+ //~| ERROR leading `+` is not supported
+ let _ = --(1+2)*3; //~ ERROR leading `+` is not supported
+ //~| ERROR leading `+` is not supported
+ let _ = (&"hello"); //~ ERROR leading `+` is not supported
+ let _ = [3, 4+6]; //~ ERROR leading `+` is not supported
+ //~| ERROR leading `+` is not supported
+}
diff --git a/src/test/ui/did_you_mean/issue-88276-unary-plus.rs b/src/test/ui/did_you_mean/issue-88276-unary-plus.rs
new file mode 100644
index 0000000000000..e2cce677b4755
--- /dev/null
+++ b/src/test/ui/did_you_mean/issue-88276-unary-plus.rs
@@ -0,0 +1,13 @@
+// run-rustfix
+#[allow(unused_parens)]
+fn main() {
+ let _ = +1; //~ ERROR leading `+` is not supported
+ let _ = -+(1+2)*3; //~ ERROR leading `+` is not supported
+ let _ = +-+(1+2)*3; //~ ERROR leading `+` is not supported
+ //~| ERROR leading `+` is not supported
+ let _ = -+-+(1+2)*3; //~ ERROR leading `+` is not supported
+ //~| ERROR leading `+` is not supported
+ let _ = (+&"hello"); //~ ERROR leading `+` is not supported
+ let _ = +[+3, 4+6]; //~ ERROR leading `+` is not supported
+ //~| ERROR leading `+` is not supported
+}
diff --git a/src/test/ui/did_you_mean/issue-88276-unary-plus.stderr b/src/test/ui/did_you_mean/issue-88276-unary-plus.stderr
new file mode 100644
index 0000000000000..9c1227d7c351a
--- /dev/null
+++ b/src/test/ui/did_you_mean/issue-88276-unary-plus.stderr
@@ -0,0 +1,83 @@
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:4:13
+ |
+LL | let _ = +1;
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:5:14
+ |
+LL | let _ = -+(1+2)*3;
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:6:13
+ |
+LL | let _ = +-+(1+2)*3;
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:6:15
+ |
+LL | let _ = +-+(1+2)*3;
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:8:14
+ |
+LL | let _ = -+-+(1+2)*3;
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:8:16
+ |
+LL | let _ = -+-+(1+2)*3;
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:10:14
+ |
+LL | let _ = (+&"hello");
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:11:13
+ |
+LL | let _ = +[+3, 4+6];
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:11:15
+ |
+LL | let _ = +[+3, 4+6];
+ | ^
+ | |
+ | unexpected `+`
+ | help: remove the `+`
+
+error: aborting due to 9 previous errors
+
From e7fb98e7258557034f0d0caf81a53b0070a87297 Mon Sep 17 00:00:00 2001
From: Theodore Luo Wang
Date: Tue, 31 Aug 2021 23:09:43 -0400
Subject: [PATCH 06/24] Apply formatting
---
compiler/rustc_parse/src/parser/expr.rs | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/compiler/rustc_parse/src/parser/expr.rs b/compiler/rustc_parse/src/parser/expr.rs
index 88dae48a9013d..43de53e87231f 100644
--- a/compiler/rustc_parse/src/parser/expr.rs
+++ b/compiler/rustc_parse/src/parser/expr.rs
@@ -522,7 +522,12 @@ impl<'a> Parser<'a> {
token::BinOp(token::Plus) => {
this.struct_span_err(lo, "leading `+` is not supported")
.span_label(lo, "unexpected `+`")
- .span_suggestion_short(lo, "remove the `+`", "".to_string(), Applicability::MachineApplicable)
+ .span_suggestion_short(
+ lo,
+ "remove the `+`",
+ "".to_string(),
+ Applicability::MachineApplicable,
+ )
.emit();
this.bump();
From 5a863d594c725d09ab8f0df5caba374d72200976 Mon Sep 17 00:00:00 2001
From: Theodore Luo Wang
Date: Wed, 1 Sep 2021 11:54:06 -0400
Subject: [PATCH 07/24] Add checks for a block before a unary plus. Fix failing
tests
---
compiler/rustc_parse/src/parser/expr.rs | 30 ++++++++---
compiler/rustc_parse/src/parser/stmt.rs | 3 ++
.../ui/associated-types/issue-36499.stderr | 7 ++-
src/test/ui/parser/expr-as-stmt.fixed | 6 +--
src/test/ui/parser/expr-as-stmt.rs | 6 +--
src/test/ui/parser/expr-as-stmt.stderr | 12 ++---
.../issue-88276-unary-plus.fixed | 4 +-
.../issue-88276-unary-plus.rs | 4 +-
.../issue-88276-unary-plus.stderr | 54 +++++++++----------
9 files changed, 73 insertions(+), 53 deletions(-)
rename src/test/ui/{did_you_mean => parser}/issue-88276-unary-plus.fixed (78%)
rename src/test/ui/{did_you_mean => parser}/issue-88276-unary-plus.rs (78%)
rename src/test/ui/{did_you_mean => parser}/issue-88276-unary-plus.stderr (61%)
diff --git a/compiler/rustc_parse/src/parser/expr.rs b/compiler/rustc_parse/src/parser/expr.rs
index 43de53e87231f..c887f9fe0cf59 100644
--- a/compiler/rustc_parse/src/parser/expr.rs
+++ b/compiler/rustc_parse/src/parser/expr.rs
@@ -165,9 +165,12 @@ impl<'a> Parser<'a> {
if [token::DotDot, token::DotDotDot, token::DotDotEq].contains(&self.token.kind) {
return self.parse_prefix_range_expr(attrs);
} else {
- self.parse_prefix_expr(attrs)?
+ let result = self.parse_prefix_expr(attrs);
+ debug!("parse_prefix_expr result: {:?}", &result);
+ result?
}
};
+ debug!("parse_assoc_expr_with(lhs = {:?})", &lhs);
let last_type_ascription_set = self.last_type_ascription.is_some();
if !self.should_continue_as_assoc_expr(&lhs) {
@@ -175,8 +178,11 @@ impl<'a> Parser<'a> {
return Ok(lhs);
}
+ debug!("continue_as_assoc_expr");
+
self.expected_tokens.push(TokenType::Operator);
while let Some(op) = self.check_assoc_op() {
+ debug!("op: {:?}", op);
// Adjust the span for interpolated LHS to point to the `$lhs` token
// and not to what it refers to.
let lhs_span = match self.prev_token.kind {
@@ -520,17 +526,25 @@ impl<'a> Parser<'a> {
make_it!(this, attrs, |this, _| this.parse_borrow_expr(lo))
}
token::BinOp(token::Plus) => {
- this.struct_span_err(lo, "leading `+` is not supported")
- .span_label(lo, "unexpected `+`")
- .span_suggestion_short(
+ debug!("leading + detected: {:?}", lo);
+ let mut err = this.struct_span_err(lo, "leading `+` is not supported");
+ err.span_label(lo, "unexpected `+`");
+
+ // a block on the LHS might have been intended to be an expression instead
+ let sp = this.sess.source_map().start_point(lo);
+ if let Some(sp) = this.sess.ambiguous_block_expr_parse.borrow().get(&sp) {
+ this.sess.expr_parentheses_needed(&mut err, *sp);
+ } else {
+ err.span_suggestion(
lo,
- "remove the `+`",
+ "try removing the `+`",
"".to_string(),
Applicability::MachineApplicable,
- )
- .emit();
- this.bump();
+ );
+ }
+ err.emit();
+ this.bump();
this.parse_prefix_expr(None)
} // `+expr`
token::Ident(..) if this.token.is_keyword(kw::Box) => {
diff --git a/compiler/rustc_parse/src/parser/stmt.rs b/compiler/rustc_parse/src/parser/stmt.rs
index 85515bd2a6314..329b60f9a8711 100644
--- a/compiler/rustc_parse/src/parser/stmt.rs
+++ b/compiler/rustc_parse/src/parser/stmt.rs
@@ -21,6 +21,8 @@ use rustc_span::symbol::{kw, sym};
use std::mem;
+use tracing::debug;
+
impl<'a> Parser<'a> {
/// Parses a statement. This stops just before trailing semicolons on everything but items.
/// e.g., a `StmtKind::Semi` parses to a `StmtKind::Expr`, leaving the trailing `;` unconsumed.
@@ -418,6 +420,7 @@ impl<'a> Parser<'a> {
if self.token == token::Eof {
break;
}
+ debug!("parsing statements, stmts: {:?}", &stmts);
let stmt = match self.parse_full_stmt(recover) {
Err(mut err) if recover.yes() => {
self.maybe_annotate_with_ascription(&mut err, false);
diff --git a/src/test/ui/associated-types/issue-36499.stderr b/src/test/ui/associated-types/issue-36499.stderr
index ff450f60acc68..990ef09e3f742 100644
--- a/src/test/ui/associated-types/issue-36499.stderr
+++ b/src/test/ui/associated-types/issue-36499.stderr
@@ -1,8 +1,11 @@
-error: expected expression, found `+`
+error: leading `+` is not supported
--> $DIR/issue-36499.rs:4:9
|
LL | 2 + +2;
- | ^ expected expression
+ | ^
+ | |
+ | unexpected `+`
+ | help: try removing the `+`
error: aborting due to previous error
diff --git a/src/test/ui/parser/expr-as-stmt.fixed b/src/test/ui/parser/expr-as-stmt.fixed
index c217ab9774fd2..79d73090a0420 100644
--- a/src/test/ui/parser/expr-as-stmt.fixed
+++ b/src/test/ui/parser/expr-as-stmt.fixed
@@ -5,18 +5,18 @@
#![allow(unused_must_use)]
fn foo() -> i32 {
- ({2}) + {2} //~ ERROR expected expression, found `+`
+ ({2}) + {2} //~ ERROR leading `+` is not supported
//~^ ERROR mismatched types
}
fn bar() -> i32 {
- ({2}) + 2 //~ ERROR expected expression, found `+`
+ ({2}) + 2 //~ ERROR leading `+` is not supported
//~^ ERROR mismatched types
}
fn zul() -> u32 {
let foo = 3;
- ({ 42 }) + foo; //~ ERROR expected expression, found `+`
+ ({ 42 }) + foo; //~ ERROR leading `+` is not supported
//~^ ERROR mismatched types
32
}
diff --git a/src/test/ui/parser/expr-as-stmt.rs b/src/test/ui/parser/expr-as-stmt.rs
index b04025faaec63..8698f99b81a41 100644
--- a/src/test/ui/parser/expr-as-stmt.rs
+++ b/src/test/ui/parser/expr-as-stmt.rs
@@ -5,18 +5,18 @@
#![allow(unused_must_use)]
fn foo() -> i32 {
- {2} + {2} //~ ERROR expected expression, found `+`
+ {2} + {2} //~ ERROR leading `+` is not supported
//~^ ERROR mismatched types
}
fn bar() -> i32 {
- {2} + 2 //~ ERROR expected expression, found `+`
+ {2} + 2 //~ ERROR leading `+` is not supported
//~^ ERROR mismatched types
}
fn zul() -> u32 {
let foo = 3;
- { 42 } + foo; //~ ERROR expected expression, found `+`
+ { 42 } + foo; //~ ERROR leading `+` is not supported
//~^ ERROR mismatched types
32
}
diff --git a/src/test/ui/parser/expr-as-stmt.stderr b/src/test/ui/parser/expr-as-stmt.stderr
index ba5cd01abfcc7..91f97c4662a97 100644
--- a/src/test/ui/parser/expr-as-stmt.stderr
+++ b/src/test/ui/parser/expr-as-stmt.stderr
@@ -1,30 +1,30 @@
-error: expected expression, found `+`
+error: leading `+` is not supported
--> $DIR/expr-as-stmt.rs:8:9
|
LL | {2} + {2}
- | ^ expected expression
+ | ^ unexpected `+`
|
help: parentheses are required to parse this as an expression
|
LL | ({2}) + {2}
| + +
-error: expected expression, found `+`
+error: leading `+` is not supported
--> $DIR/expr-as-stmt.rs:13:9
|
LL | {2} + 2
- | ^ expected expression
+ | ^ unexpected `+`
|
help: parentheses are required to parse this as an expression
|
LL | ({2}) + 2
| + +
-error: expected expression, found `+`
+error: leading `+` is not supported
--> $DIR/expr-as-stmt.rs:19:12
|
LL | { 42 } + foo;
- | ^ expected expression
+ | ^ unexpected `+`
|
help: parentheses are required to parse this as an expression
|
diff --git a/src/test/ui/did_you_mean/issue-88276-unary-plus.fixed b/src/test/ui/parser/issue-88276-unary-plus.fixed
similarity index 78%
rename from src/test/ui/did_you_mean/issue-88276-unary-plus.fixed
rename to src/test/ui/parser/issue-88276-unary-plus.fixed
index 4bd248663b884..279cdb5060a42 100644
--- a/src/test/ui/did_you_mean/issue-88276-unary-plus.fixed
+++ b/src/test/ui/parser/issue-88276-unary-plus.fixed
@@ -3,10 +3,10 @@
fn main() {
let _ = 1; //~ ERROR leading `+` is not supported
let _ = -(1+2)*3; //~ ERROR leading `+` is not supported
- let _ = -(1+2)*3; //~ ERROR leading `+` is not supported
- //~| ERROR leading `+` is not supported
let _ = --(1+2)*3; //~ ERROR leading `+` is not supported
//~| ERROR leading `+` is not supported
+ let _ = (1 + 2) * 3; //~ ERROR leading `+` is not supported
+ //~| ERROR leading `+` is not supported
let _ = (&"hello"); //~ ERROR leading `+` is not supported
let _ = [3, 4+6]; //~ ERROR leading `+` is not supported
//~| ERROR leading `+` is not supported
diff --git a/src/test/ui/did_you_mean/issue-88276-unary-plus.rs b/src/test/ui/parser/issue-88276-unary-plus.rs
similarity index 78%
rename from src/test/ui/did_you_mean/issue-88276-unary-plus.rs
rename to src/test/ui/parser/issue-88276-unary-plus.rs
index e2cce677b4755..a72dad4dc7198 100644
--- a/src/test/ui/did_you_mean/issue-88276-unary-plus.rs
+++ b/src/test/ui/parser/issue-88276-unary-plus.rs
@@ -3,10 +3,10 @@
fn main() {
let _ = +1; //~ ERROR leading `+` is not supported
let _ = -+(1+2)*3; //~ ERROR leading `+` is not supported
- let _ = +-+(1+2)*3; //~ ERROR leading `+` is not supported
- //~| ERROR leading `+` is not supported
let _ = -+-+(1+2)*3; //~ ERROR leading `+` is not supported
//~| ERROR leading `+` is not supported
+ let _ = (1 + +2) * +3; //~ ERROR leading `+` is not supported
+ //~| ERROR leading `+` is not supported
let _ = (+&"hello"); //~ ERROR leading `+` is not supported
let _ = +[+3, 4+6]; //~ ERROR leading `+` is not supported
//~| ERROR leading `+` is not supported
diff --git a/src/test/ui/did_you_mean/issue-88276-unary-plus.stderr b/src/test/ui/parser/issue-88276-unary-plus.stderr
similarity index 61%
rename from src/test/ui/did_you_mean/issue-88276-unary-plus.stderr
rename to src/test/ui/parser/issue-88276-unary-plus.stderr
index 9c1227d7c351a..255839bc684b5 100644
--- a/src/test/ui/did_you_mean/issue-88276-unary-plus.stderr
+++ b/src/test/ui/parser/issue-88276-unary-plus.stderr
@@ -5,7 +5,7 @@ LL | let _ = +1;
| ^
| |
| unexpected `+`
- | help: remove the `+`
+ | help: try removing the `+`
error: leading `+` is not supported
--> $DIR/issue-88276-unary-plus.rs:5:14
@@ -14,43 +14,43 @@ LL | let _ = -+(1+2)*3;
| ^
| |
| unexpected `+`
- | help: remove the `+`
+ | help: try removing the `+`
error: leading `+` is not supported
- --> $DIR/issue-88276-unary-plus.rs:6:13
- |
-LL | let _ = +-+(1+2)*3;
- | ^
- | |
- | unexpected `+`
- | help: remove the `+`
-
-error: leading `+` is not supported
- --> $DIR/issue-88276-unary-plus.rs:6:15
- |
-LL | let _ = +-+(1+2)*3;
- | ^
- | |
- | unexpected `+`
- | help: remove the `+`
-
-error: leading `+` is not supported
- --> $DIR/issue-88276-unary-plus.rs:8:14
+ --> $DIR/issue-88276-unary-plus.rs:6:14
|
LL | let _ = -+-+(1+2)*3;
| ^
| |
| unexpected `+`
- | help: remove the `+`
+ | help: try removing the `+`
error: leading `+` is not supported
- --> $DIR/issue-88276-unary-plus.rs:8:16
+ --> $DIR/issue-88276-unary-plus.rs:6:16
|
LL | let _ = -+-+(1+2)*3;
| ^
| |
| unexpected `+`
- | help: remove the `+`
+ | help: try removing the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:8:18
+ |
+LL | let _ = (1 + +2) * +3;
+ | ^
+ | |
+ | unexpected `+`
+ | help: try removing the `+`
+
+error: leading `+` is not supported
+ --> $DIR/issue-88276-unary-plus.rs:8:24
+ |
+LL | let _ = (1 + +2) * +3;
+ | ^
+ | |
+ | unexpected `+`
+ | help: try removing the `+`
error: leading `+` is not supported
--> $DIR/issue-88276-unary-plus.rs:10:14
@@ -59,7 +59,7 @@ LL | let _ = (+&"hello");
| ^
| |
| unexpected `+`
- | help: remove the `+`
+ | help: try removing the `+`
error: leading `+` is not supported
--> $DIR/issue-88276-unary-plus.rs:11:13
@@ -68,7 +68,7 @@ LL | let _ = +[+3, 4+6];
| ^
| |
| unexpected `+`
- | help: remove the `+`
+ | help: try removing the `+`
error: leading `+` is not supported
--> $DIR/issue-88276-unary-plus.rs:11:15
@@ -77,7 +77,7 @@ LL | let _ = +[+3, 4+6];
| ^
| |
| unexpected `+`
- | help: remove the `+`
+ | help: try removing the `+`
error: aborting due to 9 previous errors
From ce9e76528abea4d5bc8d360e3c6d40e61cffb889 Mon Sep 17 00:00:00 2001
From: Theodore Luo Wang
Date: Wed, 1 Sep 2021 11:55:36 -0400
Subject: [PATCH 08/24] Update formatting
---
compiler/rustc_parse/src/parser/expr.rs | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/compiler/rustc_parse/src/parser/expr.rs b/compiler/rustc_parse/src/parser/expr.rs
index c887f9fe0cf59..b0f29601417cb 100644
--- a/compiler/rustc_parse/src/parser/expr.rs
+++ b/compiler/rustc_parse/src/parser/expr.rs
@@ -535,7 +535,7 @@ impl<'a> Parser<'a> {
if let Some(sp) = this.sess.ambiguous_block_expr_parse.borrow().get(&sp) {
this.sess.expr_parentheses_needed(&mut err, *sp);
} else {
- err.span_suggestion(
+ err.span_suggestion(
lo,
"try removing the `+`",
"".to_string(),
From bc9877c5af5155174f1a517d41d997b446cc074e Mon Sep 17 00:00:00 2001
From: Theodore Luo Wang
Date: Wed, 1 Sep 2021 12:02:11 -0400
Subject: [PATCH 09/24] Undo debug statements
---
compiler/rustc_parse/src/parser/expr.rs | 12 +-----------
compiler/rustc_parse/src/parser/stmt.rs | 3 ---
2 files changed, 1 insertion(+), 14 deletions(-)
diff --git a/compiler/rustc_parse/src/parser/expr.rs b/compiler/rustc_parse/src/parser/expr.rs
index b0f29601417cb..4463d2fc6c8da 100644
--- a/compiler/rustc_parse/src/parser/expr.rs
+++ b/compiler/rustc_parse/src/parser/expr.rs
@@ -23,8 +23,6 @@ use rustc_span::symbol::{kw, sym, Ident, Symbol};
use rustc_span::{BytePos, Pos};
use std::mem;
-use tracing::debug;
-
/// Possibly accepts an `token::Interpolated` expression (a pre-parsed expression
/// dropped into the token stream, which happens while parsing the result of
/// macro expansion). Placement of these is not as complex as I feared it would
@@ -165,12 +163,9 @@ impl<'a> Parser<'a> {
if [token::DotDot, token::DotDotDot, token::DotDotEq].contains(&self.token.kind) {
return self.parse_prefix_range_expr(attrs);
} else {
- let result = self.parse_prefix_expr(attrs);
- debug!("parse_prefix_expr result: {:?}", &result);
- result?
+ self.parse_prefix_expr(attrs)?
}
};
- debug!("parse_assoc_expr_with(lhs = {:?})", &lhs);
let last_type_ascription_set = self.last_type_ascription.is_some();
if !self.should_continue_as_assoc_expr(&lhs) {
@@ -178,11 +173,8 @@ impl<'a> Parser<'a> {
return Ok(lhs);
}
- debug!("continue_as_assoc_expr");
-
self.expected_tokens.push(TokenType::Operator);
while let Some(op) = self.check_assoc_op() {
- debug!("op: {:?}", op);
// Adjust the span for interpolated LHS to point to the `$lhs` token
// and not to what it refers to.
let lhs_span = match self.prev_token.kind {
@@ -363,7 +355,6 @@ impl<'a> Parser<'a> {
/// but the next token implies this should be parsed as an expression.
/// For example: `if let Some(x) = x { x } else { 0 } / 2`.
fn error_found_expr_would_be_stmt(&self, lhs: &Expr) {
- debug!("error_found_expr_would_be_stmt(lhs: {:?})", lhs);
let mut err = self.struct_span_err(
self.token.span,
&format!("expected expression, found `{}`", pprust::token_to_string(&self.token),),
@@ -526,7 +517,6 @@ impl<'a> Parser<'a> {
make_it!(this, attrs, |this, _| this.parse_borrow_expr(lo))
}
token::BinOp(token::Plus) => {
- debug!("leading + detected: {:?}", lo);
let mut err = this.struct_span_err(lo, "leading `+` is not supported");
err.span_label(lo, "unexpected `+`");
diff --git a/compiler/rustc_parse/src/parser/stmt.rs b/compiler/rustc_parse/src/parser/stmt.rs
index 329b60f9a8711..85515bd2a6314 100644
--- a/compiler/rustc_parse/src/parser/stmt.rs
+++ b/compiler/rustc_parse/src/parser/stmt.rs
@@ -21,8 +21,6 @@ use rustc_span::symbol::{kw, sym};
use std::mem;
-use tracing::debug;
-
impl<'a> Parser<'a> {
/// Parses a statement. This stops just before trailing semicolons on everything but items.
/// e.g., a `StmtKind::Semi` parses to a `StmtKind::Expr`, leaving the trailing `;` unconsumed.
@@ -420,7 +418,6 @@ impl<'a> Parser<'a> {
if self.token == token::Eof {
break;
}
- debug!("parsing statements, stmts: {:?}", &stmts);
let stmt = match self.parse_full_stmt(recover) {
Err(mut err) if recover.yes() => {
self.maybe_annotate_with_ascription(&mut err, false);
From 49c680ada001a4c296d1c00f58be8d8b535d50f6 Mon Sep 17 00:00:00 2001
From: Frank Steffahn
Date: Thu, 2 Sep 2021 17:19:43 +0200
Subject: [PATCH 10/24] Add "!" doc alias for `std::ops::Not`
---
library/core/src/ops/bit.rs | 1 +
1 file changed, 1 insertion(+)
diff --git a/library/core/src/ops/bit.rs b/library/core/src/ops/bit.rs
index 51f8043817345..92f45ac9e7ea9 100644
--- a/library/core/src/ops/bit.rs
+++ b/library/core/src/ops/bit.rs
@@ -30,6 +30,7 @@
/// ```
#[lang = "not"]
#[stable(feature = "rust1", since = "1.0.0")]
+#[doc(alias = "!")]
pub trait Not {
/// The resulting type after applying the `!` operator.
#[stable(feature = "rust1", since = "1.0.0")]
From ab89c88faadbc5a4063c8473c9ce28af16324d79 Mon Sep 17 00:00:00 2001
From: Frank Steffahn
Date: Thu, 2 Sep 2021 17:21:05 +0200
Subject: [PATCH 11/24] =?UTF-8?q?Consistent=20placement=20of=20doc=20alias?=
=?UTF-8?q?=20for=20primitives=20below=20the=20`doc(primitive=E2=80=A6)`?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
library/std/src/primitive_docs.rs | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/library/std/src/primitive_docs.rs b/library/std/src/primitive_docs.rs
index dc4572cd9363b..045c1303b133f 100644
--- a/library/std/src/primitive_docs.rs
+++ b/library/std/src/primitive_docs.rs
@@ -385,8 +385,8 @@ mod prim_char {}
#[stable(feature = "rust1", since = "1.0.0")]
mod prim_unit {}
-#[doc(alias = "ptr")]
#[doc(primitive = "pointer")]
+#[doc(alias = "ptr")]
//
/// Raw, unsafe pointers, `*const T`, and `*mut T`.
///
@@ -499,10 +499,10 @@ mod prim_unit {}
#[stable(feature = "rust1", since = "1.0.0")]
mod prim_pointer {}
+#[doc(primitive = "array")]
#[doc(alias = "[]")]
#[doc(alias = "[T;N]")] // unfortunately, rustdoc doesn't have fuzzy search for aliases
#[doc(alias = "[T; N]")]
-#[doc(primitive = "array")]
/// A fixed-size array, denoted `[T; N]`, for the element type, `T`, and the
/// non-negative compile-time constant size, `N`.
///
From 34c1fce50be88eb4a0b81eb486b47e1f929b1ce3 Mon Sep 17 00:00:00 2001
From: Kevin Reid
Date: Sat, 4 Sep 2021 11:05:36 -0700
Subject: [PATCH 12/24] =?UTF-8?q?=E2=80=9CMoves=E2=80=9D=20instead=20of=20?=
=?UTF-8?q?=E2=80=9Ccopies=E2=80=9D=20in=20`