A lightweight JSON library for Lua
 
 
Go to file
rxi f36b2f34b7 Removed use of loadstring() in parse_string()
Significant performance boost
2015-08-12 18:23:30 +01:00
LICENSE Initial commit 2015-08-11 21:08:33 +01:00
README.md Initial commit 2015-08-11 21:08:33 +01:00
json.lua Removed use of loadstring() in parse_string() 2015-08-12 18:23:30 +01:00

README.md

json.lua

A minimal JSON library for Lua

Features

  • Pure Lua implementation
  • Tiny: around 250sloc, 7kb
  • Proper error messages, eg: expected '}' or ',' at line 203 col 30

Usage

The json.lua file should be dropped into an existing project and required by it:

json = require "json"

The library provides the following functions:

json.encode(value)

Returns a string representing value encoded in JSON.

json.encode({ 1, 2, 3, { x = 10 } }) -- Returns '[1,2,3,{"x":10}]'

json.decode(str)

Returns a value representing the decoded JSON string.

json.decode('[1,2,3,{"x":10}]') -- Returns { 1, 2, 3, { x = 10 } }

Notes

  • UTF-16 surrogate pairs are not supported
  • Tables with the key 1 set are treated as arrays when encoding
  • null values contained within an array or object are converted to nil and are therefore lost upon decoding
  • Pretty encoding is not supported, json.encode() only encodes to a compact format

License

This library is free software; you can redistribute it and/or modify it under the terms of the MIT license. See LICENSE for details.