sorbet-runtime 0.5.10585 → 0.5.10590

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: b8196267bef1ed6733eead434962d28f66d3162600873894bd59263efd3dd125
4
- data.tar.gz: 0d59ba0a8f4700726bf7bdad40c23055406bdb1beec1789b8a091774b68c0cff
3
+ metadata.gz: ac41fea7b5354a514a6c533af5f1e841e99f15005f518dd23eb680e1720b77a6
4
+ data.tar.gz: 6f0a88610b4647b01bdf5b90f6c59b4860fc1a33e188b3ee0db0e6f2fedf4d91
5
5
  SHA512:
6
- metadata.gz: 977c1a0ae1d580b923aa56512c954f8b7d0a3f856e1354a9e877d8fe55bffcb07ba2505f09eb1d36397ecd5e3b74f548035e63a6c24aa0cb9d88e851525c4c40
7
- data.tar.gz: 8a5c31e0585aa2444c8577d85b832f86ae732f637d5c562b2cbc6835204b38071d64326773f782c9bdeb182c34ee1f0814203bb527b99b62ae7b55addc5fc47b
6
+ metadata.gz: 60979a79a16f57bea42b4c1fdfa51b35c434d8b8073f45c23210e1302ff8e3ae2d55c65f7cfe1ab93fc960020885107c2658e8f40513e30e6c1522c5198c4c90
7
+ data.tar.gz: 0fb936fe574077ecad1514b54a4ee4144e3581048b323b89042eaa2f4b5c8c95c5a5ef44920602eb709ad36df42a982dc01e4dc2a5717a43f2c15b6d79125c6b
@@ -1,18 +1,49 @@
1
1
  # frozen_string_literal: true
2
2
  # typed: true
3
+ require 'pp'
3
4
 
4
5
  module T::Props::PrettyPrintable
5
6
  include T::Props::Plugin
6
7
 
7
- # Return a string representation of this object and all of its props
8
+ # Override the PP gem with something that's similar, but gives us a hook to do redaction and customization
9
+ def pretty_print(pp)
10
+ clazz = T.unsafe(T.cast(self, Object).class).decorator
11
+ multiline = pp.is_a?(PP)
12
+ pp.group(1, "<#{clazz.inspect_class_with_decoration(self)}", ">") do
13
+ clazz.all_props.sort.each do |prop|
14
+ pp.breakable
15
+ val = clazz.get(self, prop)
16
+ rules = clazz.prop_rules(prop)
17
+ pp.text("#{prop}=")
18
+ if (custom_inspect = rules[:inspect])
19
+ inspected = if T::Utils.arity(custom_inspect) == 1
20
+ custom_inspect.call(val)
21
+ else
22
+ custom_inspect.call(val, {multiline: multiline})
23
+ end
24
+ pp.text(inspected.nil? ? "nil" : inspected)
25
+ elsif rules[:sensitivity] && !rules[:sensitivity].empty? && !val.nil?
26
+ pp.text("<REDACTED #{rules[:sensitivity].join(', ')}>")
27
+ else
28
+ val.pretty_print(pp)
29
+ end
30
+ end
31
+ clazz.pretty_print_extra(self, pp)
32
+ end
33
+ end
34
+
35
+ # Return a string representation of this object and all of its props in a single line
8
36
  def inspect
9
- T.unsafe(T.cast(self, Object).class).decorator.inspect_instance(self)
37
+ string = +""
38
+ PP.singleline_pp(self, string)
39
+ string
10
40
  end
11
41
 
12
- # Override the PP gem with something that's similar, but gives us a hook
13
- # to do redaction
42
+ # Return a pretty string representation of this object and all of its props
14
43
  def pretty_inspect
15
- T.unsafe(T.cast(self, Object).class).decorator.inspect_instance(self, multiline: true)
44
+ string = +""
45
+ PP.pp(self, string)
46
+ string
16
47
  end
17
48
 
18
49
  module DecoratorMethods
@@ -23,85 +54,16 @@ module T::Props::PrettyPrintable
23
54
  super || key == :inspect
24
55
  end
25
56
 
26
- sig do
27
- params(instance: T::Props::PrettyPrintable, multiline: T::Boolean, indent: String)
28
- .returns(String)
57
+ # Overridable method to specify how the first part of a `pretty_print`d object's class should look like
58
+ # NOTE: This is just to support Stripe's `PrettyPrintableModel` case, and not recommended to be overriden
59
+ sig {params(instance: T::Props::PrettyPrintable).returns(String)}
60
+ def inspect_class_with_decoration(instance)
61
+ T.unsafe(instance).class.to_s
29
62
  end
