aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMuhammad Mahad <mahadtxt@gmail.com>2023-08-29 20:00:18 +0500
committerArthur Cohen <arthur.cohen@embecosm.com>2024-01-16 19:04:35 +0100
commit2b560b964d60e42ea4cc99118b786acb0d96db34 (patch)
treec352e1336c1bea0db328a4b263344dbd28fb7d3e /gcc
parentf14cbab89d7a3678dd6c3b2f4a1102b4e6e95cf8 (diff)
downloadgcc-2b560b964d60e42ea4cc99118b786acb0d96db34.zip
gcc-2b560b964d60e42ea4cc99118b786acb0d96db34.tar.gz
gcc-2b560b964d60e42ea4cc99118b786acb0d96db34.tar.bz2
gccrs: [E0599] Failed to resovle method implementation
gcc/rust/ChangeLog: * typecheck/rust-hir-type-check-expr.cc (TypeCheckExpr::visit): Added new error message, rich location and error code. gcc/testsuite/ChangeLog: * rust/compile/cfg2.rs: Updated according to new message. * rust/compile/issue-2139.rs: likewise. * rust/compile/issue-2190-1.rs: likewise. * rust/compile/method1.rs: likewise. Signed-off-by: Muhammad Mahad <mahadtxt@gmail.com>
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/typecheck/rust-hir-type-check-expr.cc6
-rw-r--r--gcc/testsuite/rust/compile/cfg2.rs2
-rw-r--r--gcc/testsuite/rust/compile/issue-2139.rs2
-rw-r--r--gcc/testsuite/rust/compile/issue-2190-1.rs2
-rw-r--r--gcc/testsuite/rust/compile/method1.rs2
5 files changed, 8 insertions, 6 deletions
diff --git a/gcc/rust/typecheck/rust-hir-type-check-expr.cc b/gcc/rust/typecheck/rust-hir-type-check-expr.cc
index f091196..4ed8484 100644
--- a/gcc/rust/typecheck/rust-hir-type-check-expr.cc
+++ b/gcc/rust/typecheck/rust-hir-type-check-expr.cc
@@ -1077,9 +1077,11 @@ TypeCheckExpr::visit (HIR::MethodCallExpr &expr)
expr.get_method_name ().get_segment ());
if (candidates.empty ())
{
+ rich_location richloc (line_table, expr.get_method_name ().get_locus ());
+ richloc.add_fixit_replace ("method not found");
rust_error_at (
- expr.get_method_name ().get_locus (),
- "failed to resolve method for %<%s%>",
+ richloc, ErrorCode::E0599,
+ "no method named %qs found in the current scope",
expr.get_method_name ().get_segment ().as_string ().c_str ());
return;
}
diff --git a/gcc/testsuite/rust/compile/cfg2.rs b/gcc/testsuite/rust/compile/cfg2.rs
index e4c90d9..ce1c5f9 100644
--- a/gcc/testsuite/rust/compile/cfg2.rs
+++ b/gcc/testsuite/rust/compile/cfg2.rs
@@ -8,5 +8,5 @@ impl Foo {
fn main() {
let a = Foo;
a.test();
- // { dg-error "failed to resolve method for .test." "" { target *-*-* } .-1 }
+ // { dg-error "no method named .test. found in the current scope" "" { target *-*-* } .-1 }
}
diff --git a/gcc/testsuite/rust/compile/issue-2139.rs b/gcc/testsuite/rust/compile/issue-2139.rs
index 3b9ad95..65f82f3 100644
--- a/gcc/testsuite/rust/compile/issue-2139.rs
+++ b/gcc/testsuite/rust/compile/issue-2139.rs
@@ -14,5 +14,5 @@ impl Foo for u16 {
fn main() {
let a: u16 = 123;
a.foo();
- // { dg-error "failed to resolve method for .foo." "" { target *-*-* } .-1 }
+ // { dg-error "no method named .foo. found in the current scope" "" { target *-*-* } .-1 }
}
diff --git a/gcc/testsuite/rust/compile/issue-2190-1.rs b/gcc/testsuite/rust/compile/issue-2190-1.rs
index 057d7c7..927f90d 100644
--- a/gcc/testsuite/rust/compile/issue-2190-1.rs
+++ b/gcc/testsuite/rust/compile/issue-2190-1.rs
@@ -9,5 +9,5 @@ trait Deref {
fn foo<T: Deref<Target = i32>>(t: &T) -> i32 {
t.max(2)
- // { dg-error "failed to resolve method for .max." "" { target *-*-* } .-1 }
+ // { dg-error "no method named .max. found in the current scope" "" { target *-*-* } .-1 }
}
diff --git a/gcc/testsuite/rust/compile/method1.rs b/gcc/testsuite/rust/compile/method1.rs
index d371bf2..3741c61 100644
--- a/gcc/testsuite/rust/compile/method1.rs
+++ b/gcc/testsuite/rust/compile/method1.rs
@@ -8,5 +8,5 @@ pub fn main() {
a = Foo(123);
a.test();
- // { dg-error "failed to resolve method for .test." "" { target *-*-* } .-1 }
+ // { dg-error "no method named .test. found in the current scope" "" { target *-*-* } .-1 }
}