activesupport 7.2.3 → 8.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (78) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +72 -347
  3. data/README.rdoc +1 -1
  4. data/lib/active_support/backtrace_cleaner.rb +2 -2
  5. data/lib/active_support/benchmark.rb +21 -0
  6. data/lib/active_support/benchmarkable.rb +3 -2
  7. data/lib/active_support/broadcast_logger.rb +74 -61
  8. data/lib/active_support/cache/file_store.rb +14 -4
  9. data/lib/active_support/cache/mem_cache_store.rb +15 -13
  10. data/lib/active_support/cache/memory_store.rb +9 -5
  11. data/lib/active_support/cache/null_store.rb +2 -2
  12. data/lib/active_support/cache/redis_cache_store.rb +6 -3
  13. data/lib/active_support/cache/strategy/local_cache.rb +20 -56
  14. data/lib/active_support/cache.rb +19 -14
  15. data/lib/active_support/callbacks.rb +7 -6
  16. data/lib/active_support/class_attribute.rb +33 -0
  17. data/lib/active_support/code_generator.rb +9 -0
  18. data/lib/active_support/concurrency/share_lock.rb +0 -1
  19. data/lib/active_support/configuration_file.rb +15 -6
  20. data/lib/active_support/core_ext/array/conversions.rb +3 -3
  21. data/lib/active_support/core_ext/benchmark.rb +6 -10
  22. data/lib/active_support/core_ext/class/attribute.rb +22 -18
  23. data/lib/active_support/core_ext/date/conversions.rb +2 -0
  24. data/lib/active_support/core_ext/date_and_time/compatibility.rb +2 -2
  25. data/lib/active_support/core_ext/date_time/conversions.rb +2 -4
  26. data/lib/active_support/core_ext/enumerable.rb +13 -20
  27. data/lib/active_support/core_ext/hash/except.rb +0 -12
  28. data/lib/active_support/core_ext/module/attr_internal.rb +3 -4
  29. data/lib/active_support/core_ext/module/introspection.rb +0 -3
  30. data/lib/active_support/core_ext/object/json.rb +15 -9
  31. data/lib/active_support/core_ext/object/try.rb +2 -2
  32. data/lib/active_support/core_ext/range.rb +0 -1
  33. data/lib/active_support/core_ext/string/filters.rb +3 -3
  34. data/lib/active_support/core_ext/string/multibyte.rb +2 -2
  35. data/lib/active_support/core_ext/thread/backtrace/location.rb +2 -7
  36. data/lib/active_support/core_ext/time/calculations.rb +14 -2
  37. data/lib/active_support/core_ext/time/conversions.rb +2 -0
  38. data/lib/active_support/current_attributes.rb +7 -14
  39. data/lib/active_support/delegation.rb +0 -2
  40. data/lib/active_support/dependencies.rb +0 -1
  41. data/lib/active_support/deprecation/reporting.rb +0 -19
  42. data/lib/active_support/deprecation.rb +1 -1
  43. data/lib/active_support/duration.rb +14 -10
  44. data/lib/active_support/encrypted_configuration.rb +20 -2
  45. data/lib/active_support/error_reporter.rb +27 -6
  46. data/lib/active_support/evented_file_update_checker.rb +0 -1
  47. data/lib/active_support/execution_wrapper.rb +1 -1
  48. data/lib/active_support/file_update_checker.rb +1 -1
  49. data/lib/active_support/gem_version.rb +3 -3
  50. data/lib/active_support/hash_with_indifferent_access.rb +31 -35
  51. data/lib/active_support/i18n_railtie.rb +19 -11
  52. data/lib/active_support/isolated_execution_state.rb +0 -2
  53. data/lib/active_support/json/decoding.rb +1 -1
  54. data/lib/active_support/json/encoding.rb +7 -25
  55. data/lib/active_support/lazy_load_hooks.rb +1 -1
  56. data/lib/active_support/message_encryptors.rb +2 -2
  57. data/lib/active_support/message_verifier.rb +0 -9
  58. data/lib/active_support/message_verifiers.rb +3 -5
  59. data/lib/active_support/messages/rotator.rb +0 -5
  60. data/lib/active_support/multibyte/chars.rb +1 -4
  61. data/lib/active_support/notifications/fanout.rb +0 -1
  62. data/lib/active_support/number_helper.rb +22 -0
  63. data/lib/active_support/railtie.rb +4 -0
  64. data/lib/active_support/tagged_logging.rb +5 -0
  65. data/lib/active_support/testing/assertions.rb +79 -21
  66. data/lib/active_support/testing/isolation.rb +0 -2
  67. data/lib/active_support/testing/parallelization/server.rb +2 -15
  68. data/lib/active_support/testing/parallelization/worker.rb +2 -2
  69. data/lib/active_support/testing/parallelization.rb +1 -12
  70. data/lib/active_support/testing/strict_warnings.rb +43 -0
  71. data/lib/active_support/testing/time_helpers.rb +2 -1
  72. data/lib/active_support/time_with_zone.rb +22 -13
  73. data/lib/active_support/values/time_zone.rb +11 -9
  74. data/lib/active_support/xml_mini.rb +0 -2
  75. data/lib/active_support.rb +10 -3
  76. metadata +27 -9
  77. data/lib/active_support/core_ext/range/sole.rb +0 -17
  78. data/lib/active_support/proxy_object.rb +0 -20
