Skip to content
/ decode Public

Ergonomic dynamic decoders for Gleam!

Notifications You must be signed in to change notification settings

lpil/decode

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

decode

Ergonomic dynamic decoders for Gleam!

Package Version Hex Docs

gleam add decode
import decode/zero as decode

pub type User {
  User(name: String, email: String, is_admin: Bool)
}

/// Decode data of this shape into a `User` record.
///
/// {
///   "name" -> "Lucy",
///   "email" -> "lucy@example.com",
///   "is-admin" -> true
/// }
///
pub fn run(data: Dynamic) {
  let decoder = {
    use name <- zero.field("name", zero.string)
    use score <- zero.field("score", zero.int)
    use colour <- zero.field("colour", zero.string)
    use enrolled <- zero.field("enrolled", zero.bool)
    zero.success(Player(name:, score:, colour:, enrolled:))
  }

  decode.from(data, decoder)
}

Or, alternatively:

import decode

pub type User {
  User(name: String, email: String, is_admin: Bool)
}

/// Decode data of this shape into a `User` record.
///
/// {
///   "name" -> "Lucy",
///   "email" -> "lucy@example.com",
///   "is-admin" -> true
/// }
///
pub fn run(data: Dynamic) {
  let decoder =
    decode.into({
      use name <- decode.parameter
      use email <- decode.parameter
      use is_admin <- decode.parameter
      User(name, email, is_admin)
    })
    |> decode.field("name", decode.string)
    |> decode.field("email", decode.string)
    |> decode.field("is-admin", decode.bool)

  decoder
  |> decode.from(data)
}

For more documentation and examples view https://hexdocs.pm/decode.