Class: JSON::Coder
Relationships & Source Files | |
Inherits: | Object |
Defined in: | ext/json/lib/json/common.rb |
Overview
Class Method Summary
-
.dump(object) ⇒ String
(also: .generate)
mod_func
Serialize the given object into a JSON document.
-
.generate(object, io = nil)
mod_func
Alias for #dump.
-
JSON.new(options = nil, &block)
mod_func
Argument
options
, if given, contains a Hash of options for both parsing and generating. -
.load(string) ⇒ Object
(also: .parse)
mod_func
Parse the given JSON document and return an equivalent Ruby object.
-
.load(path) ⇒ Object
mod_func
Parse the given JSON document and return an equivalent Ruby object.
-
.parse(source)
mod_func
Alias for #load.
-
.
constructor
private
Argument
options
, if given, contains a Hash of options for both parsing and generating.
Constructor Details
. (private)
Argument options
, if given, contains a Hash of options for both parsing and generating. See Parsing Options, and Generating Options.
For generation, the strict: true
option is always set. When a Ruby object with no native JSON counterpart is encoutered, the block provided to the initialize method is invoked, and must return a Ruby object that has a native JSON counterpart:
module MyApp
API_JSON_CODER = JSON::Coder.new do |object|
case object
when Time
object.iso8601(3)
else
object # Unknown type, will raise
end
end
end
puts MyApp::API_JSON_CODER.dump(Time.now.utc) # => "2025-01-21T08:41:44.286Z"
# File 'ext/json/lib/json/common.rb', line 900
def initialize( = nil, &as_json) if .nil? = { strict: true } else = .dup [:strict] = true end [:as_json] = as_json if as_json [:create_additions] = false unless .key?(:create_additions) @state = State.new( ).freeze @parser_config = Ext::Parser::Config.new( ) end
Class Method Details
.dump(object) ⇒ String
(mod_func)
.dump(object, io) ⇒ IO
Also known as: .generate
String
(mod_func)
.dump(object, io) ⇒ IO
Serialize the given object into a JSON document.
# File 'ext/json/lib/json/common.rb', line 919
def dump(object, io = nil) @state.generate_new(object, io) end
.generate(object, io = nil) (mod_func)
Alias for #dump.
# File 'ext/json/lib/json/common.rb', line 922
alias_method :generate, :dump
JSON.new(options = nil, &block) (mod_func)
Argument options
, if given, contains a Hash of options for both parsing and generating. See Parsing Options, and Generating Options.
For generation, the strict: true
option is always set. When a Ruby object with no native JSON counterpart is encoutered, the block provided to the initialize method is invoked, and must return a Ruby object that has a native JSON counterpart:
module MyApp
API_JSON_CODER = JSON::Coder.new do |object|
case object
when Time
object.iso8601(3)
else
object # Unknown type, will raise
end
end
end
puts MyApp::API_JSON_CODER.dump(Time.now.utc) # => "2025-01-21T08:41:44.286Z"
# File 'ext/json/lib/json/common.rb', line 900
def initialize( = nil, &as_json) if .nil? = { strict: true } else = .dup [:strict] = true end [:as_json] = as_json if as_json [:create_additions] = false unless .key?(:create_additions) @state = State.new( ).freeze @parser_config = Ext::Parser::Config.new( ) end
.load(string) ⇒ Object (mod_func) Also known as: .parse
Parse the given JSON document and return an equivalent Ruby object.
# File 'ext/json/lib/json/common.rb', line 928
def load(source) @parser_config.parse(source) end
.load(path) ⇒ Object (mod_func)
Parse the given JSON document and return an equivalent Ruby object.
# File 'ext/json/lib/json/common.rb', line 937
def load_file(path) load(File.read(path, encoding: Encoding::UTF_8)) end
.parse(source) (mod_func)
Alias for #load.
# File 'ext/json/lib/json/common.rb', line 931
alias_method :parse, :load