enumerator-parallel 0.1.0 → 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +14 -1
- data/Gemfile +1 -1
- data/enumerator-parallel.gemspec +3 -3
- data/lib/enumerator-parallel.rb +22 -4
- data/lib/enumerator-parallel/version.rb +1 -1
- metadata +12 -12
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 017e6dc651f791d27ee297fedc72c5107e37640a
|
4
|
+
data.tar.gz: f0bc9e0aa37f12f488b8eb537f475a968a19ad9b
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: e8128e9204e4e494e08e440c76f64a128811219ea4f072505e63d1bcef84b9a0261200e3f309c190f5ee99963876e1b925701580e526762b2a49ef84d71cd373
|
7
|
+
data.tar.gz: f757a735dbf87ceb44ea2e924e820d433663636895a1efee4904c543609649884fbcc80377f477bdf409b780d69b52b1f6e6a9f54dc2ae9cf01753ea7b2dca0a
|
data/.travis.yml
CHANGED
data/Gemfile
CHANGED
data/enumerator-parallel.gemspec
CHANGED
@@ -18,9 +18,9 @@ Gem::Specification.new do |spec|
|
|
18
18
|
spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
|
19
19
|
spec.require_paths = ["lib"]
|
20
20
|
|
21
|
-
spec.add_dependency 'parallel'
|
21
|
+
spec.add_dependency 'parallel', ['>=1.4.1']
|
22
22
|
|
23
|
-
spec.add_development_dependency
|
24
|
-
spec.add_development_dependency
|
23
|
+
spec.add_development_dependency 'bundler', ['>= 1.0.0']
|
24
|
+
spec.add_development_dependency 'rake', ['>= 0']
|
25
25
|
spec.add_development_dependency "minitest"
|
26
26
|
end
|
data/lib/enumerator-parallel.rb
CHANGED
@@ -9,17 +9,35 @@ module Enumerable
|
|
9
9
|
end
|
10
10
|
|
11
11
|
class Enumerator::Parallel
|
12
|
-
include Enumerable
|
13
12
|
def initialize(enum, options)
|
14
13
|
mappings = { processes: :in_processes, threads: :in_threads }
|
15
|
-
@enum, @options = enum, Hash[options.map { |k, v| [(mappings[k] || k), v] }]
|
14
|
+
@enum, @options = enum.to_a, Hash[options.map { |k, v| [(mappings[k] || k), v] }]
|
16
15
|
end
|
17
16
|
|
18
|
-
def each(
|
17
|
+
def each(&block)
|
19
18
|
::Parallel.each(@enum, @options, &block)
|
20
19
|
end
|
21
20
|
|
22
|
-
def map(
|
21
|
+
def map(&block)
|
23
22
|
::Parallel.map(@enum, @options, &block)
|
24
23
|
end
|
24
|
+
|
25
|
+
def all?(&block)
|
26
|
+
map(&block).all?
|
27
|
+
end
|
28
|
+
|
29
|
+
def any?(&block)
|
30
|
+
map(&block).any?
|
31
|
+
end
|
32
|
+
|
33
|
+
%w|group_by select reject|.each do |mth|
|
34
|
+
define_method(mth) do |*args, &block|
|
35
|
+
map_num = map(&block)
|
36
|
+
@enum.send(mth).with_index { |_, i| map_num[i] }
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
def count(&block)
|
41
|
+
map(&block).count(true)
|
42
|
+
end
|
25
43
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: enumerator-parallel
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- gogotanaka
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-05-
|
11
|
+
date: 2015-05-06 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: parallel
|
@@ -16,42 +16,42 @@ dependencies:
|
|
16
16
|
requirements:
|
17
17
|
- - ">="
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version:
|
19
|
+
version: 1.4.1
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
24
|
- - ">="
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version:
|
26
|
+
version: 1.4.1
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: bundler
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
|
-
- - "
|
31
|
+
- - ">="
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version:
|
33
|
+
version: 1.0.0
|
34
34
|
type: :development
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
|
-
- - "
|
38
|
+
- - ">="
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version:
|
40
|
+
version: 1.0.0
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: rake
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
|
-
- - "
|
45
|
+
- - ">="
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version: '
|
47
|
+
version: '0'
|
48
48
|
type: :development
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
|
-
- - "
|
52
|
+
- - ">="
|
53
53
|
- !ruby/object:Gem::Version
|
54
|
-
version: '
|
54
|
+
version: '0'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
56
|
name: minitest
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|