aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib/rails/generators/model_helpers.rb
diff options
context:
space:
mode:
authorRafael França <rafaelmfranca@gmail.com>2018-08-31 14:22:01 -0500
committerGitHub <noreply@github.com>2018-08-31 14:22:01 -0500
commite28725cfa6f87408e1560c4329b2d807456b1ce6 (patch)
treedf729a5b2ecf281b422aa883af12ff33f33db951 /railties/lib/rails/generators/model_helpers.rb
parent12fadea8aee3981654149d6e8ff5099bca31c679 (diff)
parentae6adf98cc3d6ac085c9c6a4887dad65f3c4be17 (diff)
downloadrails-e28725cfa6f87408e1560c4329b2d807456b1ce6.tar.gz
rails-e28725cfa6f87408e1560c4329b2d807456b1ce6.tar.bz2
rails-e28725cfa6f87408e1560c4329b2d807456b1ce6.zip
Merge pull request #33766 from yskkin/warn_plural
Emit warning for unknown inflection rule when generating model.
Diffstat (limited to 'railties/lib/rails/generators/model_helpers.rb')
-rw-r--r--railties/lib/rails/generators/model_helpers.rb9
1 files changed, 8 insertions, 1 deletions
diff --git a/railties/lib/rails/generators/model_helpers.rb b/railties/lib/rails/generators/model_helpers.rb
index 50078404b3..3676432d5c 100644
--- a/railties/lib/rails/generators/model_helpers.rb
+++ b/railties/lib/rails/generators/model_helpers.rb
@@ -7,6 +7,10 @@ module Rails
module ModelHelpers # :nodoc:
PLURAL_MODEL_NAME_WARN_MESSAGE = "[WARNING] The model name '%s' was recognized as a plural, using the singular '%s' instead. " \
"Override with --force-plural or setup custom inflection rules for this noun before running the generator."
+ IRREGULAR_MODEL_NAME_WARN_MESSAGE = <<~WARNING
+ [WARNING] Rails cannot recover singular form from its plural form '%s'.
+ Please setup custom inflection rules for this noun before running the generator in config/initializers/inflections.rb.
+ WARNING
mattr_accessor :skip_warn
def self.included(base) #:nodoc:
@@ -19,11 +23,14 @@ module Rails
singular = name.singularize
unless ModelHelpers.skip_warn
say PLURAL_MODEL_NAME_WARN_MESSAGE % [name, singular]
- ModelHelpers.skip_warn = true
end
name.replace singular
assign_names!(name)
end
+ if name.singularize != name.pluralize.singularize && ! ModelHelpers.skip_warn
+ say IRREGULAR_MODEL_NAME_WARN_MESSAGE % [name.pluralize]
+ end
+ ModelHelpers.skip_warn = true
end
end
end