Module: MultiJson::OkJson

Extended by:
OkJson
Included in:
OkJson
Defined in:
lib/multi_json/vendor/okjson.rb

Overview

Defined Under Namespace

Classes: Error, Utf8Error

Constant Summary collapse

Upstream =
'43'

Instance Method Summary collapse

Instance Method Details

#decode(s) ⇒ Object

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.



44
45
46
47
48
49
50
51
# File 'lib/multi_json/vendor/okjson.rb', line 44

def decode(s)
  ts = lex(s)
  v, ts = textparse(ts)
  if ts.length > 0
    raise Error, 'trailing garbage'
  end
  v
end

#encode(x) ⇒ Object

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.



63
64
65
66
67
68
69
70
# File 'lib/multi_json/vendor/okjson.rb', line 63

def encode(x)
  case x
  when Hash    then objenc(x)
  when Array   then arrenc(x)
  else
    raise Error, 'root value must be an Array or a Hash'
  end
end

#valenc(x) ⇒ Object



73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
# File 'lib/multi_json/vendor/okjson.rb', line 73

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