Class: JSON::Pure::Generator::State

Inherits:
Object
  • Object
show all
Defined in:
lib/json/pure/generator.rb

Overview

This class is used to create State instances, that are use to hold data while generating a JSON text from a Ruby data structure.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(opts = {}) ⇒ State

Instantiates a new State object, configured by opts.

opts can have the following keys:

  • indent: a string used to indent levels (default: ”),

  • space: a string that is put after, a : or , delimiter (default: ”),

  • space_before: a string that is put before a : pair delimiter (default: ”),

  • object_nl: a string that is put at the end of a JSON object (default: ”),

  • array_nl: a string that is put at the end of a JSON array (default: ”),

  • escape_slash: true if forward slash (/) should be escaped (default: false)

  • check_circular: is deprecated now, use the :max_nesting option instead,

  • max_nesting: sets the maximum level of data structure nesting in the generated JSON, max_nesting = 0 if no maximum should be checked.

  • allow_nan: true if NaN, Infinity, and -Infinity should be generated, otherwise an exception is thrown, if these values are encountered. This options defaults to false.



125
126
127
128
129
130
131
132
133
134
135
136
# File 'lib/json/pure/generator.rb', line 125

def initialize(opts = {})
  @indent                = ''
  @space                 = ''
  @space_before          = ''
  @object_nl             = ''
  @array_nl              = ''
  @allow_nan             = false
  @ascii_only            = false
  @escape_slash          = false
  @buffer_initial_length = 1024
  configure opts
end

Instance Attribute Details

#array_nlObject

This string is put at the end of a line that holds a JSON array.



153
154
155
# File 'lib/json/pure/generator.rb', line 153

def array_nl
  @array_nl
end

#buffer_initial_lengthObject

:stopdoc:



164
165
166
# File 'lib/json/pure/generator.rb', line 164

def buffer_initial_length
  @buffer_initial_length
end

#depthObject

This integer returns the current depth data structure nesting in the generated JSON.



175
176
177
# File 'lib/json/pure/generator.rb', line 175

def depth
  @depth
end

#escape_slashObject

If this attribute is set to true, forward slashes will be escaped in all json strings.



161
162
163
# File 'lib/json/pure/generator.rb', line 161

def escape_slash
  @escape_slash
end

#indentObject

This string is used to indent levels in the JSON text.



139
140
141
# File 'lib/json/pure/generator.rb', line 139

def indent
  @indent
end

#max_nestingObject

This integer returns the maximum level of data structure nesting in the generated JSON, max_nesting = 0 if no maximum is checked.



157
158
159
# File 'lib/json/pure/generator.rb', line 157

def max_nesting
  @max_nesting
end

#object_nlObject

This string is put at the end of a line that holds a JSON object (or Hash).



150
151
152
# File 'lib/json/pure/generator.rb', line 150

def object_nl
  @object_nl
end

#spaceObject

This string is used to insert a space between the tokens in a JSON string.



143
144
145
# File 'lib/json/pure/generator.rb', line 143

def space
  @space
end

#space_beforeObject

This string is used to insert a space before the ‘:’ in JSON objects.



146
147
148
# File 'lib/json/pure/generator.rb', line 146

def space_before
  @space_before
end

Class Method Details

.from_state(opts) ⇒ Object

Creates a State object from opts, which ought to be Hash to create a new State instance configured by opts, something else to create an unconfigured instance. If opts is a State object, it is just returned.



96
97
98
99
100
101
102
103
104
105
106
107
# File 'lib/json/pure/generator.rb', line 96

def self.from_state(opts)
  case
  when self === opts
    opts
  when opts.respond_to?(:to_hash)
    new(opts.to_hash)
  when opts.respond_to?(:to_h)
    new(opts.to_h)
  else
    SAFE_STATE_PROTOTYPE.dup
  end
end

Instance Method Details

#[](name) ⇒ Object

Return the value returned by method name.



267
268
269
270
271
272
273
274
# File 'lib/json/pure/generator.rb', line 267

