Module: CouchPotato::Persistence::DirtyAttributes
- Defined in:
- lib/couch_potato/persistence/dirty_attributes.rb
Class Method Summary collapse
-
.included(base) ⇒ Object
:nodoc:.
Instance Method Summary collapse
-
#dirty? ⇒ Boolean
returns true if a model has dirty attributes, i.e.
- #initialize(attributes = {}) ⇒ Object
-
#is_dirty ⇒ Object
marks a model as dirty.
Class Method Details
.included(base) ⇒ Object
:nodoc:
6 7 8 9 10 |
# File 'lib/couch_potato/persistence/dirty_attributes.rb', line 6 def self.included(base) #:nodoc: base.class_eval do after_save :reset_dirty_attributes end end |
Instance Method Details
#dirty? ⇒ Boolean
returns true if a model has dirty attributes, i.e. their value has changed since the last save
18 19 20 21 22 |
# File 'lib/couch_potato/persistence/dirty_attributes.rb', line 18 def dirty? new? || @forced_dirty || self.class.properties.inject(false) do |res, property| res || property.dirty?(self) end end |
#initialize(attributes = {}) ⇒ Object
12 13 14 15 |
# File 'lib/couch_potato/persistence/dirty_attributes.rb', line 12 def initialize(attributes = {}) super assign_attribute_copies_for_dirty_tracking end |
#is_dirty ⇒ Object
marks a model as dirty
25 26 27 |
# File 'lib/couch_potato/persistence/dirty_attributes.rb', line 25 def is_dirty @forced_dirty = true end |