activesupport 4.0.12 → 7.0.2.4
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.
Potentially problematic release.
This version of activesupport might be problematic. Click here for more details.
- checksums.yaml +5 -5
- data/CHANGELOG.md +249 -501
- data/MIT-LICENSE +2 -2
- data/README.rdoc +10 -5
- data/lib/active_support/actionable_error.rb +48 -0
- data/lib/active_support/all.rb +5 -3
- data/lib/active_support/array_inquirer.rb +48 -0
- data/lib/active_support/backtrace_cleaner.rb +41 -13
- data/lib/active_support/benchmarkable.rb +7 -15
- data/lib/active_support/builder.rb +3 -1
- data/lib/active_support/cache/file_store.rb +96 -74
- data/lib/active_support/cache/mem_cache_store.rb +211 -103
- data/lib/active_support/cache/memory_store.rb +90 -58
- data/lib/active_support/cache/null_store.rb +19 -7
- data/lib/active_support/cache/redis_cache_store.rb +468 -0
- data/lib/active_support/cache/strategy/local_cache.rb +86 -83
- data/lib/active_support/cache/strategy/local_cache_middleware.rb +45 -0
- data/lib/active_support/cache.rb +580 -241
- data/lib/active_support/callbacks.rb +812 -425
- data/lib/active_support/code_generator.rb +65 -0
- data/lib/active_support/concern.rb +103 -14
- data/lib/active_support/concurrency/load_interlock_aware_monitor.rb +33 -0
- data/lib/active_support/concurrency/share_lock.rb +226 -0
- data/lib/active_support/configurable.rb +21 -19
- data/lib/active_support/configuration_file.rb +51 -0
- data/lib/active_support/core_ext/array/access.rb +47 -1
- data/lib/active_support/core_ext/array/conversions.rb +35 -44
- data/lib/active_support/core_ext/array/deprecated_conversions.rb +25 -0
- data/lib/active_support/core_ext/array/extract.rb +21 -0
- data/lib/active_support/core_ext/array/extract_options.rb +2 -0
- data/lib/active_support/core_ext/array/grouping.rb +26 -16
- data/lib/active_support/core_ext/array/inquiry.rb +19 -0
- data/lib/active_support/core_ext/array/wrap.rb +7 -4
- data/lib/active_support/core_ext/array.rb +10 -7
- data/lib/active_support/core_ext/benchmark.rb +5 -3
- data/lib/active_support/core_ext/big_decimal/conversions.rb +9 -26
- data/lib/active_support/core_ext/big_decimal.rb +3 -1
- data/lib/active_support/core_ext/class/attribute.rb +52 -49
- data/lib/active_support/core_ext/class/attribute_accessors.rb +5 -169
- data/lib/active_support/core_ext/class/subclasses.rb +25 -26
- data/lib/active_support/core_ext/class.rb +4 -4
- data/lib/active_support/core_ext/date/acts_like.rb +3 -1
- data/lib/active_support/core_ext/date/blank.rb +14 -0
- data/lib/active_support/core_ext/date/calculations.rb +31 -18
- data/lib/active_support/core_ext/date/conversions.rb +43 -32
- data/lib/active_support/core_ext/date/deprecated_conversions.rb +26 -0
- data/lib/active_support/core_ext/date/zones.rb +5 -34
- data/lib/active_support/core_ext/date.rb +7 -4
- data/lib/active_support/core_ext/date_and_time/calculations.rb +198 -66
- data/lib/active_support/core_ext/date_and_time/compatibility.rb +31 -0
- data/lib/active_support/core_ext/date_and_time/zones.rb +40 -0
- data/lib/active_support/core_ext/date_time/acts_like.rb +4 -2
- data/lib/active_support/core_ext/date_time/blank.rb +14 -0
- data/lib/active_support/core_ext/date_time/calculations.rb +79 -38
- data/lib/active_support/core_ext/date_time/compatibility.rb +18 -0
- data/lib/active_support/core_ext/date_time/conversions.rb +31 -26
- data/lib/active_support/core_ext/date_time/deprecated_conversions.rb +22 -0
- data/lib/active_support/core_ext/date_time.rb +8 -4
- data/lib/active_support/core_ext/digest/uuid.rb +79 -0
- data/lib/active_support/core_ext/digest.rb +3 -0
- data/lib/active_support/core_ext/enumerable.rb +249 -17
- data/lib/active_support/core_ext/file/atomic.rb +41 -32
- data/lib/active_support/core_ext/file.rb +3 -1
- data/lib/active_support/core_ext/hash/conversions.rb +71 -49
- data/lib/active_support/core_ext/hash/deep_merge.rb +9 -13
- data/lib/active_support/core_ext/hash/deep_transform_values.rb +46 -0
- data/lib/active_support/core_ext/hash/except.rb +14 -5
- data/lib/active_support/core_ext/hash/indifferent_access.rb +5 -3
- data/lib/active_support/core_ext/hash/keys.rb +39 -56
- data/lib/active_support/core_ext/hash/reverse_merge.rb +5 -2
- data/lib/active_support/core_ext/hash/slice.rb +8 -23
- data/lib/active_support/core_ext/hash.rb +10 -8
- data/lib/active_support/core_ext/integer/inflections.rb +3 -1
- data/lib/active_support/core_ext/integer/multiple.rb +3 -1
- data/lib/active_support/core_ext/integer/time.rb +11 -33
- data/lib/active_support/core_ext/integer.rb +5 -3
- data/lib/active_support/core_ext/kernel/concern.rb +14 -0
- data/lib/active_support/core_ext/kernel/reporting.rb +9 -78
- data/lib/active_support/core_ext/kernel/singleton_class.rb +2 -0
- data/lib/active_support/core_ext/kernel.rb +5 -4
- data/lib/active_support/core_ext/load_error.rb +5 -21
- data/lib/active_support/core_ext/module/aliasing.rb +6 -44
- data/lib/active_support/core_ext/module/anonymous.rb +12 -1
- data/lib/active_support/core_ext/module/attr_internal.rb +8 -8
- data/lib/active_support/core_ext/module/attribute_accessors.rb +186 -44
- data/lib/active_support/core_ext/module/attribute_accessors_per_thread.rb +157 -0
- data/lib/active_support/core_ext/module/concerning.rb +140 -0
- data/lib/active_support/core_ext/module/delegation.rb +172 -45
- data/lib/active_support/core_ext/module/deprecation.rb +3 -3
- data/lib/active_support/core_ext/module/introspection.rb +23 -38
- data/lib/active_support/core_ext/module/redefine_method.rb +40 -0
- data/lib/active_support/core_ext/module/remove_method.rb +8 -3
- data/lib/active_support/core_ext/module.rb +13 -10
- data/lib/active_support/core_ext/name_error.rb +45 -4
- data/lib/active_support/core_ext/numeric/bytes.rb +22 -0
- data/lib/active_support/core_ext/numeric/conversions.rb +135 -127
- data/lib/active_support/core_ext/numeric/deprecated_conversions.rb +60 -0
- data/lib/active_support/core_ext/numeric/time.rb +37 -50
- data/lib/active_support/core_ext/numeric.rb +6 -3
- data/lib/active_support/core_ext/object/acts_like.rb +41 -6
- data/lib/active_support/core_ext/object/blank.rb +70 -20
- data/lib/active_support/core_ext/object/conversions.rb +6 -4
- data/lib/active_support/core_ext/object/deep_dup.rb +19 -10
- data/lib/active_support/core_ext/object/duplicable.rb +17 -47
- data/lib/active_support/core_ext/object/inclusion.rb +18 -15
- data/lib/active_support/core_ext/object/instance_variables.rb +3 -1
- data/lib/active_support/core_ext/object/json.rb +244 -0
- data/lib/active_support/core_ext/object/to_param.rb +3 -1
- data/lib/active_support/core_ext/object/to_query.rb +21 -8
- data/lib/active_support/core_ext/object/try.rb +106 -26
- data/lib/active_support/core_ext/object/with_options.rb +64 -5
- data/lib/active_support/core_ext/object.rb +14 -12
- data/lib/active_support/core_ext/pathname/existence.rb +21 -0
- data/lib/active_support/core_ext/pathname.rb +3 -0
- data/lib/active_support/core_ext/range/compare_range.rb +57 -0
- data/lib/active_support/core_ext/range/conversions.rb +37 -15
- data/lib/active_support/core_ext/range/deprecated_conversions.rb +26 -0
- data/lib/active_support/core_ext/range/each.rb +18 -17
- data/lib/active_support/core_ext/range/include_time_with_zone.rb +7 -0
- data/lib/active_support/core_ext/range/overlaps.rb +2 -0
- data/lib/active_support/core_ext/range.rb +7 -4
- data/lib/active_support/core_ext/regexp.rb +10 -1
- data/lib/active_support/core_ext/securerandom.rb +45 -0
- data/lib/active_support/core_ext/string/access.rb +42 -51
- data/lib/active_support/core_ext/string/behavior.rb +3 -1
- data/lib/active_support/core_ext/string/conversions.rb +18 -13
- data/lib/active_support/core_ext/string/exclude.rb +5 -3
- data/lib/active_support/core_ext/string/filters.rb +97 -7
- data/lib/active_support/core_ext/string/indent.rb +6 -4
- data/lib/active_support/core_ext/string/inflections.rb +106 -25
- data/lib/active_support/core_ext/string/inquiry.rb +4 -1
- data/lib/active_support/core_ext/string/multibyte.rb +18 -9
- data/lib/active_support/core_ext/string/output_safety.rb +227 -54
- data/lib/active_support/core_ext/string/starts_ends_with.rb +4 -2
- data/lib/active_support/core_ext/string/strip.rb +6 -5
- data/lib/active_support/core_ext/string/zones.rb +4 -1
- data/lib/active_support/core_ext/string.rb +15 -13
- data/lib/active_support/core_ext/symbol/starts_ends_with.rb +6 -0
- data/lib/active_support/core_ext/symbol.rb +3 -0
- data/lib/active_support/core_ext/time/acts_like.rb +3 -1
- data/lib/active_support/core_ext/time/calculations.rb +178 -116
- data/lib/active_support/core_ext/time/compatibility.rb +16 -0
- data/lib/active_support/core_ext/time/conversions.rb +37 -25
- data/lib/active_support/core_ext/time/deprecated_conversions.rb +22 -0
- data/lib/active_support/core_ext/time/zones.rb +44 -42
- data/lib/active_support/core_ext/time.rb +8 -5
- data/lib/active_support/core_ext/uri.rb +4 -25
- data/lib/active_support/core_ext.rb +4 -2
- data/lib/active_support/current_attributes/test_helper.rb +13 -0
- data/lib/active_support/current_attributes.rb +226 -0
- data/lib/active_support/dependencies/autoload.rb +3 -1
- data/lib/active_support/dependencies/interlock.rb +49 -0
- data/lib/active_support/dependencies/require_dependency.rb +28 -0
- data/lib/active_support/dependencies.rb +71 -696
- data/lib/active_support/deprecation/behaviors.rb +65 -16
- data/lib/active_support/deprecation/constant_accessor.rb +52 -0
- data/lib/active_support/deprecation/disallowed.rb +56 -0
- data/lib/active_support/deprecation/instance_delegator.rb +16 -2
- data/lib/active_support/deprecation/method_wrappers.rb +62 -21
- data/lib/active_support/deprecation/proxy_wrappers.rb +82 -31
- data/lib/active_support/deprecation/reporting.rb +81 -18
- data/lib/active_support/deprecation.rb +19 -11
- data/lib/active_support/descendants_tracker.rb +192 -34
- data/lib/active_support/digest.rb +22 -0
- data/lib/active_support/duration/iso8601_parser.rb +123 -0
- data/lib/active_support/duration/iso8601_serializer.rb +67 -0
- data/lib/active_support/duration.rb +437 -39
- data/lib/active_support/encrypted_configuration.rb +56 -0
- data/lib/active_support/encrypted_file.rb +117 -0
- data/lib/active_support/environment_inquirer.rb +20 -0
- data/lib/active_support/error_reporter.rb +117 -0
- data/lib/active_support/evented_file_update_checker.rb +170 -0
- data/lib/active_support/execution_context/test_helper.rb +13 -0
- data/lib/active_support/execution_context.rb +53 -0
- data/lib/active_support/execution_wrapper.rb +151 -0
- data/lib/active_support/executor/test_helper.rb +7 -0
- data/lib/active_support/executor.rb +8 -0
- data/lib/active_support/file_update_checker.rb +62 -37
- data/lib/active_support/fork_tracker.rb +71 -0
- data/lib/active_support/gem_version.rb +17 -0
- data/lib/active_support/gzip.rb +7 -5
- data/lib/active_support/hash_with_indifferent_access.rb +207 -54
- data/lib/active_support/html_safe_translation.rb +43 -0
- data/lib/active_support/i18n.rb +10 -6
- data/lib/active_support/i18n_railtie.rb +48 -19
- data/lib/active_support/inflections.rb +19 -12
- data/lib/active_support/inflector/inflections.rb +97 -37
- data/lib/active_support/inflector/methods.rb +192 -157
- data/lib/active_support/inflector/transliterate.rb +83 -33
- data/lib/active_support/inflector.rb +7 -5
- data/lib/active_support/isolated_execution_state.rb +64 -0
- data/lib/active_support/json/decoding.rb +37 -42
- data/lib/active_support/json/encoding.rb +93 -293
- data/lib/active_support/json.rb +4 -2
- data/lib/active_support/key_generator.rb +30 -47
- data/lib/active_support/lazy_load_hooks.rb +54 -21
- data/lib/active_support/locale/en.rb +33 -0
- data/lib/active_support/locale/en.yml +10 -4
- data/lib/active_support/log_subscriber/test_helper.rb +14 -12
- data/lib/active_support/log_subscriber.rb +61 -18
- data/lib/active_support/logger.rb +40 -4
- data/lib/active_support/logger_silence.rb +17 -20
- data/lib/active_support/logger_thread_safe_level.rb +69 -0
- data/lib/active_support/message_encryptor.rb +178 -55
- data/lib/active_support/message_verifier.rb +195 -26
- data/lib/active_support/messages/metadata.rb +80 -0
- data/lib/active_support/messages/rotation_configuration.rb +23 -0
- data/lib/active_support/messages/rotator.rb +57 -0
- data/lib/active_support/multibyte/chars.rb +45 -92
- data/lib/active_support/multibyte/unicode.rb +44 -377
- data/lib/active_support/multibyte.rb +5 -3
- data/lib/active_support/notifications/fanout.rb +177 -44
- data/lib/active_support/notifications/instrumenter.rb +117 -17
- data/lib/active_support/notifications.rb +106 -39
- data/lib/active_support/number_helper/number_converter.rb +181 -0
- data/lib/active_support/number_helper/number_to_currency_converter.rb +46 -0
- data/lib/active_support/number_helper/number_to_delimited_converter.rb +30 -0
- data/lib/active_support/number_helper/number_to_human_converter.rb +69 -0
- data/lib/active_support/number_helper/number_to_human_size_converter.rb +60 -0
- data/lib/active_support/number_helper/number_to_percentage_converter.rb +16 -0
- data/lib/active_support/number_helper/number_to_phone_converter.rb +59 -0
- data/lib/active_support/number_helper/number_to_rounded_converter.rb +59 -0
- data/lib/active_support/number_helper/rounding_helper.rb +46 -0
- data/lib/active_support/number_helper.rb +152 -394
- data/lib/active_support/option_merger.rb +18 -5
- data/lib/active_support/ordered_hash.rb +8 -6
- data/lib/active_support/ordered_options.rb +43 -7
- data/lib/active_support/parameter_filter.rb +138 -0
- data/lib/active_support/per_thread_registry.rb +24 -11
- data/lib/active_support/proxy_object.rb +2 -0
- data/lib/active_support/rails.rb +10 -11
- data/lib/active_support/railtie.rb +118 -12
- data/lib/active_support/reloader.rb +130 -0
- data/lib/active_support/rescuable.rb +112 -57
- data/lib/active_support/ruby_features.rb +7 -0
- data/lib/active_support/secure_compare_rotator.rb +51 -0
- data/lib/active_support/security_utils.rb +38 -0
- data/lib/active_support/string_inquirer.rb +11 -4
- data/lib/active_support/subscriber.rb +109 -39
- data/lib/active_support/tagged_logging.rb +54 -17
- data/lib/active_support/test_case.rb +121 -37
- data/lib/active_support/testing/assertions.rb +177 -39
- data/lib/active_support/testing/autorun.rb +5 -3
- data/lib/active_support/testing/constant_lookup.rb +3 -6
- data/lib/active_support/testing/declarative.rb +10 -22
- data/lib/active_support/testing/deprecation.rb +65 -11
- data/lib/active_support/testing/file_fixtures.rb +38 -0
- data/lib/active_support/testing/isolation.rb +56 -87
- data/lib/active_support/testing/method_call_assertions.rb +70 -0
- data/lib/active_support/testing/parallelization/server.rb +82 -0
- data/lib/active_support/testing/parallelization/worker.rb +103 -0
- data/lib/active_support/testing/parallelization.rb +55 -0
- data/lib/active_support/testing/parallelize_executor.rb +76 -0
- data/lib/active_support/testing/setup_and_teardown.rb +30 -10
- data/lib/active_support/testing/stream.rb +41 -0
- data/lib/active_support/testing/tagged_logging.rb +6 -4
- data/lib/active_support/testing/time_helpers.rb +246 -0
- data/lib/active_support/time.rb +13 -13
- data/lib/active_support/time_with_zone.rb +315 -90
- data/lib/active_support/values/time_zone.rb +306 -135
- data/lib/active_support/version.rb +6 -7
- data/lib/active_support/xml_mini/jdom.rb +117 -115
- data/lib/active_support/xml_mini/libxml.rb +22 -21
- data/lib/active_support/xml_mini/libxmlsax.rb +17 -19
- data/lib/active_support/xml_mini/nokogiri.rb +19 -19
- data/lib/active_support/xml_mini/nokogirisax.rb +16 -17
- data/lib/active_support/xml_mini/rexml.rb +25 -17
- data/lib/active_support/xml_mini.rb +67 -56
- data/lib/active_support.rb +58 -3
- metadata +125 -66
- data/lib/active_support/basic_object.rb +0 -11
- data/lib/active_support/buffered_logger.rb +0 -21
- data/lib/active_support/concurrency/latch.rb +0 -27
- data/lib/active_support/core_ext/array/prepend_and_append.rb +0 -7
- data/lib/active_support/core_ext/array/uniq_by.rb +0 -19
- data/lib/active_support/core_ext/class/delegating_attributes.rb +0 -40
- data/lib/active_support/core_ext/date_time/zones.rb +0 -24
- data/lib/active_support/core_ext/hash/diff.rb +0 -14
- data/lib/active_support/core_ext/kernel/agnostics.rb +0 -11
- data/lib/active_support/core_ext/kernel/debugger.rb +0 -10
- data/lib/active_support/core_ext/logger.rb +0 -67
- data/lib/active_support/core_ext/marshal.rb +0 -21
- data/lib/active_support/core_ext/module/qualified_const.rb +0 -52
- data/lib/active_support/core_ext/module/reachable.rb +0 -8
- data/lib/active_support/core_ext/object/to_json.rb +0 -27
- data/lib/active_support/core_ext/proc.rb +0 -17
- data/lib/active_support/core_ext/range/include_range.rb +0 -23
- data/lib/active_support/core_ext/string/encoding.rb +0 -8
- data/lib/active_support/core_ext/struct.rb +0 -6
- data/lib/active_support/core_ext/thread.rb +0 -79
- data/lib/active_support/core_ext/time/marshal.rb +0 -30
- data/lib/active_support/file_watcher.rb +0 -36
- data/lib/active_support/json/variable.rb +0 -18
- data/lib/active_support/testing/pending.rb +0 -14
- data/lib/active_support/values/unicode_tables.dat +0 -0
| @@ -1,13 +1,18 @@ | |
| 1 | 
            -
             | 
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require "active_support/time_with_zone"
         | 