@@ -5,8 +5,6 @@ require "active_support/testing/parallelize_executor"
5
5
  module ActiveSupport
6
6
  module Testing
7
7
  module Isolation
8
- require "thread"
9
-
10
8
  SubprocessCrashed = Class.new(StandardError)
11
9
 
12
10
  def self.included(klass) # :nodoc:
@@ -14,7 +14,6 @@ module ActiveSupport
14
14
  def initialize
15
15
  @queue = Queue.new
16
16
  @active_workers = Concurrent::Map.new
17
- @worker_pids = Concurrent::Map.new
18
17
  @in_flight = Concurrent::Map.new
19
18
  end
20
19
 
@@ -41,24 +40,12 @@ module ActiveSupport
41
40
  end
42
41
  end
43
42
 
44
- def start_worker(worker_id, worker_pid)
43
+ def start_worker(worker_id)
45
44
  @active_workers[worker_id] = true
46
- @worker_pids[worker_id] = worker_pid
47
45
  end
48
46
 
49
- def stop_worker(worker_id, worker_pid)
47
+ def stop_worker(worker_id)
50
48
  @active_workers.delete(worker_id)
51
- @worker_pids.delete(worker_id)
52
- end
53
-
54
- def remove_dead_workers(dead_pids)
55
- dead_pids.each do |dead_pid|
56
- worker_id = @worker_pids.key(dead_pid)
57
- if worker_id
58
- @active_workers.delete(worker_id)
59
- @worker_pids.delete(worker_id)
60
- end
61
- end
62
49
  end
63
50
 
64
51
  def active_workers?
@@ -18,7 +18,7 @@ module ActiveSupport
18
18
  DRb.stop_service
19
19
 
20
20
  @queue = DRbObject.new_with_uri(@url)
21
- @queue.start_worker(@id, Process.pid)
21
+ @queue.start_worker(@id)
22
22
 
23
23
  begin
24
24
  after_fork
@@ -29,7 +29,7 @@ module ActiveSupport
29
29
  set_process_title("(stopping)")
30
30
 
31
31
  run_cleanup
32
- @queue.stop_worker(@id, Process.pid)
32
+ @queue.stop_worker(@id)
33
33
  end
34
34
  end
35
35
 
@@ -47,19 +47,8 @@ module ActiveSupport
47
47
  end
48
48
 
49
49
  def shutdown
50
- dead_worker_pids = @worker_pool.filter_map do |pid|
51
- Process.waitpid(pid, Process::WNOHANG)
52
- rescue Errno::ECHILD
53
- pid
54
- end
55
- @queue_server.remove_dead_workers(dead_worker_pids)
56
-
57
50
  @queue_server.shutdown
58
- @worker_pool.each do |pid|
59
- Process.waitpid(pid)
60
- rescue Errno::ECHILD
61
- nil
62
- end
51
+ @worker_pool.each { |pid| Process.waitpid pid }
63
52
  end
64
53
  end
65
54
  end
