atomic 1.1.14-java → 1.1.15-java

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 72564326160408e9f9482ab514bc775b18f43cab
4
+ data.tar.gz: aa84d58c559365ae4f0601eaf7ce917ffa3e1075
5
+ SHA512:
6
+ metadata.gz: b2b44325c91f4cc74e3c38c0b99d3744a89bbbb88eee3119b294ecc87cbdc7a874fd387674329ba94b17e14d26c1f5b97ae1aba2366cce65872d3e162dad0b6f
7
+ data.tar.gz: 94ae3147e24a4f0f41f4c3d1554bb3739cb528783214e070f885733ed499ae5c1d70e98d483666d6238bbfa9d131a5154340835da67f3f91014c8246dabf68d5
@@ -3,8 +3,8 @@ rvm:
3
3
  - 2.0.0
4
4
  - 1.9.3
5
5
  - 1.8.7
6
- # Because we need JDK8 to build, these are disabled temporarily
7
- # - jruby-18mode # JRuby in 1.8 mode
8
- # - jruby-19mode # JRuby in 1.9 mode
9
- - rbx-18mode
10
- - rbx-19mode
6
+ - jruby-18mode # JRuby in 1.8 mode
7
+ - jruby-19mode # JRuby in 1.9 mode
8
+ - rbx-2
9
+ jdk:
10
+ - oraclejdk8
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source "https://rubygems.org"
2
+
3
+ gem 'rake-compiler'
4
+ gem 'minitest', :group => :development
data/README.md CHANGED
@@ -9,8 +9,8 @@ This library provides:
9
9
 
10
10
  The Atomic class provides accessors for the contained "value" plus two update methods:
11
11
 
12
- * update will run the provided block, passing the current value and replacing it with the block result iff the value has not been changed in the mean time. It may run the block repeatedly if there are other concurrent updates in progress.
13
- * try_update will run the provided block, passing the current value and replacing it with the block result. If the value changes before the update can happen, it will throw Atomic::ConcurrentUpdateError.
12
+ * update will run the provided block, passing the current value and replacing it with the block result if the value has not been changed in the meantime. It may run the block repeatedly if there are other concurrent updates in progress.
13
+ * try_update will run the provided block, passing the current value and replacing it with the block result. If the value changes before the update can happen, it will throw an Atomic::ConcurrentUpdateError.
14
14
 
15
15
  The atomic repository is at http://github.com/headius/ruby-atomic.
16
16
 
@@ -21,24 +21,28 @@ The simplest way to use "atomic" is to call the "update" or "try_update" methods
21
21
 
22
22
  "try_update" and "update" both call the given block, passing the current value and using the block's result as the new value. If the value is updated by another thread before the block completes, "try update" raises a ConcurrentUpdateError and "update" retries the block. Because "update" may call the block several times when multiple threads are all updating the same value, the block's logic should be kept as simple as possible.
23
23
 
24
- require 'atomic'
24
+ ```ruby
25
+ require 'atomic'
25
26
 
26
- my_atomic = Atomic.new(0)
27
- my_atomic.update {|v| v + 1}
28
- begin
29
- my_atomic.try_update {|v| v + 1}
30
- rescue Atomic::ConcurrentUpdateError => cue
31
- # deal with it (retry, propagate, etc)
32
- end
27
+ my_atomic = Atomic.new(0)
28
+ my_atomic.update {|v| v + 1}
29
+ begin
30
+ my_atomic.try_update {|v| v + 1}
31
+ rescue Atomic::ConcurrentUpdateError => cue
32
+ # deal with it (retry, propagate, etc)
33
+ end
34
+ ```
33
35
 
34
36
  It's also possible to use the regular get/set operations on the Atomic, if you want to avoid the exception and respond to contended changes in some other way.
35
37
 