| 4 | 
            +
            require "active_support/core_ext/time/acts_like"
         | 
| 5 | 
            +
            require "active_support/core_ext/date_and_time/zones"
         | 
| 2 6 |  | 
| 3 7 | 
             
            class Time
         | 
| 8 | 
            +
              include DateAndTime::Zones
         | 
| 4 9 | 
             
              class << self
         | 
| 5 10 | 
             
                attr_accessor :zone_default
         | 
| 6 11 |  | 
| 7 12 | 
             
                # Returns the TimeZone for the current request, if this has been set (via Time.zone=).
         | 
| 8 13 | 
             
                # If <tt>Time.zone</tt> has not been set for the current request, returns the TimeZone specified in <tt>config.time_zone</tt>.
         | 
| 9 14 | 
             
                def zone
         | 
| 10 | 
            -
                   | 
| 15 | 
            +
                  ::ActiveSupport::IsolatedExecutionState[:time_zone] || zone_default
         | 
| 11 16 | 
             
                end
         | 
| 12 17 |  | 
| 13 18 | 
             
                # Sets <tt>Time.zone</tt> to a TimeZone object for the current request/thread.
         | 
| @@ -23,7 +28,7 @@ class Time | |
| 23 28 | 
             
                # <tt>current_user.time_zone</tt> just needs to return a string identifying the user's preferred time zone:
         | 
