Skip to content
This repository has been archived by the owner on Sep 11, 2024. It is now read-only.
/ JSON Public archive

A simple library for parsing and serializing JSON to Swift data structures.

License

Notifications You must be signed in to change notification settings

kryptco/JSON

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A simple library for parsing and serializing JSON to any Swift data structures. Complete style control with minimal changes.

Developed at KryptCo (https://krypt.co)

Install

We recommend managing dependencies with git submodules.

git submodule add [email protected]:KryptCo/JSON.git

Use

This library works with all Swift data structures (i.e Structs, Classes, and Enums).

To use with your data structures:

- JSON to Swift: implement JsonReadable.
- Swift to JSON: implement JsonWritable.
- Both: implement Jsonable

Examples

To convert data structures to JSON and back we do the following.

do {
    let car = Car(make: "Toyota", model: "Rav4", year: "2004")

    // Serialize to JSON data/string
    let carJson = try car.jsonString()

    // Init object from JSON
    let parsedCar = try Car(jsonString: carJson)
} catch {
    // catch errors here
}

To implement a struct that can be initialized from JSON or can be serialized to JSON we do the following.

struct Car:Jsonable {
    var make:String
    var model:String
    var year:Int

    // use the `~>` operator function
    // to easily parse json into stored properties
    // type inference makes the syntax simple

    init(json:Object) throws {
        make = try json ~> "make"
        model = try json ~> "model"
        year = try json ~> "year"
    }

    var object:Object {
        return ["make": make,
                "model": model,
                "year": year
        ]
    }
}

See more examples in JSONTests/TestTypes.swift

About

A simple library for parsing and serializing JSON to Swift data structures.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published