Decodes a json document in string s and returns the corresponding ruby value. String s must be valid UTF-8. If you have a string in some other encoding, convert it first.
String values in the resulting structure will be UTF-8.
# File lib/multi_json/vendor/okjson.rb, line 43 def decode(s) ts = lex(s) v, ts = textparse(ts) if ts.length > 0 raise Error, 'trailing garbage' end v end
Encodes x into a json text. It may contain only Array, Hash, String, Numeric, true, false, nil. (Note, this list excludes Symbol.) X itself must be an Array or a Hash. No other value can be encoded, and an error will be raised if x contains any other value, such as Nan, Infinity, Symbol, and Proc, or if a Hash key is not a String. Strings contained in x must be valid UTF-8.
# File lib/multi_json/vendor/okjson.rb, line 62 def encode(x) case x when Hash then objenc(x) when Array then arrenc(x) else valenc(x) end end
# File lib/multi_json/vendor/okjson.rb, line 71 def valenc(x) case x when Hash then objenc(x) when Array then arrenc(x) when String then strenc(x) when Numeric then numenc(x) when true then "true" when false then "false" when nil then "null" else if x.respond_to?(:to_json) x.to_json else raise Error, "cannot encode #{x.class}: #{x.inspect}" end end end
Generated with the Darkfish Rdoc Generator 2.