| 24 29 | 
             
                #
         | 
| 25 30 | 
             
                #   class ApplicationController < ActionController::Base
         | 
| 26 | 
            -
                #      | 
| 31 | 
            +
                #     around_action :set_time_zone
         | 
| 27 32 | 
             
                #
         | 
| 28 33 | 
             
                #     def set_time_zone
         | 
| 29 34 | 
             
                #       if logged_in?
         | 
| @@ -34,10 +39,26 @@ class Time | |
| 34 39 | 
             
                #     end
         | 
| 35 40 | 
             
                #   end
         | 
| 36 41 | 
             
                def zone=(time_zone)
         | 
| 37 | 
            -
                   | 
| 42 | 
            +
                  ::ActiveSupport::IsolatedExecutionState[:time_zone] = find_zone!(time_zone)
         | 
| 38 43 | 
             
                end
         | 
| 39 44 |  | 
| 40 | 
            -
                # Allows override of <tt>Time.zone</tt> locally inside supplied block; | 
| 45 | 
            +
                # Allows override of <tt>Time.zone</tt> locally inside supplied block;
         | 
| 46 | 
            +
                # resets <tt>Time.zone</tt> to existing value when done.
         | 
| 47 | 
            +
                #
         | 
| 48 | 
            +
                #   class ApplicationController < ActionController::Base
         | 
