Module: JSON::Pure::Generator::GeneratorMethods::String
- Defined in:
- lib/json/pure/generator.rb
Defined Under Namespace
Modules: Extend
Class Method Summary collapse
-
.included(modul) ⇒ Object
Extends modul with the String::Extend module.
Instance Method Summary collapse
-
#to_json(state = nil, *args) ⇒ Object
This string should be encoded with UTF-8 A call to this method returns a JSON string encoded with UTF16 big endian characters as u????.
-
#to_json_raw(*args) ⇒ Object
This method creates a JSON text from the result of a call to to_json_raw_object of this String.
-
#to_json_raw_object ⇒ Object
This method creates a raw object hash, that can be nested into other data structures and will be unparsed as a raw string.
Class Method Details
Instance Method Details
#to_json(state = nil, *args) ⇒ Object
This string should be encoded with UTF-8 A call to this method returns a JSON string encoded with UTF16 big endian characters as u????.
361 362 363 364 365 366 367 368 369 370 371 372 373 |
# File 'lib/json/pure/generator.rb', line 361 def to_json(state = nil, *args) state = State.from_state(state) if encoding == ::Encoding::UTF_8 string = self else string = encode(::Encoding::UTF_8) end if state.ascii_only? '"' << JSON.utf8_to_json_ascii(string) << '"' else '"' << JSON.utf8_to_json(string) << '"' end end |
#to_json_raw(*args) ⇒ Object
This method creates a JSON text from the result of a call to to_json_raw_object of this String.
417 418 419 |
# File 'lib/json/pure/generator.rb', line 417 def to_json_raw(*args) to_json_raw_object.to_json(*args) end |
#to_json_raw_object ⇒ Object
This method creates a raw object hash, that can be nested into other data structures and will be unparsed as a raw string. This method should be used, if you want to convert raw strings to JSON instead of UTF-8 strings, e. g. binary data.
408 409 410 411 412 413 |
# File 'lib/json/pure/generator.rb', line 408 def to_json_raw_object { JSON.create_id => self.class.name, 'raw' => self.unpack('C*'), } end |