GitXplorerGitXplorer
c

gserde

public
27 stars
1 forks
1 issues

Commits

List of commits on branch main.
Unverified
9a9addcc8ca66ee88f65e7c66d9d6af7cfc55d51

feat: support non primitives

ccdaringe committed a year ago
Unverified
6cf278549830e82911cc84ebc97a60d40f400463

feat: add DEBUG support

ccdaringe committed a year ago
Verified
5acd26b2e6d86a2e0979d1272a0ff2922f8c475b

Merge pull request #8 from cdaringe/renovate/lock-file-maintenance

ccdaringe committed a year ago
Unverified
f4f6d51bd581d1729b29621bba7b8a84e901c35a

chore(deps): lock file maintenance

rrenovate-bot committed a year ago
Verified
93c34a0e754a219ae904dc0dc596be18b10354b0

Update renovate.json

ccdaringe committed a year ago
Verified
d6abc2546796691886f79d02e9cbd1b5f280c9a6

Merge pull request #4 from cdaringe/renovate/actions-checkout-4.x

ccdaringe committed a year ago

README

The README file for this repository.

gserde

warning: alpha quality package with poor code hygiene, including assert/panic/todo statements.

Package Version Hex Docs

gleam add gserde

usage

  1. Create custom type with a singular variant constructor. See the example src/foo.gleam below.
  2. Run gleam run -m gserde.
  3. Observe the generated file src/foo_json.gleam.
  4. Use the new foo_json module!
// src/foo.gleam
import gleam/option.{type Option}
pub type FooJson {
  Foo(
    a_bool: Bool,
    b_int: Int,
    c_float: Float,
    d_two_tuple: #(Int, String),
    e_option_int: Option(Int),
    f_string_list: List(String),
  )
}

// src/foo_json.gleam
// generated!
import gleam/json
import gleam/dynamic
import internal/foo

pub fn to_json(t: foo.FooJson) {
  json.object([
    #("a_bool", json.bool(t.a_bool)),
    #("b_int", json.int(t.b_int)),
    #("c_float", json.float(t.c_float)),
    #(
      "d_two_tuple",
      json.preprocessed_array([
        json.int(t.d_two_tuple.0),
        json.string(t.d_two_tuple.1),
      ]),
    ),
    #("e_option_int", json.nullable(t.e_option_int, json.int)),
    #("f_string_list", json.array(t.f_string_list, json.string)),
  ])
}

pub fn to_string(t: foo.FooJson) {
  json.to_string(to_json(t))
}

pub fn get_decoder_foo() {
  dynamic.decode6(
    foo.Foo,
    dynamic.field("a_bool", dynamic.bool),
    dynamic.field("b_int", dynamic.int),
    dynamic.field("c_float", dynamic.float),
    dynamic.field("d_two_tuple", dynamic.tuple2(dynamic.int, dynamic.string)),
    dynamic.field("e_option_int", dynamic.optional(dynamic.int)),
    dynamic.field("f_string_list", dynamic.list(dynamic.string)),
  )
}

pub fn from_string(json_str: String) {
  json.decode(json_str, get_decoder_foo())
}

// src/my_module.gleam
import foo
import foo_json

pub fn serialization_identity_test() {
  let foo_1 = foo.Foo(..) // make a Foo

  let foo_2 = foo_1
    |> foo_json.to_string // 👀, stringify the Foo to JSON!
    |> foo_json.from_string // 👀, parse the Foo from JSON!

  foo_1 == foo_2 // pass the identity test
}

You can set DEBUG=1 to get verbose output during codegen.

todo

  • [ ] complete all cases
  • [ ] remove all invocations of assert/panic/todo
  • [x] support non-gleam primitive types
  • [ ] handle all module references properly

Further documentation can be found at https://hexdocs.pm/gserde.

Development

gleam test  # Run the tests