| 49 | 
            +
                #     around_action :set_time_zone
         | 
| 50 | 
            +
                #
         | 
| 51 | 
            +
                #     private
         | 
| 52 | 
            +
                #
         | 
| 53 | 
            +
                #     def set_time_zone
         | 
| 54 | 
            +
                #       Time.use_zone(current_user.timezone) { yield }
         | 
| 55 | 
            +
                #     end
         | 
| 56 | 
            +
                #   end
         | 
| 57 | 
            +
                #
         | 
| 58 | 
            +
                # NOTE: This won't affect any <tt>ActiveSupport::TimeWithZone</tt>
         | 
| 59 | 
            +
                # objects that have already been created, e.g. any model timestamp
         | 
| 60 | 
            +
                # attributes that have been read before the block will remain in
         | 
| 61 | 
            +
                # the application's default timezone.
         | 
| 41 62 | 
             
                def use_zone(time_zone)
         | 
| 42 63 | 
             
                  new_zone = find_zone!(time_zone)
         | 
| 43 64 | 
             
                  begin
         | 
| @@ -48,49 +69,30 @@ class Time | |
| 48 69 | 
             
                  end
         | 
| 49 70 | 
             
                end
         | 
| 50 71 |  | 
| 51 | 
            -
                # Returns a TimeZone instance  | 
| 72 | 
            +
                # Returns a TimeZone instance matching the time zone provided.
         | 
| 73 | 
            +
                # Accepts the time zone in any format supported by <tt>Time.zone=</tt>.
         | 
| 74 | 
            +
                # Raises an +ArgumentError+ for invalid time zones.
         | 
| 75 | 
            +
                #
         | 
| 76 | 
            +
                #   Time.find_zone! "America/New_York" # => #<ActiveSupport::TimeZone @name="America/New_York" ...>
         | 
| 77 | 
            +
                #   Time.find_zone! "EST"              # => #<ActiveSupport::TimeZone @name="EST" ...>
         | 
| 78 | 
            +
                #   Time.find_zone! -5.hours           # => #<ActiveSupport::TimeZone @name="Bogota" ...>
         | 
| 79 | 
            +
                #   Time.find_zone! nil                # => nil
         | 
| 80 | 
            +
                #   Time.find_zone! false              # => false
         | 
| 81 | 
            +
                #   Time.find_zone! "NOT-A-TIMEZONE"   # => ArgumentError: Invalid Timezone: NOT-A-TIMEZONE
         | 
| 52 82 | 
             
                def find_zone!(time_zone)
         | 
| 53 | 
            -
                   | 
| 54 | 
            -
                    time_zone
         | 
| 55 | 
            -
                  else
         | 
| 56 | 
            -
                    # lookup timezone based on identifier (unless we've been passed a TZInfo::Timezone)
         | 
| 57 | 
            -
                    unless time_zone.respond_to?(:period_for_local)
         | 
| 58 | 
            -
                      time_zone = ActiveSupport::TimeZone[time_zone] || TZInfo::Timezone.get(time_zone)
         | 
| 59 | 
            -
                    end
         | 
| 83 | 
            +
                  return time_zone unless time_zone
         | 
| 60 84 |  | 
| 61 | 
            -
             | 
| 62 | 
            -
                    if time_zone.is_a?(ActiveSupport::TimeZone)
         | 
| 63 | 
            -
                      time_zone
         | 