30
- def inspect_instance(instance, multiline: false, indent: ' ')
31
- components =
32
- inspect_instance_components(
33
- instance,
34
- multiline: multiline,
35
- indent: indent
36
- )
37
- .reject(&:empty?)
38
-
39
- # Not using #<> here as that makes pry highlight these objects
40
- # as if they were all comments, whereas this makes them look
41
- # like the structured thing they are.
42
- if multiline
43
- "#{components[0]}:\n" + T.must(components[1..-1]).join("\n")
44
- else
45
- "<#{components.join(' ')}>"
46
- end
47
- end
48
-
49
- sig do
50
- params(instance: T::Props::PrettyPrintable, multiline: T::Boolean, indent: String)
51
- .returns(T::Array[String])
52
- end
53
- private def inspect_instance_components(instance, multiline:, indent:)
54
- pretty_props = T.unsafe(self).all_props.map do |prop|
55
- [prop, inspect_prop_value(instance, prop, multiline: multiline, indent: indent)]
56
- end
57
-
58
- joined_props = join_props_with_pretty_values(
59
- pretty_props,
60
- multiline: multiline,
61
- indent: indent
62
- )
63
63
 
64
- [
65
- T.unsafe(self).decorated_class.to_s,
66
- joined_props,
67
- ]
68
- end
69
-
70
- sig do
71
- params(instance: T::Props::PrettyPrintable, prop: Symbol, multiline: T::Boolean, indent: String)
72
- .returns(String)
73
- .checked(:never)
74
- end
75
- private def inspect_prop_value(instance, prop, multiline:, indent:)
76
- val = T.unsafe(self).get(instance, prop)
77
- rules = T.unsafe(self).prop_rules(prop)
78
- if (custom_inspect = rules[:inspect])
79
- if T::Utils.arity(custom_inspect) == 1
80
- custom_inspect.call(val)
81
- else
82
- custom_inspect.call(val, {multiline: multiline, indent: indent})
83
- end
84
- elsif rules[:sensitivity] && !rules[:sensitivity].empty? && !val.nil?
85
- "<REDACTED #{rules[:sensitivity].join(', ')}>"
86
- else
87
- val.inspect
88
- end
89
- end
90
-
91
- sig do
92
- params(pretty_kvs: T::Array[[Symbol, String]], multiline: T::Boolean, indent: String)
93
- .returns(String)
94
- end
95
- private def join_props_with_pretty_values(pretty_kvs, multiline:, indent: ' ')
96
- pairs = pretty_kvs
97
- .sort_by {|k, _v| k.to_s}
98
- .map {|k, v| "#{k}=#{v}"}
99
-
100
- if multiline
101
- indent + pairs.join("\n#{indent}")
102
- else
103
- pairs.join(', ')
104
- end
105
- end
64
+ # Overridable method to add anything that is not a prop
65
+ # NOTE: This is to support cases like Serializable's `@_extra_props`, and Stripe's `PrettyPrintableModel#@_deleted`
66
+ sig {params(instance: T::Props::PrettyPrintable, pp: T.any(PrettyPrint, PP::SingleLine)).void}
67
+ def pretty_print_extra(instance, pp); end
106
68
  end
107
69
  end
@@ -338,14 +338,21 @@ module T::Props::Serializable::DecoratorMethods
338
338
  end
339
339
  end
340
340
 
341
- # overrides T::Props::PrettyPrintable
342
- private def inspect_instance_components(instance, multiline:, indent:)
341
+ # adds to the default result of T::Props::PrettyPrintable
342
+ def pretty_print_extra(instance, pp)
343
+ # This is to maintain backwards compatibility with Stripe's codebase, where only the single line (through `inspect`)
344
+ # version is expected to add anything extra
345
+ return if !pp.is_a?(PP::SingleLine)
343
346
  if (extra_props = extra_props(instance)) && !extra_props.empty?
344
- pretty_kvs = extra_props.map {|k, v| [k.to_sym, v.inspect]}
345
- extra = join_props_with_pretty_values(pretty_kvs, multiline: false)
346
- super + ["@_extra_props=<#{extra}>"]
347
- else
348
- super
347
+ pp.breakable
348
+ pp.text("@_extra_props=")
349
+ pp.group(1, "<", ">") do
350
+ extra_props.each_with_index do |(prop, value), i|
351
+ pp.breakable unless i.zero?
352
+ pp.text("#{prop}=")
353
+ value.pretty_print(pp)
354
+ end
355
+ end
349
356
  end
350
357
  end
351
358
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: sorbet-runtime
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.10585
4
+ version: 0.5.10590
5
5
  platform: ruby
6
6
  authors:
7
7
  - Stripe
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-12-09 00:00:00.000000000 Z
11
+ date: 2022-12-15 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: minitest