From 683f324ddd64ae71f77dfdf54f4a9f50e25169da Mon Sep 17 00:00:00 2001 From: Ben Kraft Date: Wed, 9 Feb 2022 16:50:29 -0800 Subject: [PATCH] Release v0.4.0 It's been a while, time for a release! This commit updates the changelog, and I'll tag it with the release once it lands. Fixes #163. I'll wait for #169 and #170 to land before merging this. Test plan: Craig tested a fairly recent main branch in webapp. --- docs/CHANGELOG.md | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/docs/CHANGELOG.md b/docs/CHANGELOG.md index f1bd00d6..61d65a86 100644 --- a/docs/CHANGELOG.md +++ b/docs/CHANGELOG.md @@ -22,17 +22,30 @@ When releasing a new version: ### Breaking changes: +### New features: + +### Bug fixes: + +## v0.4.0 + +Version 0.4.0 adds several new configuration options, as well as additional methods to simplify the use of interfaces. + +### Breaking changes: + - The `Config` fields `Schema` and `Operations` are now both of type `StringList`. This does not affect configuration via `genqlient.yaml`, only via the Go API. ### New features: - genqlient now generates getter methods for all fields, even those which do not implement a genqlient-generated interface; this can be useful for callers who wish to define their own interface and have several unrelated genqlient types which have the same fields implement it. -- genqlient config now accepts either a single or multiple files for the `schema` and `operations` fields (previously it accepted only one `schema`, and required a list of `operations` files). +- The new `struct_references` option automatically sets the `pointer` and `omitempty` options on fields of struct type; see the [`genqlient.yaml` documentation](docs/genqlient.yaml) for details. +- genqlient config now accepts either a single or multiple files (or globs) for the `schema` and `operations` fields (previously it accepted only one `schema`, and required a list of `operations` files). +- genqlient now looks for its config file as `[.]genqlient.y[a]ml` in any ancestor directory, if unspecified, rather than only as `genqlient.yaml` in the current directory. - The `typename` option can now be used on basic types (string, int, etc) as well as structs; this can be useful to have genqlient define new types like `type Language string` and use that type for specified fields. ### Bug fixes: - In certain very rare cases involving duplicate fields in fragment spreads, genqlient would generate code that failed to compile due to duplicate methods not getting promoted; genqlient now generates correct types. (See #126 for a more complete description.) +- genqlient no longer rejects schemas which include the implicitly declared types (`scalar String`, etc.) explicitly; this makes it easier to use schemas generate via introspection. ## v0.3.0