| 64 | 
            -
                    else
         | 
| 65 | 
            -
                      ActiveSupport::TimeZone.create(time_zone.name, nil, time_zone)
         | 
| 66 | 
            -
                    end
         | 
| 67 | 
            -
                  end
         | 
| 68 | 
            -
                rescue TZInfo::InvalidTimezoneIdentifier
         | 
| 69 | 
            -
                  raise ArgumentError, "Invalid Timezone: #{time_zone}"
         | 
| 85 | 
            +
                  ActiveSupport::TimeZone[time_zone] || raise(ArgumentError, "Invalid Timezone: #{time_zone}")
         | 
| 70 86 | 
             
                end
         | 
| 71 87 |  | 
| 88 | 
            +
                # Returns a TimeZone instance matching the time zone provided.
         | 
| 89 | 
            +
                # Accepts the time zone in any format supported by <tt>Time.zone=</tt>.
         | 
| 90 | 
            +
                # Returns +nil+ for invalid time zones.
         | 
| 91 | 
            +
                #
         | 
| 92 | 
            +
                #   Time.find_zone "America/New_York" # => #<ActiveSupport::TimeZone @name="America/New_York" ...>
         | 
| 93 | 
            +
                #   Time.find_zone "NOT-A-TIMEZONE"   # => nil
         | 
| 72 94 | 
             
                def find_zone(time_zone)
         | 
| 73 95 | 
             
                  find_zone!(time_zone) rescue nil
         | 
| 74 96 | 
             
                end
         | 
| 75 97 | 
             
              end
         | 
| 76 | 
            -
             | 
| 77 | 
            -
              # Returns the simultaneous time in <tt>Time.zone</tt>.
         | 
| 78 | 
            -
              #
         | 
| 79 | 
            -
              #   Time.zone = 'Hawaii'        # => 'Hawaii'
         | 
| 80 | 
            -
              #   Time.utc(2000).in_time_zone # => Fri, 31 Dec 1999 14:00:00 HST -10:00
         | 
| 81 | 
            -
              #
         | 
| 82 | 
            -
              # This method is similar to Time#localtime, except that it uses <tt>Time.zone</tt> as the local zone
         | 
| 83 | 
            -
              # instead of the operating system's time zone.
         | 
| 84 | 
            -
              #
         | 
| 85 | 
            -
              # You can also pass in a TimeZone instance or string that identifies a TimeZone as an argument,
         | 
| 86 | 
            -
              # and the conversion will be based on that zone instead of <tt>Time.zone</tt>.
         | 
| 87 | 
            -
              #
         | 
| 88 | 
            -
              #   Time.utc(2000).in_time_zone('Alaska') # => Fri, 31 Dec 1999 15:00:00 AKST -09:00
         | 
| 89 | 
            -
              def in_time_zone(zone = ::Time.zone)
         | 
| 90 | 
            -
                if zone
         | 
| 91 | 
            -
                  ActiveSupport::TimeWithZone.new(utc? ? self : getutc, ::Time.find_zone!(zone))
         | 
| 92 | 
            -
                else
         | 
| 93 | 
            -
                  self
         | 
| 94 | 
            -
                end
         | 
| 95 | 
            -
              end
         | 
| 96 98 | 
             
            end
         | 
| @@ -1,5 +1,8 @@ | |
| 1 | 
            -
             | 
| 2 | 
            -
             | 
| 3 | 
            -
            require  | 
| 4 | 
            -
            require  | 
| 5 | 
            -
            require  | 
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require "active_support/core_ext/time/acts_like"
         | 
| 4 | 
            +
            require "active_support/core_ext/time/calculations"
         | 
| 5 | 
            +
            require "active_support/core_ext/time/compatibility"
         | 
| 6 | 
            +
            require "active_support/core_ext/time/conversions"
         | 
| 7 | 
            +
            require "active_support/core_ext/time/deprecated_conversions" unless ENV["RAILS_DISABLE_DEPRECATED_TO_S_CONVERSION"]
         | 
| 8 | 
            +
            require "active_support/core_ext/time/zones"
         | 
| @@ -1,26 +1,5 @@ | |
| 1 | 
            -
            #  | 
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 2 |  | 
| 3 | 
            -
             | 
| 4 | 
            -
             | 
| 5 | 
            -
             | 
| 6 | 
            -
             | 
| 7 | 
            -
            unless str == parser.unescape(parser.escape(str))
         | 
| 8 | 
            -
              URI::Parser.class_eval do
         | 
| 9 | 
            -
                remove_method :unescape
         | 
| 10 | 
            -
                def unescape(str, escaped = /%[a-fA-F\d]{2}/)
         | 
| 11 | 
            -
                  # TODO: Are we actually sure that ASCII == UTF-8?
         | 
| 12 | 
            -
                  # YK: My initial experiments say yes, but let's be sure please
         | 
| 13 | 
            -
                  enc = str.encoding
         | 
| 14 | 
            -
                  enc = Encoding::UTF_8 if enc == Encoding::US_ASCII
         | 
| 15 | 
            -
                  str.gsub(escaped) { [$&[1, 2].hex].pack('C') }.force_encoding(enc)
         | 
| 16 | 
            -
                end
         | 
| 17 | 
            -
              end
         | 
| 18 | 
            -
            end
         | 
| 19 | 
            -
             | 
| 20 | 
            -
            module URI
         | 
| 21 | 
            -
              class << self
         | 
| 22 | 
            -
                def parser
         | 
| 23 | 
            -
                  @parser ||= URI::Parser.new
         | 
| 24 | 
            -
                end
         | 
| 25 | 
            -
              end
         | 
| 26 | 
            -
            end
         | 
| 3 | 
            +
            ActiveSupport::Deprecation.warn(<<-MSG.squish)
         | 
| 4 | 
            +
              `active_support/core_ext/uri` is deprecated and will be removed in Rails 7.1.
         | 
| 5 | 
            +
            MSG
         | 
| @@ -1,4 +1,6 @@ | |
| 1 | 
            -
             | 
| 2 | 
            -
             | 
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Dir.glob(File.expand_path("core_ext/*.rb", __dir__)).sort.each do |path|
         | 
| 4 | 
            +
              next if path.end_with?("core_ext/uri.rb")
         | 
| 3 5 | 
             
              require path
         | 
| 4 6 | 
             
            end
         | 
| @@ -0,0 +1,13 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            module ActiveSupport::CurrentAttributes::TestHelper # :nodoc:
         | 
| 4 | 
            +
              def before_setup
         | 
| 5 | 
            +
                ActiveSupport::CurrentAttributes.reset_all
         | 
| 6 | 
            +
                super
         | 
