Skip to content

Commit

Permalink
Don't use bytepos offsets when computing semicolon span for removal
Browse files Browse the repository at this point in the history
  • Loading branch information
compiler-errors committed Apr 7, 2024
1 parent e78913b commit fc06582
Show file tree
Hide file tree
Showing 3 changed files with 44 additions and 2 deletions.
11 changes: 9 additions & 2 deletions compiler/rustc_infer/src/infer/error_reporting/suggest.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ use rustc_middle::traits::{
};
use rustc_middle::ty::print::with_no_trimmed_paths;
use rustc_middle::ty::{self as ty, GenericArgKind, IsSuggestable, Ty, TypeVisitableExt};
use rustc_span::{sym, BytePos, Span};
use rustc_span::{sym, Span};

use crate::errors::{
ConsiderAddingAwait, FnConsiderCasting, FnItemsAreDistinct, FnUniqTypes,
Expand Down Expand Up @@ -763,8 +763,15 @@ impl<'tcx> TypeErrCtxt<'_, 'tcx> {
let mac_call = rustc_span::source_map::original_sp(last_stmt.span, blk.span);
self.tcx.sess.source_map().mac_call_stmt_semi_span(mac_call)?
} else {
last_stmt.span.with_lo(last_stmt.span.hi() - BytePos(1))
self.tcx
.sess
.source_map()
.span_extend_while(last_expr.span, |c| c.is_whitespace())
.ok()?
.shrink_to_hi()
.with_hi(last_stmt.span.hi())
};

Some((span, needs_box))
}

Expand Down
10 changes: 10 additions & 0 deletions tests/ui/typeck/remove-semi-but-confused-char.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
// Ensures our "remove semicolon" suggestion isn't hardcoded with a character width,
// in case it was accidentally mixed up with a greek question mark.

pub fn square(num: i32) -> i32 {
//~^ ERROR mismatched types
num * num;
//~^ ERROR unknown start of token
}

fn main() {}
25 changes: 25 additions & 0 deletions tests/ui/typeck/remove-semi-but-confused-char.stderr
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
error: unknown start of token: \u{37e}
--> $DIR/remove-semi-but-confused-char.rs:6:14
|
LL | num * num;
| ^
|
help: Unicode character ';' (Greek Question Mark) looks like ';' (Semicolon), but it is not
|
LL | num * num;
| ~

error[E0308]: mismatched types
--> $DIR/remove-semi-but-confused-char.rs:4:28
|
LL | pub fn square(num: i32) -> i32 {
| ------ ^^^ expected `i32`, found `()`
| |
| implicitly returns `()` as its body has no tail or `return` expression
LL |
LL | num * num;
| - help: remove this semicolon to return this value

error: aborting due to 2 previous errors

For more information about this error, try `rustc --explain E0308`.

0 comments on commit fc06582

Please sign in to comment.