Exception: Exception
- Defined in:
- lib/json/add/exception.rb
Class Method Summary collapse
-
.json_create(object) ⇒ Object
See #as_json.
Instance Method Summary collapse
-
#as_json ⇒ Object
Methods
Exception#as_json
andException.json_create
may be used to serialize and deserialize a Exception object; see Marshal. -
#to_json(*args) ⇒ Object
Returns a JSON string representing
self
:.
Class Method Details
.json_create(object) ⇒ Object
See #as_json.
9 10 11 12 13 |
# File 'lib/json/add/exception.rb', line 9 def self.json_create(object) result = new(object['m']) result.set_backtrace object['b'] result end |
Instance Method Details
#as_json ⇒ Object
Methods Exception#as_json
and Exception.json_create
may be used to serialize and deserialize a Exception object; see Marshal.
Method Exception#as_json
serializes self
, returning a 2-element hash representing self
:
require 'json/add/exception'
x = Exception.new('Foo').as_json # => {"json_class"=>"Exception", "m"=>"Foo", "b"=>nil}
Method JSON.create
deserializes such a hash, returning a Exception object:
Exception.json_create(x) # => #<Exception: Foo>
29 30 31 32 33 34 35 |
# File 'lib/json/add/exception.rb', line 29 def as_json(*) { JSON.create_id => self.class.name, 'm' => , 'b' => backtrace, } end |
#to_json(*args) ⇒ Object
Returns a JSON string representing self
:
require 'json/add/exception'
puts Exception.new('Foo').to_json
Output:
{"json_class":"Exception","m":"Foo","b":null}
46 47 48 |
# File 'lib/json/add/exception.rb', line 46 def to_json(*args) as_json.to_json(*args) end |