From 582a49f74eea25715378e2ccedd3875caef8e13f Mon Sep 17 00:00:00 2001 From: yassun7010 Date: Sat, 6 Jan 2024 22:51:43 +0900 Subject: [PATCH] fix: error handling. --- serde_valid_derive/src/error.rs | 13 +++++++++++-- serde_valid_derive/src/validate.rs | 7 ++++--- 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/serde_valid_derive/src/error.rs b/serde_valid_derive/src/error.rs index 4d7d17a..7d7a52a 100644 --- a/serde_valid_derive/src/error.rs +++ b/serde_valid_derive/src/error.rs @@ -1,3 +1,4 @@ +use crate::validate::{MetaListValidation, MetaNameValueValidation, MetaPathValidation}; use proc_macro2::TokenStream; use quote::quote; use syn::spanned::Spanned; @@ -241,7 +242,15 @@ impl Error { } pub fn validate_type_required_error(attribute: &syn::Attribute) -> Self { - Self::new(attribute.span(), "#[validate(???)] needs validation type.") + let filterd_candidates: Vec<&str> = (MetaPathValidation::iter().map(|x| x.name())) + .chain(MetaNameValueValidation::iter().map(|x| x.name())) + .chain(MetaListValidation::iter().map(|x| x.name())) + .collect::>(); + + Self::new( + attribute.meta.span(), + format!("#[validate(???)] needs validation type. Is it one of the following?\n{filterd_candidates:#?}"), + ) } pub fn validate_unknown_type(path: &syn::Path, unknown: &str, candidates: &[&str]) -> Self { @@ -250,7 +259,7 @@ impl Error { Self::new( path.span(), - format!("Unknown: `{unknown}`. Is it one of the following?\n{filterd_candidates:#?}"), + format!("Unknown: `{unknown}` validation type. Is it one of the following?\n{filterd_candidates:#?}"), ) } diff --git a/serde_valid_derive/src/validate.rs b/serde_valid_derive/src/validate.rs index 0f73c2c..5ca432d 100644 --- a/serde_valid_derive/src/validate.rs +++ b/serde_valid_derive/src/validate.rs @@ -7,8 +7,9 @@ mod numeric; mod object; mod string; +pub use common::{ + MetaListMessage, MetaListValidation, MetaNameValueValidation, MetaPathValidation, +}; + pub use field::{FieldValidators, Validator}; pub use meta::extract_meta_validator; - -#[cfg(feature = "fluent")] -pub use common::MetaListMessage;