def [](name)
  if respond_to?(name)
    __send__(name)
  else
    instance_variable_get("@#{name}") if
      instance_variables.include?("@#{name}".to_sym) # avoid warning
  end
end

#[]=(name, value) ⇒ Object



276
277
278
279
280
281
282
# File 'lib/json/pure/generator.rb', line 276

def []=(name, value)
  if respond_to?(name_writer = "#{name}=")
    __send__ name_writer, value
  else
    instance_variable_set "@#{name}", value
  end
end

#allow_nan?Boolean

Returns true if NaN, Infinity, and -Infinity should be considered as valid JSON and output.

Returns:

  • (Boolean)


192
193
194
# File 'lib/json/pure/generator.rb', line 192

def allow_nan?
  @allow_nan
end

#ascii_only?Boolean

Returns true, if only ASCII characters should be generated. Otherwise returns false.

Returns:

  • (Boolean)


198
199
200
# File 'lib/json/pure/generator.rb', line 198

def ascii_only?
  @ascii_only
end

#check_circular?Boolean

Returns true, if circular data structures are checked, otherwise returns false.

Returns:

  • (Boolean)


186
187
188
# File 'lib/json/pure/generator.rb', line 186

def check_circular?
  !@max_nesting.zero?
end

#check_max_nestingObject

:nodoc:



177
178
179
180
181
182
# File 'lib/json/pure/generator.rb', line 177

def check_max_nesting # :nodoc:
  return if @max_nesting.zero?
  current_nesting = depth + 1
  current_nesting > @max_nesting and
    raise NestingError, "nesting of #{current_nesting} is too deep"
end

#configure(opts) ⇒ Object Also known as: merge

Configure this State instance with the Hash opts, and return itself.



209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
# File 'lib/json/pure/generator.rb', line 209

def configure(opts)
  if opts.respond_to?(:to_hash)
    opts = opts.to_hash
  elsif opts.respond_to?(:to_h)
    opts = opts.to_h
  else
    raise TypeError, "can't convert #{opts.class} into Hash"
  end
  for key, value in opts
    instance_variable_set "@#{key}", value
  end
  @indent                = opts[:indent] if opts.key?(:indent)
  @space                 = opts[:space] if opts.key?(:space)
  @space_before          = opts[:space_before] if opts.key?(:space_before)
  @object_nl             = opts[:object_nl] if opts.key?(:object_nl)
  @array_nl              = opts[:array_nl] if opts.key?(:array_nl)
  @allow_nan             = !!opts[:allow_nan] if opts.key?(:allow_nan)
  @ascii_only            = opts[:ascii_only] if opts.key?(:ascii_only)
  @depth                 = opts[:depth] || 0
  @buffer_initial_length ||= opts[:buffer_initial_length]
  @escape_slash          = !!opts[:escape_slash] if opts.key?(:escape_slash)

  if !opts.key?(:max_nesting) # defaults to 100
    @max_nesting = 100
  elsif opts[:max_nesting]
    @max_nesting = opts[:max_nesting]
  else
    @max_nesting = 0
  end
  self
end

#escape_slash?Boolean

Returns true, if forward slashes are escaped. Otherwise returns false.

Returns:

  • (Boolean)


203
204
205
# File 'lib/json/pure/generator.rb', line 203

def escape_slash?
  @escape_slash
end

#generate(obj) ⇒ Object

Generates a valid JSON document from object obj and returns the result. If no valid JSON document can be created this method raises a GeneratorError exception.



259
260
261
262
263
264
# File 'lib/json/pure/generator.rb', line 259

def generate(obj)
  result = obj.to_json(self)
  JSON.valid_utf8?(result) or raise GeneratorError,
    "source sequence #{result.inspect} is illegal/malformed utf-8"
  result
end

#to_hObject Also known as: to_hash

Returns the configuration instance variables as a hash, that can be passed to the configure method.



244
245
246
247
248
249
250
251
# File 'lib/json/pure/generator.rb', line 244

def to_h
  result = {}
  for iv in instance_variables
    iv = iv.to_s[1..-1]
    result[iv.to_sym] = self[iv]
  end
  result
end