forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of rust-lang#103003 - TaKO8Ki:fix-102989, r=compiler-errors
Fix `suggest_floating_point_literal` ICE Fixes rust-lang#102989
- Loading branch information
Showing
3 changed files
with
84 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
// normalize-stderr-test "loaded from .*libcore-.*.rlib" -> "loaded from SYSROOT/libcore-*.rlib" | ||
|
||
#![feature(lang_items)] | ||
#[lang="sized"] | ||
trait Sized { } //~ ERROR found duplicate lang item `sized` | ||
|
||
fn ref_Struct(self: &Struct, f: &u32) -> &u32 { | ||
//~^ ERROR `self` parameter is only allowed in associated functions | ||
//~| ERROR cannot find type `Struct` in this scope | ||
//~| ERROR mismatched types | ||
let x = x << 1; | ||
//~^ ERROR the size for values of type `{integer}` cannot be known at compilation time | ||
//~| ERROR cannot find value `x` in this scope | ||
} | ||
|
||
fn main() {} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
error: `self` parameter is only allowed in associated functions | ||
--> $DIR/issue-102989.rs:7:15 | ||
| | ||
LL | fn ref_Struct(self: &Struct, f: &u32) -> &u32 { | ||
| ^^^^ not semantically valid as function parameter | ||
| | ||
= note: associated functions are those in `impl` or `trait` definitions | ||
|
||
error[E0412]: cannot find type `Struct` in this scope | ||
--> $DIR/issue-102989.rs:7:22 | ||
| | ||
LL | fn ref_Struct(self: &Struct, f: &u32) -> &u32 { | ||
| ^^^^^^ not found in this scope | ||
|
||
error[E0425]: cannot find value `x` in this scope | ||
--> $DIR/issue-102989.rs:11:13 | ||
| | ||
LL | let x = x << 1; | ||
| ^ help: a local variable with a similar name exists: `f` | ||
|
||
error[E0152]: found duplicate lang item `sized` | ||
--> $DIR/issue-102989.rs:5:1 | ||
| | ||
LL | trait Sized { } | ||
| ^^^^^^^^^^^ | ||
| | ||
= note: the lang item is first defined in crate `core` (which `std` depends on) | ||
= note: first definition in `core` loaded from SYSROOT/libcore-*.rlib | ||
= note: second definition in the local crate (`issue_102989`) | ||
|
||
error[E0277]: the size for values of type `{integer}` cannot be known at compilation time | ||
--> $DIR/issue-102989.rs:11:15 | ||
| | ||
LL | let x = x << 1; | ||
| ^^ doesn't have a size known at compile-time | ||
| | ||
= help: the trait `std::marker::Sized` is not implemented for `{integer}` | ||
|
||
error[E0308]: mismatched types | ||
--> $DIR/issue-102989.rs:7:42 | ||
| | ||
LL | fn ref_Struct(self: &Struct, f: &u32) -> &u32 { | ||
| ---------- ^^^^ expected `&u32`, found `()` | ||
| | | ||
| implicitly returns `()` as its body has no tail or `return` expression | ||
| | ||
note: consider returning one of these bindings | ||
--> $DIR/issue-102989.rs:7:30 | ||
| | ||
LL | fn ref_Struct(self: &Struct, f: &u32) -> &u32 { | ||
| ^ | ||
... | ||
LL | let x = x << 1; | ||
| ^ | ||
|
||
error: aborting due to 6 previous errors | ||
|
||
Some errors have detailed explanations: E0152, E0277, E0308, E0412, E0425. | ||
For more information about an error, try `rustc --explain E0152`. |