| 7 | 
            +
              end
         | 
| 8 | 
            +
             | 
| 9 | 
            +
              def after_teardown
         | 
| 10 | 
            +
                super
         | 
| 11 | 
            +
                ActiveSupport::CurrentAttributes.reset_all
         | 
| 12 | 
            +
              end
         | 
| 13 | 
            +
            end
         | 
| @@ -0,0 +1,226 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require "active_support/callbacks"
         | 
| 4 | 
            +
            require "active_support/core_ext/enumerable"
         | 
| 5 | 
            +
            require "active_support/core_ext/module/delegation"
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            module ActiveSupport
         | 
| 8 | 
            +
              # Abstract super class that provides a thread-isolated attributes singleton, which resets automatically
         | 
| 9 | 
            +
              # before and after each request. This allows you to keep all the per-request attributes easily
         | 
| 10 | 
            +
              # available to the whole system.
         | 
| 11 | 
            +
              #
         | 
| 12 | 
            +
              # The following full app-like example demonstrates how to use a Current class to
         | 
| 13 | 
            +
              # facilitate easy access to the global, per-request attributes without passing them deeply
         | 
| 14 | 
            +
              # around everywhere:
         | 
| 15 | 
            +
              #
         | 
| 16 | 
            +
              #   # app/models/current.rb
         | 
| 17 | 
            +
              #   class Current < ActiveSupport::CurrentAttributes
         | 
| 18 | 
            +
              #     attribute :account, :user
         | 
| 19 | 
            +
              #     attribute :request_id, :user_agent, :ip_address
         | 
| 20 | 
            +
              #
         | 
| 21 | 
            +
              #     resets { Time.zone = nil }
         | 
| 22 | 
            +
              #
         | 
| 23 | 
            +
              #     def user=(user)
         | 
| 24 | 
            +
              #       super
         | 
| 25 | 
            +
              #       self.account = user.account
         | 
| 26 | 
            +
              #       Time.zone    = user.time_zone
         | 
| 27 | 
            +
              #     end
         | 
| 28 | 
            +
              #   end
         | 
| 29 | 
            +
              #
         | 
| 30 | 
            +
              #   # app/controllers/concerns/authentication.rb
         | 
| 31 | 
            +
              #   module Authentication
         | 
| 32 | 
            +
              #     extend ActiveSupport::Concern
         | 
| 33 | 
            +
              #
         | 
| 34 | 
            +
              #     included do
         | 
| 35 | 
            +
              #       before_action :authenticate
         | 
| 36 | 
            +
              #     end
         | 
| 37 | 
            +
              #
         | 
| 38 | 
            +
              #     private
         | 
| 39 | 
            +
              #       def authenticate
         | 
| 40 | 
            +
              #         if authenticated_user = User.find_by(id: cookies.encrypted[:user_id])
         | 
| 41 | 
            +
              #           Current.user = authenticated_user
         | 
| 42 | 
            +
              #         else
         | 
| 43 | 
            +
              #           redirect_to new_session_url
         | 
| 44 | 
            +
              #         end
         | 
| 45 | 
            +
              #       end
         | 
| 46 | 
            +
              #   end
         | 
| 47 | 
            +
              #
         | 
| 48 | 
            +
              #   # app/controllers/concerns/set_current_request_details.rb
         | 
| 49 | 
            +
              #   module SetCurrentRequestDetails
         | 
| 50 | 
            +
              #     extend ActiveSupport::Concern
         | 
| 51 | 
            +
              #
         | 
| 52 | 
            +
              #     included do
         | 
| 53 | 
            +
              #       before_action do
         | 
| 54 | 
            +
              #         Current.request_id = request.uuid
         | 
| 55 | 
            +
              #         Current.user_agent = request.user_agent
         | 
| 56 | 
            +
              #         Current.ip_address = request.ip
         | 
| 57 | 
            +
              #       end
         | 
| 58 | 
            +
              #     end
         | 
| 59 | 
            +
              #   end
         | 
| 60 | 
            +
              #
         | 
| 61 | 
            +
              #   class ApplicationController < ActionController::Base
         | 
| 62 | 
            +
              #     include Authentication
         | 
| 63 | 
            +
              #     include SetCurrentRequestDetails
         | 
| 64 | 
            +
              #   end
         | 
| 65 | 
            +
              #
         | 
| 66 | 
            +
              #   class MessagesController < ApplicationController
         | 
| 67 | 
            +
              #     def create
         | 
| 68 | 
            +
              #       Current.account.messages.create(message_params)
         | 
| 69 | 
            +
              #     end
         | 
| 70 | 
            +
              #   end
         | 
| 71 | 
            +
              #
         | 
| 72 | 
            +
              #   class Message < ApplicationRecord
         | 
| 73 | 
            +
              #     belongs_to :creator, default: -> { Current.user }
         | 
| 74 | 
            +
              #     after_create { |message| Event.create(record: message) }
         | 
| 75 | 
            +
              #   end
         | 
| 76 | 
            +
              #
         | 
| 77 | 
            +
              #   class Event < ApplicationRecord
         | 
| 78 | 
            +
              #     before_create do
         | 
| 79 | 
            +
              #       self.request_id = Current.request_id
         | 
| 80 | 
            +
              #       self.user_agent = Current.user_agent
         | 
| 81 | 
            +
              #       self.ip_address = Current.ip_address
         | 
| 82 | 
            +
              #     end
         | 
| 83 | 
            +
              #   end
         | 
| 84 | 
            +
              #
         | 
| 85 | 
            +
              # A word of caution: It's easy to overdo a global singleton like Current and tangle your model as a result.
         | 
| 86 | 
            +
              # Current should only be used for a few, top-level globals, like account, user, and request details.
         | 
| 87 | 
            +
              # The attributes stuck in Current should be used by more or less all actions on all requests. If you start
         | 
| 88 | 
            +
              # sticking controller-specific attributes in there, you're going to create a mess.
         | 
| 89 | 
            +
              class CurrentAttributes
         | 
| 90 | 
            +
                include ActiveSupport::Callbacks
         | 
| 91 | 
            +
                define_callbacks :reset
         | 
| 92 | 
            +
             | 
| 93 | 
            +
                class << self
         | 
| 94 | 
            +
                  # Returns singleton instance for this class in this thread. If none exists, one is created.
         | 
| 95 | 
            +
                  def instance
         | 
| 96 | 
            +
                    current_instances[current_instances_key] ||= new
         | 
| 97 | 
            +
                  end
         | 
| 98 | 
            +
             | 
| 99 | 
            +
                  # Declares one or more attributes that will be given both class and instance accessor methods.
         | 
