Skip to content

Latest commit

 

History

History
84 lines (63 loc) · 3.64 KB

CHANGELOG.md

File metadata and controls

84 lines (63 loc) · 3.64 KB

Oksa CHANGELOG

We use Break Versioning. The version numbers follow a <major>.<minor>.<patch> scheme with the following intent:

Bump Intent
major Major breaking changes -- check the changelog for details.
minor Minor breaking changes -- check the changelog for details.
patch No breaking changes, ever!!

-SNAPSHOT versions are preview versions for upcoming releases.

Oksa is currently experimental.

1.1.1-SNAPSHOT

  • Add test-doc-blocks to run tests continuously against examples in README.md #21 #22 #23

1.1.0

  • Add generative tests #12 a7d0214
  • Restrict fragment-spread map to be required #13
  • BREAKING CHANGE: Restrict values inside ListValue and ObjectValue #14
  • Add missing :min to selection set refs #15
  • Add support for persistent hash map formatting #16
  • Fixes parser to restrict fragment spread & subsequent selection set #18
  • Fixes ClojureScript -name redef warning #20

1.0.0

  • Adds support for name transformers #10
    • You can provide a custom function to transform names, fields, enums, directives, and types. See README for examples.
    • With this change, both the data DSL and API now uses the same unparser implementation under the hood.
  • Fixes parser bug with sequential selection sets #9
  • Adds babashka support #11

Name transformation

Supports top-level definitions and local overrides for transformers.

; clj -Sdeps '{:deps {fi.metosin/oksa {:mvn/version "1.0.0"} camel-snake-kebab/camel-snake-kebab {:mvn/version "0.4.3"}}}'

(require '[oksa.core :as o])
(require '[camel-snake-kebab.core :as csk])

(o/gql* {:oksa/name-fn csk/->camelCase
         :oksa/directive-fn csk/->snake_case
         :oksa/enum-fn csk/->SCREAMING_SNAKE_CASE
         :oksa/field-fn csk/->Camel_Snake_Case
         :oksa/type-fn csk/->PascalCase}
  [[:foo-bar {:alias :bar-foo
              :oksa/name-fn csk/->SCREAMING_SNAKE_CASE
              :directives [:foo-bar]
              :arguments {:foo-arg :bar-value}}
    [:foo-bar]]
   :naked-foo-bar
   [:...
    [:foo-bar]]
   [:... {:on :foo-bar-fragment
          :directives [:foo-bar]}
    [:foo-bar]]])

; => "{BAR_FOO:Foo_Bar(FOO_ARG:BAR_VALUE)@foo_bar{Foo_Bar} Naked_Foo_Bar ...{Foo_Bar} ...on fooBarFragment@foo_bar{Foo_Bar}}"

0.1.0

  • Adds oksa.core/explain as a convenience function for malli.core/explain
  • Fixes default value formatting #6
  • Introduces oksa.alpha.api for programmatic API access #7
    • Restricts FragmentDefinition and OperationDefinition to have just single SelectionSet as per spec
    • Fixes TypeName to also support string-typed name

0.0.1

First release! 🎉