@@ -0,0 +1,43 @@
1
+ # frozen_string_literal: true
2
+
3
+ $VERBOSE = true
4
+ Warning[:deprecated] = true
5
+
6
+ module ActiveSupport
7
+ module RaiseWarnings # :nodoc:
8
+ class WarningError < StandardError; end
9
+
10
+ PROJECT_ROOT = File.expand_path("../../../../", __dir__)
11
+ ALLOWED_WARNINGS = Regexp.union(
12
+ /circular require considered harmful.*delayed_job/, # Bug in delayed job.
13
+
14
+ # Expected non-verbose warning emitted by Rails.
15
+ /Ignoring .*\.yml because it has expired/,
16
+ /Failed to validate the schema cache because/,
17
+
18
+ # TODO: We need to decide what to do with this.
19
+ /Status code :unprocessable_entity is deprecated/,
20
+ )
21
+
22
+ SUPPRESSED_WARNINGS = Regexp.union(
23
+ # TODO: remove if https://github.com/mikel/mail/pull/1557 or similar fix
24
+ %r{/lib/mail/parsers/.*statement not reached},
25
+ %r{/lib/mail/parsers/.*assigned but unused variable - disp_type_s},
26
+ %r{/lib/mail/parsers/.*assigned but unused variable - testEof}
27
+ )
28
+
29
+ def warn(message, ...)
30
+ return if SUPPRESSED_WARNINGS.match?(message)
31
+
32
+ super
33
+
34
+ return unless message.include?(PROJECT_ROOT)
35
+ return if ALLOWED_WARNINGS.match?(message)
36
+ return unless ENV["RAILS_STRICT_WARNINGS"] || ENV["BUILDKITE"]
37
+
38
+ raise WarningError.new(message)
39
+ end
40
+ end
41
+ end
42
+
43
+ Warning.singleton_class.prepend(ActiveSupport::RaiseWarnings)
@@ -166,9 +166,10 @@ module ActiveSupport
166
166
  else
167
167
  now = date_or_time
168
168
  now = now.to_time unless now.is_a?(Time)
169
- now = now.change(usec: 0) unless with_usec
170
169
  end
171
170
 
171
+ now = now.change(usec: 0) unless with_usec
172
+
172
173
  # +now+ must be in local system timezone, because +Time.at(now)+
173
174
  # and +now.to_date+ (see stubs below) will use +now+'s timezone too!
174
175
  now = now.getlocal
@@ -136,9 +136,9 @@ module ActiveSupport
136
136
 
137
137
  # Returns a string of the object's date, time, zone, and offset from UTC.
138
138
  #
139
- # Time.zone.now.inspect # => "Thu, 04 Dec 2014 11:00:25.624541392 EST -05:00"
139
+ # Time.zone.now.inspect # => "2024-11-13 07:00:10.528054960 UTC +00:00"
140
140
  def inspect
141
- "#{time.strftime('%a, %d %b %Y %H:%M:%S.%9N')} #{zone} #{formatted_offset}"
141
+ "#{time.strftime('%F %H:%M:%S.%9N')} #{zone} #{formatted_offset}"
142
142
  end
143
143
 
144
144
  # Returns a string of the object's date and time in the ISO 8601 standard
@@ -157,11 +157,11 @@ module ActiveSupport
157
157
  # to +false+.
158
158
  #
159
159
  # # With ActiveSupport::JSON::Encoding.use_standard_json_time_format = true
160
- # Time.utc(2005,2,1,15,15,10).in_time_zone("Hawaii").to_json
160
+ # Time.utc(2005,2,1,15,15,10).in_time_zone("Hawaii").as_json
161
161
  # # => "2005-02-01T05:15:10.000-10:00"
162
162
  #
163
163
  # # With ActiveSupport::JSON::Encoding.use_standard_json_time_format = false
164
- # Time.utc(2005,2,1,15,15,10).in_time_zone("Hawaii").to_json
164
+ # Time.utc(2005,2,1,15,15,10).in_time_zone("Hawaii").as_json
165
165
  # # => "2005/02/01 05:15:10 -1000"
166
166
  def as_json(options = nil)
167
167
  if ActiveSupport::JSON::Encoding.use_standard_json_time_format
@@ -215,8 +215,7 @@ module ActiveSupport
215
215
  elsif formatter = ::Time::DATE_FORMATS[format]
216
216
  formatter.respond_to?(:call) ? formatter.call(self).to_s : strftime(formatter)
217
217
  else
218
- # Change to to_s when deprecation is gone.
219
- "#{time.strftime("%Y-%m-%d %H:%M:%S")} #{formatted_offset(false, 'UTC')}"
218
+ to_s
220
219
  end
