Class: Chef::ChefFS::Parallelizer
- Inherits:
-
Object
- Object
- Chef::ChefFS::Parallelizer
show all
- Defined in:
- lib/chef/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.
19
20
21
22
23
24
25
26
|
# File 'lib/chef/chef_fs/parallelizer.rb', line 19
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
14
15
16
17
|
# File 'lib/chef/chef_fs/parallelizer.rb', line 14
def self.parallelize(enumerator, options = {}, &block)
@@parallelizer ||= Parallelizer.new(@@threads)
@@parallelizer.parallelize(enumerator, options, &block)
end
|
.threads=(value) ⇒ Object
7
8
9
10
11
12
|
# File 'lib/chef/chef_fs/parallelizer.rb', line 7
def self.threads=(value)
if @@threads != value
@@threads = value
@@parallelizer = nil
end
end
|
Instance Method Details
#parallelize(enumerator, options = {}, &block) ⇒ Object
28
29
30
31
32
33
34
|
# File 'lib/chef/chef_fs/parallelizer.rb', line 28
def parallelize(enumerator, options = {}, &block)
task = ParallelizedResults.new(enumerator, options, &block)
@tasks_mutex.synchronize do
@tasks << task
end
task
end
|