1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
use crate::ast::definition::{ArgumentsDefinition, OutputTypeReference};
use crate::ast::{ConstDirectives, FromTokens, ParseError, Tokens, TryFromTokens};
use crate::lexical_token::{Name, PunctuatorType, StringValue};
use crate::Span;
use bluejay_core::definition::FieldDefinition as CoreFieldDefinition;
#[derive(Debug)]
pub struct FieldDefinition<'a> {
description: Option<StringValue>,
name: Name<'a>,
arguments_definition: Option<ArgumentsDefinition<'a>>,
r#type: OutputTypeReference<'a>,
directives: Option<ConstDirectives<'a>>,
is_builtin: bool,
}
impl<'a> FieldDefinition<'a> {
pub(crate) fn typename() -> FieldDefinition<'a> {
FieldDefinition {
description: None,
name: Name::new("__typename", Span::empty()),
arguments_definition: None,
r#type: OutputTypeReference::non_null_string(),
directives: None,
is_builtin: true,
}
}
}
impl<'a> CoreFieldDefinition for FieldDefinition<'a> {
type ArgumentsDefinition = ArgumentsDefinition<'a>;
type OutputTypeReference = OutputTypeReference<'a>;
type Directives = ConstDirectives<'a>;
fn description(&self) -> Option<&str> {
self.description.as_ref().map(AsRef::as_ref)
}
fn name(&self) -> &str {
self.name.as_ref()
}
fn arguments_definition(&self) -> Option<&Self::ArgumentsDefinition> {
self.arguments_definition.as_ref()
}
fn r#type(&self) -> &Self::OutputTypeReference {
&self.r#type
}
fn directives(&self) -> Option<&Self::Directives> {
self.directives.as_ref()
}
fn is_builtin(&self) -> bool {
self.is_builtin
}
}
impl<'a> FromTokens<'a> for FieldDefinition<'a> {
fn from_tokens(tokens: &mut impl Tokens<'a>) -> Result<Self, ParseError> {
let description = tokens.next_if_string_value();
let name = tokens.expect_name()?;
let arguments_definition = ArgumentsDefinition::try_from_tokens(tokens).transpose()?;
tokens.expect_punctuator(PunctuatorType::Colon)?;
let r#type = OutputTypeReference::from_tokens(tokens)?;
let directives = ConstDirectives::try_from_tokens(tokens).transpose()?;
Ok(Self {
description,
name,
arguments_definition,
r#type,
directives,
is_builtin: false,
})
}
}