Updated book for master ***NO_CI***

This commit is contained in:
Juniper Bot 2020-11-14 13:58:04 +00:00
parent 3fda1ed1ed
commit ffa36e19f7
5 changed files with 40 additions and 40 deletions

View file

@ -1414,7 +1414,7 @@ use juniper::{graphql_interface, GraphQLObject};
trait Character { trait Character {
fn id(&self) -> &str; fn id(&self) -> &str;
#[graphql_interface(ignore)] // or `#[graphql_interface(skip)]`, your choice #[graphql(ignore)] // or `#[graphql(skip)]`, your choice
fn ignored(&self) -> u32 { 0 } fn ignored(&self) -> u32 { 0 }
} }
@ -1447,26 +1447,26 @@ use juniper::graphql_interface;
/// This doc is absent in GraphQL schema. /// This doc is absent in GraphQL schema.
trait Character { trait Character {
// Renames the field in GraphQL schema. // Renames the field in GraphQL schema.
#[graphql_interface(name = "myId")] #[graphql(name = "myId")]
// Deprecates the field in GraphQL schema. // Deprecates the field in GraphQL schema.
// Usual Rust `#[deprecated]` attribute is supported too as field deprecation, // Usual Rust `#[deprecated]` attribute is supported too as field deprecation,
// but `deprecated` attribute argument takes precedence over it, if specified. // but `deprecated` attribute argument takes precedence over it, if specified.
#[graphql_interface(deprecated = "Do not use it.")] #[graphql(deprecated = "Do not use it.")]
// Describes the field in GraphQL schema. // Describes the field in GraphQL schema.
#[graphql_interface(description = "ID of my own character.")] #[graphql(description = "ID of my own character.")]
// Usual Rust docs are supported too as field description, // Usual Rust docs are supported too as field description,
// but `description` attribute argument takes precedence over them, if specified. // but `description` attribute argument takes precedence over them, if specified.
/// This description is absent in GraphQL schema. /// This description is absent in GraphQL schema.
fn id( fn id(
&self, &self,
// Renames the argument in GraphQL schema. // Renames the argument in GraphQL schema.
#[graphql_interface(name = "myNum")] #[graphql(name = "myNum")]
// Describes the argument in GraphQL schema. // Describes the argument in GraphQL schema.
#[graphql_interface(description = "ID number of my own character.")] #[graphql(description = "ID number of my own character.")]
// Specifies the default value for the argument. // Specifies the default value for the argument.
// The concrete value may be omitted, and the `Default::default` one // The concrete value may be omitted, and the `Default::default` one
// will be used in such case. // will be used in such case.
#[graphql_interface(default = 5)] #[graphql(default = 5)]
num: i32, num: i32,
) -> &str; ) -> &str;
} }
@ -1491,7 +1491,7 @@ trait Character { // while still can be specified via `Context =
fn id(&self, context: &Database) -> Option<&str>; fn id(&self, context: &Database) -> Option<&str>;
// Otherwise, you may mark it explicitly as a context argument. // Otherwise, you may mark it explicitly as a context argument.
fn name(&self, #[graphql_interface(context)] db: &Database) -> Option<&str>; fn name(&self, #[graphql(context)] db: &Database) -> Option<&str>;
} }
#[derive(GraphQLObject)] #[derive(GraphQLObject)]
@ -1538,7 +1538,7 @@ trait Character<S: ScalarValue> {
// Otherwise, you may mark it explicitly as an executor argument. // Otherwise, you may mark it explicitly as an executor argument.
async fn name<'b>( async fn name<'b>(
&'b self, &'b self,
#[graphql_interface(executor)] another: &Executor<'_, '_, (), S>, #[graphql(executor)] another: &Executor<'_, '_, (), S>,
) -> &'b str ) -> &'b str
where where
S: Send + Sync; S: Send + Sync;
@ -1550,7 +1550,7 @@ struct Human {
id: String, id: String,
name: String, name: String,
} }
#[graphql_interface(Scalar = S)] #[graphql_interface(scalar = S)]
impl<S: ScalarValue> Character<S> for Human { impl<S: ScalarValue> Character<S> for Human {
async fn id<'a>(&self, executor: &'a Executor<'_, '_, (), S>) -> &'a str async fn id<'a>(&self, executor: &'a Executor<'_, '_, (), S>) -> &'a str
where where
@ -1581,12 +1581,12 @@ struct Database {
} }
impl juniper::Context for Database {} impl juniper::Context for Database {}
#[graphql_interface(for = [Human, Droid], Context = Database)] #[graphql_interface(for = [Human, Droid], context = Database)]
#[graphql_interface(on Droid = get_droid)] // enables downcasting `Droid` via `get_droid()` function #[graphql_interface(on Droid = get_droid)] // enables downcasting `Droid` via `get_droid()` function
trait Character { trait Character {
fn id(&self) -> &str; fn id(&self) -> &str;
#[graphql_interface(downcast)] // makes method a downcast to `Human`, not a field #[graphql(downcast)] // makes method a downcast to `Human`, not a field
// NOTICE: The method signature may optionally contain `&Database` context argument. // NOTICE: The method signature may optionally contain `&Database` context argument.
fn as_human(&self) -> Option<&Human> { fn as_human(&self) -> Option<&Human> {
None None
@ -1636,7 +1636,7 @@ fn get_droid<'db>(ch: &CharacterValue, db: &'db Database) -> Op
use juniper::{graphql_interface, DefaultScalarValue, GraphQLObject}; use juniper::{graphql_interface, DefaultScalarValue, GraphQLObject};
#[graphql_interface(for = [Human, Droid])] #[graphql_interface(for = [Human, Droid])]
#[graphql_interface(Scalar = DefaultScalarValue)] // removing this line will fail compilation #[graphql_interface(scalar = DefaultScalarValue)] // removing this line will fail compilation
trait Character { trait Character {
fn id(&self) -> &str; fn id(&self) -> &str;
} }
@ -1647,7 +1647,7 @@ struct Human {
id: String, id: String,
home_planet: String, home_planet: String,
} }
#[graphql_interface(Scalar = DefaultScalarValue)] #[graphql_interface(scalar = DefaultScalarValue)]
impl Character for Human { impl Character for Human {
fn id(&self) -> &str { fn id(&self) -> &str {
&self.id &self.id
@ -1660,7 +1660,7 @@ struct Droid {
id: String, id: String,
primary_function: String, primary_function: String,
} }
#[graphql_interface(Scalar = DefaultScalarValue)] #[graphql_interface(scalar = DefaultScalarValue)]
impl Character for Droid { impl Character for Droid {
fn id(&self) -> &str { fn id(&self) -> &str {
&self.id &self.id
@ -2123,7 +2123,7 @@ struct Database {
} }
impl juniper::Context for Database {} impl juniper::Context for Database {}
#[graphql_union(Context = Database)] #[graphql_union(context = Database)]
trait Character { trait Character {
// NOTICE: The method signature may optionally contain `&Context`. // NOTICE: The method signature may optionally contain `&Context`.
fn as_human<'db>(&self, ctx: &'db Database) -> Option<&'db Human> { None } fn as_human<'db>(&self, ctx: &'db Database) -> Option<&'db Human> { None }
@ -2165,7 +2165,7 @@ struct Droid {
trait Character { trait Character {
fn as_human(&self) -> Option<&Human> { None } fn as_human(&self) -> Option<&Human> { None }
fn as_droid(&self) -> Option<&Droid> { None } fn as_droid(&self) -> Option<&Droid> { None }
#[graphql_union(ignore)] // or `#[graphql_union(skip)]`, your choice #[graphql(ignore)] // or `#[graphql(skip)]`, your choice
fn id(&self) -> &str; fn id(&self) -> &str;
} }
@ -2207,13 +2207,13 @@ struct Database {
} }
impl juniper::Context for Database {} impl juniper::Context for Database {}
#[graphql_union(Context = Database)] #[graphql_union(context = Database)]
#[graphql_union( #[graphql_union(
on Human = DynCharacter::get_human, on Human = DynCharacter::get_human,
on Droid = get_droid, on Droid = get_droid,
)] )]
trait Character { trait Character {
#[graphql_union(ignore)] // or `#[graphql_union(skip)]`, your choice #[graphql(ignore)] // or `#[graphql(skip)]`, your choice
fn id(&self) -> &str; fn id(&self) -> &str;
} }

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View file

@ -276,7 +276,7 @@ use juniper::{graphql_interface, GraphQLObject};
trait Character { trait Character {
fn id(&self) -> &str; fn id(&self) -> &str;
#[graphql_interface(ignore)] // or `#[graphql_interface(skip)]`, your choice #[graphql(ignore)] // or `#[graphql(skip)]`, your choice
fn ignored(&self) -> u32 { 0 } fn ignored(&self) -> u32 { 0 }
} }
@ -309,26 +309,26 @@ use juniper::graphql_interface;
/// This doc is absent in GraphQL schema. /// This doc is absent in GraphQL schema.
trait Character { trait Character {
// Renames the field in GraphQL schema. // Renames the field in GraphQL schema.
#[graphql_interface(name = "myId")] #[graphql(name = "myId")]
// Deprecates the field in GraphQL schema. // Deprecates the field in GraphQL schema.
// Usual Rust `#[deprecated]` attribute is supported too as field deprecation, // Usual Rust `#[deprecated]` attribute is supported too as field deprecation,
// but `deprecated` attribute argument takes precedence over it, if specified. // but `deprecated` attribute argument takes precedence over it, if specified.
#[graphql_interface(deprecated = "Do not use it.")] #[graphql(deprecated = "Do not use it.")]
// Describes the field in GraphQL schema. // Describes the field in GraphQL schema.
#[graphql_interface(description = "ID of my own character.")] #[graphql(description = "ID of my own character.")]
// Usual Rust docs are supported too as field description, // Usual Rust docs are supported too as field description,
// but `description` attribute argument takes precedence over them, if specified. // but `description` attribute argument takes precedence over them, if specified.
/// This description is absent in GraphQL schema. /// This description is absent in GraphQL schema.
fn id( fn id(
&self, &self,
// Renames the argument in GraphQL schema. // Renames the argument in GraphQL schema.
#[graphql_interface(name = "myNum")] #[graphql(name = "myNum")]
// Describes the argument in GraphQL schema. // Describes the argument in GraphQL schema.
#[graphql_interface(description = "ID number of my own character.")] #[graphql(description = "ID number of my own character.")]
// Specifies the default value for the argument. // Specifies the default value for the argument.
// The concrete value may be omitted, and the `Default::default` one // The concrete value may be omitted, and the `Default::default` one
// will be used in such case. // will be used in such case.
#[graphql_interface(default = 5)] #[graphql(default = 5)]
num: i32, num: i32,
) -> &str; ) -> &str;
} }
@ -353,7 +353,7 @@ trait Character { // while still can be specified via `Context =
fn id(&self, context: &Database) -> Option<&str>; fn id(&self, context: &Database) -> Option<&str>;
// Otherwise, you may mark it explicitly as a context argument. // Otherwise, you may mark it explicitly as a context argument.
fn name(&self, #[graphql_interface(context)] db: &Database) -> Option<&str>; fn name(&self, #[graphql(context)] db: &Database) -> Option<&str>;
} }
#[derive(GraphQLObject)] #[derive(GraphQLObject)]
@ -400,7 +400,7 @@ trait Character<S: ScalarValue> {
// Otherwise, you may mark it explicitly as an executor argument. // Otherwise, you may mark it explicitly as an executor argument.
async fn name<'b>( async fn name<'b>(
&'b self, &'b self,
#[graphql_interface(executor)] another: &Executor<'_, '_, (), S>, #[graphql(executor)] another: &Executor<'_, '_, (), S>,
) -> &'b str ) -> &'b str
where where
S: Send + Sync; S: Send + Sync;
@ -412,7 +412,7 @@ struct Human {
id: String, id: String,
name: String, name: String,
} }
#[graphql_interface(Scalar = S)] #[graphql_interface(scalar = S)]
impl<S: ScalarValue> Character<S> for Human { impl<S: ScalarValue> Character<S> for Human {
async fn id<'a>(&self, executor: &'a Executor<'_, '_, (), S>) -> &'a str async fn id<'a>(&self, executor: &'a Executor<'_, '_, (), S>) -> &'a str
where where
@ -443,12 +443,12 @@ struct Database {
} }
impl juniper::Context for Database {} impl juniper::Context for Database {}
#[graphql_interface(for = [Human, Droid], Context = Database)] #[graphql_interface(for = [Human, Droid], context = Database)]
#[graphql_interface(on Droid = get_droid)] // enables downcasting `Droid` via `get_droid()` function #[graphql_interface(on Droid = get_droid)] // enables downcasting `Droid` via `get_droid()` function
trait Character { trait Character {
fn id(&self) -> &str; fn id(&self) -> &str;
#[graphql_interface(downcast)] // makes method a downcast to `Human`, not a field #[graphql(downcast)] // makes method a downcast to `Human`, not a field
// NOTICE: The method signature may optionally contain `&Database` context argument. // NOTICE: The method signature may optionally contain `&Database` context argument.
fn as_human(&self) -> Option<&Human> { fn as_human(&self) -> Option<&Human> {
None None
@ -498,7 +498,7 @@ fn get_droid<'db>(ch: &CharacterValue, db: &'db Database) -> Op
use juniper::{graphql_interface, DefaultScalarValue, GraphQLObject}; use juniper::{graphql_interface, DefaultScalarValue, GraphQLObject};
#[graphql_interface(for = [Human, Droid])] #[graphql_interface(for = [Human, Droid])]
#[graphql_interface(Scalar = DefaultScalarValue)] // removing this line will fail compilation #[graphql_interface(scalar = DefaultScalarValue)] // removing this line will fail compilation
trait Character { trait Character {
fn id(&self) -> &str; fn id(&self) -> &str;
} }
@ -509,7 +509,7 @@ struct Human {
id: String, id: String,
home_planet: String, home_planet: String,
} }
#[graphql_interface(Scalar = DefaultScalarValue)] #[graphql_interface(scalar = DefaultScalarValue)]
impl Character for Human { impl Character for Human {
fn id(&self) -> &str { fn id(&self) -> &str {
&self.id &self.id
@ -522,7 +522,7 @@ struct Droid {
id: String, id: String,
primary_function: String, primary_function: String,
} }
#[graphql_interface(Scalar = DefaultScalarValue)] #[graphql_interface(scalar = DefaultScalarValue)]
impl Character for Droid { impl Character for Droid {
fn id(&self) -> &str { fn id(&self) -> &str {
&self.id &self.id

View file

@ -415,7 +415,7 @@ struct Database {
} }
impl juniper::Context for Database {} impl juniper::Context for Database {}
#[graphql_union(Context = Database)] #[graphql_union(context = Database)]
trait Character { trait Character {
// NOTICE: The method signature may optionally contain `&Context`. // NOTICE: The method signature may optionally contain `&Context`.
fn as_human<'db>(&self, ctx: &'db Database) -> Option<&'db Human> { None } fn as_human<'db>(&self, ctx: &'db Database) -> Option<&'db Human> { None }
@ -457,7 +457,7 @@ struct Droid {
trait Character { trait Character {
fn as_human(&self) -> Option<&Human> { None } fn as_human(&self) -> Option<&Human> { None }
fn as_droid(&self) -> Option<&Droid> { None } fn as_droid(&self) -> Option<&Droid> { None }
#[graphql_union(ignore)] // or `#[graphql_union(skip)]`, your choice #[graphql(ignore)] // or `#[graphql(skip)]`, your choice
fn id(&self) -> &str; fn id(&self) -> &str;
} }
@ -499,13 +499,13 @@ struct Database {
} }
impl juniper::Context for Database {} impl juniper::Context for Database {}
#[graphql_union(Context = Database)] #[graphql_union(context = Database)]
#[graphql_union( #[graphql_union(
on Human = DynCharacter::get_human, on Human = DynCharacter::get_human,
on Droid = get_droid, on Droid = get_droid,
)] )]
trait Character { trait Character {
#[graphql_union(ignore)] // or `#[graphql_union(skip)]`, your choice #[graphql(ignore)] // or `#[graphql(skip)]`, your choice
fn id(&self) -> &str; fn id(&self) -> &str;
} }