You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Paul J. Davis f09f30262d More README updates. 14 years ago
c_src Improve support for bignums. 14 years ago
src Improve support for bignums. 14 years ago
test Add tests for invalid utf-8 14 years ago
.gitignore Initial import. 14 years ago
Makefile Initial import. 14 years ago
README.md More README updates. 14 years ago
rebar Initial import. 14 years ago
rebar.config Initial import. 14 years ago

README.md

Jiffy - JSON NIFs for Erlang

A JSON parser as a NIF. This is a complete rewrite of the work I did in EEP0018 that was based on Yajl. This new version is a hand crafted state machine that does its best to be as quick and efficient as possible while not placing any constraints on the parsed JSON.

Usage

Jiffy's API is nearly an exact duplicate of the EEP0018 behaviour except for one small difference. jiffy:encode/1 now returns an iolist (specifically, a binary or list of binaries). This is to allow for the encoding of large numbers.

Eshell V5.8.2  (abort with ^G)
1> jiffy:decode(<<"{\"foo\": \"bar\"}">>).
{ok,{[{<<"foo">>,<<"bar">>}]}}
2> Doc = {[{foo, [<<"bing">>, 2.3, true]}]}.
{[{foo,[<<"bing">>,2.3,true]}]}
3> jiffy:encode(Doc).
{ok,<<"{\"foo\":[\"bing\",2.2999999999999998224,true]}">>}

Data Format

JSON             ->   Erlang
null             ->   null
true             ->   true
false            ->   false
1                ->   1
1.25             ->   1.25
[]               ->   []
[true, 1.0]      ->   [true, 1.0]
{}               ->   {[]}
{"foo": "bar"}   ->   {[{<<"foo">>, <<"bar">>}]}

Improvements over EEP0018

Jiffy should be in all ways an improvemnt over EEP0018. It no longer imposes limits on the nesting depth. It is capable of encoding and decoding large numbers and t does quite a bit more checking for validity of valid UTF-8 in strings.