From 33ce74f308ac0d849b9cd4d88f3ebdb4238be18a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9my=20Rakic?= Date: Sun, 12 Jan 2025 08:13:45 +0000 Subject: [PATCH] add error message to `string_enum!`s string conversions --- src/tools/compiletest/src/common.rs | 6 +++--- src/tools/compiletest/src/tests.rs | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/tools/compiletest/src/common.rs b/src/tools/compiletest/src/common.rs index 8c4a89baa00..4e2510ed9ab 100644 --- a/src/tools/compiletest/src/common.rs +++ b/src/tools/compiletest/src/common.rs @@ -39,12 +39,12 @@ macro_rules! string_enum { } impl FromStr for $name { - type Err = (); + type Err = String; - fn from_str(s: &str) -> Result { + fn from_str(s: &str) -> Result { match s { $($repr => Ok(Self::$variant),)* - _ => Err(()), + _ => Err(format!(concat!("unknown `", stringify!($name), "` variant: `{}`"), s)), } } } diff --git a/src/tools/compiletest/src/tests.rs b/src/tools/compiletest/src/tests.rs index f8a74528101..43c6dc0a67e 100644 --- a/src/tools/compiletest/src/tests.rs +++ b/src/tools/compiletest/src/tests.rs @@ -91,5 +91,5 @@ fn string_enums() { // Invalid conversions let animal = "nya".parse::(); - assert!(matches!(animal, Err(()))); + assert_eq!("unknown `Animal` variant: `nya`", animal.unwrap_err()); }