36
- my_atomic = Atomic.new(0)
37
- my_atomic.value # => 0
38
- my_atomic.value = 1
39
- my_atomic.swap(2) # => 1
40
- my_atomic.compare_and_swap(2, 3) # => true, updated to 3
41
- my_atomic.compare_and_swap(2, 3) # => false, current is not 2
38
+ ```ruby
39
+ my_atomic = Atomic.new(0)
40
+ my_atomic.value # => 0
41
+ my_atomic.value = 1
42
+ my_atomic.swap(2) # => 1
43
+ my_atomic.compare_and_swap(2, 3) # => true, updated to 3
44
+ my_atomic.compare_and_swap(2, 3) # => false, current is not 2
45
+ ```
42
46
 
43
47
  Building
44
48
  ========
data/Rakefile CHANGED
@@ -39,27 +39,25 @@ if defined?(JRUBY_VERSION)
39
39
  end
40
40
 
41
41
  desc "Compile the extension"
42
- task :compile => "pkg/classes" do |t|
42
+ task :compile_java => "pkg/classes" do |t|
43
43
  ant.javac :srcdir => "ext", :destdir => t.prerequisites.first,
44
44
  :source => "1.5", :target => "1.5", :debug => true,
45
45
  :classpath => "${java.class.path}:${sun.boot.class.path}"
46
46
  end
47
47
 
48
48
  desc "Build the jar"
49
- task :jar => :compile do
49
+ task :jar => :compile_java do
50
50
  ant.jar :basedir => "pkg/classes", :destfile => "lib/atomic_reference.jar", :includes => "**/*.class"
51
51
  end
52
52
 
53
- task :package => :jar
53
+ task :compile => :jar
54
54
  else
55
- task :package do
56
- Dir.chdir("ext") do
57
- # this does essentially the same thing
58
- # as what RubyGems does
59
- ruby "extconf.rb"
60
- sh "make"
61
- end
55
+ require "rake/extensiontask"
56
+ Rake::ExtensionTask.new "atomic" do |ext|
57
+ ext.ext_dir = 'ext'
58
+ ext.name ='atomic_reference'
62
59
  end
63
60
  end
64
61
 
65
- task :test => :package
62
+ task :package => :compile
63
+ task :test => :compile
@@ -4,7 +4,7 @@
4
4
 
5
5
  Gem::Specification.new do |s|
6
6
  s.name = %q{atomic}
7
- s.version = "1.1.14"
7
+ s.version = "1.1.15"
8
8
  s.authors = ["Charles Oliver Nutter", "MenTaLguY", "Sokolov Yura"]
9
9
  s.date = Time.now.strftime('%Y-%m-%d')
10
10
  s.summary = "An atomic reference implementation for JRuby, Rubinius, and MRI"
@@ -15,6 +15,10 @@
15
15
  #include <atomic.h>
16
16
  #endif
17
17
 
18
+ #ifdef HAVE_LIBKERN_OSATOMIC_H
19
+ #include <libkern/OSAtomic.h>
20
+ #endif
21
+
18
22
  static void ir_mark(void *value) {
19
23
  rb_gc_mark_maybe((VALUE) value);
20
24
  }
@@ -67,12 +71,18 @@ static VALUE ir_compare_and_set(volatile VALUE self, VALUE expect_value, VALUE n
67
71
  return Qtrue;
68
72
  }
69
73
  #endif
70
- #elif HAVE_GCC_CAS
71
- if (__sync_bool_compare_and_swap(&DATA_PTR(self), expect_value, new_value)) {
74
+ #elif defined _MSC_VER && defined _M_AMD64
75
+ if (InterlockedCompareExchange64((LONGLONG*)&DATA_PTR(self), new_value, expect_value)) {
76
+ return Qtrue;
77
+ }
78
+ #elif defined _MSC_VER && defined _M_IX86
79
+ if (InterlockedCompareExchange((LONG*)&DATA_PTR(self), new_value, expect_value)) {
72
80
  return Qtrue;
73
81
  }
74
82
  #else
75
- #error No CAS operation available for this platform
83
+ if (__sync_bool_compare_and_swap(&DATA_PTR(self), expect_value, new_value)) {
84
+ return Qtrue;
85
+ }
76
86
  #endif
77
87
  return Qfalse;
78
88
  }
