concurrent-ruby 0.8.0.pre1-java → 0.8.0.pre2-java
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/CHANGELOG.md +1 -0
- data/README.md +47 -12
- data/lib/concurrent/atomic/semaphore.rb +232 -0
- data/lib/concurrent/atomics.rb +2 -0
- data/lib/concurrent/executor/thread_pool_executor.rb +0 -2
- data/lib/concurrent/executor/timer_set.rb +15 -3
- data/lib/concurrent/version.rb +1 -2
- data/lib/concurrent_ruby_ext.jar +0 -0
- data/lib/extension_helper.rb +10 -5
- metadata +52 -53
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: f05e002bf687416f80b224ae58618eaaabd55cda
|
4
|
+
data.tar.gz: 0189afd2a533af45e9809e870810996c9fb77f8f
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: d00c87168dff492aeb6503c648f745a95d5b1ac5cd4b27872d9c437a3fc0b5dc8d96ae2109a42ac2253dc8655d6f20516028025e5447b117d72cb7bc0c7ce656
|
7
|
+
data.tar.gz: 129a31e92dae0d916399fbf81f90bee31d5d57a7ca3e71e48aef34f704b231c5c07e339c6862e89aa0e5b2c55dcfcdfa7a80fecd15ec8b9c2c0da3715ee200ba
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,6 @@
|
|
1
1
|
### Next Release v0.7.2 (TBD)
|
2
2
|
|
3
|
+
* New `Semaphore` class based on [java.util.concurrent.Semaphore](http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/Semaphore.html)
|
3
4
|
* New `Promise.all?` and `Promise.any?` class methods
|
4
5
|
* Renamed `:overflow_policy` on thread pools to `:fallback_policy`
|
5
6
|
* Thread pools still accept the `:overflow_policy` option but display a warning
|
data/README.md
CHANGED
@@ -37,7 +37,7 @@
|
|
37
37
|
|
38
38
|
### Supported Ruby versions
|
39
39
|
|
40
|
-
MRI 1.9.3, 2.0, 2.1, JRuby (1.9 mode), and Rubinius 2.x are supported.
|
40
|
+
MRI 1.9.3, 2.0, 2.1, 2.2, JRuby (1.9 mode), and Rubinius 2.x are supported.
|
41
41
|
This gem should be fully compatible with any interpreter that is compliant with Ruby 1.9.3 or newer.
|
42
42
|
|
43
43
|
## Features & Documentation
|
@@ -52,19 +52,19 @@ This library contains a variety of concurrency abstractions at high and low leve
|
|
52
52
|
|
53
53
|
### High-level, general-purpose asynchronous concurrency abstractions
|
54
54
|
|
55
|
-
* [Actor](
|
56
|
-
* [Agent](
|
57
|
-
* [Async](
|
58
|
-
* [Future](
|
59
|
-
* [Dataflow](
|
60
|
-
* [Promise](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Promise.html): Similar to Futures, with more features.
|
61
|
-
* [ScheduledTask](
|
55
|
+
* [Actor](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Actor.html): Implements the Actor Model, where concurrent actors exchange messages.
|
56
|
+
* [Agent](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Agent.html): A single atomic value that represents an identity.
|
57
|
+
* [Async](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Async.html): A mixin module that provides simple asynchronous behavior to any standard class/object or object.
|
58
|
+
* [Future](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Future.html): An asynchronous operation that produces a value.
|
59
|
+
* [Dataflow](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Dataflow.html): Built on Futures, Dataflow allows you to create a task that will be scheduled when all of its data dependencies are available.
|
60
|
+
* [Promise](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Promise.html): Similar to Futures, with more features.
|
61
|
+
* [ScheduledTask](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/ScheduledTask.html): Like a Future scheduled for a specific future time.
|
62
62
|
* [TimerTask](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/TimerTask.html): A Thread that periodically wakes up to perform work at regular intervals.
|
63
63
|
* [Channel](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Channel.html): Communicating Sequential Processes (CSP).
|
64
64
|
|
65
65
|
### Java-inspired ThreadPools and other executors
|
66
66
|
|
67
|
-
* See [ThreadPool](
|
67
|
+
* See [ThreadPool](http://ruby-concurrency.github.io/concurrent-ruby/file.thread_pools.html) overview, which also contains a list of other Executors available.
|
68
68
|
|
69
69
|
### Thread-safe Observers
|
70
70
|
|
@@ -73,6 +73,7 @@ This library contains a variety of concurrency abstractions at high and low leve
|
|
73
73
|
* [CopyOnWriteObserverSet](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/CopyOnWriteObserverSet.html)
|
74
74
|
|
75
75
|
### Thread synchronization classes and algorithms
|
76
|
+
|
76
77
|
Lower-level abstractions mainly used as building blocks.
|
77
78
|
|
78
79
|
* [condition](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Condition.html)
|
@@ -80,10 +81,12 @@ Lower-level abstractions mainly used as building blocks.
|
|
80
81
|
* [cyclic barrier](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/CyclicBarrier.html)
|
81
82
|
* [event](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Event.html)
|
82
83
|
* [exchanger](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Exchanger.html)
|
84
|
+
* [semaphore](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/Semaphore.html)
|
83
85
|
* [timeout](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent.html#timeout-class_method)
|
84
86
|
* [timer](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent.html#timer-class_method)
|
85
87
|
|
86
88
|
### Thread-safe variables
|
89
|
+
|
87
90
|
Lower-level abstractions mainly used as building blocks.
|
88
91
|
|
89
92
|
* [AtomicBoolean](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/AtomicBoolean.html)
|
@@ -92,7 +95,7 @@ Lower-level abstractions mainly used as building blocks.
|
|
92
95
|
* [I-Structures](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/IVar.html) (IVar)
|
93
96
|
* [M-Structures](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/MVar.html) (MVar)
|
94
97
|
* [thread-local variables](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/ThreadLocalVar.html)
|
95
|
-
* [software transactional memory](
|
98
|
+
* [software transactional memory](http://ruby-concurrency.github.io/concurrent-ruby/Concurrent/TVar.html) (TVar)
|
96
99
|
|
97
100
|
## Usage
|
98
101
|
|
@@ -153,7 +156,7 @@ To minimize installation errors the C extensions are available in the `concurren
|
|
153
156
|
gem. The extension gem lists `concurrent-ruby` as a dependency so it is not necessary to install both.
|
154
157
|
Simply install the extension gen:
|
155
158
|
|
156
|
-
```
|
159
|
+
```ruby
|
157
160
|
gem install concurrent-ruby-ext
|
158
161
|
```
|
159
162
|
|
@@ -167,13 +170,45 @@ and run `bundle install` from your shell.
|
|
167
170
|
|
168
171
|
In code it is only necessary to
|
169
172
|
|
170
|
-
```
|
173
|
+
```ruby
|
171
174
|
require 'concurrent'
|
172
175
|
```
|
173
176
|
|
174
177
|
The `concurrent-ruby` gem will automatically detect the presence of the `concurrent-ruby-ext` gem
|
175
178
|
and load the appropriate C extensions.
|
176
179
|
|
180
|
+
#### Note For gem developers
|
181
|
+
|
182
|
+
No gems should depend on `concurrent-ruby-ext`. Doing so will force C extensions on your users.
|
183
|
+
The best practice is to depend on `concurrent-ruby` and let users to decide if they want C extensions.
|
184
|
+
|
185
|
+
### Building
|
186
|
+
|
187
|
+
All published versions of this gem (core, extension, and several platform-specific packages) are compiled,
|
188
|
+
packaged, tested, and published using an open, [automated process](https://github.com/ruby-concurrency/rake-compiler-dev-box).
|
189
|
+
This process can also be used to create pre-compiled binaries of the extension gem for virtally
|
190
|
+
any platform. *Documentation is forthcoming...*
|
191
|
+
|
192
|
+
```
|
193
|
+
*MRI only*
|
194
|
+
rake build:native # Build concurrent-ruby-ext-<version>-<platform>.gem into the pkg directory
|
195
|
+
rake compile:extension # Compile extension
|
196
|
+
|
197
|
+
*JRuby only*
|
198
|
+
rake build # Build JRuby-specific core gem (alias for `build:core`)
|
199
|
+
rake build:core # Build concurrent-ruby-<version>-java.gem into the pkg directory
|
200
|
+
|
201
|
+
*All except JRuby*
|
202
|
+
rake build # Build core and extension gems
|
203
|
+
rake build:core # Build concurrent-ruby-<version>.gem into the pkg directory
|
204
|
+
rake build:ext # Build concurrent-ruby-ext-<version>.gem into the pkg directory
|
205
|
+
|
206
|
+
*All*
|
207
|
+
rake clean # Remove any temporary products
|
208
|
+
rake clobber # Remove any generated file
|
209
|
+
rake compile # Compile all the extensions
|
210
|
+
```
|
211
|
+
|
177
212
|
## Maintainers
|
178
213
|
|
179
214
|
* [Jerry D'Antonio](https://github.com/jdantonio)
|
@@ -0,0 +1,232 @@
|
|
1
|
+
require 'concurrent/atomic/condition'
|
2
|
+
|
3
|
+
module Concurrent
|
4
|
+
class MutexSemaphore
|
5
|
+
# @!macro [attach] semaphore_method_initialize
|
6
|
+
#
|
7
|
+
# Create a new `Semaphore` with the initial `count`.
|
8
|
+
#
|
9
|
+
# @param [Fixnum] count the initial count
|
10
|
+
#
|
11
|
+
# @raise [ArgumentError] if `count` is not an integer or is less than zero
|
12
|
+
def initialize(count)
|
13
|
+
unless count.is_a?(Fixnum) && count >= 0
|
14
|
+
fail ArgumentError, 'count must be an non-negative integer'
|
15
|
+
end
|
16
|
+
@mutex = Mutex.new
|
17
|
+
@condition = Condition.new
|
18
|
+
@free = count
|
19
|
+
end
|
20
|
+
|
21
|
+
# @!macro [attach] semaphore_method_acquire
|
22
|
+
#
|
23
|
+
# Acquires the given number of permits from this semaphore,
|
24
|
+
# blocking until all are available.
|
25
|
+
#
|
26
|
+
# @param [Fixnum] permits Number of permits to acquire
|
27
|
+
#
|
28
|
+
# @raise [ArgumentError] if `permits` is not an integer or is less than
|
29
|
+
# one
|
30
|
+
#
|
31
|
+
# @return [Nil]
|
32
|
+
def acquire(permits = 1)
|
33
|
+
unless permits.is_a?(Fixnum) && permits > 0
|
34
|
+
fail ArgumentError, 'permits must be an integer greater than zero'
|
35
|
+
end
|
36
|
+
@mutex.synchronize do
|
37
|
+
try_acquire_timed(permits, nil)
|
38
|
+
nil
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
# @!macro [attach] semaphore_method_available_permits
|
43
|
+
#
|
44
|
+
# Returns the current number of permits available in this semaphore.
|
45
|
+
#
|
46
|
+
# @return [Integer]
|
47
|
+
def available_permits
|
48
|
+
@mutex.synchronize { @free }
|
49
|
+
end
|
50
|
+
|
51
|
+
# @!macro [attach] semaphore_method_drain_permits
|
52
|
+
#
|
53
|
+
# Acquires and returns all permits that are immediately available.
|
54
|
+
#
|
55
|
+
# @return [Integer]
|
56
|
+
def drain_permits
|
57
|
+
@mutex.synchronize do
|
58
|
+
@free.tap { |_| @free = 0 }
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
# @!macro [attach] semaphore_method_try_acquire
|
63
|
+
#
|
64
|
+
# Acquires the given number of permits from this semaphore,
|
65
|
+
# only if all are available at the time of invocation or within
|
66
|
+
# `timeout` interval
|
67
|
+
#
|
68
|
+
# @param [Fixnum] permits the number of permits to acquire
|
69
|
+
#
|
70
|
+
# @param [Fixnum] timeout the number of seconds to wait for the counter
|
71
|
+
# or `nil` to return immediately
|
72
|
+
#
|
73
|
+
# @raise [ArgumentError] if `permits` is not an integer or is less than
|
74
|
+
# one
|
75
|
+
#
|
76
|
+
# @return [Boolean] `false` if no permits are available, `true` when
|
77
|
+
# acquired a permit
|
78
|
+
def try_acquire(permits = 1, timeout = nil)
|
79
|
+
unless permits.is_a?(Fixnum) && permits > 0
|
80
|
+
fail ArgumentError, 'permits must be an integer greater than zero'
|
81
|
+
end
|
82
|
+
@mutex.synchronize do
|
83
|
+
if timeout.nil?
|
84
|
+
try_acquire_now(permits)
|
85
|
+
else
|
86
|
+
try_acquire_timed(permits, timeout)
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
# @!macro [attach] semaphore_method_release
|
92
|
+
#
|
93
|
+
# Releases the given number of permits, returning them to the semaphore.
|
94
|
+
#
|
95
|
+
# @param [Fixnum] permits Number of permits to return to the semaphore.
|
96
|
+
#
|
97
|
+
# @raise [ArgumentError] if `permits` is not a number or is less than one
|
98
|
+
#
|
99
|
+
# @return [Nil]
|
100
|
+
def release(permits = 1)
|
101
|
+
unless permits.is_a?(Fixnum) && permits > 0
|
102
|
+
fail ArgumentError, 'permits must be an integer greater than zero'
|
103
|
+
end
|
104
|
+
@mutex.synchronize do
|
105
|
+
@free += permits
|
106
|
+
permits.times { @condition.signal }
|
107
|
+
end
|
108
|
+
nil
|
109
|
+
end
|
110
|
+
|
111
|
+
# @!macro [attach] semaphore_method_reduce_permits
|
112
|
+
#
|
113
|
+
# @api private
|
114
|
+
#
|
115
|
+
# Shrinks the number of available permits by the indicated reduction.
|
116
|
+
#
|
117
|
+
# @param [Fixnum] reduction Number of permits to remove.
|
118
|
+
#
|
119
|
+
# @raise [ArgumentError] if `reduction` is not an integer or is negative
|
120
|
+
#
|
121
|
+
# @raise [ArgumentError] if `@free` - `@reduction` is less than zero
|
122
|
+
#
|
123
|
+
# @return [Nil]
|
124
|
+
def reduce_permits(reduction)
|
125
|
+
unless reduction.is_a?(Fixnum) && reduction >= 0
|
126
|
+
fail ArgumentError, 'reduction must be an non-negative integer'
|
127
|
+
end
|
128
|
+
@mutex.synchronize { @free -= reduction }
|
129
|
+
nil
|
130
|
+
end
|
131
|
+
|
132
|
+
private
|
133
|
+
|
134
|
+
def try_acquire_now(permits)
|
135
|
+
if @free >= permits
|
136
|
+
@free -= permits
|
137
|
+
true
|
138
|
+
else
|
139
|
+
false
|
140
|
+
end
|
141
|
+
end
|
142
|
+
|
143
|
+
def try_acquire_timed(permits, timeout)
|
144
|
+
remaining = Condition::Result.new(timeout)
|
145
|
+
while !try_acquire_now(permits) && remaining.can_wait?
|
146
|
+
@condition.signal
|
147
|
+
remaining = @condition.wait(@mutex, remaining.remaining_time)
|
148
|
+
end
|
149
|
+
remaining.can_wait? ? true : false
|
150
|
+
end
|
151
|
+
end
|
152
|
+
|
153
|
+
if RUBY_PLATFORM == 'java'
|
154
|
+
|
155
|
+
# @!macro semaphore
|
156
|
+
#
|
157
|
+
# A counting semaphore. Conceptually, a semaphore maintains a set of permits. Each {#acquire} blocks if necessary
|
158
|
+
# until a permit is available, and then takes it. Each {#release} adds a permit,
|
159
|
+
# potentially releasing a blocking acquirer.
|
160
|
+
# However, no actual permit objects are used; the Semaphore just keeps a count of the number available and
|
161
|
+
# acts accordingly.
|
162
|
+
class JavaSemaphore
|
163
|
+
# @!macro semaphore_method_initialize
|
164
|
+
def initialize(count)
|
165
|
+
unless count.is_a?(Fixnum) && count >= 0
|
166
|
+
fail(ArgumentError,
|
167
|
+
'count must be in integer greater than or equal zero')
|
168
|
+
end
|
169
|
+
@semaphore = java.util.concurrent.Semaphore.new(count)
|
170
|
+
end
|
171
|
+
|
172
|
+
# @!macro semaphore_method_acquire
|
173
|
+
def acquire(permits = 1)
|
174
|
+
unless permits.is_a?(Fixnum) && permits > 0
|
175
|
+
fail ArgumentError, 'permits must be an integer greater than zero'
|
176
|
+
end
|
177
|
+
@semaphore.acquire(permits)
|
178
|
+
end
|
179
|
+
|
180
|
+
# @!macro semaphore_method_available_permits
|
181
|
+
def available_permits
|
182
|
+
@semaphore.availablePermits
|
183
|
+
end
|
184
|
+
|
185
|
+
# @!macro semaphore_method_drain_permits
|
186
|
+
def drain_permits
|
187
|
+
@semaphore.drainPermits
|
188
|
+
end
|
189
|
+
|
190
|
+
# @!macro semaphore_method_try_acquire
|
191
|
+
def try_acquire(permits = 1, timeout = nil)
|
192
|
+
unless permits.is_a?(Fixnum) && permits > 0
|
193
|
+
fail ArgumentError, 'permits must be an integer greater than zero'
|
194
|
+
end
|
195
|
+
if timeout.nil?
|
196
|
+
@semaphore.tryAcquire(permits)
|
197
|
+
else
|
198
|
+
@semaphore.tryAcquire(permits,
|
199
|
+
timeout,
|
200
|
+
java.util.concurrent.TimeUnit::SECONDS)
|
201
|
+
end
|
202
|
+
end
|
203
|
+
|
204
|
+
# @!macro semaphore_method_release
|
205
|
+
def release(permits = 1)
|
206
|
+
unless permits.is_a?(Fixnum) && permits > 0
|
207
|
+
fail ArgumentError, 'permits must be an integer greater than zero'
|
208
|
+
end
|
209
|
+
@semaphore.release(permits)
|
210
|
+
true
|
211
|
+
end
|
212
|
+
|
213
|
+
# @!macro semaphore_method_reduce_permits
|
214
|
+
def reduce_permits(reduction)
|
215
|
+
unless reduction.is_a?(Fixnum) && reduction >= 0
|
216
|
+
fail ArgumentError, 'reduction must be an non-negative integer'
|
217
|
+
end
|
218
|
+
@semaphore.reducePermits(reduction)
|
219
|
+
end
|
220
|
+
end
|
221
|
+
|
222
|
+
# @!macro semaphore
|
223
|
+
class Semaphore < JavaSemaphore
|
224
|
+
end
|
225
|
+
|
226
|
+
else
|
227
|
+
|
228
|
+
# @!macro semaphore
|
229
|
+
class Semaphore < MutexSemaphore
|
230
|
+
end
|
231
|
+
end
|
232
|
+
end
|
data/lib/concurrent/atomics.rb
CHANGED
@@ -49,8 +49,6 @@ module Concurrent
|
|
49
49
|
# * `:discard`: Discard the task and return false.
|
50
50
|
# * `:caller_runs`: Execute the task on the calling thread.
|
51
51
|
#
|
52
|
-
# {include:file:doc/thread_pools.md}
|
53
|
-
#
|
54
52
|
# @note When running on the JVM (JRuby) this class will inherit from `JavaThreadPoolExecutor`.
|
55
53
|
# On all other platforms it will inherit from `RubyThreadPoolExecutor`.
|
56
54
|
#
|
@@ -55,10 +55,10 @@ module Concurrent
|
|
55
55
|
@queue.push(Task.new(time, args, task))
|
56
56
|
@timer_executor.post(&method(:process_tasks))
|
57
57
|
end
|
58
|
-
|
59
|
-
true
|
60
58
|
end
|
61
59
|
|
60
|
+
@condition.signal
|
61
|
+
true
|
62
62
|
end
|
63
63
|
|
64
64
|
# For a timer, #kill is like an orderly shutdown, except we need to manually
|
@@ -129,8 +129,20 @@ module Concurrent
|
|
129
129
|
interval = task.time - Time.now.to_f
|
130
130
|
|
131
131
|
if interval <= 0
|
132
|
+
# We need to remove the task from the queue before passing
|
133
|
+
# it to the executor, to avoid race conditions where we pass
|
134
|
+
# the peek'ed task to the executor and then pop a different
|
135
|
+
# one that's been added in the meantime.
|
136
|
+
#
|
137
|
+
# Note that there's no race condition between the peek and
|
138
|
+
# this pop - this pop could retrieve a different task from
|
139
|
+
# the peek, but that task would be due to fire now anyway
|
140
|
+
# (because @queue is a priority queue, and this thread is
|
141
|
+
# the only reader, so whatever timer is at the head of the
|
142
|
+
# queue now must have the same pop time, or a closer one, as
|
143
|
+
# when we peeked).
|
144
|
+
task = mutex.synchronize { @queue.pop }
|
132
145
|
@task_executor.post(*task.args, &task.op)
|
133
|
-
mutex.synchronize { @queue.pop }
|
134
146
|
else
|
135
147
|
mutex.synchronize do
|
136
148
|
@condition.wait(mutex, [interval, 60].min)
|
data/lib/concurrent/version.rb
CHANGED
data/lib/concurrent_ruby_ext.jar
CHANGED
Binary file
|
data/lib/extension_helper.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
module Concurrent
|
2
|
-
|
2
|
+
|
3
3
|
@@c_ext_loaded ||= false
|
4
4
|
@@java_ext_loaded ||= false
|
5
5
|
|
@@ -8,25 +8,30 @@ module Concurrent
|
|
8
8
|
defined?(RUBY_ENGINE) && RUBY_ENGINE == 'ruby'
|
9
9
|
end
|
10
10
|
|
11
|
+
# @!visibility private
|
12
|
+
def self.jruby?
|
13
|
+
RUBY_PLATFORM == 'java'
|
14
|
+
end
|
15
|
+
|
11
16
|
if allow_c_extensions? && !@@c_ext_loaded
|
12
17
|
begin
|
13
|
-
require '
|
18
|
+
require 'concurrent/extension'
|
14
19
|
@@c_ext_loaded = true
|
15
20
|
rescue LoadError
|
16
21
|
# may be a Windows cross-compiled native gem
|
17
22
|
begin
|
18
|
-
require "#{RUBY_VERSION[0..2]}/
|
23
|
+
require "#{RUBY_VERSION[0..2]}/concurrent/extension"
|
19
24
|
@@c_ext_loaded = true
|
20
25
|
rescue LoadError
|
21
26
|
warn 'Performance on MRI may be improved with the concurrent-ruby-ext gem. Please see http://concurrent-ruby.com'
|
22
27
|
end
|
23
28
|
end
|
24
|
-
elsif
|
29
|
+
elsif jruby? && !@@java_ext_loaded
|
25
30
|
begin
|
26
31
|
require 'concurrent_ruby_ext'
|
27
32
|
@@java_ext_loaded = true
|
28
33
|
rescue LoadError
|
29
|
-
|
34
|
+
warn 'Attempted to load Java extensions on unsupported platform. Continuing with pure-Ruby.'
|
30
35
|
end
|
31
36
|
end
|
32
37
|
end
|
metadata
CHANGED
@@ -1,15 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: concurrent-ruby
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.8.0.
|
5
|
-
prerelease: 6
|
4
|
+
version: 0.8.0.pre2
|
6
5
|
platform: java
|
7
6
|
authors:
|
8
7
|
- Jerry D'Antonio
|
9
8
|
autorequire:
|
10
9
|
bindir: bin
|
11
10
|
cert_chain: []
|
12
|
-
date:
|
11
|
+
date: 2015-01-15 00:00:00.000000000 Z
|
13
12
|
dependencies: []
|
14
13
|
description: |2
|
15
14
|
Modern concurrency tools including agents, futures, promises, thread pools, actors, supervisors, and more.
|
@@ -22,50 +21,12 @@ extra_rdoc_files:
|
|
22
21
|
- LICENSE.txt
|
23
22
|
- CHANGELOG.md
|
24
23
|
files:
|
24
|
+
- CHANGELOG.md
|
25
|
+
- LICENSE.txt
|
26
|
+
- README.md
|
25
27
|
- lib/concurrent.rb
|
26
|
-
- lib/concurrent_ruby.rb
|
27
|
-
- lib/extension_helper.rb
|
28
28
|
- lib/concurrent/actor.rb
|
29
|
-
- lib/concurrent/actress.rb
|
30
|
-
- lib/concurrent/agent.rb
|
31
|
-
- lib/concurrent/async.rb
|
32
|
-
- lib/concurrent/atomic.rb
|
33
|
-
- lib/concurrent/atomics.rb
|
34
|
-
- lib/concurrent/channels.rb
|
35
|
-
- lib/concurrent/collections.rb
|
36
|
-
- lib/concurrent/configuration.rb
|
37
|
-
- lib/concurrent/dataflow.rb
|
38
|
-
- lib/concurrent/delay.rb
|
39
|
-
- lib/concurrent/dereferenceable.rb
|
40
|
-
- lib/concurrent/errors.rb
|
41
|
-
- lib/concurrent/exchanger.rb
|
42
|
-
- lib/concurrent/executors.rb
|
43
|
-
- lib/concurrent/future.rb
|
44
|
-
- lib/concurrent/ivar.rb
|
45
|
-
- lib/concurrent/lazy_register.rb
|
46
|
-
- lib/concurrent/logging.rb
|
47
|
-
- lib/concurrent/mvar.rb
|
48
|
-
- lib/concurrent/obligation.rb
|
49
|
-
- lib/concurrent/observable.rb
|
50
|
-
- lib/concurrent/options_parser.rb
|
51
|
-
- lib/concurrent/promise.rb
|
52
|
-
- lib/concurrent/scheduled_task.rb
|
53
|
-
- lib/concurrent/timer_task.rb
|
54
|
-
- lib/concurrent/tvar.rb
|
55
|
-
- lib/concurrent/utilities.rb
|
56
|
-
- lib/concurrent/version.rb
|
57
29
|
- lib/concurrent/actor/behaviour.rb
|
58
|
-
- lib/concurrent/actor/context.rb
|
59
|
-
- lib/concurrent/actor/core.rb
|
60
|
-
- lib/concurrent/actor/default_dead_letter_handler.rb
|
61
|
-
- lib/concurrent/actor/envelope.rb
|
62
|
-
- lib/concurrent/actor/errors.rb
|
63
|
-
- lib/concurrent/actor/internal_delegations.rb
|
64
|
-
- lib/concurrent/actor/public_delegations.rb
|
65
|
-
- lib/concurrent/actor/reference.rb
|
66
|
-
- lib/concurrent/actor/root.rb
|
67
|
-
- lib/concurrent/actor/type_check.rb
|
68
|
-
- lib/concurrent/actor/utils.rb
|
69
30
|
- lib/concurrent/actor/behaviour/abstract.rb
|
70
31
|
- lib/concurrent/actor/behaviour/awaits.rb
|
71
32
|
- lib/concurrent/actor/behaviour/buffer.rb
|
@@ -79,10 +40,25 @@ files:
|
|
79
40
|
- lib/concurrent/actor/behaviour/supervising.rb
|
80
41
|
- lib/concurrent/actor/behaviour/terminates_children.rb
|
81
42
|
- lib/concurrent/actor/behaviour/termination.rb
|
43
|
+
- lib/concurrent/actor/context.rb
|
44
|
+
- lib/concurrent/actor/core.rb
|
45
|
+
- lib/concurrent/actor/default_dead_letter_handler.rb
|
46
|
+
- lib/concurrent/actor/envelope.rb
|
47
|
+
- lib/concurrent/actor/errors.rb
|
48
|
+
- lib/concurrent/actor/internal_delegations.rb
|
49
|
+
- lib/concurrent/actor/public_delegations.rb
|
50
|
+
- lib/concurrent/actor/reference.rb
|
51
|
+
- lib/concurrent/actor/root.rb
|
52
|
+
- lib/concurrent/actor/type_check.rb
|
53
|
+
- lib/concurrent/actor/utils.rb
|
82
54
|
- lib/concurrent/actor/utils/ad_hoc.rb
|
83
55
|
- lib/concurrent/actor/utils/balancer.rb
|
84
56
|
- lib/concurrent/actor/utils/broadcast.rb
|
85
57
|
- lib/concurrent/actor/utils/pool.rb
|
58
|
+
- lib/concurrent/actress.rb
|
59
|
+
- lib/concurrent/agent.rb
|
60
|
+
- lib/concurrent/async.rb
|
61
|
+
- lib/concurrent/atomic.rb
|
86
62
|
- lib/concurrent/atomic/atomic_boolean.rb
|
87
63
|
- lib/concurrent/atomic/atomic_fixnum.rb
|
88
64
|
- lib/concurrent/atomic/condition.rb
|
@@ -91,6 +67,7 @@ files:
|
|
91
67
|
- lib/concurrent/atomic/count_down_latch.rb
|
92
68
|
- lib/concurrent/atomic/cyclic_barrier.rb
|
93
69
|
- lib/concurrent/atomic/event.rb
|
70
|
+
- lib/concurrent/atomic/semaphore.rb
|
94
71
|
- lib/concurrent/atomic/synchronization.rb
|
95
72
|
- lib/concurrent/atomic/thread_local_var.rb
|
96
73
|
- lib/concurrent/atomic_reference/concurrent_update_error.rb
|
@@ -100,13 +77,22 @@ files:
|
|
100
77
|
- lib/concurrent/atomic_reference/numeric_cas_wrapper.rb
|
101
78
|
- lib/concurrent/atomic_reference/rbx.rb
|
102
79
|
- lib/concurrent/atomic_reference/ruby.rb
|
80
|
+
- lib/concurrent/atomics.rb
|
103
81
|
- lib/concurrent/channel/buffered_channel.rb
|
104
82
|
- lib/concurrent/channel/channel.rb
|
105
83
|
- lib/concurrent/channel/unbuffered_channel.rb
|
106
84
|
- lib/concurrent/channel/waitable_list.rb
|
85
|
+
- lib/concurrent/channels.rb
|
107
86
|
- lib/concurrent/collection/blocking_ring_buffer.rb
|
108
87
|
- lib/concurrent/collection/priority_queue.rb
|
109
88
|
- lib/concurrent/collection/ring_buffer.rb
|
89
|
+
- lib/concurrent/collections.rb
|
90
|
+
- lib/concurrent/configuration.rb
|
91
|
+
- lib/concurrent/dataflow.rb
|
92
|
+
- lib/concurrent/delay.rb
|
93
|
+
- lib/concurrent/dereferenceable.rb
|
94
|
+
- lib/concurrent/errors.rb
|
95
|
+
- lib/concurrent/exchanger.rb
|
110
96
|
- lib/concurrent/executor/cached_thread_pool.rb
|
111
97
|
- lib/concurrent/executor/executor.rb
|
112
98
|
- lib/concurrent/executor/fixed_thread_pool.rb
|
@@ -127,36 +113,49 @@ files:
|
|
127
113
|
- lib/concurrent/executor/single_thread_executor.rb
|
128
114
|
- lib/concurrent/executor/thread_pool_executor.rb
|
129
115
|
- lib/concurrent/executor/timer_set.rb
|
116
|
+
- lib/concurrent/executors.rb
|
117
|
+
- lib/concurrent/future.rb
|
118
|
+
- lib/concurrent/ivar.rb
|
119
|
+
- lib/concurrent/lazy_register.rb
|
120
|
+
- lib/concurrent/logging.rb
|
121
|
+
- lib/concurrent/mvar.rb
|
122
|
+
- lib/concurrent/obligation.rb
|
123
|
+
- lib/concurrent/observable.rb
|
124
|
+
- lib/concurrent/options_parser.rb
|
125
|
+
- lib/concurrent/promise.rb
|
126
|
+
- lib/concurrent/scheduled_task.rb
|
127
|
+
- lib/concurrent/timer_task.rb
|
128
|
+
- lib/concurrent/tvar.rb
|
129
|
+
- lib/concurrent/utilities.rb
|
130
130
|
- lib/concurrent/utility/processor_count.rb
|
131
131
|
- lib/concurrent/utility/timeout.rb
|
132
132
|
- lib/concurrent/utility/timer.rb
|
133
|
-
-
|
134
|
-
-
|
135
|
-
- CHANGELOG.md
|
133
|
+
- lib/concurrent/version.rb
|
134
|
+
- lib/concurrent_ruby.rb
|
136
135
|
- lib/concurrent_ruby_ext.jar
|
136
|
+
- lib/extension_helper.rb
|
137
137
|
homepage: http://www.concurrent-ruby.com
|
138
138
|
licenses:
|
139
139
|
- MIT
|
140
|
+
metadata: {}
|
140
141
|
post_install_message:
|
141
142
|
rdoc_options: []
|
142
143
|
require_paths:
|
143
144
|
- lib
|
144
145
|
required_ruby_version: !ruby/object:Gem::Requirement
|
145
146
|
requirements:
|
146
|
-
- -
|
147
|
+
- - ">="
|
147
148
|
- !ruby/object:Gem::Version
|
148
149
|
version: 1.9.3
|
149
|
-
none: false
|
150
150
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
151
151
|
requirements:
|
152
|
-
- -
|
152
|
+
- - ">"
|
153
153
|
- !ruby/object:Gem::Version
|
154
154
|
version: 1.3.1
|
155
|
-
none: false
|
156
155
|
requirements: []
|
157
156
|
rubyforge_project:
|
158
|
-
rubygems_version:
|
157
|
+
rubygems_version: 2.4.5
|
159
158
|
signing_key:
|
160
|
-
specification_version:
|
159
|
+
specification_version: 4
|
161
160
|
summary: Modern concurrency tools for Ruby. Inspired by Erlang, Clojure, Scala, Haskell, F#, C#, Java, and classic concurrency patterns.
|
162
161
|
test_files: []
|