Module: Mongoid::Extensions::String
- Defined in:
- lib/mongoid/extensions/string.rb
Defined Under Namespace
Modules: ClassMethods
Instance Attribute Summary collapse
-
#unconvertable_to_bson ⇒ Object
Returns the value of attribute unconvertable_to_bson.
- #unconvertable_to_bson If the document is unconvertable.(Ifthedocumentisunconvertable.) ⇒ Object
Instance Method Summary collapse
-
#__evolve_object_id__ ⇒ String, BSON::ObjectId
Evolve the string into an object id if possible.
-
#__mongoize_object_id__ ⇒ String, ...
Mongoize the string into an object id if possible.
-
#__mongoize_time__ ⇒ Time | ActiveSupport::TimeWithZone
Mongoize the string for storage.
-
#before_type_cast? ⇒ true, false
Does the string end with _before_type_cast?.
-
#collectionize ⇒ String
Convert the string to a collection friendly name.
-
#mongoid_id? ⇒ true, false
Is the string a valid value for a Mongoid id?.
-
#numeric? ⇒ true, false
Is the string a number? The literals “NaN”, “Infinity”, and “-Infinity” are counted as numbers.
-
#reader ⇒ String
Get the string as a getter string.
-
#unconvertable_to_bson? ⇒ true, false
Is the object not to be converted to bson on criteria creation?.
-
#valid_method_name? ⇒ true, false
Is this string a valid_method_name?.
-
#writer? ⇒ true, false
Is this string a writer?.
Instance Attribute Details
#unconvertable_to_bson ⇒ Object
Returns the value of attribute unconvertable_to_bson.
9 10 11 |
# File 'lib/mongoid/extensions/string.rb', line 9 def unconvertable_to_bson @unconvertable_to_bson end |
#unconvertable_to_bson If the document is unconvertable.(Ifthedocumentisunconvertable.) ⇒ Object
9 |
# File 'lib/mongoid/extensions/string.rb', line 9 attr_accessor :unconvertable_to_bson |
Instance Method Details
#__evolve_object_id__ ⇒ String, BSON::ObjectId
Evolve the string into an object id if possible.
19 20 21 |
# File 'lib/mongoid/extensions/string.rb', line 19 def __evolve_object_id__ convert_to_object_id end |
#__mongoize_object_id__ ⇒ String, ...
Mongoize the string into an object id if possible.
31 32 33 |
# File 'lib/mongoid/extensions/string.rb', line 31 def __mongoize_object_id__ convert_to_object_id unless blank? end |
#__mongoize_time__ ⇒ Time | ActiveSupport::TimeWithZone
Returns a local time in the default time zone.
Mongoize the string for storage.
47 48 49 50 51 52 53 54 55 56 57 58 |
# File 'lib/mongoid/extensions/string.rb', line 47 def __mongoize_time__ # This extra parse from Time is because ActiveSupport::TimeZone # either returns nil or Time.now if the string is empty or invalid, # which is a regression from pre-3.0 and also does not agree with # the core Time API. parsed = ::Time.parse(self) if ::Time == ::Time.configured parsed else ::Time.configured.parse(self) end end |
#before_type_cast? ⇒ true, false
Does the string end with _before_type_cast?
143 144 145 |
# File 'lib/mongoid/extensions/string.rb', line 143 def before_type_cast? ends_with?("_before_type_cast") end |
#collectionize ⇒ String
Convert the string to a collection friendly name.
68 69 70 |
# File 'lib/mongoid/extensions/string.rb', line 68 def collectionize tableize.gsub("/", "_") end |
#mongoid_id? ⇒ true, false
Is the string a valid value for a Mongoid id?
80 81 82 |
# File 'lib/mongoid/extensions/string.rb', line 80 def mongoid_id? self =~ /\A(|_)id\z/ end |
#numeric? ⇒ true, false
Is the string a number? The literals “NaN”, “Infinity”, and “-Infinity” are counted as numbers.
93 94 95 96 97 |
# File 'lib/mongoid/extensions/string.rb', line 93 def numeric? !!Float(self) rescue ArgumentError (self =~ /\A(?:NaN|-?Infinity)\z/) == 0 end |
#reader ⇒ String
Get the string as a getter string.
107 108 109 |
# File 'lib/mongoid/extensions/string.rb', line 107 def reader delete("=").sub(/\_before\_type\_cast\z/, '') end |
#unconvertable_to_bson? ⇒ true, false
Is the object not to be converted to bson on criteria creation?
155 156 157 |
# File 'lib/mongoid/extensions/string.rb', line 155 def unconvertable_to_bson? @unconvertable_to_bson ||= false end |
#valid_method_name? ⇒ true, false
Is this string a valid_method_name?
131 132 133 |
# File 'lib/mongoid/extensions/string.rb', line 131 def valid_method_name? /[@$"-]/ !~ self end |
#writer? ⇒ true, false
Is this string a writer?
119 120 121 |
# File 'lib/mongoid/extensions/string.rb', line 119 def writer? include?("=") end |