diff --git a/.codespellrc b/.codespellrc new file mode 100644 index 00000000..8511d3f6 --- /dev/null +++ b/.codespellrc @@ -0,0 +1,2 @@ +[codespell] +ignore-words-list = crate diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 37f11917..fe234eee 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -24,6 +24,7 @@ jobs: if: ${{ github.event_name == 'pull_request' }} needs: - bench + - codespell - clippy - feature - msrv @@ -54,6 +55,15 @@ jobs: - run: make cargo.lint + codespell: + name: codespell (Book) + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: codespell-project/actions-codespell@v2 + with: + path: book/ + rustfmt: runs-on: ubuntu-latest steps: @@ -342,6 +352,7 @@ jobs: needs: - bench - clippy + - codespell - feature - msrv - package @@ -391,7 +402,7 @@ jobs: name: deploy (Book) if: ${{ github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/juniper@') }} - needs: ["test", "test-book"] + needs: ["codespell", "test", "test-book"] runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 diff --git a/Makefile b/Makefile index 50741cf7..e9656402 100644 --- a/Makefile +++ b/Makefile @@ -18,6 +18,9 @@ eq = $(if $(or $(1),$(2)),$(and $(findstring $(1),$(2)),\ book: book.build +codespell: book.codespell + + fmt: cargo.fmt @@ -137,6 +140,15 @@ book.build: mdbook build book/ $(if $(call eq,$(out),),,-d $(out)) +# Spellcheck Book. +# +# Usage: +# make book.codespell [fix=(no|yes)] + +book.codespell: + codespell book/ $(if $(call eq,$(fix),yes),--write-changes,) + + # Serve Book on some port. # # Usage: @@ -180,8 +192,8 @@ graphql-playground: # .PHONY section # ################## -.PHONY: book fmt lint release test \ - book.build book.serve \ +.PHONY: book codespell fmt lint release test \ + book.build book.codespell book.serve \ cargo.fmt cargo.lint cargo.release cargo.test \ graphiql graphql-playground \ test.book test.cargo diff --git a/book/src/advanced/dataloaders.md b/book/src/advanced/dataloaders.md index ef03afc1..703514c0 100644 --- a/book/src/advanced/dataloaders.md +++ b/book/src/advanced/dataloaders.md @@ -1,7 +1,7 @@ # Avoiding the N+1 Problem With Dataloaders A common issue with graphql servers is how the resolvers query their datasource. -This issue results in a large number of unneccessary database queries or http requests. +This issue results in a large number of unnecessary database queries or http requests. Say you were wanting to list a bunch of cults people were in ```graphql diff --git a/book/src/advanced/multiple_ops_per_request.md b/book/src/advanced/multiple_ops_per_request.md index 27d88c96..781b994f 100644 --- a/book/src/advanced/multiple_ops_per_request.md +++ b/book/src/advanced/multiple_ops_per_request.md @@ -1,6 +1,6 @@ # Multiple operations per request -The GraphQL standard generally assumes there will be one server request for each client operation you want to perform (such as a query or mutation). This is conceptually simple but has the potential to be inefficent. +The GraphQL standard generally assumes there will be one server request for each client operation you want to perform (such as a query or mutation). This is conceptually simple but has the potential to be inefficient. Some client libraries such as [apollo-link-batch-http](https://www.apollographql.com/docs/link/links/batch-http.html) have added the ability to batch operations in a single HTTP request to save network round-trips and potentially increase performance. There are some [tradeoffs](https://blog.apollographql.com/batching-client-graphql-queries-a685f5bcd41b) that should be considered before batching requests. diff --git a/book/src/types/interfaces.md b/book/src/types/interfaces.md index 87b72348..8990a094 100644 --- a/book/src/types/interfaces.md +++ b/book/src/types/interfaces.md @@ -61,13 +61,13 @@ Also, enum name can be specified explicitly, if desired. # extern crate juniper; use juniper::{graphql_interface, GraphQLObject}; -#[graphql_interface(enum = CharaterInterface, for = Human)] +#[graphql_interface(enum = CharacterInterface, for = Human)] trait Character { fn id(&self) -> &str; } #[derive(GraphQLObject)] -#[graphql(impl = CharaterInterface)] +#[graphql(impl = CharacterInterface)] struct Human { id: String, home_planet: String, @@ -248,7 +248,7 @@ use juniper::{graphql_interface, GraphQLObject}; pub struct ObjA { id: Vec, // ^^ the evaluated program panicked at -// 'Failed to implement interface `Character` on `ObjA`: Field `id`: implementor is expected to return a subtype of +// 'Failed to implement interface `Character` on `ObjA`: Field `id`: implementer is expected to return a subtype of // interface's return object: `[String!]!` is not a subtype of `String!`.' } diff --git a/book/src/types/objects/using_contexts.md b/book/src/types/objects/using_contexts.md index a795e09c..c917e087 100644 --- a/book/src/types/objects/using_contexts.md +++ b/book/src/types/objects/using_contexts.md @@ -127,7 +127,7 @@ impl User { let DatabaseContext(context) = context; // If context is immutable use .read() on RwLock. let mut context = context.write().await; - // Preform a mutable operation. + // Perform a mutable operation. context.requested_count.entry(self.id).and_modify(|e| { *e += 1 }).or_insert(1).clone() } diff --git a/book/src/types/other-index.md b/book/src/types/other-index.md index 621b8d2f..83be17d7 100644 --- a/book/src/types/other-index.md +++ b/book/src/types/other-index.md @@ -1,6 +1,6 @@ # Other Types -The GraphQL type system provides several types in additon to objects. +The GraphQL type system provides several types in addition to objects. Find out more about each type below: