aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--mingling/src/parser/picker.rs16
-rw-r--r--mingling_core/src/asset/enum_tag.rs4
-rw-r--r--mingling_macros/src/enum_tag.rs9
3 files changed, 24 insertions, 5 deletions
diff --git a/mingling/src/parser/picker.rs b/mingling/src/parser/picker.rs
index c6c2beb..9258002 100644
--- a/mingling/src/parser/picker.rs
+++ b/mingling/src/parser/picker.rs
@@ -1,7 +1,7 @@
use std::marker::PhantomData;
use crate::parser::Argument;
-use mingling_core::Flag;
+use mingling_core::{EnumTag, Flag};
#[doc(hidden)]
pub mod builtin;
@@ -316,3 +316,17 @@ impl_pick_structs! { Pick8 Pick9 val_9 T1 val_1, T2 val_2, T3 val_3, T4 val_4, T
impl_pick_structs! { Pick9 Pick10 val_10 T1 val_1, T2 val_2, T3 val_3, T4 val_4, T5 val_5, T6 val_6, T7 val_7, T8 val_8, T9 val_9 }
impl_pick_structs! { Pick10 Pick11 val_11 T1 val_1, T2 val_2, T3 val_3, T4 val_4, T5 val_5, T6 val_6, T7 val_7, T8 val_8, T9 val_9, T10 val_10 }
impl_pick_structs! { Pick11 Pick12 val_12 T1 val_1, T2 val_2, T3 val_3, T4 val_4, T5 val_5, T6 val_6, T7 val_7, T8 val_8, T9 val_9, T10 val_10, T11 val_11 }
+
+pub trait PickableEnum: EnumTag + Default {}
+
+impl<T> Pickable for T
+where
+ T: PickableEnum,
+{
+ type Output = T;
+
+ fn pick(args: &mut Argument, flag: Flag) -> Option<Self::Output> {
+ let name = args.pick_argument(flag)?;
+ T::build_enum(name)
+ }
+}
diff --git a/mingling_core/src/asset/enum_tag.rs b/mingling_core/src/asset/enum_tag.rs
index 563d826..28428a6 100644
--- a/mingling_core/src/asset/enum_tag.rs
+++ b/mingling_core/src/asset/enum_tag.rs
@@ -7,5 +7,7 @@ pub trait EnumTag {
fn enums() -> &'static [(&'static str, &'static str)];
/// Build the enum from a name
- fn build_enum(name: String) -> Self;
+ fn build_enum(name: String) -> Option<Self>
+ where
+ Self: Sized;
}
diff --git a/mingling_macros/src/enum_tag.rs b/mingling_macros/src/enum_tag.rs
index a30a0d5..497bc88 100644
--- a/mingling_macros/src/enum_tag.rs
+++ b/mingling_macros/src/enum_tag.rs
@@ -70,10 +70,13 @@ fn derive_enum_tag_impl(input: DeriveInput) -> Result<proc_macro2::TokenStream>
}
}
- fn build_enum(name: String) -> Self {
+ fn build_enum(name: String) -> Option<Self>
+ where
+ Self: Sized
+ {
match name.as_str() {
#(#build_match_arms)*
- _ => panic!("Invalid enum variant name: {}", name),
+ _ => None,
}
}
@@ -128,7 +131,7 @@ fn process_variant(
});
build_match_arms.push(quote! {
- #variant_name_str => #enum_name::#variant_name,
+ #variant_name_str => Some(#enum_name::#variant_name),
});
Ok(())