Refactor input_value!
macro position [skip ci]
This commit is contained in:
parent
97c88d219c
commit
b716a45215
4 changed files with 213 additions and 195 deletions
|
@ -1,67 +1,88 @@
|
|||
use crate::{behavior, resolve};
|
||||
|
||||
pub use crate::{
|
||||
ast::InputValue, graphql_input_value as input_value, graphql_value as value, value::Value,
|
||||
ast::InputValue, graphql_value as value, macros::input_value,
|
||||
resolve::Type, value::Value,
|
||||
};
|
||||
|
||||
pub trait Interface<S>:
|
||||
OutputType<S>
|
||||
/*
|
||||
+ resolve::TypeName
|
||||
+ resolve::ConcreteTypeName
|
||||
+ resolve::Value<S>
|
||||
+ resolve::ValueAsync<S>
|
||||
+ resolve::ConcreteValue<S>
|
||||
+ resolve::ConcreteValueAsync<S>
|
||||
+ resolve::Field<S>
|
||||
+ resolve::FieldAsync<S>
|
||||
pub trait Interface<S>
|
||||
/*: OutputType<S>
|
||||
+ resolve::TypeName
|
||||
+ resolve::ConcreteTypeName
|
||||
+ resolve::Value<S>
|
||||
+ resolve::ValueAsync<S>
|
||||
+ resolve::ConcreteValue<S>
|
||||
+ resolve::ConcreteValueAsync<S>
|
||||
+ resolve::Field<S>
|
||||
+ resolve::FieldAsync<S>
|
||||
|
||||
*/
|
||||
*/
|
||||
{
|
||||
fn assert_interface();
|
||||
}
|
||||
|
||||
pub trait Object<S>:
|
||||
OutputType<S>
|
||||
/*
|
||||
+ resolve::TypeName
|
||||
+ resolve::ConcreteTypeName
|
||||
+ resolve::Value<S>
|
||||
+ resolve::ValueAsync<S>
|
||||
+ resolve::Field<S>
|
||||
+ resolve::FieldAsync<S>
|
||||
pub trait Object<S>
|
||||
/*: OutputType<S>
|
||||
+ resolve::TypeName
|
||||
+ resolve::ConcreteTypeName
|
||||
+ resolve::Value<S>
|
||||
+ resolve::ValueAsync<S>
|
||||
+ resolve::Field<S>
|
||||
+ resolve::FieldAsync<S>
|
||||
|
||||
*/
|
||||
*/
|
||||
{
|
||||
fn assert_object();
|
||||
}
|
||||
|
||||
pub trait Scalar<S>:
|
||||
OutputType<S> + /*
|
||||
resolve::TypeName + resolve::Value<S> + resolve::ValueAsync<S> */
|
||||
pub trait Scalar<
|
||||
'inp,
|
||||
TypeInfo: ?Sized,
|
||||
Context: ?Sized,
|
||||
ScalarValue: 'inp,
|
||||
Behavior: ?Sized = behavior::Standard,
|
||||
>:
|
||||
InputType<'inp, TypeInfo, ScalarValue, Behavior>
|
||||
+ OutputType<TypeInfo, Context, ScalarValue, Behavior>
|
||||
+ resolve::ScalarToken<ScalarValue, Behavior>
|
||||
{
|
||||
fn assert_scalar();
|
||||
}
|
||||
|
||||
pub trait Union<S>:
|
||||
OutputType<S>
|
||||
/*
|
||||
+ resolve::TypeName
|
||||
+ resolve::ConcreteTypeName
|
||||
+ resolve::Value<S>
|
||||
+ resolve::ValueAsync<S>
|
||||
+ resolve::ConcreteValue<S>
|
||||
+ resolve::ConcreteValueAsync<S> */
|
||||
pub trait Union<S>
|
||||
/*: OutputType<S>
|
||||
+ resolve::TypeName
|
||||
+ resolve::ConcreteTypeName
|
||||
+ resolve::Value<S>
|
||||
+ resolve::ValueAsync<S>
|
||||
+ resolve::ConcreteValue<S>
|
||||
+ resolve::ConcreteValueAsync<S> */
|
||||
{
|
||||
fn assert_union();
|
||||
}
|
||||
|
||||
pub trait InputType<'inp, Info: ?Sized, S: 'inp> /*:
|
||||
crate::resolve::Type<Info, S>
|
||||
+ crate::resolve::ToInputValue<S>
|
||||
+ crate::resolve::InputValue<'inp, S>*/
|
||||
pub trait InputType<
|
||||
'inp,
|
||||
TypeInfo: ?Sized,
|
||||
ScalarValue: 'inp,
|
||||
Behavior: ?Sized = behavior::Standard,
|
||||
>:
|
||||
Type<TypeInfo, ScalarValue, Behavior>
|
||||
+ resolve::ToInputValue<ScalarValue, Behavior>
|
||||
+ resolve::InputValue<'inp, ScalarValue, Behavior>
|
||||
{
|
||||
fn assert_input_type();
|
||||
}
|
||||
|
||||
pub trait OutputType<S>: /*Type<S>*/ {
|
||||
pub trait OutputType<
|
||||
TypeInfo: ?Sized,
|
||||
Context: ?Sized,
|
||||
ScalarValue,
|
||||
Behavior: ?Sized = behavior::Standard,
|
||||
>:
|
||||
Type<TypeInfo, ScalarValue, Behavior>
|
||||
+ resolve::Value<TypeInfo, Context, ScalarValue, Behavior>
|
||||
+ resolve::ValueAsync<TypeInfo, Context, ScalarValue, Behavior>
|
||||
{
|
||||
fn assert_output_type();
|
||||
}
|
||||
|
|
|
@ -74,7 +74,10 @@ pub use crate::{
|
|||
LookAheadSelection, LookAheadValue, OwnedExecutor, Registry, ValuesStream, Variables,
|
||||
},
|
||||
introspection::IntrospectionFormat,
|
||||
macros::helper::subscription::{ExtractTypeFromStream, IntoFieldResult},
|
||||
macros::{
|
||||
input_value as graphql_input_value,
|
||||
helper::subscription::{ExtractTypeFromStream, IntoFieldResult},
|
||||
},
|
||||
parser::{ParseError, ScalarToken, Spanning},
|
||||
schema::{
|
||||
meta,
|
||||
|
|
|
@ -1,45 +1,43 @@
|
|||
//! [`graphql_input_value!`] macro implementation.
|
||||
//!
|
||||
//! [`graphql_input_value!`]: graphql_input_value
|
||||
//! [`input_value!`] macro implementation.
|
||||
|
||||
/// Constructs [`InputValue`]s via JSON-like syntax.
|
||||
/// Constructs [`graphql::InputValue`]s via JSON-like syntax.
|
||||
///
|
||||
/// # Differences from [`graphql_value!`]
|
||||
///
|
||||
/// - [`InputValue::Enum`] is constructed with `ident`, so to capture outer
|
||||
/// variable as [`InputValue::Scalar`] surround it with parens: `(var)`.
|
||||
/// ```rust
|
||||
/// # use juniper::{graphql_input_value, graphql_value};
|
||||
/// # use juniper::{graphql, graphql_value};
|
||||
/// #
|
||||
/// # type InputValue = juniper::InputValue;
|
||||
/// # type Value = juniper::Value;
|
||||
/// # type InputValue = graphql::InputValue;
|
||||
/// # type Value = graphql::Value;
|
||||
/// #
|
||||
/// const OUTER_VAR: i32 = 42;
|
||||
/// assert_eq!(graphql_value!(OUTER_VAR), Value::scalar(42));
|
||||
/// assert_eq!(graphql_input_value!(OUTER_VAR), InputValue::enum_value("OUTER_VAR"));
|
||||
/// assert_eq!(graphql_input_value!((OUTER_VAR)), InputValue::scalar(42));
|
||||
/// assert_eq!(graphql::value!(OUTER_VAR), Value::scalar(42));
|
||||
/// assert_eq!(graphql::input_value!(OUTER_VAR), InputValue::enum_value("OUTER_VAR"));
|
||||
/// assert_eq!(graphql::input_value!((OUTER_VAR)), InputValue::scalar(42));
|
||||
/// ```
|
||||
///
|
||||
/// - [`InputValue::Variable`] is constructed by prefixing `ident` with `@`.
|
||||
/// ```rust
|
||||
/// # use juniper::graphql_input_value;
|
||||
/// # use juniper::graphql;
|
||||
/// #
|
||||
/// # type InputValue = juniper::InputValue;
|
||||
/// # type InputValue = graphql::InputValue;
|
||||
/// #
|
||||
/// assert_eq!(graphql_input_value!(@var), InputValue::variable("var"));
|
||||
/// assert_eq!(graphql::input_value!(@var), InputValue::variable("var"));
|
||||
/// ```
|
||||
///
|
||||
/// - [`InputValue::Object`] key should implement [`Into`]`<`[`String`]`>`.
|
||||
/// ```rust
|
||||
/// # use std::borrow::Cow;
|
||||
/// #
|
||||
/// # use juniper::{graphql_input_value, InputValue};
|
||||
/// # use juniper::graphql;
|
||||
/// #
|
||||
/// let code = 200;
|
||||
/// let features = vec!["key", "value"];
|
||||
/// let key: Cow<'static, str> = "key".into();
|
||||
///
|
||||
/// let value: InputValue = graphql_input_value!({
|
||||
/// let value: graphql::InputValue = graphql::input_value!({
|
||||
/// "code": code,
|
||||
/// "success": code == 200,
|
||||
/// "payload": {
|
||||
|
@ -55,128 +53,127 @@
|
|||
/// # Example
|
||||
///
|
||||
/// ```rust
|
||||
/// # use juniper::{graphql_input_value, InputValue};
|
||||
/// # use juniper::graphql;
|
||||
/// #
|
||||
/// # type V = InputValue;
|
||||
/// # type V = graphql::InputValue;
|
||||
/// #
|
||||
/// # let _: V =
|
||||
/// graphql_input_value!(null);
|
||||
/// graphql::input_value!(null);
|
||||
/// # let _: V =
|
||||
/// graphql_input_value!(1234);
|
||||
/// graphql::input_value!(1234);
|
||||
/// # let _: V =
|
||||
/// graphql_input_value!("test");
|
||||
/// graphql::input_value!("test");
|
||||
/// # let _: V =
|
||||
/// graphql_input_value!([1234, "test", true]);
|
||||
/// graphql::input_value!([1234, "test", true]);
|
||||
/// # let _: V =
|
||||
/// graphql_input_value!({"key": "value", "foo": 1234});
|
||||
/// graphql::input_value!({"key": "value", "foo": 1234});
|
||||
/// # let _: V =
|
||||
/// graphql_input_value!({"key": ENUM});
|
||||
/// graphql::input_value!({"key": ENUM});
|
||||
/// let captured_var = 42;
|
||||
/// # let _: V =
|
||||
/// graphql_input_value!({"key": (captured_var)});
|
||||
/// graphql::input_value!({"key": (captured_var)});
|
||||
/// # let _: V =
|
||||
/// graphql_input_value!({"key": @variable});
|
||||
/// graphql::input_value!({"key": @variable});
|
||||
/// ```
|
||||
///
|
||||
/// [`InputValue`]: crate::InputValue
|
||||
/// [`InputValue::Enum`]: crate::InputValue::Enum
|
||||
/// [`InputValue::List`]: crate::InputValue::List
|
||||
/// [`InputValue::Object`]: crate::InputValue::Object
|
||||
/// [`InputValue::Scalar`]: crate::InputValue::Scalar
|
||||
/// [`InputValue::Variable`]: crate::InputValue::Variable
|
||||
/// [`graphql::InputValue`]: crate::graphql::InputValue
|
||||
/// [`InputValue::Enum`]: crate::graphql::InputValue::Enum
|
||||
/// [`InputValue::List`]: crate::graphql::InputValue::List
|
||||
/// [`InputValue::Object`]: crate::graphql::InputValue::Object
|
||||
/// [`InputValue::Scalar`]: crate::graphql::InputValue::Scalar
|
||||
/// [`InputValue::Variable`]: crate::graphql::InputValue::Variable
|
||||
/// [`Spanning::unlocated`]: crate::Spanning::unlocated
|
||||
#[macro_export]
|
||||
macro_rules! graphql_input_value {
|
||||
macro_rules! input_value {
|
||||
///////////
|
||||
// Array //
|
||||
///////////
|
||||
|
||||
// Done with trailing comma.
|
||||
(@@array [$($elems:expr,)*]) => {
|
||||
$crate::InputValue::list(vec![
|
||||
$crate::graphql::InputValue::list(::std::vec![
|
||||
$( $elems, )*
|
||||
])
|
||||
};
|
||||
|
||||
// Done without trailing comma.
|
||||
(@@array [$($elems:expr),*]) => {
|
||||
$crate::InputValue::list(vec![
|
||||
$crate::graphql::InputValue::list(::std::vec![
|
||||
$( $elems, )*
|
||||
])
|
||||
};
|
||||
|
||||
// Next element is `null`.
|
||||
(@@array [$($elems:expr,)*] null $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!(null)] $($rest)*
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!(null)] $($rest)*
|
||||
)
|
||||
};
|
||||
|
||||
// Next element is `None`.
|
||||
(@@array [$($elems:expr,)*] None $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!(None)] $($rest)*
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!(None)] $($rest)*
|
||||
)
|
||||
};
|
||||
|
||||
// Next element is a variable.
|
||||
(@@array [$($elems:expr,)*] @$var:ident $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!(@$var)] $($rest)*
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!(@$var)] $($rest)*
|
||||
)
|
||||
};
|
||||
|
||||
|
||||
// Next element is an array.
|
||||
(@@array [$($elems:expr,)*] [$($array:tt)*] $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!([$($array)*])] $($rest)*
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!([$($array)*])] $($rest)*
|
||||
)
|
||||
};
|
||||
|
||||
// Next element is a map.
|
||||
(@@array [$($elems:expr,)*] {$($map:tt)*} $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!({$($map)*})] $($rest)*
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!({$($map)*})] $($rest)*
|
||||
)
|
||||
};
|
||||
|
||||
// Next element is `true`, `false` or enum ident followed by comma.
|
||||
(@@array [$($elems:expr,)*] $ident:ident, $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!($ident),] $($rest)*
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!($ident),] $($rest)*
|
||||
)
|
||||
};
|
||||
|
||||
// Next element is `true`, `false` or enum ident without trailing comma.
|
||||
(@@array [$($elems:expr,)*] $last:ident ) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!($last)]
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!($last)]
|
||||
)
|
||||
};
|
||||
|
||||
// Next element is an expression followed by comma.
|
||||
(@@array [$($elems:expr,)*] $next:expr, $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!($next),] $($rest)*
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!($next),] $($rest)*
|
||||
)
|
||||
};
|
||||
|
||||
// Last element is an expression with no trailing comma.
|
||||
(@@array [$($elems:expr,)*] $last:expr) => {
|
||||
$crate::graphql_input_value!(
|
||||
@@array [$($elems,)* $crate::graphql_input_value!($last)]
|
||||
$crate::graphql::input_value!(
|
||||
@@array [$($elems,)* $crate::graphql::input_value!($last)]
|
||||
)
|
||||
};
|
||||
|
||||
// Comma after the most recent element.
|
||||
(@@array [$($elems:expr),*] , $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(@@array [$($elems,)*] $($rest)*)
|
||||
$crate::graphql::input_value!(@@array [$($elems,)*] $($rest)*)
|
||||
};
|
||||
|
||||
// Unexpected token after most recent element.
|
||||
(@@array [$($elems:expr),*] $unexpected:tt $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(@unexpected $unexpected)
|
||||
$crate::graphql::input_value!(@unexpected $unexpected)
|
||||
};
|
||||
|
||||
////////////
|
||||
|
@ -192,12 +189,12 @@ macro_rules! graphql_input_value {
|
|||
$crate::Spanning::unlocated(($($key)+).into()),
|
||||
$crate::Spanning::unlocated($value),
|
||||
));
|
||||
$crate::graphql_input_value!(@@object $object () ($($rest)*) ($($rest)*));
|
||||
$crate::graphql::input_value!(@@object $object () ($($rest)*) ($($rest)*));
|
||||
};
|
||||
|
||||
// Current entry followed by unexpected token.
|
||||
(@@object $object:ident [$($key:tt)+] ($value:expr) $unexpected:tt $($rest:tt)*) => {
|
||||
$crate::graphql_input_value!(@unexpected $unexpected);
|
||||
$crate::graphql::input_value!(@unexpected $unexpected);
|
||||
};
|
||||
|
||||
// Insert the last entry without trailing comma.
|
||||
|
@ -210,114 +207,114 @@ macro_rules! graphql_input_value {
|
|||
|
||||
// Next value is `null`.
|
||||
(@@object $object:ident ($($key:tt)+) (: null $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!(null)) $($rest)*
|
||||
($crate::graphql::input_value!(null)) $($rest)*
|
||||
);
|
||||
};
|
||||
|
||||
// Next value is `None`.
|
||||
(@@object $object:ident ($($key:tt)+) (: None $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!(None)) $($rest)*
|
||||
($crate::graphql::input_value!(None)) $($rest)*
|
||||
);
|
||||
};
|
||||
|
||||
// Next value is a variable.
|
||||
(@@object $object:ident ($($key:tt)+) (: @$var:ident $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!(@$var)) $($rest)*
|
||||
($crate::graphql::input_value!(@$var)) $($rest)*
|
||||
);
|
||||
};
|
||||
|
||||
// Next value is an array.
|
||||
(@@object $object:ident ($($key:tt)+) (: [$($array:tt)*] $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!([$($array)*])) $($rest)*
|
||||
($crate::graphql::input_value!([$($array)*])) $($rest)*
|
||||
);
|
||||
};
|
||||
|
||||
// Next value is a map.
|
||||
(@@object $object:ident ($($key:tt)+) (: {$($map:tt)*} $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!({$($map)*})) $($rest)*
|
||||
($crate::graphql::input_value!({$($map)*})) $($rest)*
|
||||
);
|
||||
};
|
||||
|
||||
// Next value is `true`, `false` or enum ident followed by comma.
|
||||
(@@object $object:ident ($($key:tt)+) (: $ident:ident , $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!($ident)) , $($rest)*
|
||||
($crate::graphql::input_value!($ident)) , $($rest)*
|
||||
);
|
||||
};
|
||||
|
||||
// Next value is `true`, `false` or enum ident without trailing comma.
|
||||
(@@object $object:ident ($($key:tt)+) (: $last:ident ) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!($last))
|
||||
($crate::graphql::input_value!($last))
|
||||
);
|
||||
};
|
||||
|
||||
// Next value is an expression followed by comma.
|
||||
(@@object $object:ident ($($key:tt)+) (: $value:expr , $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!($value)) , $($rest)*
|
||||
($crate::graphql::input_value!($value)) , $($rest)*
|
||||
);
|
||||
};
|
||||
|
||||
// Last value is an expression with no trailing comma.
|
||||
(@@object $object:ident ($($key:tt)+) (: $value:expr) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
[$($key)+]
|
||||
($crate::graphql_input_value!($value))
|
||||
($crate::graphql::input_value!($value))
|
||||
);
|
||||
};
|
||||
|
||||
// Missing value for last entry. Trigger a reasonable error message.
|
||||
(@@object $object:ident ($($key:tt)+) (:) $copy:tt) => {
|
||||
// "unexpected end of macro invocation"
|
||||
$crate::graphql_input_value!();
|
||||
$crate::graphql::input_value!();
|
||||
};
|
||||
|
||||
// Missing colon and value for last entry. Trigger a reasonable error
|
||||
// message.
|
||||
(@@object $object:ident ($($key:tt)+) () $copy:tt) => {
|
||||
// "unexpected end of macro invocation"
|
||||
$crate::graphql_input_value!();
|
||||
$crate::graphql::input_value!();
|
||||
};
|
||||
|
||||
// Misplaced colon. Trigger a reasonable error message.
|
||||
(@@object $object:ident () (: $($rest:tt)*) ($colon:tt $($copy:tt)*)) => {
|
||||
// Takes no arguments so "no rules expected the token `:`".
|
||||
$crate::graphql_input_value!(@unexpected $colon);
|
||||
$crate::graphql::input_value!(@unexpected $colon);
|
||||
};
|
||||
|
||||
// Found a comma inside a key. Trigger a reasonable error message.
|
||||
(@@object $object:ident ($($key:tt)*) (, $($rest:tt)*) ($comma:tt $($copy:tt)*)) => {
|
||||
// Takes no arguments so "no rules expected the token `,`".
|
||||
$crate::graphql_input_value!(@unexpected $comma);
|
||||
$crate::graphql::input_value!(@unexpected $comma);
|
||||
};
|
||||
|
||||
// Key is fully parenthesized. This avoids `clippy::double_parens` false
|
||||
// positives because the parenthesization may be necessary here.
|
||||
(@@object $object:ident () (($key:expr) : $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
($key)
|
||||
(: $($rest)*) (: $($rest)*)
|
||||
|
@ -326,12 +323,12 @@ macro_rules! graphql_input_value {
|
|||
|
||||
// Refuse to absorb colon token into key expression.
|
||||
(@@object $object:ident ($($key:tt)*) (: $($unexpected:tt)+) $copy:tt) => {
|
||||
$crate::graphql_input_value!(@@unexpected $($unexpected)+);
|
||||
$crate::graphql::input_value!(@@unexpected $($unexpected)+);
|
||||
};
|
||||
|
||||
// Munch a token into the current key.
|
||||
(@@object $object:ident ($($key:tt)*) ($tt:tt $($rest:tt)*) $copy:tt) => {
|
||||
$crate::graphql_input_value!(
|
||||
$crate::graphql::input_value!(
|
||||
@@object $object
|
||||
($($key)* $tt)
|
||||
($($rest)*) ($($rest)*)
|
||||
|
@ -349,109 +346,107 @@ macro_rules! graphql_input_value {
|
|||
//////////////
|
||||
|
||||
([ $($arr:tt)* ]$(,)?) => {
|
||||
$crate::graphql_input_value!(@@array [] $($arr)*)
|
||||
$crate::graphql::input_value!(@@array [] $($arr)*)
|
||||
};
|
||||
|
||||
({}$(,)?) => {
|
||||
$crate::InputValue::parsed_object(vec![])
|
||||
$crate::graphql::InputValue::parsed_object(vec![])
|
||||
};
|
||||
|
||||
({ $($map:tt)+ }$(,)?) => {
|
||||
$crate::InputValue::parsed_object({
|
||||
$crate::graphql::InputValue::parsed_object({
|
||||
let mut object = vec![];
|
||||
$crate::graphql_input_value!(@@object object () ($($map)*) ($($map)*));
|
||||
$crate::graphql::input_value!(@@object object () ($($map)*) ($($map)*));
|
||||
object
|
||||
})
|
||||
};
|
||||
|
||||
(null$(,)?) => ($crate::InputValue::null());
|
||||
(null$(,)?) => ($crate::graphql::InputValue::null());
|
||||
|
||||
(None$(,)?) => ($crate::InputValue::null());
|
||||
(None$(,)?) => ($crate::graphql::InputValue::null());
|
||||
|
||||
(true$(,)?) => ($crate::InputValue::from(true));
|
||||
(true$(,)?) => ($crate::graphql::InputValue::from(true));
|
||||
|
||||
(false$(,)?) => ($crate::InputValue::from(false));
|
||||
(false$(,)?) => ($crate::graphql::InputValue::from(false));
|
||||
|
||||
(@$var:ident$(,)?) => ($crate::InputValue::variable(stringify!($var)));
|
||||
(@$var:ident$(,)?) => ($crate::graphql::InputValue::variable(stringify!($var)));
|
||||
|
||||
($enum:ident$(,)?) => ($crate::InputValue::enum_value(stringify!($enum)));
|
||||
($enum:ident$(,)?) => ($crate::graphql::InputValue::enum_value(stringify!($enum)));
|
||||
|
||||
(($e:expr)$(,)?) => ($crate::InputValue::from($e));
|
||||
(($e:expr)$(,)?) => ($crate::graphql::InputValue::from($e));
|
||||
|
||||
($e:expr$(,)?) => ($crate::InputValue::from($e));
|
||||
($e:expr$(,)?) => ($crate::graphql::InputValue::from($e));
|
||||
}
|
||||
|
||||
#[doc(inline)]
|
||||
pub(super) use input_value;
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use indexmap::{indexmap, IndexMap};
|
||||
|
||||
type V = crate::InputValue;
|
||||
use crate::graphql;
|
||||
|
||||
use super::input_value;
|
||||
|
||||
type V = graphql::InputValue;
|
||||
|
||||
#[test]
|
||||
fn null() {
|
||||
assert_eq!(graphql_input_value!(null), V::Null);
|
||||
assert_eq!(input_value!(null), V::Null);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn scalar() {
|
||||
let val = 42;
|
||||
assert_eq!(graphql_input_value!(1), V::scalar(1));
|
||||
assert_eq!(graphql_input_value!("val"), V::scalar("val"));
|
||||
assert_eq!(graphql_input_value!(1.34), V::scalar(1.34));
|
||||
assert_eq!(graphql_input_value!(false), V::scalar(false));
|
||||
assert_eq!(graphql_input_value!(1 + 2), V::scalar(3));
|
||||
assert_eq!(graphql_input_value!((val)), V::scalar(42));
|
||||
assert_eq!(input_value!(1), V::scalar(1));
|
||||
assert_eq!(input_value!("val"), V::scalar("val"));
|
||||
assert_eq!(input_value!(1.34), V::scalar(1.34));
|
||||
assert_eq!(input_value!(false), V::scalar(false));
|
||||
assert_eq!(input_value!(1 + 2), V::scalar(3));
|
||||
assert_eq!(input_value!((val)), V::scalar(42));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn r#enum() {
|
||||
assert_eq!(graphql_input_value!(ENUM), V::enum_value("ENUM"));
|
||||
assert_eq!(graphql_input_value!(lowercase), V::enum_value("lowercase"));
|
||||
assert_eq!(input_value!(ENUM), V::enum_value("ENUM"));
|
||||
assert_eq!(input_value!(lowercase), V::enum_value("lowercase"));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn variable() {
|
||||
assert_eq!(graphql_input_value!(@var), V::variable("var"));
|
||||
assert_eq!(graphql_input_value!(@array), V::variable("array"));
|
||||
assert_eq!(graphql_input_value!(@object), V::variable("object"));
|
||||
assert_eq!(input_value!(@var), V::variable("var"));
|
||||
assert_eq!(input_value!(@array), V::variable("array"));
|
||||
assert_eq!(input_value!(@object), V::variable("object"));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn list() {
|
||||
let val = 42;
|
||||
|
||||
assert_eq!(graphql_input_value!([]), V::list(vec![]));
|
||||
assert_eq!(input_value!([]), V::list(vec![]));
|
||||
|
||||
assert_eq!(graphql_input_value!([null]), V::list(vec![V::Null]));
|
||||
assert_eq!(input_value!([null]), V::list(vec![V::Null]));
|
||||
|
||||
assert_eq!(graphql_input_value!([1]), V::list(vec![V::scalar(1)]));
|
||||
assert_eq!(graphql_input_value!([1 + 2]), V::list(vec![V::scalar(3)]));
|
||||
assert_eq!(graphql_input_value!([(val)]), V::list(vec![V::scalar(42)]));
|
||||
assert_eq!(input_value!([1]), V::list(vec![V::scalar(1)]));
|
||||
assert_eq!(input_value!([1 + 2]), V::list(vec![V::scalar(3)]));
|
||||
assert_eq!(input_value!([(val)]), V::list(vec![V::scalar(42)]));
|
||||
|
||||
assert_eq!(input_value!([ENUM]), V::list(vec![V::enum_value("ENUM")]));
|
||||
assert_eq!(
|
||||
graphql_input_value!([ENUM]),
|
||||
V::list(vec![V::enum_value("ENUM")]),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!([lowercase]),
|
||||
input_value!([lowercase]),
|
||||
V::list(vec![V::enum_value("lowercase")]),
|
||||
);
|
||||
|
||||
assert_eq!(input_value!([@var]), V::list(vec![V::variable("var")]),);
|
||||
assert_eq!(input_value!([@array]), V::list(vec![V::variable("array")]));
|
||||
assert_eq!(
|
||||
graphql_input_value!([@var]),
|
||||
V::list(vec![V::variable("var")]),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!([@array]),
|
||||
V::list(vec![V::variable("array")]),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!([@object]),
|
||||
input_value!([@object]),
|
||||
V::list(vec![V::variable("object")]),
|
||||
);
|
||||
|
||||
assert_eq!(
|
||||
graphql_input_value!([1, [2], 3]),
|
||||
input_value!([1, [2], 3]),
|
||||
V::list(vec![
|
||||
V::scalar(1),
|
||||
V::list(vec![V::scalar(2)]),
|
||||
|
@ -459,7 +454,7 @@ mod tests {
|
|||
]),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!([1, [2 + 3], 3]),
|
||||
input_value!([1, [2 + 3], 3]),
|
||||
V::list(vec![
|
||||
V::scalar(1),
|
||||
V::list(vec![V::scalar(5)]),
|
||||
|
@ -467,7 +462,7 @@ mod tests {
|
|||
]),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!([1, [ENUM], (val)]),
|
||||
input_value!([1, [ENUM], (val)]),
|
||||
V::list(vec![
|
||||
V::scalar(1),
|
||||
V::list(vec![V::enum_value("ENUM")]),
|
||||
|
@ -475,7 +470,7 @@ mod tests {
|
|||
]),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!([1 + 2, [(val)], @val]),
|
||||
input_value!([1 + 2, [(val)], @val]),
|
||||
V::list(vec![
|
||||
V::scalar(3),
|
||||
V::list(vec![V::scalar(42)]),
|
||||
|
@ -483,7 +478,7 @@ mod tests {
|
|||
]),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!([1, [@val], ENUM]),
|
||||
input_value!([1, [@val], ENUM]),
|
||||
V::list(vec![
|
||||
V::scalar(1),
|
||||
V::list(vec![V::variable("val")]),
|
||||
|
@ -495,68 +490,65 @@ mod tests {
|
|||
#[test]
|
||||
fn object() {
|
||||
let val = 42;
|
||||
assert_eq!(
|
||||
graphql_input_value!({}),
|
||||
V::object(IndexMap::<String, _>::new()),
|
||||
);
|
||||
assert_eq!(input_value!({}), V::object(IndexMap::<String, _>::new()));
|
||||
|
||||
assert_eq!(
|
||||
graphql_input_value!({ "key": null }),
|
||||
input_value!({ "key": null }),
|
||||
V::object(indexmap! {"key" => V::Null}),
|
||||
);
|
||||
|
||||
assert_eq!(
|
||||
graphql_input_value!({"key": 123}),
|
||||
input_value!({"key": 123}),
|
||||
V::object(indexmap! {"key" => V::scalar(123)}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({"key": 1 + 2}),
|
||||
input_value!({"key": 1 + 2}),
|
||||
V::object(indexmap! {"key" => V::scalar(3)}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({ "key": (val) }),
|
||||
input_value!({ "key": (val) }),
|
||||
V::object(indexmap! {"key" => V::scalar(42)}),
|
||||
);
|
||||
|
||||
assert_eq!(
|
||||
graphql_input_value!({"key": []}),
|
||||
input_value!({"key": []}),
|
||||
V::object(indexmap! {"key" => V::list(vec![])}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({ "key": [null] }),
|
||||
input_value!({ "key": [null] }),
|
||||
V::object(indexmap! {"key" => V::list(vec![V::Null])}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({"key": [1] }),
|
||||
input_value!({"key": [1] }),
|
||||
V::object(indexmap! {"key" => V::list(vec![V::scalar(1)])}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({"key": [1 + 2] }),
|
||||
input_value!({"key": [1 + 2] }),
|
||||
V::object(indexmap! {"key" => V::list(vec![V::scalar(3)])}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({ "key": [(val)] }),
|
||||
input_value!({ "key": [(val)] }),
|
||||
V::object(indexmap! {"key" => V::list(vec![V::scalar(42)])}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({ "key": ENUM }),
|
||||
input_value!({ "key": ENUM }),
|
||||
V::object(indexmap! {"key" => V::enum_value("ENUM")}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({ "key": lowercase }),
|
||||
input_value!({ "key": lowercase }),
|
||||
V::object(indexmap! {"key" => V::enum_value("lowercase")}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({"key": @val}),
|
||||
input_value!({"key": @val}),
|
||||
V::object(indexmap! {"key" => V::variable("val")}),
|
||||
);
|
||||
assert_eq!(
|
||||
graphql_input_value!({"key": @array }),
|
||||
input_value!({"key": @array }),
|
||||
V::object(indexmap! {"key" => V::variable("array")}),
|
||||
);
|
||||
|
||||
assert_eq!(
|
||||
graphql_input_value!({
|
||||
input_value!({
|
||||
"inner": {
|
||||
"key1": (val),
|
||||
"key2": "val",
|
||||
|
@ -606,8 +598,8 @@ mod tests {
|
|||
fn option() {
|
||||
let val = Some(42);
|
||||
|
||||
assert_eq!(graphql_input_value!(None), V::Null);
|
||||
assert_eq!(graphql_input_value!(Some(42)), V::scalar(42));
|
||||
assert_eq!(graphql_input_value!((val)), V::scalar(42));
|
||||
assert_eq!(input_value!(None), V::Null);
|
||||
assert_eq!(input_value!(Some(42)), V::scalar(42));
|
||||
assert_eq!(input_value!((val)), V::scalar(42));
|
||||
}
|
||||
}
|
|
@ -6,9 +6,11 @@ pub mod helper;
|
|||
#[macro_use]
|
||||
pub mod reflect;
|
||||
|
||||
#[macro_use]
|
||||
mod graphql_input_value;
|
||||
mod input_value;
|
||||
#[macro_use]
|
||||
mod graphql_value;
|
||||
#[macro_use]
|
||||
mod graphql_vars;
|
||||
|
||||
#[doc(inline)]
|
||||
pub use self::input_value::input_value;
|
||||
|
|
Loading…
Reference in a new issue