221
220
  end
222
221
  alias_method :to_formatted_s, :to_fs
@@ -300,7 +299,16 @@ module ActiveSupport
300
299
  if duration_of_variable_length?(other)
301
300
  method_missing(:+, other)
302
301
  else
303
- result = utc.acts_like?(:date) ? utc.since(other) : utc + other rescue utc.since(other)
302
+ begin
303
+ result = utc + other
304
+ rescue TypeError
305
+ result = utc.to_datetime.since(other)
306
+ ActiveSupport.deprecator.warn(
307
+ "Adding an instance of #{other.class} to an instance of #{self.class} is deprecated. This behavior will raise " \
308
+ "a `TypeError` in Rails 8.1."
309
+ )
310
+ result.in_time_zone(time_zone)
311
+ end
304
312
  result.in_time_zone(time_zone)
305
313
  end
306
314
  end
@@ -336,7 +344,7 @@ module ActiveSupport
336
344
  elsif duration_of_variable_length?(other)
337
345
  method_missing(:-, other)
338
346
  else
339
- result = utc.acts_like?(:date) ? utc.ago(other) : utc - other rescue utc.ago(other)
347
+ result = utc - other
340
348
  result.in_time_zone(time_zone)
341
349
  end
342
350
  end
@@ -479,11 +487,13 @@ module ActiveSupport
479
487
  @to_datetime ||= utc.to_datetime.new_offset(Rational(utc_offset, 86_400))
480
488
  end
481
489
 
482
- # Returns an instance of +Time+, either with the same UTC offset
483
- # as +self+ or in the local system timezone depending on the setting
484
- # of +ActiveSupport.to_time_preserves_timezone+.
490
+ # Returns an instance of +Time+, either with the same timezone as +self+,
491
+ # with the same UTC offset as +self+ or in the local system timezone
492
+ # depending on the setting of +ActiveSupport.to_time_preserves_timezone+.
485
493
  def to_time
486
- if preserve_timezone
494
+ if preserve_timezone == :zone
495
+ @to_time_with_timezone ||= getlocal(time_zone)
496
+ elsif preserve_timezone
487
497
  @to_time_with_instance_offset ||= getlocal(utc_offset)
488
498
  else
489
499
  @to_time_with_system_offset ||= getlocal
@@ -535,7 +545,6 @@ module ActiveSupport
535
545
  # Ensure proxy class responds to all methods that underlying time instance
536
546
  # responds to.
537
547
  def respond_to_missing?(sym, include_priv)
538
- return false if sym.to_sym == :acts_like_date?
539
548
  time.respond_to?(sym, include_priv)
540
549
  end
541
550
 
@@ -208,9 +208,7 @@ module ActiveSupport
208
208
  TZInfo::Timezone.get(MAPPING[name] || name)
209
209
  end
210
210
 
211
- # :stopdoc:
212
- alias_method :create, :new
213
- # :startdoc:
211
+ alias_method :create, :new # :nodoc:
214
212
 
215
213
  # Returns a TimeZone instance with the given name, or +nil+ if no
216
214
  # such TimeZone instance exists. (This exists to support the use of
@@ -554,15 +552,11 @@ module ActiveSupport
554
552
  tzinfo.local_to_utc(time, dst)
555
553
  end
556
554
 
557
- # Available so that TimeZone instances respond like +TZInfo::Timezone+
558
- # instances.
559
- def period_for_utc(time)
555
+ def period_for_utc(time) # :nodoc:
560
556
  tzinfo.period_for_utc(time)
561
557
  end
562
558
 
563
- # Available so that TimeZone instances respond like +TZInfo::Timezone+
564
- # instances.
565
- def period_for_local(time, dst = true)
559
+ def period_for_local(time, dst = true) # :nodoc:
566
560
  tzinfo.period_for_local(time, dst) { |periods| periods.last }
567
561
  end
568
562
 
@@ -570,6 +564,14 @@ module ActiveSupport
570
564
  tzinfo.periods_for_local(time)
571
565
  end
572
566
 
567
+ def abbr(time) # :nodoc:
568
+ tzinfo.abbr(time)
569
+ end
570
+
571
+ def dst?(time) # :nodoc:
572
+ tzinfo.dst?(time)
573
+ end
574
+
573
575
  def init_with(coder) # :nodoc:
574
576
  initialize(coder["name"])
