pub struct InterfaceDefinition { /* private fields */ }
Expand description
InterfaceDefinition is an abstract type where there are common fields declared.
Any type that implements an interface must define all the fields with names and types exactly matching. The implementations of this interface are explicitly listed out in possibleTypes.
InterfaceDefTypeDefinition: Description? interface Name ImplementsInterfaceDefs? Directives?
Detailed documentation can be found in GraphQL spec.
§Example
use apollo_encoder::{Type_, FieldDefinition, InterfaceDefinition};
use indoc::indoc;
let ty_1 = Type_::NamedType {
name: "String".to_string(),
};
let ty_2 = Type_::NamedType {
name: "String".to_string(),
};
let ty_3 = Type_::NonNull { ty: Box::new(ty_2) };
let ty_4 = Type_::List { ty: Box::new(ty_3) };
let ty_5 = Type_::NonNull { ty: Box::new(ty_4) };
let ty_6 = Type_::NamedType {
name: "Boolean".to_string(),
};
let mut field_1 = FieldDefinition::new("main".to_string(), ty_1);
field_1.description("Cat's main dish of a meal.".to_string());
let mut field_2 = FieldDefinition::new("snack".to_string(), ty_5);
field_2.description("Cat's post meal snack.".to_string());
let mut field_3 = FieldDefinition::new("pats".to_string(), ty_6);
field_3.description("Does cat get a pat after meal?".to_string());
// a schema definition
let mut interface = InterfaceDefinition::new("Meal".to_string());
interface.description(
"Meal interface for various\nmeals during the day.".to_string(),
);
interface.field(field_1);
interface.field(field_2);
interface.field(field_3);
assert_eq!(
interface.to_string(),
indoc! { r#"
"""
Meal interface for various
meals during the day.
"""
interface Meal {
"Cat's main dish of a meal."
main: String
"Cat's post meal snack."
snack: [String!]!
"Does cat get a pat after meal?"
pats: Boolean
}
"# }
);
Implementations§
Source§impl InterfaceDefinition
impl InterfaceDefinition
Sourcepub fn description(&mut self, description: String)
pub fn description(&mut self, description: String)
Set the schema def’s description.
Sourcepub fn field(&mut self, field: FieldDefinition)
pub fn field(&mut self, field: FieldDefinition)
Push a Field to schema def’s fields vector.
Trait Implementations§
Source§impl Clone for InterfaceDefinition
impl Clone for InterfaceDefinition
Source§fn clone(&self) -> InterfaceDefinition
fn clone(&self) -> InterfaceDefinition
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for InterfaceDefinition
impl Debug for InterfaceDefinition
Source§impl Display for InterfaceDefinition
impl Display for InterfaceDefinition
Source§impl TryFrom<InterfaceTypeDefinition> for InterfaceDefinition
impl TryFrom<InterfaceTypeDefinition> for InterfaceDefinition
Source§fn try_from(node: InterfaceTypeDefinition) -> Result<Self, Self::Error>
fn try_from(node: InterfaceTypeDefinition) -> Result<Self, Self::Error>
Create an apollo-encoder node from an apollo-parser one.
§Errors
This returns an error if the apollo-parser tree is not valid. The error doesn’t have much context due to TryFrom API constraints: validate the parse tree before using TryFrom if granular errors are important to you.
Source§impl TryFrom<InterfaceTypeExtension> for InterfaceDefinition
impl TryFrom<InterfaceTypeExtension> for InterfaceDefinition
Source§fn try_from(node: InterfaceTypeExtension) -> Result<Self, Self::Error>
fn try_from(node: InterfaceTypeExtension) -> Result<Self, Self::Error>
Create an apollo-encoder node from an apollo-parser one.
§Errors
This returns an error if the apollo-parser tree is not valid. The error doesn’t have much context due to TryFrom API constraints: validate the parse tree before using TryFrom if granular errors are important to you.