mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
c81af6ae72
We sometimes say "✂️ newline after `private`" in a code review (e.g. https://github.com/rails/rails/pull/18546#discussion_r23188776, https://github.com/rails/rails/pull/34832#discussion_r244847195). Now `Layout/EmptyLinesAroundAccessModifier` cop have new enforced style `EnforcedStyle: only_before` (https://github.com/rubocop-hq/rubocop/pull/7059). That cop and enforced style will reduce the our code review cost.
33 lines
863 B
Ruby
33 lines
863 B
Ruby
# frozen_string_literal: true
|
|
|
|
module ActiveSupport
|
|
# Wrapping a string in this class gives you a prettier way to test
|
|
# for equality. The value returned by <tt>Rails.env</tt> is wrapped
|
|
# in a StringInquirer object, so instead of calling this:
|
|
#
|
|
# Rails.env == 'production'
|
|
#
|
|
# you can call this:
|
|
#
|
|
# Rails.env.production?
|
|
#
|
|
# == Instantiating a new StringInquirer
|
|
#
|
|
# vehicle = ActiveSupport::StringInquirer.new('car')
|
|
# vehicle.car? # => true
|
|
# vehicle.bike? # => false
|
|
class StringInquirer < String
|
|
private
|
|
def respond_to_missing?(method_name, include_private = false)
|
|
(method_name[-1] == "?") || super
|
|
end
|
|
|
|
def method_missing(method_name, *arguments)
|
|
if method_name[-1] == "?"
|
|
self == method_name[0..-2]
|
|
else
|
|
super
|
|
end
|
|
end
|
|
end
|
|
end
|