| 100 | 
            +
                  def attribute(*names)
         | 
| 101 | 
            +
                    ActiveSupport::CodeGenerator.batch(generated_attribute_methods, __FILE__, __LINE__) do |owner|
         | 
| 102 | 
            +
                      names.each do |name|
         | 
| 103 | 
            +
                        owner.define_cached_method(name, namespace: :current_attributes) do |batch|
         | 
| 104 | 
            +
                          batch <<
         | 
| 105 | 
            +
                            "def #{name}" <<
         | 
| 106 | 
            +
                            "attributes[:#{name}]" <<
         | 
| 107 | 
            +
                            "end"
         | 
| 108 | 
            +
                        end
         | 
| 109 | 
            +
                        owner.define_cached_method("#{name}=", namespace: :current_attributes) do |batch|
         | 
| 110 | 
            +
                          batch <<
         | 
| 111 | 
            +
                            "def #{name}=(value)" <<
         | 
| 112 | 
            +
                            "attributes[:#{name}] = value" <<
         | 
| 113 | 
            +
                            "end"
         | 
| 114 | 
            +
                        end
         | 
| 115 | 
            +
                      end
         | 
| 116 | 
            +
                    end
         | 
| 117 | 
            +
             | 
| 118 | 
            +
                    ActiveSupport::CodeGenerator.batch(singleton_class, __FILE__, __LINE__) do |owner|
         | 
| 119 | 
            +
                      names.each do |name|
         | 
| 120 | 
            +
                        owner.define_cached_method(name, namespace: :current_attributes_delegation) do |batch|
         | 
| 121 | 
            +
                          batch <<
         | 
| 122 | 
            +
                            "def #{name}" <<
         | 
| 123 | 
            +
                            "instance.#{name}" <<
         | 
| 124 | 
            +
                            "end"
         | 
| 125 | 
            +
                        end
         | 
| 126 | 
            +
                        owner.define_cached_method("#{name}=", namespace: :current_attributes_delegation) do |batch|
         | 
| 127 | 
            +
                          batch <<
         | 
| 128 | 
            +
                            "def #{name}=(value)" <<
         | 
| 129 | 
            +
                            "instance.#{name} = value" <<
         | 
| 130 | 
            +
                            "end"
         | 
| 131 | 
            +
                        end
         | 
| 132 | 
            +
                      end
         | 
| 133 | 
            +
                    end
         | 
| 134 | 
            +
                  end
         | 
| 135 | 
            +
             | 
| 136 | 
            +
                  # Calls this block before #reset is called on the instance. Used for resetting external collaborators that depend on current values.
         | 
| 137 | 
            +
                  def before_reset(&block)
         | 
| 138 | 
            +
                    set_callback :reset, :before, &block
         | 
| 139 | 
            +
                  end
         | 
| 140 | 
            +
             | 
| 141 | 
            +
                  # Calls this block after #reset is called on the instance. Used for resetting external collaborators, like Time.zone.
         | 
| 142 | 
            +
                  def resets(&block)
         | 
| 143 | 
            +
                    set_callback :reset, :after, &block
         | 
| 144 | 
            +
                  end
         | 
| 145 | 
            +
                  alias_method :after_reset, :resets
         | 
| 146 | 
            +
             | 
| 147 | 
            +
                  delegate :set, :reset, to: :instance
         | 
| 148 | 
            +
             | 
| 149 | 
            +
                  def reset_all # :nodoc:
         | 
| 150 | 
            +
                    current_instances.each_value(&:reset)
         | 
| 151 | 
            +
                  end
         | 
| 152 | 
            +
             | 
| 153 | 
            +
                  def clear_all # :nodoc:
         | 
| 154 | 
            +
                    reset_all
         | 
| 155 | 
            +
                    current_instances.clear
         | 
| 156 | 
            +
                  end
         | 
| 157 | 
            +
             | 
| 158 | 
            +
                  private
         | 
| 159 | 
            +
                    def generated_attribute_methods
         | 
| 160 | 
            +
                      @generated_attribute_methods ||= Module.new.tap { |mod| include mod }
         | 
| 161 | 
            +
                    end
         | 
| 162 | 
            +
             | 
| 163 | 
            +
                    def current_instances
         | 
| 164 | 
            +
                      IsolatedExecutionState[:current_attributes_instances] ||= {}
         | 
| 165 | 
            +
                    end
         | 
| 166 | 
            +
             | 
| 167 | 
            +
                    def current_instances_key
         | 
| 168 | 
            +
                      @current_instances_key ||= name.to_sym
         | 
| 169 | 
            +
                    end
         | 
| 170 | 
            +
             | 
| 171 | 
            +
                    def method_missing(name, *args, &block)
         | 
| 172 | 
            +
                      # Caches the method definition as a singleton method of the receiver.
         | 
| 173 | 
            +
                      #
         | 
| 174 | 
            +
                      # By letting #delegate handle it, we avoid an enclosure that'll capture args.
         | 
| 175 | 
            +
                      singleton_class.delegate name, to: :instance
         | 
| 176 | 
            +
             | 
| 177 | 
            +
                      send(name, *args, &block)
         | 
| 178 | 
            +
                    end
         | 
| 179 | 
            +
                    ruby2_keywords(:method_missing)
         | 
| 180 | 
            +
             | 
| 181 | 
            +
                    def respond_to_missing?(name, _)
         | 
| 182 | 
            +
                      super || instance.respond_to?(name)
         | 
| 183 | 
            +
                    end
         | 
| 184 | 
            +
                end
         | 
| 185 | 
            +
             | 
| 186 | 
            +
                attr_accessor :attributes
         | 
| 187 | 
            +
             | 
| 188 | 
            +
                def initialize
         | 
| 189 | 
            +
                  @attributes = {}
         | 
| 190 | 
            +
                end
         | 
| 191 | 
            +
             | 
| 192 | 
            +
                # Expose one or more attributes within a block. Old values are returned after the block concludes.
         | 
| 193 | 
            +
                # Example demonstrating the common use of needing to set Current attributes outside the request-cycle:
         | 
| 194 | 
            +
                #
         | 
| 195 | 
            +
                #   class Chat::PublicationJob < ApplicationJob
         | 
| 196 | 
            +
                #     def perform(attributes, room_number, creator)
         | 
| 197 | 
            +
                #       Current.set(person: creator) do
         | 
| 198 | 
            +
                #         Chat::Publisher.publish(attributes: attributes, room_number: room_number)
         | 
| 199 | 
            +
                #       end
         | 
| 200 | 
            +
                #     end
         | 
| 201 | 
            +
                #   end
         | 