@@ -14,6 +14,8 @@ require 'mkmf'
14
14
  extension_name = 'atomic_reference'
15
15
  dir_config(extension_name)
16
16
 
17
+ have_header "libkern/OSAtomic.h"
18
+
17
19
  if CONFIG["GCC"] && CONFIG["GCC"] != ""
18
20
  case CONFIG["arch"]
19
21
  when /mswin32|mingw|solaris/
@@ -10,10 +10,10 @@
10
10
  # See the License for the specific language governing permissions and
11
11
  # limitations under the License.
12
12
 
13
- require 'test/unit'
13
+ require 'minitest/autorun'
14
14
  require 'atomic'
15
15
 
16
- class TestAtomic < Test::Unit::TestCase
16
+ class TestAtomic < MiniTest::Test
17
17
  def test_construct
18
18
  atomic = Atomic.new
19
19
  assert_equal nil, atomic.value
@@ -58,7 +58,7 @@ class TestAtomic < Test::Unit::TestCase
58
58
  def test_try_update_fails
59
59
  # use a number outside JRuby's fixnum cache range, to ensure identity is preserved
60
60
  atomic = Atomic.new(1000)
61
- assert_raise Atomic::ConcurrentUpdateError do
61
+ assert_raises Atomic::ConcurrentUpdateError do
62
62
  # assigning within block exploits implementation detail for test
63
63
  atomic.try_update{|v| atomic.value = 1001 ; v + 1}
64
64
  end
metadata CHANGED
@@ -1,8 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: atomic
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.14
5
- prerelease:
4
+ version: 1.1.15
6
5
  platform: java
7
6
  authors:
8
7
  - Charles Oliver Nutter
@@ -11,7 +10,7 @@ authors:
11
10
  autorequire:
12
11
  bindir: bin
13
12
  cert_chain: []
14
- date: 2013-09-10 00:00:00.000000000 Z
13
+ date: 2014-02-26 00:00:00.000000000 Z
15
14
  dependencies: []
16
15
  description: An atomic reference implementation for JRuby, Rubinius, and MRI
17
16
  email:
@@ -22,10 +21,9 @@ executables: []
22
21
  extensions: []
23
22
  extra_rdoc_files: []
24
23
  files:
25
- - lib/atomic_reference.jar
26
- - test/test_atomic.rb
27
- - .gitignore
28
- - .travis.yml
24
+ - ".gitignore"
25
+ - ".travis.yml"
26
+ - Gemfile
29
27
  - LICENSE
30
28
  - README.md
31
29
  - Rakefile
@@ -47,30 +45,31 @@ files:
47
45
  - lib/atomic/numeric_cas_wrapper.rb
48
46
  - lib/atomic/rbx.rb
49
47
  - lib/atomic/ruby.rb
48
+ - lib/atomic_reference.jar
49
+ - test/test_atomic.rb
50
50
  homepage: http://github.com/headius/ruby-atomic
51
51
  licenses:
52
52
  - Apache-2.0
53
+ metadata: {}
53
54
  post_install_message:
54
55
  rdoc_options: []
55
56
  require_paths:
56
57
  - lib
57
58
  required_ruby_version: !ruby/object:Gem::Requirement
58
59
  requirements:
59
- - - '>='
60
+ - - ">="
60
61
  - !ruby/object:Gem::Version
61
62
  version: '0'
62
- none: false
63
63
  required_rubygems_version: !ruby/object:Gem::Requirement
64
64
  requirements:
65
- - - '>='
65
+ - - ">="
66
66
  - !ruby/object:Gem::Version
67
67
  version: '0'
68
- none: false
69
68
  requirements: []
70
69
  rubyforge_project:
71
- rubygems_version: 1.8.24
70
+ rubygems_version: 2.2.2
72
71
  signing_key:
73
- specification_version: 3
72
+ specification_version: 4
74
73
  summary: An atomic reference implementation for JRuby, Rubinius, and MRI
75
74
  test_files:
76
75
  - test/test_atomic.rb