mirror https://github.com/sile/jsone

Takeru Ohta d9058ec9a8 文字列デコード用のバッファを持ちまわすようにして、文字列が多いJSONのデコード処理効率を向上させた 11 years ago
doc 573c053f55 ドキュメントを追加 11 years ago
src d9058ec9a8 文字列デコード用のバッファを持ちまわすようにして、文字列が多いJSONのデコード処理効率を向上させた 11 years ago
test 0c1d8d8857 meckを依存ライブラリから除去 11 years ago
.gitignore bff1c05ea2 first commit 11 years ago
COPYING 27423dcf2a specおよびedocコメントを追加 11 years ago
Makefile 573c053f55 ドキュメントを追加 11 years ago
README.md d9058ec9a8 文字列デコード用のバッファを持ちまわすようにして、文字列が多いJSONのデコード処理効率を向上させた 11 years ago
rebar bff1c05ea2 first commit 11 years ago
rebar.config 0c1d8d8857 meckを依存ライブラリから除去 11 years ago

README.md

jsone (0.1.1)

Erlangで実装されたJSONのエンコード/デコードライブラリ。

特徴

  • RFC4627準拠
  • 日本語を含む文字列に対応
    • ただし文字列はUTF-8のみをサポート
  • Pure Erlang
  • デコード処理部を実験的にCPS的に実装
    • パース途中にサブバイナリが生成されることを極力抑制して最適化
    • NIFを使わない実装の中ではおそらく最速

ビルド方法

ビルドツールにはrebarを使用している。

ビルド手順:

# ビルド
$ git clone git://github.com/sile/jsone.git
$ make init

# テスト & dialyzer 実行
$ make

# ロードパスに追加してErlangシェルを起動
$ make start
1> jsone:decode(<<"[1,2,3]">>).
[1,2,3]

API

EDOCドキュメント

使用例

%% デコード
> jsone:decode(<<"[1,2,3]">>).
{[1,2,3],<<>>}                  % 返り値は {デコード結果, 未使用バイナリ} 形式

> json:decode(<<"{\"1\":2}">>).
{{object,[{<<"1">>,2}]},<<>>}   % オブジェクトは {object, [Key, Value]} 形式にデコードされる

%% エンコード
> jsone:encode([1,2,3]).
[91,[[<<"1">>,44,<<"2">>],44,<<"3">>],93]  % iodata()が返る

> iolist_to_binary(jsone:encode([1,2,3])).
<<"[1,2,3]">>

参考