Module: JSON::Pure::Generator::GeneratorMethods::String

Defined in:
lib/json/pure/generator.rb

Defined Under Namespace

Modules: Extend

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.included(modul) ⇒ Object

Extends modul with the String::Extend module.



560
561
562
# File 'lib/json/pure/generator.rb', line 560

def self.included(modul)
  modul.extend Extend
end

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????.



531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
# File 'lib/json/pure/generator.rb', line 531

def to_json(state = nil, *args)
  state = State.from_state(state)
  if encoding == ::Encoding::UTF_8
    unless valid_encoding?
      raise GeneratorError, "source sequence is illegal/malformed utf-8"
    end
    string = self
  else
    string = encode(::Encoding::UTF_8)
  end
  if state.ascii_only?
    %("#{JSON.utf8_to_json_ascii(string, state.script_safe)}")
  else
    %("#{JSON.utf8_to_json(string, state.script_safe)}")
  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.



577
578
579
# File 'lib/json/pure/generator.rb', line 577

def to_json_raw(*args)
  to_json_raw_object.to_json(*args)
end

#to_json_raw_objectObject

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.



568
569
570
571
572
573
# File 'lib/json/pure/generator.rb', line 568

def to_json_raw_object
  {
    JSON.create_id  => self.class.name,
    'raw'           => self.unpack('C*'),
  }
end