Concurrent Revisions is a concurrency control model designed to guarantee determinacy, meaning that each forked task gets a conceptual copy of all the shared state, and state changes are integrated only when tasks are joined, at which time write-write conflicts are deterministically resolved.
Clone repository manually:
git clone https://github.com/TobiasGSmollett/concurrent_revisions.cr && cd concurrent_revisions.cr/
Or add the dependency to your shard.yml
:
dependencies:
concurrent_revisions:
github: TobiasGSmollett/concurrent_revisions.cr
Run shards install
.
The fastest way to try it is by using Crystal Playground (crystal play):
require "concurrent_revisions"
include ConcurrentRevisions
x = Versioned(Int32).new(0)
y = Versioned(Int32).new(0)
r : Revision = rfork do
x.set(1)
rfork { }
x.set(y.get)
end
x.set(2)
rjoin(r)
puts "#{x.get} #{y.get}" # => 0 0
- Fork it (https://github.com/TobiasGSmollett/concurrent_revisions/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- tobya - creator and maintainer