Module: T::Props::Serializable::DecoratorMethods
Overview
Instance Method Summary
collapse
#eagerly_define_lazy_methods!, #eagerly_define_lazy_vm_methods!
Methods included from Sig
#sig
Instance Method Details
#add_prop_definition(prop, rules) ⇒ Object
224
225
226
227
228
229
230
231
232
233
234
235
236
237
|
# File 'lib/types/props/serializable.rb', line 224
def add_prop_definition(prop, rules)
serialized_form = rules.fetch(:name, prop.to_s)
rules[:serialized_form] = serialized_form
res = super
prop_by_serialized_forms[serialized_form] = prop
if T::Configuration.use_vm_prop_serde?
enqueue_lazy_vm_method_definition!(:__t_props_generated_serialize) { generate_serialize2 }
enqueue_lazy_vm_method_definition!(:__t_props_generated_deserialize) { generate_deserialize2 }
else
enqueue_lazy_method_definition!(:__t_props_generated_serialize) { generate_serialize_source }
enqueue_lazy_method_definition!(:__t_props_generated_deserialize) { generate_deserialize_source }
end
res
end
|
354
355
356
|
# File 'lib/types/props/serializable.rb', line 354
def (instance)
instance.instance_variable_get(:@_extra_props) ||
end
|
#from_hash(hash, strict = false) ⇒ Object
207
208
209
210
211
212
213
214
|
# File 'lib/types/props/serializable.rb', line 207
def from_hash(hash, strict=false)
raise ArgumentError.new("#{hash.inspect} provided to from_hash") if !(hash && hash.is_a?(Hash))
i = @class.allocate
i.deserialize(hash, strict)
i
end
|
#get_id(instance) ⇒ Object
342
343
344
345
346
347
348
349
|
# File 'lib/types/props/serializable.rb', line 342
def get_id(instance)
prop = prop_by_serialized_forms['_id']
if prop
get(instance, prop)
else
nil
end
end
|
#message_with_generated_source_context(error, generated_method, generate_source_method) ⇒ Object
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
|
# File 'lib/types/props/serializable.rb', line 262
def message_with_generated_source_context(error, generated_method, generate_source_method)
generated_method = generated_method.to_s
if error.backtrace_locations
line_loc = error.backtrace_locations.find { |l| l.base_label == generated_method }
return unless line_loc
line_num = line_loc.lineno
else
label = if RUBY_VERSION >= "3.4"
"##{generated_method}'"
else
"in `#{generated_method}'"
end
line_label = error.backtrace.find { |l| l.end_with?(label) }
return unless line_label
line_num = if line_label.start_with?("(eval)")
line_label.split(':')[1]&.to_i
else
line_label.split(':')[2]&.to_i
end
end
return unless line_num
source_lines = self.send(generate_source_method).split("\n")
previous_blank = source_lines[0...line_num].rindex(&:empty?) || 0
next_blank = line_num + (source_lines[line_num..-1]&.find_index(&:empty?) || 0)
context = " #{source_lines[(previous_blank + 1)...next_blank].join("\n ")}"
" Error in \#{decorated_class.name}#\#{generated_method}: \#{error.message}\n at line \#{line_num - previous_blank - 1} in:\n \#{context}\n MSG\nend\n"
|
adds to the default result of T::Props::PrettyPrintable
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
|
# File 'lib/types/props/serializable.rb', line 359
def (instance, pp)
return if !pp.is_a?(PP::SingleLine)
if ( = (instance)) && !.empty?
pp.breakable
pp.text("@_extra_props=")
pp.group(1, "<", ">") do
.each_with_index do |(prop, value), i|
pp.breakable unless i.zero?
pp.text("#{prop}=")
value.pretty_print(pp)
end
end
end
end
|
203
204
205
|
# File 'lib/types/props/serializable.rb', line 203
def prop_by_serialized_forms
@class.prop_by_serialized_forms
end
|
#prop_dont_store?(prop) ⇒ Boolean
200
201
202
|
# File 'lib/types/props/serializable.rb', line 200
def prop_dont_store?(prop)
prop_rules(prop)[:dont_store]
end
|
216
217
218
|
# File 'lib/types/props/serializable.rb', line 216
def prop_serialized_form(prop)
prop_rules(prop)[:serialized_form]
end
|
#prop_validate_definition!(name, cls, rules, type) ⇒ Object
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
|
# File 'lib/types/props/serializable.rb', line 324
def prop_validate_definition!(name, cls, rules, type)
result = super
if (rules_name = rules[:name])
unless rules_name.is_a?(String)
raise ArgumentError.new("Invalid name in prop #{@class.name}.#{name}: #{rules_name.inspect}")
end
validate_prop_name(rules_name)
end
if !rules[:raise_on_nil_write].nil? && rules[:raise_on_nil_write] != true
raise ArgumentError.new("The value of `raise_on_nil_write` if specified must be `true` (given: #{rules[:raise_on_nil_write]}).")
end
result
end
|
#raise_nil_deserialize_error(hkey) ⇒ Object
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
|
# File 'lib/types/props/serializable.rb', line 301
def raise_nil_deserialize_error(hkey)
msg = "Tried to deserialize a required prop from a nil value. It's "\
"possible that a nil value exists in the database, so you should "\
"provide a `default: or factory:` for this prop (see go/optional "\
"for more details). If this is already the case, you probably "\
"omitted a required prop from the `fields:` option when doing a "\
"partial load."
storytime = {prop: hkey, klass: decorated_class.name}
begin
if T::Configuration.class_owner_finder && (owner = T::Configuration.class_owner_finder.call(decorated_class))
T::Configuration.hard_assert_handler(
msg,
storytime: storytime,
project: owner
)
end
ensure
T::Configuration.hard_assert_handler(msg, storytime: storytime)
end
end
|
#required_props ⇒ Object
196
197
198
|
# File 'lib/types/props/serializable.rb', line 196
def required_props
@class.props.select { |_, v| T::Props::Utils.required_prop?(v) }.keys
end
|
220
221
222
|
# File 'lib/types/props/serializable.rb', line 220
def serialized_form_prop(serialized_form)
prop_by_serialized_forms[serialized_form.to_s] || raise("No such serialized form: #{serialized_form.inspect}")
end
|
#valid_rule_key?(key) ⇒ Boolean
192
193
194
|
# File 'lib/types/props/serializable.rb', line 192
def valid_rule_key?(key)
super || VALID_RULE_KEYS[key]
end
|