instance method
safe_constantize
Ruby on Rails 7.0.10
Since v3.2.22.5Signature
safe_constantize(camel_cased_word)
Tries to find a constant with the name specified in the argument string.
safe_constantize('Module') # => Module safe_constantize('Foo::Bar') # => Foo::Bar
The name is assumed to be the one of a top-level constant, no matter whether it starts with “::” or not. No lexical context is taken into account:
C = 'outside' module M C = 'inside' C # => 'inside' safe_constantize('C') # => 'outside', same as ::C end
nil is returned when the name is not in CamelCase or the constant (or part of it) is unknown.
safe_constantize('blargle') # => nil safe_constantize('UnknownModule') # => nil safe_constantize('UnknownModule::Foo::Bar') # => nil
Parameters
-
camel_cased_wordreq
Source
# File activesupport/lib/active_support/inflector/methods.rb, line 303
def safe_constantize(camel_cased_word)
constantize(camel_cased_word)
rescue NameError => e
raise if e.name && !(camel_cased_word.to_s.split("::").include?(e.name.to_s) ||
e.name.to_s == camel_cased_word.to_s)
rescue LoadError => e
message = e.respond_to?(:original_message) ? e.original_message : e.message
raise unless /Unable to autoload constant #{const_regexp(camel_cased_word)}/.match?(message)
end
Defined in activesupport/lib/active_support/inflector/methods.rb line 303
· View on GitHub
· Improve this page
· Find usages on GitHub
Defined in ActiveSupport::Inflector