Module: VestalVersions::Control::InstanceMethods

Defined in:
lib/vestal_versions/control.rb

Overview

Control blocks are called on ActiveRecord::Base instances as to not cause any conflict with other instances of the versioned class whose behavior could be inadvertently altered within a control block.

Instance Method Summary collapse

Instance Method Details

#append_versionObject

Appending versions with the append_version block acts similarly to the merge_version block in that all would-be version creations within the block are defered until the block closes. The major difference is that with append_version, a new version is not created. Rather, the cumulative changes are appended to the serialized changes of the instance’s last version. A new version is not created, so the version number is not incremented.

Example

user = User.find_by_first_name("Steve")
user.version # => 2
user.versions.last.changes
# => {"first_name" => ["Stephen", "Steve"]}
user.append_version do
  user.last_name = "Jobs"
end
user.versions.last.changes
# => {"first_name" => ["Stephen", "Steve"], "last_name" => ["Richert", "Jobs"]}
user.version # => 2

See VestalVersions::Changes for an explanation on how changes are appended.



118
119
120
121
122
123
124
125
126
# File 'lib/vestal_versions/control.rb', line 118

def append_version
  with_version_flag(:merge_version) do
    yield if block_given?
  end

  with_version_flag(:append_version) do
    save
  end
end

#append_version!Object

Behaving almost identically to the append_version block, the only difference with the append_version! block is that the save automatically performed at the close of the block is a save!, meaning that an exception will be raised if the object cannot be saved.



131
132
133
134
135
136
137
138
139
# File 'lib/vestal_versions/control.rb', line 131

def append_version!
  with_version_flag(:merge_version) do
    yield if block_given?
  end

  with_version_flag(:append_version) do
    save!
  end
end

#append_version?Boolean

A convenience method for determining whether a versioned instance is set to append its next version’s changes into the last version changes.

Returns:

  • (Boolean)


143
144
145
# File 'lib/vestal_versions/control.rb', line 143

def append_version?
  !!@append_version
end

#merge_versionObject

Merging versions with the merge_version block will take all of the versions that would be created within the block and merge them into one version and pushing that single version onto the ActiveRecord::Base instance’s version history. A new version will be created and the instance’s version number will be incremented.

Example

user = User.find_by_first_name("Steve")
user.version # => 1
user.merge_version do
  user.update_attributes(:first_name => "Steven", :last_name => "Tyler")
  user.update_attribute(:first_name, "Stephen")
  user.update_attribute(:last_name, "Richert")
end
user.version # => 2
user.versions.last.changes
# => {"first_name" => ["Steve", "Stephen"], "last_name" => ["Jobs", "Richert"]}

See VestalVersions::Changes for an explanation on how changes are appended.



75
76
77
78
79
80
# File 'lib/vestal_versions/control.rb', line 75

def merge_version
  with_version_flag(:merge_version) do
    yield if block_given?
  end
  save
end

#merge_version!Object

Behaving almost identically to the merge_version block, the only difference with the merge_version! block is that the save automatically performed at the close of the block is a save!, meaning that an exception will be raised if the object cannot be saved.



85
86
87
88
89
90
# File 'lib/vestal_versions/control.rb', line 85

def merge_version!
  with_version_flag(:merge_version) do
    yield if block_given?
  end
  save!
end

#merge_version?Boolean

A convenience method for determining whether a versioned instance is set to merge its next versions into one before version creation.

Returns:

  • (Boolean)


94
95
96
# File 'lib/vestal_versions/control.rb', line 94

def merge_version?
  !!@merge_version
end

#skip_versionObject

The skip_version block simply allows for updates to be made to an instance of a versioned ActiveRecord model while ignoring all new version creation. The :if and :unless conditions (if given) will not be evaulated inside a skip_version block.

When the block closes, the instance is automatically saved, so explicitly saving the object within the block is unnecessary.

Example

user = User.find_by_first_name("Steve")
user.version # => 1
user.skip_version do
  user.first_name = "Stephen"
end
user.version # => 1


33
34
35
36
37
38
# File 'lib/vestal_versions/control.rb', line 33

def skip_version
  with_version_flag(:skip_version) do
    yield if block_given?
    save
  end
end

#skip_version!Object

Behaving almost identically to the skip_version block, the only difference with the skip_version! block is that the save automatically performed at the close of the block is a save!, meaning that an exception will be raised if the object cannot be saved.



43
44
45
46
47
48
# File 'lib/vestal_versions/control.rb', line 43

def skip_version!
  with_version_flag(:skip_version) do
    yield if block_given?
    save!
  end
end

#skip_version?Boolean

A convenience method for determining whether a versioned instance is set to skip its next version creation.

Returns:

  • (Boolean)


52
53
54
# File 'lib/vestal_versions/control.rb', line 52

def skip_version?
  !!@skip_version
end