Skip to content
This repository has been archived by the owner on Mar 28, 2023. It is now read-only.

folktale/encoding.json

Repository files navigation

encoding.json

Build status NPM version Dependencies status Licence Experimental

Lossless serialisation and parsing of JSON structures for complex objects

Example

var Enc = require('encoding.json');

// Simple structures
var Nothing = {
  // A toJSON method should return the representation of the object
  toJSON: function() {
    return { '#type': 'Nothing' }
  },
  // And a fromJSON method should return an Either.Right, if the
  // provided data can be parsed, otherwise an Either.Left with the
  // reasons it can't be parsed.
  fromJSON: function(data) {
    return Enc.foldType({
      'Nothing': function(){ return Nothing }
    }, data)
  },
  toString: function(){ return 'Nothing' }
}

var Just = function(value) {
  return {
    toJSON: function() {
      return { '#type': 'Just', value: value }
    },
    fromJSON: function(data) {
      return Enc.foldType({
        'Just': function(data){ return Just(data.value) }
      }, data)
    },
    toString: function(){ return 'Just(' + value + ')' }
  }
}

var a = Enc.serialise(Nothing)
// => (String) '{ "#type": "Nothing" }'
Enc.parseAs(Nothing, a)
// => Nothing

var b = Enc.serialise(Just(2))
// => (String) '{ "#type": "Just", "value": 2 }'
Enc.parseSAs(Just, b)
// => Just(2)
Enc.parseAs(Just, a)
// => Either.Left("Unknow type: Nothing")


// Complex interfaces
var IPerson = Enc.spec({
  name: Enc.Any,
  age: Enc.Any,
  avatar: Maybe
});

var personA = { name: "Alice", age: 12, avatar: Maybe.Just("/alice.png") };
var personB = { name: "Rabbit", age: 100, avatar: Maybe.Nothing };

Enc.reifyAs(IPerson, Enc.serialise(personA)) // => personA
Enc.reifyAs(IPerson, Enc.serialise(personB)) // => personB

Installing

The easiest way is to grab it from NPM. If you're running in a Browser environment, you can use Browserify

$ npm install encoding.json

Using with CommonJS

If you're not using NPM, Download the latest release, and require the encoding.json.umd.js file:

var JSON = require('encoding.json')

Using with AMD

Download the latest release, and require the encoding.json.umd.js file:

require(['encoding.json'], function(JSON) {
  ( ... )
})

Using without modules

Download the latest release, and load the encoding.json.umd.js file. The properties are exposed in the global Folktale.Encoding.JSON object:

<script src="/path/to/encoding.json.umd.js"></script>

Compiling from source

If you want to compile this library from the source, you'll need Git, Make, Node.js, and run the following commands:

$ git clone git://github.com/folktale/encoding.json.git
$ cd encoding.json
$ npm install
$ make bundle

This will generate the dist/encoding.json.umd.js file, which you can load in any JavaScript environment.

Documentation

You can read the documentation online or build it yourself:

$ git clone git://github.com/folktale/encoding.json.git
$ cd encoding.json
$ npm install
$ make documentation

Then open the file docs/index.html in your browser.

Platform support

This library assumes an ES5 environment, but can be easily supported in ES3 platforms by the use of shims. Just include es5-shim :)

Licence

Copyright (c) 2014 Quildreen Motta.

Released under the MIT licence.