575
577
  end
@@ -74,8 +74,6 @@ module ActiveSupport
74
74
  "decimal" => Proc.new do |number|
75
75
  if String === number
76
76
  number.to_d
77
- elsif Float === number
78
- BigDecimal(number, 0)
79
77
  else
80
78
  BigDecimal(number)
81
79
  end
@@ -57,11 +57,12 @@ module ActiveSupport
57
57
 
58
58
  eager_autoload do
59
59
  autoload :BacktraceCleaner
60
- autoload :ProxyObject
60
+ autoload :Benchmark
61
61
  autoload :Benchmarkable
62
62
  autoload :Cache
63
63
  autoload :Callbacks
64
64
  autoload :Configurable
65
+ autoload :ClassAttribute
65
66
  autoload :Deprecation
66
67
  autoload :Delegation
67
68
  autoload :Digest
@@ -115,9 +116,15 @@ module ActiveSupport
115
116
  end
116
117
 
117
118
  def self.to_time_preserves_timezone=(value)
118
- unless value
119
+ if !value
119
120
  ActiveSupport.deprecator.warn(
120
- "Support for the pre-Ruby 2.4 behavior of to_time has been deprecated and will be removed in Rails 8.0."
121
+ "`to_time` will always preserve the receiver timezone rather than system local time in Rails 8.1. " \
122
+ "To opt in to the new behavior, set `config.active_support.to_time_preserves_timezone = :zone`."
123
+ )
124
+ elsif value != :zone
125
+ ActiveSupport.deprecator.warn(
126
+ "`to_time` will always preserve the full timezone rather than offset of the receiver in Rails 8.1. " \
127
+ "To opt in to the new behavior, set `config.active_support.to_time_preserves_timezone = :zone`."
121
128
  )
122
129
  end
123
130
 
metadata CHANGED
@@ -1,13 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: activesupport
3
3
  version: !ruby/object:Gem::Version
4
- version: 7.2.3
4
+ version: 8.0.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - David Heinemeier Hansson
8
+ autorequire:
8
9
  bindir: bin
9
10
  cert_chain: []
10
- date: 1980-01-02 00:00:00.000000000 Z
11
+ date: 2024-12-13 00:00:00.000000000 Z
11
12
  dependencies:
12
13
  - !ruby/object:Gem::Dependency
13
14
  name: i18n
@@ -167,6 +168,20 @@ dependencies:
167
168
  - - ">="
168
169
  - !ruby/object:Gem::Version
169
170
  version: '0.3'
171
+ - !ruby/object:Gem::Dependency
172
+ name: uri
173
+ requirement: !ruby/object:Gem::Requirement
174
+ requirements:
175
+ - - ">="
176
+ - !ruby/object:Gem::Version
177
+ version: 0.13.1
178
+ type: :runtime
179
+ prerelease: false
180
+ version_requirements: !ruby/object:Gem::Requirement
181
+ requirements:
182
+ - - ">="
183
+ - !ruby/object:Gem::Version
184
+ version: 0.13.1
170
185
  - !ruby/object:Gem::Dependency
171
186
  name: benchmark
172
187
  requirement: !ruby/object:Gem::Requirement
@@ -197,6 +212,7 @@ files:
197
212
  - lib/active_support/all.rb
198
213
  - lib/active_support/array_inquirer.rb
199
214
  - lib/active_support/backtrace_cleaner.rb
215
+ - lib/active_support/benchmark.rb
200
216
  - lib/active_support/benchmarkable.rb
201
217
  - lib/active_support/broadcast_logger.rb
202
218
  - lib/active_support/builder.rb
@@ -212,6 +228,7 @@ files:
212
228
  - lib/active_support/cache/strategy/local_cache.rb
213
229
  - lib/active_support/cache/strategy/local_cache_middleware.rb
214
230
  - lib/active_support/callbacks.rb
231
+ - lib/active_support/class_attribute.rb
215
232
  - lib/active_support/code_generator.rb
216
233
  - lib/active_support/concern.rb
217
234
  - lib/active_support/concurrency/load_interlock_aware_monitor.rb
@@ -313,7 +330,6 @@ files:
313
330
  - lib/active_support/core_ext/range/conversions.rb
314
331
  - lib/active_support/core_ext/range/each.rb
315
332
  - lib/active_support/core_ext/range/overlap.rb
