Module: T::Configuration
- Defined in:
- lib/types/configuration.rb
Overview
typed: true frozen_string_literal: true
Class Method Summary collapse
- .call_validation_error_handler(signature, opts = {}) ⇒ Object
-
.call_validation_error_handler=(value) ⇒ Object
Set a handler for type errors that result from calling a method.
-
.can_enable_vm_prop_serde? ⇒ T::Boolean
Whether VM-defined prop serialization/deserialization routines can be enabled.
- .class_owner_finder ⇒ Object
-
.class_owner_finder=(handler) ⇒ Object
Set to a function which can get the ‘owner’ of a class.
-
.default_checked_level=(default_checked_level) ⇒ Object
Configure the default checked level for a sig with no explicit
.checkedbuilder. - .disable_legacy_t_enum_migration_mode ⇒ Object
-
.disable_vm_prop_serde ⇒ Object
Disable using VM-defined prop serialization/deserialization routines.
-
.enable_checking_for_sigs_marked_checked_tests ⇒ Object
Announces to Sorbet that we are currently in a test environment, so it should treat any sigs which are marked ‘.checked(:tests)` as if they were just a normal sig.
-
.enable_final_checks_on_hooks ⇒ Object
Announce to Sorbet that we would like the final checks to be enabled when including and extending modules.
- .enable_legacy_t_enum_migration_mode ⇒ Object
-
.enable_vm_prop_serde ⇒ Object
Enable using VM-defined prop serialization/deserialization routines.
-
.exclude_value_in_type_errors ⇒ Object
Configure if type errors excludes the value of the problematic type.
- .hard_assert_handler(str, extra = {}) ⇒ Object
-
.hard_assert_handler=(value) ⇒ Object
Set a handler for hard assertions.
-
.include_value_in_type_errors ⇒ Object
Opposite of exclude_value_in_type_errors.
-
.include_value_in_type_errors? ⇒ T::Boolean
Whether to include values in TypeError messages.
- .inline_type_error_handler(error, opts = {}) ⇒ Object
-
.inline_type_error_handler=(value) ⇒ Object
Set a handler to handle ‘TypeError`s raised by any in-line type assertions, including
T.must,T.let,T.cast, andT.assert_type!. - .legacy_t_enum_migration_mode? ⇒ Boolean
- .log_info_handler(str, extra) ⇒ Object
-
.log_info_handler=(value) ⇒ Object
Set a handler for logging.
- .module_name_mangler ⇒ Object
-
.module_name_mangler=(handler) ⇒ Object
Set to override the default behavior for converting types to names in generated code.
- .normalize_sensitivity_and_pii_handler ⇒ Object
-
.normalize_sensitivity_and_pii_handler=(handler) ⇒ Object
Set to a PII handler function.
- .redaction_handler ⇒ Object
-
.redaction_handler=(handler) ⇒ Object
Set to a redaction handling function.
-
.reset_final_checks_on_hooks ⇒ Object
Undo the effects of a previous call to
enable_final_checks_on_hooks. - .scalar_types ⇒ Object
-
.scalar_types=(values) ⇒ Object
Set a list of class strings that are to be considered scalar.
- .sealed_violation_whitelist ⇒ Object
- .sealed_violation_whitelist=(sealed_violation_whitelist) ⇒ Object
- .sig_builder_error_handler(error, location) ⇒ Object
-
.sig_builder_error_handler=(value) ⇒ Object
Set a handler to handle errors that occur when the builder methods in the body of a sig are executed.
- .sig_validation_error_handler(error, opts = {}) ⇒ Object
-
.sig_validation_error_handler=(value) ⇒ Object
Set a handler to handle sig validation errors.
- .soft_assert_handler(str, extra) ⇒ Object
-
.soft_assert_handler=(value) ⇒ Object
Set a handler for soft assertions.
-
.use_vm_prop_serde? ⇒ T::Boolean
Whether to use VM-defined prop serialization/deserialization routines.
-
.without_ruby_warnings { ... } ⇒ Object
Temporarily disable ruby warnings while executing the given block.
Class Method Details
.call_validation_error_handler(signature, opts = {}) ⇒ Object
296 297 298 299 300 301 302 303 |
# File 'lib/types/configuration.rb', line 296 def self.call_validation_error_handler(signature, opts={}) if @call_validation_error_handler @call_validation_error_handler.call(signature, opts) else call_validation_error_handler_default(signature, opts) end nil end |
.call_validation_error_handler=(value) ⇒ Object
Set a handler for type errors that result from calling a method.
By default, errors from calling a method cause an exception to be raised. Setting call_validation_error_handler to an object that implements :call (e.g. proc or lambda) allows users to customize the behavior when a method is called with invalid parameters, or returns an invalid value.
Parameters passed to value.call:
@param [T::Private::Methods::Signature] signature Signature that failed
@param [Hash] opts A hash containing contextual information on the error:
@option opts [String] :message Error message
@option opts [String] :kind One of:
['Parameter', 'Block parameter', 'Return value']
@option opts [Symbol] :name Param or block param name (nil for return
value)
@option opts [Object] :type Expected param/return value type
@option opts [Object] :value Actual param/return value
@option opts [Thread::Backtrace::Location] :location Location of the
caller
287 288 289 290 |
# File 'lib/types/configuration.rb', line 287 def self.call_validation_error_handler=(value) validate_lambda_given!(value) @call_validation_error_handler = value end |
.can_enable_vm_prop_serde? ⇒ T::Boolean
Whether VM-defined prop serialization/deserialization routines can be enabled.
76 77 78 |
# File 'lib/types/configuration.rb', line 76 def self.can_enable_vm_prop_serde? T::Props::Private::DeserializerGenerator.respond_to?(:generate2) end |
.class_owner_finder ⇒ Object
506 507 508 |
# File 'lib/types/configuration.rb', line 506 def self.class_owner_finder @class_owner_finder end |
.class_owner_finder=(handler) ⇒ Object
Set to a function which can get the ‘owner’ of a class. This is used in reporting deserialization errors
produces its owner, or nil if it does not have one.
502 503 504 |
# File 'lib/types/configuration.rb', line 502 def self.class_owner_finder=(handler) @class_owner_finder = handler end |
.default_checked_level=(default_checked_level) ⇒ Object
Configure the default checked level for a sig with no explicit .checked builder. When unset, the default checked level is :always.
Note: setting this option is potentially dangerous! Sorbet can’t check all code statically. The runtime checks complement the checks that Sorbet does statically, so that methods don’t have to guard themselves from being called incorrectly by untyped code.
114 115 116 |
# File 'lib/types/configuration.rb', line 114 def self.default_checked_level=(default_checked_level) T::Private::RuntimeLevels.default_checked_level = default_checked_level end |
.disable_legacy_t_enum_migration_mode ⇒ Object
535 536 537 |
# File 'lib/types/configuration.rb', line 535 def self.disable_legacy_t_enum_migration_mode @legacy_t_enum_migration_mode = false end |
.disable_vm_prop_serde ⇒ Object
Disable using VM-defined prop serialization/deserialization routines.
101 102 103 |
# File 'lib/types/configuration.rb', line 101 def self.disable_vm_prop_serde @use_vm_prop_serde = false end |
.enable_checking_for_sigs_marked_checked_tests ⇒ Object
Announces to Sorbet that we are currently in a test environment, so it should treat any sigs which are marked ‘.checked(:tests)` as if they were just a normal sig.
If this method is not called, sigs marked ‘.checked(:tests)` will not be checked. In fact, such methods won’t even be wrapped–the runtime will put back the original method.
Note: Due to the way sigs are evaluated and methods are wrapped, this method MUST be called before any code calls sig. This method raises if it has been called too late.
16 17 18 |
# File 'lib/types/configuration.rb', line 16 def self.enable_checking_for_sigs_marked_checked_tests T::Private::RuntimeLevels.enable_checking_in_tests end |
.enable_final_checks_on_hooks ⇒ Object
35 36 37 |
# File 'lib/types/configuration.rb', line 35 def self.enable_final_checks_on_hooks T::Private::Methods.set_final_checks_on_hooks(true) end |
.enable_legacy_t_enum_migration_mode ⇒ Object
531 532 533 534 |
# File 'lib/types/configuration.rb', line 531 def self.enable_legacy_t_enum_migration_mode T::Enum.include(T::Enum::LegacyMigrationMode) @legacy_t_enum_migration_mode = true end |
.enable_vm_prop_serde ⇒ Object
Enable using VM-defined prop serialization/deserialization routines.
This method is likely to break things outside of Stripe’s systems.
93 94 95 96 97 98 |
# File 'lib/types/configuration.rb', line 93 def self.enable_vm_prop_serde if !can_enable_vm_prop_serde? hard_assert_handler('Ruby VM is not setup to use VM-defined prop serde') end @use_vm_prop_serde = true end |
.exclude_value_in_type_errors ⇒ Object
Configure if type errors excludes the value of the problematic type.
The default is to include values in type errors:
TypeError: Expected type Integer, got String with value "foo"
When values are excluded from type errors:
TypeError: Expected type Integer, got String
63 64 65 |
# File 'lib/types/configuration.rb', line 63 def self.exclude_value_in_type_errors @include_value_in_type_errors = false end |
.hard_assert_handler(str, extra = {}) ⇒ Object
399 400 401 402 403 404 405 |
# File 'lib/types/configuration.rb', line 399 def self.hard_assert_handler(str, extra={}) if @hard_assert_handler @hard_assert_handler.call(str, extra) else hard_assert_handler_default(str, extra) end end |
.hard_assert_handler=(value) ⇒ Object
Set a handler for hard assertions
These generally should stop execution of the program, and optionally inform some party of the assertion.
Parameters passed to value.call:
@param [String] str Assertion message
@param [Hash] extra A hash containing additional parameters to be passed along to the handler.
390 391 392 393 |
# File 'lib/types/configuration.rb', line 390 def self.hard_assert_handler=(value) validate_lambda_given!(value) @hard_assert_handler = value end |
.include_value_in_type_errors ⇒ Object
Opposite of exclude_value_in_type_errors. (Including values in type errors is the default)
69 70 71 |
# File 'lib/types/configuration.rb', line 69 def self.include_value_in_type_errors @include_value_in_type_errors = true end |
.include_value_in_type_errors? ⇒ T::Boolean
Whether to include values in TypeError messages.
Including values is useful for debugging, but can potentially leak sensitive information to logs.
52 53 54 |
# File 'lib/types/configuration.rb', line 52 def self.include_value_in_type_errors? @include_value_in_type_errors end |
.inline_type_error_handler(error, opts = {}) ⇒ Object
152 153 154 155 156 157 158 159 160 161 162 163 164 |
# File 'lib/types/configuration.rb', line 152 def self.inline_type_error_handler(error, opts={}) if @inline_type_error_handler # Backwards compatibility before `inline_type_error_handler` took a second arg if @inline_type_error_handler.arity == 1 @inline_type_error_handler.call(error) else @inline_type_error_handler.call(error, opts) end else inline_type_error_handler_default(error, opts) end nil end |
.inline_type_error_handler=(value) ⇒ Object
Set a handler to handle ‘TypeError`s raised by any in-line type assertions, including T.must, T.let, T.cast, and T.assert_type!.
By default, any ‘TypeError`s detected by this gem will be raised. Setting inline_type_error_handler to an object that implements :call (e.g. proc or lambda) allows users to customize the behavior when a TypeError is raised on any inline type assertion.
Parameters passed to value.call:
@param [TypeError] error TypeError that was raised
@param [Hash] opts A hash containing contextual information on the error:
@option opts [String] :kind One of:
['T.cast', 'T.let', 'T.bind', 'T.assert_type!', 'T.must', 'T.absurd']
@option opts [Object, nil] :type Expected param/return value type
@option opts [Object] :value Actual param/return value
143 144 145 146 |
# File 'lib/types/configuration.rb', line 143 def self.inline_type_error_handler=(value) validate_lambda_given!(value) @inline_type_error_handler = value end |
.legacy_t_enum_migration_mode? ⇒ Boolean
538 539 540 |
# File 'lib/types/configuration.rb', line 538 def self.legacy_t_enum_migration_mode? @legacy_t_enum_migration_mode || false end |
.log_info_handler(str, extra) ⇒ Object
329 330 331 332 333 334 335 |
# File 'lib/types/configuration.rb', line 329 def self.log_info_handler(str, extra) if @log_info_handler @log_info_handler.call(str, extra) else log_info_handler_default(str, extra) end end |
.log_info_handler=(value) ⇒ Object
Set a handler for logging
Parameters passed to value.call:
@param [String] str Message to be logged
@param [Hash] extra A hash containing additional parameters to be passed along to the logger.
320 321 322 323 |
# File 'lib/types/configuration.rb', line 320 def self.log_info_handler=(value) validate_lambda_given!(value) @log_info_handler = value end |
.module_name_mangler ⇒ Object
452 453 454 |
# File 'lib/types/configuration.rb', line 452 def self.module_name_mangler @module_name_mangler || @default_module_name_mangler end |
.module_name_mangler=(handler) ⇒ Object
Set to override the default behavior for converting types
to names in generated code. Used by the runtime implementation
associated with `--sorbet-packages` mode.
462 463 464 |
# File 'lib/types/configuration.rb', line 462 def self.module_name_mangler=(handler) @module_name_mangler = handler end |
.normalize_sensitivity_and_pii_handler ⇒ Object
476 477 478 |
# File 'lib/types/configuration.rb', line 476 def self.normalize_sensitivity_and_pii_handler @sensitivity_and_pii_handler end |
.normalize_sensitivity_and_pii_handler=(handler) ⇒ Object
Set to a PII handler function. This will be called with the sensitivity: annotations on things that use T::Props and can modify them ahead-of-time.
prop values. Pass nil to avoid changing sensitivity: annotations.
472 473 474 |
# File 'lib/types/configuration.rb', line 472 def self.normalize_sensitivity_and_pii_handler=(handler) @sensitivity_and_pii_handler = handler end |
.redaction_handler ⇒ Object
492 493 494 |
# File 'lib/types/configuration.rb', line 492 def self.redaction_handler @redaction_handler end |
.redaction_handler=(handler) ⇒ Object
Set to a redaction handling function. This will be called when the _redacted version of a prop reader is used. By default this is set to nil and will raise an exception when the redacted version of a prop is accessed.
redacted version according to the spec passed as the second argument.
488 489 490 |
# File 'lib/types/configuration.rb', line 488 def self.redaction_handler=(handler) @redaction_handler = handler end |
.reset_final_checks_on_hooks ⇒ Object
Undo the effects of a previous call to enable_final_checks_on_hooks.
41 42 43 |
# File 'lib/types/configuration.rb', line 41 def self.reset_final_checks_on_hooks T::Private::Methods.set_final_checks_on_hooks(false) end |
.scalar_types ⇒ Object
440 441 442 |
# File 'lib/types/configuration.rb', line 440 def self.scalar_types @scalar_types || @default_scalar_types end |
.scalar_types=(values) ⇒ Object
Set a list of class strings that are to be considered scalar.
(pass nil to reset to default behavior)
415 416 417 418 419 420 421 422 423 424 425 426 |
# File 'lib/types/configuration.rb', line 415 def self.scalar_types=(values) if values.nil? @scalar_types = values else bad_values = values.reject { |v| v.class == String } unless bad_values.empty? raise ArgumentError.new("Provided values must all be class name strings.") end @scalar_types = values.each_with_object({}) { |x, acc| acc[x] = true }.freeze end end |
.sealed_violation_whitelist ⇒ Object
566 567 568 |
# File 'lib/types/configuration.rb', line 566 def self.sealed_violation_whitelist @sealed_violation_whitelist end |
.sealed_violation_whitelist=(sealed_violation_whitelist) ⇒ Object
547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 |
# File 'lib/types/configuration.rb', line 547 def self.sealed_violation_whitelist=(sealed_violation_whitelist) if !@sealed_violation_whitelist.nil? raise ArgumentError.new("Cannot overwrite sealed_violation_whitelist after setting it") end case sealed_violation_whitelist when Array sealed_violation_whitelist.each do |x| case x when Regexp then nil else raise TypeError.new("sealed_violation_whitelist accepts an Array of Regexp") end end else raise TypeError.new("sealed_violation_whitelist= accepts an Array of Regexp") end @sealed_violation_whitelist = sealed_violation_whitelist end |
.sig_builder_error_handler(error, location) ⇒ Object
198 199 200 201 202 203 204 205 |
# File 'lib/types/configuration.rb', line 198 def self.sig_builder_error_handler(error, location) if @sig_builder_error_handler @sig_builder_error_handler.call(error, location) else sig_builder_error_handler_default(error, location) end nil end |
.sig_builder_error_handler=(value) ⇒ Object
Set a handler to handle errors that occur when the builder methods in the body of a sig are executed. The sig builder methods are inside a proc so that they can be lazily evaluated the first time the method being sig’d is called.
By default, improper use of the builder methods within the body of a sig cause an ArgumentError to be raised. Setting sig_builder_error_handler to an object that implements :call (e.g. proc or lambda) allows users to customize the behavior when a sig can’t be built for some reason.
Parameters passed to value.call:
@param [StandardError] error The error that was raised
@param [Thread::Backtrace::Location] location Location of the error
189 190 191 192 |
# File 'lib/types/configuration.rb', line 189 def self.sig_builder_error_handler=(value) validate_lambda_given!(value) @sig_builder_error_handler = value end |
.sig_validation_error_handler(error, opts = {}) ⇒ Object
249 250 251 252 253 254 255 256 |
# File 'lib/types/configuration.rb', line 249 def self.sig_validation_error_handler(error, opts={}) if @sig_validation_error_handler @sig_validation_error_handler.call(error, opts) else sig_validation_error_handler_default(error, opts) end nil end |
.sig_validation_error_handler=(value) ⇒ Object
Set a handler to handle sig validation errors.
Sig validation errors include things like abstract checks, override checks, and type compatibility of arguments. They happen after a sig has been successfully built, but the built sig is incompatible with other sigs in some way.
By default, sig validation errors cause an exception to be raised. Setting sig_validation_error_handler to an object that implements :call (e.g. proc or lambda) allows users to customize the behavior when a method signature’s build fails.
Parameters passed to value.call:
@param [StandardError] error The error that was raised
@param [Hash] opts A hash containing contextual information on the error:
@option opts [Method, UnboundMethod] :method Method on which the signature build failed
@option opts [T::Private::Methods::Declaration] :declaration Method
signature declaration struct
@option opts [T::Private::Methods::Signature, nil] :signature Signature
that failed (nil if sig build failed before Signature initialization)
@option opts [T::Private::Methods::Signature, nil] :super_signature Super
method's signature (nil if method is not an override or super method
does not have a method signature)
240 241 242 243 |
# File 'lib/types/configuration.rb', line 240 def self.sig_validation_error_handler=(value) validate_lambda_given!(value) @sig_validation_error_handler = value end |
.soft_assert_handler(str, extra) ⇒ Object
364 365 366 367 368 369 370 |
# File 'lib/types/configuration.rb', line 364 def self.soft_assert_handler(str, extra) if @soft_assert_handler @soft_assert_handler.call(str, extra) else soft_assert_handler_default(str, extra) end end |
.soft_assert_handler=(value) ⇒ Object
Set a handler for soft assertions
These generally shouldn’t stop execution of the program, but rather inform some party of the assertion to action on later.
Parameters passed to value.call:
@param [String] str Assertion message
@param [Hash] extra A hash containing additional parameters to be passed along to the handler.
355 356 357 358 |
# File 'lib/types/configuration.rb', line 355 def self.soft_assert_handler=(value) validate_lambda_given!(value) @soft_assert_handler = value end |
.use_vm_prop_serde? ⇒ T::Boolean
Whether to use VM-defined prop serialization/deserialization routines.
The default is to use runtime codegen inside sorbet-runtime itself.
86 87 88 |
# File 'lib/types/configuration.rb', line 86 def self.use_vm_prop_serde? @use_vm_prop_serde || false end |
.without_ruby_warnings { ... } ⇒ Object
Temporarily disable ruby warnings while executing the given block. This is useful when doing something that would normally cause a warning to be emitted in Ruby verbose mode ($VERBOSE = true).
516 517 518 519 520 521 522 523 524 525 526 527 528 |
# File 'lib/types/configuration.rb', line 516 def self.without_ruby_warnings if $VERBOSE begin original_verbose = $VERBOSE $VERBOSE = false yield ensure $VERBOSE = original_verbose end else yield end end |