Class: ChefFS::Parallelizer
- Inherits:
-
Object
- Object
- ChefFS::Parallelizer
show all
- Defined in:
- lib/chef_fs/parallelizer.rb
Defined Under Namespace
Classes: ParallelizedResults
Constant Summary
collapse
- @@parallelizer =
nil
- @@threads =
0
Class Method Summary
collapse
Instance Method Summary
collapse
Constructor Details
Returns a new instance of Parallelizer.
18
19
20
21
22
23
24
25
|
# File 'lib/chef_fs/parallelizer.rb', line 18
def initialize(threads)
@tasks_mutex = Mutex.new
@tasks = []
@threads = []
1.upto(threads) do
@threads << Thread.new { worker_loop }
end
end
|
Class Method Details
.parallelize(enumerator, options = {}, &block) ⇒ Object
13
14
15
16
|
# File 'lib/chef_fs/parallelizer.rb', line 13
def self.parallelize(enumerator, options = {}, &block)
@@parallelizer ||= Parallelizer.new(@@threads)
@@parallelizer.parallelize(enumerator, options, &block)
end
|
.threads=(value) ⇒ Object
6
7
8
9
10
11
|
# File 'lib/chef_fs/parallelizer.rb', line 6
def self.threads=(value)
if @@threads != value
@@threads = value
@@parallelizer = nil
end
end
|
Instance Method Details
#parallelize(enumerator, options = {}, &block) ⇒ Object
27
28
29
30
31
32
33
|
# File 'lib/chef_fs/parallelizer.rb', line 27
def parallelize(enumerator, options = {}, &block)
task = ParallelizedResults.new(enumerator, options, &block)
@tasks_mutex.synchronize do
@tasks << task
end
task
end
|