316
- - lib/active_support/core_ext/range/sole.rb
317
333
  - lib/active_support/core_ext/regexp.rb
318
334
  - lib/active_support/core_ext/securerandom.rb
319
335
  - lib/active_support/core_ext/string.rb
@@ -432,7 +448,6 @@ files:
432
448
  - lib/active_support/ordered_hash.rb
433
449
  - lib/active_support/ordered_options.rb
434
450
  - lib/active_support/parameter_filter.rb
435
- - lib/active_support/proxy_object.rb
436
451
  - lib/active_support/rails.rb
437
452
  - lib/active_support/railtie.rb
438
453
  - lib/active_support/reloader.rb
@@ -460,6 +475,7 @@ files:
460
475
  - lib/active_support/testing/parallelize_executor.rb
461
476
  - lib/active_support/testing/setup_and_teardown.rb
462
477
  - lib/active_support/testing/stream.rb
478
+ - lib/active_support/testing/strict_warnings.rb
463
479
  - lib/active_support/testing/tagged_logging.rb
464
480
  - lib/active_support/testing/tests_without_assertions.rb
465
481
  - lib/active_support/testing/time_helpers.rb
@@ -479,11 +495,12 @@ licenses:
479
495
  - MIT
480
496
  metadata:
481
497
  bug_tracker_uri: https://github.com/rails/rails/issues
482
- changelog_uri: https://github.com/rails/rails/blob/v7.2.3/activesupport/CHANGELOG.md
483
- documentation_uri: https://api.rubyonrails.org/v7.2.3/
498
+ changelog_uri: https://github.com/rails/rails/blob/v8.0.1/activesupport/CHANGELOG.md
499
+ documentation_uri: https://api.rubyonrails.org/v8.0.1/
484
500
  mailing_list_uri: https://discuss.rubyonrails.org/c/rubyonrails-talk
485
- source_code_uri: https://github.com/rails/rails/tree/v7.2.3/activesupport
501
+ source_code_uri: https://github.com/rails/rails/tree/v8.0.1/activesupport
486
502
  rubygems_mfa_required: 'true'
503
+ post_install_message:
487
504
  rdoc_options:
488
505
  - "--encoding"
489
506
  - UTF-8
@@ -493,14 +510,15 @@ required_ruby_version: !ruby/object:Gem::Requirement
493
510
  requirements:
494
511
  - - ">="
495
512
  - !ruby/object:Gem::Version
496
- version: 3.1.0
513
+ version: 3.2.0
497
514
  required_rubygems_version: !ruby/object:Gem::Requirement
498
515
  requirements:
499
516
  - - ">="
500
517
  - !ruby/object:Gem::Version
501
518
  version: '0'
502
519
  requirements: []
503
- rubygems_version: 3.6.9
520
+ rubygems_version: 3.5.22
521
+ signing_key:
504
522
  specification_version: 4
505
523
  summary: A toolkit of support libraries and Ruby core extensions extracted from the
506
524
  Rails framework.
@@ -1,17 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- class Range
4
- # Returns the sole item in the range. If there are no items, or more
5
- # than one item, raises Enumerable::SoleItemExpectedError.
6
- #
7
- # (1..1).sole # => 1
8
- # (2..1).sole # => Enumerable::SoleItemExpectedError: no item found
9
- # (..1).sole # => Enumerable::SoleItemExpectedError: infinite range cannot represent a sole item
10
- def sole
11
- if self.begin.nil? || self.end.nil?
12
- raise ActiveSupport::EnumerableCoreExt::SoleItemExpectedError, "infinite range '#{inspect}' cannot represent a sole item"
13
- end
14
-
15
- super
16
- end
17
- end
@@ -1,20 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module ActiveSupport
4
- class ProxyObject < ::BasicObject # :nodoc:
5
- undef_method :==
6
- undef_method :equal?
7
-
8
- # Let ActiveSupport::ProxyObject at least raise exceptions.
9
- def raise(*args)
10
- ::Object.send(:raise, *args)
11
- end
12
-
13
- def self.inherited(_subclass)
14
- ::ActiveSupport.deprecator.warn(<<~MSG)
15
- ActiveSupport::ProxyObject is deprecated and will be removed in Rails 8.0.
16
- Use Ruby's built-in BasicObject instead.
17
- MSG
18
- end
19
- end
20
- end