module ActiveSupport::Deprecation::InstanceDelegator::ClassMethods
def _instance
def _instance @_instance ||= MUTEX.synchronize { @_instance ||= new } end
def include(included_module)
def include(included_module) included_module.instance_methods.each { |m| method_added(m) } super end
def instance
def instance ActiveSupport.deprecator.warn("ActiveSupport::Deprecation.instance is deprecated (use your own Deprecation object)") _instance end
def method_added(method_name)
def method_added(method_name) use_instead = case method_name when :silence, :behavior=, :disallowed_behavior=, :disallowed_warnings=, :silenced=, :debug= target = "(defined?(Rails.application.deprecators) ? Rails.application.deprecators : ActiveSupport::Deprecation._instance)" "Rails.application.deprecators.#{method_name}" when :warn, :deprecate_methods, :gem_name, :gem_name=, :deprecation_horizon, :deprecation_horizon= "your own Deprecation object" else "Rails.application.deprecators[framework].#{method_name} where framework is for example :active_record" end args = /[^\]]=\z/.match?(method_name) ? "arg" : "..." target ||= "ActiveSupport::Deprecation._instance" singleton_class.module_eval <<~RUBY, __FILE__, __LINE__ + 1 def #{method_name}(#{args}) #{target}.#{method_name}(#{args}) ensure ActiveSupport.deprecator.warn("Calling #{method_name} on ActiveSupport::Deprecation is deprecated and will be removed from Rails (use #{use_instead} instead)") end RUBY end