| 202 | 
            +
                def set(set_attributes)
         | 
| 203 | 
            +
                  old_attributes = compute_attributes(set_attributes.keys)
         | 
| 204 | 
            +
                  assign_attributes(set_attributes)
         | 
| 205 | 
            +
                  yield
         | 
| 206 | 
            +
                ensure
         | 
| 207 | 
            +
                  assign_attributes(old_attributes)
         | 
| 208 | 
            +
                end
         | 
| 209 | 
            +
             | 
| 210 | 
            +
                # Reset all attributes. Should be called before and after actions, when used as a per-request singleton.
         | 
| 211 | 
            +
                def reset
         | 
| 212 | 
            +
                  run_callbacks :reset do
         | 
| 213 | 
            +
                    self.attributes = {}
         | 
| 214 | 
            +
                  end
         | 
| 215 | 
            +
                end
         | 
| 216 | 
            +
             | 
| 217 | 
            +
                private
         | 
| 218 | 
            +
                  def assign_attributes(new_attributes)
         | 
| 219 | 
            +
                    new_attributes.each { |key, value| public_send("#{key}=", value) }
         | 
| 220 | 
            +
                  end
         | 
| 221 | 
            +
             | 
| 222 | 
            +
                  def compute_attributes(keys)
         | 
| 223 | 
            +
                    keys.index_with { |key| public_send(key) }
         | 
| 224 | 
            +
                  end
         | 
| 225 | 
            +
              end
         | 
| 226 | 
            +
            end
         | 
| @@ -1,3 +1,5 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 1 3 | 
             
            require "active_support/inflector/methods"
         | 
| 2 4 |  | 
| 3 5 | 
             
            module ActiveSupport
         | 
| @@ -67,7 +69,7 @@ module ActiveSupport | |
| 67 69 | 
             
                end
         | 
| 68 70 |  | 
| 69 71 | 
             
                def eager_load!
         | 
| 70 | 
            -
                  @_autoloads. | 
| 72 | 
            +
                  @_autoloads.each_value { |file| require file }
         | 
| 71 73 | 
             
                end
         | 
| 72 74 |  | 
| 73 75 | 
             
                def autoloads
         | 
| @@ -0,0 +1,49 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require "active_support/concurrency/share_lock"
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            module ActiveSupport # :nodoc:
         | 
| 6 | 
            +
              module Dependencies # :nodoc:
         | 
| 7 | 
            +
                class Interlock
         | 
| 8 | 
            +
                  def initialize # :nodoc:
         | 
| 9 | 
            +
                    @lock = ActiveSupport::Concurrency::ShareLock.new
         | 
| 10 | 
            +
                  end
         | 
| 11 | 
            +
             | 
| 12 | 
            +
                  def loading(&block)
         | 
| 13 | 
            +
                    @lock.exclusive(purpose: :load, compatible: [:load], after_compatible: [:load], &block)
         | 
| 14 | 
            +
                  end
         | 
| 15 | 
            +
             | 
| 16 | 
            +
                  def unloading(&block)
         | 
| 17 | 
            +
                    @lock.exclusive(purpose: :unload, compatible: [:load, :unload], after_compatible: [:load, :unload], &block)
         | 
| 18 | 
            +
                  end
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                  def start_unloading
         | 
| 21 | 
            +
                    @lock.start_exclusive(purpose: :unload, compatible: [:load, :unload])
         | 
| 22 | 
            +
                  end
         | 
| 23 | 
            +
             | 
| 24 | 
            +
                  def done_unloading
         | 
| 25 | 
            +
                    @lock.stop_exclusive(compatible: [:load, :unload])
         | 
| 26 | 
            +
                  end
         | 
| 27 | 
            +
             | 
| 28 | 
            +
                  def start_running
         | 
| 29 | 
            +
                    @lock.start_sharing
         | 
| 30 | 
            +
                  end
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                  def done_running
         | 
| 33 | 
            +
                    @lock.stop_sharing
         | 
| 34 | 
            +
                  end
         | 
| 35 | 
            +
             | 
| 36 | 
            +
                  def running(&block)
         | 
| 37 | 
            +
                    @lock.sharing(&block)
         | 
| 38 | 
            +
                  end
         | 
| 39 | 
            +
             | 
| 40 | 
            +
                  def permit_concurrent_loads(&block)
         | 
| 41 | 
            +
                    @lock.yield_shares(compatible: [:load], &block)
         | 
| 42 | 
            +
                  end
         | 
| 43 | 
            +
             | 
| 44 | 
            +
                  def raw_state(&block) # :nodoc:
         | 
| 45 | 
            +
                    @lock.raw_state(&block)
         | 
| 46 | 
            +
                  end
         | 
| 47 | 
            +
                end
         | 
| 48 | 
            +
              end
         | 
| 49 | 
            +
            end
         | 
| @@ -0,0 +1,28 @@ | |
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            module ActiveSupport::Dependencies::RequireDependency
         | 
| 4 | 
            +
              # <b>Warning:</b> This method is obsolete. The semantics of the autoloader
         | 
| 5 | 
            +
              # match Ruby's and you do not need to be defensive with load order anymore.
         | 
| 6 | 
            +
              # Just refer to classes and modules normally.
         | 
| 7 | 
            +
              #
         | 
| 8 | 
            +
              # Engines that do not control the mode in which their parent application runs
         | 
| 9 | 
            +
              # should call +require_dependency+ where needed in case the runtime mode is
         | 
| 10 | 
            +
              # +:classic+.
         | 
| 11 | 
            +
              def require_dependency(filename)
         | 
| 12 | 
            +
                filename = filename.to_path if filename.respond_to?(:to_path)
         | 
| 13 | 
            +
             | 
| 14 | 
            +
                unless filename.is_a?(String)
         | 
| 15 | 
            +
                  raise ArgumentError, "the file name must be either a String or implement #to_path -- you passed #{filename.inspect}"
         | 
| 16 | 
            +
                end
         | 
| 17 | 
            +
             | 
| 18 | 
            +
                if abspath = ActiveSupport::Dependencies.search_for_file(filename)
         | 
| 19 | 
            +
                  require abspath
         | 
| 20 | 
            +
                else
         | 
| 21 | 
            +
                  require filename
         | 
| 22 | 
            +
                end
         | 
| 23 | 
            +
              end
         | 
| 24 | 
            +
             | 
| 25 | 
            +
              # We could define require_dependency in Object directly, but a module makes
         | 
| 26 | 
            +
              # the extension apparent if you list ancestors.
         | 
| 27 | 
            +
              Object.prepend(self)
         | 
| 28 | 
            +
            end
         |