sixarm_ruby_array_slice 2.1.4 → 2.1.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- checksums.yaml.gz.sig +0 -0
- data.tar.gz.sig +0 -0
- data/Rakefile +4 -4
- data/lib/sixarm_ruby_array_slice.rb +1 -65
- data/lib/sixarm_ruby_array_slice/array.rb +66 -0
- data/test/sixarm_ruby_array_slice_test.rb +9 -105
- data/test/sixarm_ruby_array_slice_test/array_test.rb +104 -0
- metadata +134 -41
- metadata.gz.sig +0 -0
- data/.gemtest +0 -0
- data/README.md +0 -78
- data/VERSION +0 -1
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: ff77a74133d4988170b58c17c27bea75378c1a89
|
4
|
+
data.tar.gz: 6fce1f9f68829d45c509d9380b724f8aee24667b
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: e5e11679627e98867a0c33f75559b0ea4e7786f1dd391706ac29a88de33f9600dde05f61547aee98eb424c8bf8e05d6d4686196414b035508e7a047db359839d
|
7
|
+
data.tar.gz: 542f529026779212f8fbf1137b54f9f3e9554062ff2ee72f302951aacd69f77d39ad5fb163dcedfb90a0fab3dd50c6acdf3602ff8e36ba8ed0c9595878a5b4e5
|
checksums.yaml.gz.sig
ADDED
Binary file
|
data.tar.gz.sig
CHANGED
Binary file
|
data/Rakefile
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
# -*- coding: utf-8 -*-
|
2
|
-
require
|
3
|
-
require
|
2
|
+
require "rake"
|
3
|
+
require "rake/testtask"
|
4
4
|
|
5
5
|
Rake::TestTask.new(:test) do |t|
|
6
|
-
t.libs
|
7
|
-
t.pattern =
|
6
|
+
t.libs.push("lib", "test")
|
7
|
+
t.pattern = "test/**/*.rb"
|
8
8
|
end
|
@@ -3,68 +3,4 @@
|
|
3
3
|
Please see README
|
4
4
|
=end
|
5
5
|
|
6
|
-
|
7
|
-
class Array
|
8
|
-
|
9
|
-
|
10
|
-
# Slice the array into sub-arrays of size _n_.
|
11
|
-
#
|
12
|
-
# @return [Array<Array<Object>>] slices where each slice has approximately _n_ items
|
13
|
-
#
|
14
|
-
# If the array divides evenly then each slice has _n_ items:
|
15
|
-
#
|
16
|
-
# [1,2,3,4,5,6,7,8].slice_by_size(2) => [[1,2],[3,4],[5,6],[7,8]]
|
17
|
-
# [1,2,3,4,5,6,7,8].slice_by_size(4) => [[1,2,3,4],[5,6,7,8]]
|
18
|
-
#
|
19
|
-
# If the array does not divide evenly then the last slice will be smaller:
|
20
|
-
#
|
21
|
-
# [1,2,3,4,5,6,7,8].slice_by_size(3) => [[1,2,3],[4,5,6],[7,8]]
|
22
|
-
#
|
23
|
-
# If the array size is small compared to _n_ then the results will be best-attempt:
|
24
|
-
#
|
25
|
-
# [1,2,3,4,5,6,7,8].slice_by_size(7) => [[1,2,3,4,5,6,7],[8]]
|
26
|
-
#
|
27
|
-
# Compare #slice_by_share
|
28
|
-
|
29
|
-
def slice_by_size(size)
|
30
|
-
(size.is_a? Integer) or (raise ArgumentError, "size must be an integer")
|
31
|
-
(size > 0) or (raise ArgumentError, "size must be > 0")
|
32
|
-
arr=[]
|
33
|
-
index=0
|
34
|
-
while index<length
|
35
|
-
arr.push self[index...(index+size)]
|
36
|
-
index+=size
|
37
|
-
end
|
38
|
-
return arr
|
39
|
-
end
|
40
|
-
|
41
|
-
|
42
|
-
# Slice the array into _n_ sub-arrays of the same size.
|
43
|
-
#
|
44
|
-
# @return [Array<Array<Object>>] _n_ slices where each slice is approximately the same size.
|
45
|
-
#
|
46
|
-
# If the array divides evenly, then each slice has size/n items:
|
47
|
-
#
|
48
|
-
# [1,2,3,4,5,6,7,8].slice_by_share(2) => [[1,2,3,4],[5,6,7,8]]
|
49
|
-
# [1,2,3,4,5,6,7,8].slice_by_share(4) => [[1,2],[3,4],[5,6],[7,8]]
|
50
|
-
#
|
51
|
-
# If the array does not divide evenly then the latter slices will be smaller:
|
52
|
-
#
|
53
|
-
# [1,2,3,4,5,6,7,8].slice_by_share(3) => [[1,2,3],[4,5,6],[7,8]]
|
54
|
-
#
|
55
|
-
# If the array size is small compared to _n_ then the results will be best-attempt:
|
56
|
-
#
|
57
|
-
# [1,2,3,4,5,6,7,8].slice_by_share(7) => [[1,2],[3,4],[5,6],[7,8],[],[],[]]
|
58
|
-
#
|
59
|
-
# Compare #slice_by_size
|
60
|
-
|
61
|
-
def slice_by_share(share)
|
62
|
-
(share.is_a? Integer) or (raise ArgumentError, "share must be an integer")
|
63
|
-
(share > 0) or (raise ArgumentError, "share must be > 0")
|
64
|
-
arr = slice_by_size((length.to_f/share.to_f).ceil)
|
65
|
-
while arr.size < share do arr << [] end
|
66
|
-
return arr
|
67
|
-
end
|
68
|
-
|
69
|
-
|
70
|
-
end
|
6
|
+
require_relative "sixarm_ruby_array_slice/array"
|
@@ -0,0 +1,66 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
=begin rdoc
|
3
|
+
Array extentions.
|
4
|
+
=end
|
5
|
+
|
6
|
+
class Array
|
7
|
+
|
8
|
+
# Slice the array into sub-arrays of size _n_.
|
9
|
+
#
|
10
|
+
# @return [Array<Array<Object>>] slices where each slice has approximately _n_ items
|
11
|
+
#
|
12
|
+
# If the array divides evenly then each slice has _n_ items:
|
13
|
+
#
|
14
|
+
# [1,2,3,4,5,6,7,8].slice_by_size(2) => [[1,2],[3,4],[5,6],[7,8]]
|
15
|
+
# [1,2,3,4,5,6,7,8].slice_by_size(4) => [[1,2,3,4],[5,6,7,8]]
|
16
|
+
#
|
17
|
+
# If the array does not divide evenly then the last slice will be smaller:
|
18
|
+
#
|
19
|
+
# [1,2,3,4,5,6,7,8].slice_by_size(3) => [[1,2,3],[4,5,6],[7,8]]
|
20
|
+
#
|
21
|
+
# If the array size is small compared to _n_ then the results will be best-attempt:
|
22
|
+
#
|
23
|
+
# [1,2,3,4,5,6,7,8].slice_by_size(7) => [[1,2,3,4,5,6,7],[8]]
|
24
|
+
#
|
25
|
+
# Compare #slice_by_share
|
26
|
+
|
27
|
+
def slice_by_size(size)
|
28
|
+
(size.is_a? Integer) or (raise ArgumentError, "size must be an integer")
|
29
|
+
(size > 0) or (raise ArgumentError, "size must be > 0")
|
30
|
+
arr=[]
|
31
|
+
index=0
|
32
|
+
while index<length
|
33
|
+
arr.push self[index...(index+size)]
|
34
|
+
index+=size
|
35
|
+
end
|
36
|
+
return arr
|
37
|
+
end
|
38
|
+
|
39
|
+
# Slice the array into _n_ sub-arrays of the same size.
|
40
|
+
#
|
41
|
+
# @return [Array<Array<Object>>] _n_ slices where each slice is approximately the same size.
|
42
|
+
#
|
43
|
+
# If the array divides evenly, then each slice has size/n items:
|
44
|
+
#
|
45
|
+
# [1,2,3,4,5,6,7,8].slice_by_share(2) => [[1,2,3,4],[5,6,7,8]]
|
46
|
+
# [1,2,3,4,5,6,7,8].slice_by_share(4) => [[1,2],[3,4],[5,6],[7,8]]
|
47
|
+
#
|
48
|
+
# If the array does not divide evenly then the latter slices will be smaller:
|
49
|
+
#
|
50
|
+
# [1,2,3,4,5,6,7,8].slice_by_share(3) => [[1,2,3],[4,5,6],[7,8]]
|
51
|
+
#
|
52
|
+
# If the array size is small compared to _n_ then the results will be best-attempt:
|
53
|
+
#
|
54
|
+
# [1,2,3,4,5,6,7,8].slice_by_share(7) => [[1,2],[3,4],[5,6],[7,8],[],[],[]]
|
55
|
+
#
|
56
|
+
# Compare #slice_by_size
|
57
|
+
|
58
|
+
def slice_by_share(share)
|
59
|
+
(share.is_a? Integer) or (raise ArgumentError, "share must be an integer")
|
60
|
+
(share > 0) or (raise ArgumentError, "share must be > 0")
|
61
|
+
arr = slice_by_size((length.to_f/share.to_f).ceil)
|
62
|
+
while arr.size < share do arr << [] end
|
63
|
+
return arr
|
64
|
+
end
|
65
|
+
|
66
|
+
end
|
@@ -1,107 +1,11 @@
|
|
1
1
|
# -*- coding: utf-8 -*-
|
2
|
-
require
|
3
|
-
require
|
2
|
+
require "minitest/autorun"
|
3
|
+
require "coveralls"
|
4
|
+
require "simplecov"
|
5
|
+
Coveralls.wear!
|
6
|
+
SimpleCov.formatter = SimpleCov::Formatter::MultiFormatter[
|
7
|
+
SimpleCov::Formatter::HTMLFormatter,
|
8
|
+
Coveralls::SimpleCov::Formatter
|
9
|
+
]
|
4
10
|
SimpleCov.start
|
5
|
-
require
|
6
|
-
|
7
|
-
describe Array do
|
8
|
-
|
9
|
-
before do
|
10
|
-
A ||= [1,2,3,4,5,6,7,8]
|
11
|
-
end
|
12
|
-
|
13
|
-
describe "#slice_by_size" do
|
14
|
-
|
15
|
-
it "with 1 count" do
|
16
|
-
A.slice_by_size(1).must_equal [[1],[2],[3],[4],[5],[6],[7],[8]]
|
17
|
-
end
|
18
|
-
|
19
|
-
it "with balanced results" do
|
20
|
-
A.slice_by_size(2).must_equal [[1,2],[3,4],[5,6],[7,8]]
|
21
|
-
A.slice_by_size(4).must_equal [[1,2,3,4],[5,6,7,8]]
|
22
|
-
end
|
23
|
-
|
24
|
-
it "with unbalanced results" do
|
25
|
-
A.slice_by_size(3).must_equal [[1,2,3],[4,5,6],[7,8]]
|
26
|
-
end
|
27
|
-
|
28
|
-
it "with very unbalanced results" do
|
29
|
-
A.slice_by_size(7).must_equal [[1,2,3,4,5,6,7],[8]]
|
30
|
-
end
|
31
|
-
|
32
|
-
it "with empty input" do
|
33
|
-
[].slice_by_size(1).must_equal []
|
34
|
-
end
|
35
|
-
|
36
|
-
it "with 0 count" do
|
37
|
-
assert_raise ArgumentError do
|
38
|
-
A.slice_by_size(0)
|
39
|
-
end
|
40
|
-
end
|
41
|
-
|
42
|
-
it "with negative count" do
|
43
|
-
assert_raise ArgumentError do
|
44
|
-
A.slice_by_size(-1)
|
45
|
-
end
|
46
|
-
end
|
47
|
-
|
48
|
-
it "with float count" do
|
49
|
-
assert_raise ArgumentError do
|
50
|
-
A.slice_by_size(1.234)
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
it "with non numeric count" do
|
55
|
-
assert_raise ArgumentError do
|
56
|
-
A.slice_by_size(1.234)
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
end
|
61
|
-
|
62
|
-
describe "#slice_by_share" do
|
63
|
-
|
64
|
-
it "with 1 count" do
|
65
|
-
A.slice_by_share(1).must_equal [[1,2,3,4,5,6,7,8]]
|
66
|
-
end
|
67
|
-
|
68
|
-
it "with balanced results" do
|
69
|
-
A.slice_by_share(2).must_equal [[1,2,3,4],[5,6,7,8]]
|
70
|
-
A.slice_by_share(4).must_equal [[1,2],[3,4],[5,6],[7,8]]
|
71
|
-
end
|
72
|
-
|
73
|
-
it "with unbalanced results" do
|
74
|
-
A.slice_by_share(3).must_equal [[1,2,3],[4,5,6],[7,8]]
|
75
|
-
end
|
76
|
-
|
77
|
-
it "with very unbalanced results" do
|
78
|
-
A.slice_by_share(7).must_equal [[1,2],[3,4],[5,6],[7,8],[],[],[]]
|
79
|
-
end
|
80
|
-
|
81
|
-
it "with zero count" do
|
82
|
-
assert_raise ArgumentError do
|
83
|
-
A.slice_by_share(0)
|
84
|
-
end
|
85
|
-
end
|
86
|
-
|
87
|
-
it "with negative count" do
|
88
|
-
assert_raise ArgumentError do
|
89
|
-
A.slice_by_share(-1)
|
90
|
-
end
|
91
|
-
end
|
92
|
-
|
93
|
-
it "with float count" do
|
94
|
-
assert_raise ArgumentError do
|
95
|
-
A.slice_by_share(1.234)
|
96
|
-
end
|
97
|
-
end
|
98
|
-
|
99
|
-
it "with non numeric count" do
|
100
|
-
assert_raise ArgumentError do
|
101
|
-
A.slice_by_share("")
|
102
|
-
end
|
103
|
-
end
|
104
|
-
|
105
|
-
end
|
106
|
-
|
107
|
-
end
|
11
|
+
require "sixarm_ruby_array_slice"
|
@@ -0,0 +1,104 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
require "sixarm_ruby_array_slice_test"
|
3
|
+
|
4
|
+
describe Array do
|
5
|
+
|
6
|
+
before do
|
7
|
+
A ||= [1,2,3,4,5,6,7,8]
|
8
|
+
end
|
9
|
+
|
10
|
+
describe "#slice_by_size" do
|
11
|
+
|
12
|
+
it "with 1 count" do
|
13
|
+
A.slice_by_size(1).must_equal [[1],[2],[3],[4],[5],[6],[7],[8]]
|
14
|
+
end
|
15
|
+
|
16
|
+
it "with balanced results" do
|
17
|
+
A.slice_by_size(2).must_equal [[1,2],[3,4],[5,6],[7,8]]
|
18
|
+
A.slice_by_size(4).must_equal [[1,2,3,4],[5,6,7,8]]
|
19
|
+
end
|
20
|
+
|
21
|
+
it "with unbalanced results" do
|
22
|
+
A.slice_by_size(3).must_equal [[1,2,3],[4,5,6],[7,8]]
|
23
|
+
end
|
24
|
+
|
25
|
+
it "with very unbalanced results" do
|
26
|
+
A.slice_by_size(7).must_equal [[1,2,3,4,5,6,7],[8]]
|
27
|
+
end
|
28
|
+
|
29
|
+
it "with empty input" do
|
30
|
+
[].slice_by_size(1).must_equal []
|
31
|
+
end
|
32
|
+
|
33
|
+
it "with 0 count" do
|
34
|
+
assert_raise ArgumentError do
|
35
|
+
A.slice_by_size(0)
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
it "with negative count" do
|
40
|
+
assert_raise ArgumentError do
|
41
|
+
A.slice_by_size(-1)
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
it "with float count" do
|
46
|
+
assert_raise ArgumentError do
|
47
|
+
A.slice_by_size(1.234)
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
it "with non numeric count" do
|
52
|
+
assert_raise ArgumentError do
|
53
|
+
A.slice_by_size(1.234)
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
end
|
58
|
+
|
59
|
+
describe "#slice_by_share" do
|
60
|
+
|
61
|
+
it "with 1 count" do
|
62
|
+
A.slice_by_share(1).must_equal [[1,2,3,4,5,6,7,8]]
|
63
|
+
end
|
64
|
+
|
65
|
+
it "with balanced results" do
|
66
|
+
A.slice_by_share(2).must_equal [[1,2,3,4],[5,6,7,8]]
|
67
|
+
A.slice_by_share(4).must_equal [[1,2],[3,4],[5,6],[7,8]]
|
68
|
+
end
|
69
|
+
|
70
|
+
it "with unbalanced results" do
|
71
|
+
A.slice_by_share(3).must_equal [[1,2,3],[4,5,6],[7,8]]
|
72
|
+
end
|
73
|
+
|
74
|
+
it "with very unbalanced results" do
|
75
|
+
A.slice_by_share(7).must_equal [[1,2],[3,4],[5,6],[7,8],[],[],[]]
|
76
|
+
end
|
77
|
+
|
78
|
+
it "with zero count" do
|
79
|
+
assert_raise ArgumentError do
|
80
|
+
A.slice_by_share(0)
|
81
|
+
end
|
82
|
+
end
|
83
|
+
|
84
|
+
it "with negative count" do
|
85
|
+
assert_raise ArgumentError do
|
86
|
+
A.slice_by_share(-1)
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
it "with float count" do
|
91
|
+
assert_raise ArgumentError do
|
92
|
+
A.slice_by_share(1.234)
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
it "with non numeric count" do
|
97
|
+
assert_raise ArgumentError do
|
98
|
+
A.slice_by_share("")
|
99
|
+
end
|
100
|
+
end
|
101
|
+
|
102
|
+
end
|
103
|
+
|
104
|
+
end
|
metadata
CHANGED
@@ -1,78 +1,171 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sixarm_ruby_array_slice
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.1.
|
5
|
-
prerelease:
|
4
|
+
version: 2.1.6
|
6
5
|
platform: ruby
|
7
6
|
authors:
|
8
7
|
- SixArm
|
9
8
|
autorequire:
|
10
9
|
bindir: bin
|
11
10
|
cert_chain:
|
12
|
-
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
11
|
+
- |
|
12
|
+
-----BEGIN CERTIFICATE-----
|
13
|
+
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
|
45
|
+
n+ES/gQPOnvmVkLDGw==
|
46
|
+
-----END CERTIFICATE-----
|
47
|
+
date: 2015-07-19 00:00:00.000000000 Z
|
48
|
+
dependencies:
|
49
|
+
- !ruby/object:Gem::Dependency
|
50
|
+
name: minitest
|
51
|
+
requirement: !ruby/object:Gem::Requirement
|
52
|
+
requirements:
|
53
|
+
- - ">="
|
54
|
+
- !ruby/object:Gem::Version
|
55
|
+
version: 5.7.0
|
56
|
+
- - "<"
|
57
|
+
- !ruby/object:Gem::Version
|
58
|
+
version: '6'
|
59
|
+
type: :development
|
60
|
+
prerelease: false
|
61
|
+
version_requirements: !ruby/object:Gem::Requirement
|
62
|
+
requirements:
|
63
|
+
- - ">="
|
64
|
+
- !ruby/object:Gem::Version
|
65
|
+
version: 5.7.0
|
66
|
+
- - "<"
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '6'
|
69
|
+
- !ruby/object:Gem::Dependency
|
70
|
+
name: rake
|
71
|
+
requirement: !ruby/object:Gem::Requirement
|
72
|
+
requirements:
|
73
|
+
- - ">"
|
74
|
+
- !ruby/object:Gem::Version
|
75
|
+
version: 10.4.2
|
76
|
+
- - "<"
|
77
|
+
- !ruby/object:Gem::Version
|
78
|
+
version: '11'
|
79
|
+
type: :development
|
80
|
+
prerelease: false
|
81
|
+
version_requirements: !ruby/object:Gem::Requirement
|
82
|
+
requirements:
|
83
|
+
- - ">"
|
84
|
+
- !ruby/object:Gem::Version
|
85
|
+
version: 10.4.2
|
86
|
+
- - "<"
|
87
|
+
- !ruby/object:Gem::Version
|
88
|
+
version: '11'
|
89
|
+
- !ruby/object:Gem::Dependency
|
90
|
+
name: simplecov
|
91
|
+
requirement: !ruby/object:Gem::Requirement
|
92
|
+
requirements:
|
93
|
+
- - ">="
|
94
|
+
- !ruby/object:Gem::Version
|
95
|
+
version: 0.10.0
|
96
|
+
- - "<"
|
97
|
+
- !ruby/object:Gem::Version
|
98
|
+
version: '2'
|
99
|
+
type: :development
|
100
|
+
prerelease: false
|
101
|
+
version_requirements: !ruby/object:Gem::Requirement
|
102
|
+
requirements:
|
103
|
+
- - ">="
|
104
|
+
- !ruby/object:Gem::Version
|
105
|
+
version: 0.10.0
|
106
|
+
- - "<"
|
107
|
+
- !ruby/object:Gem::Version
|
108
|
+
version: '2'
|
109
|
+
- !ruby/object:Gem::Dependency
|
110
|
+
name: coveralls
|
111
|
+
requirement: !ruby/object:Gem::Requirement
|
112
|
+
requirements:
|
113
|
+
- - ">="
|
114
|
+
- !ruby/object:Gem::Version
|
115
|
+
version: 0.8.2
|
116
|
+
- - "<"
|
117
|
+
- !ruby/object:Gem::Version
|
118
|
+
version: '2'
|
119
|
+
type: :development
|
120
|
+
prerelease: false
|
121
|
+
version_requirements: !ruby/object:Gem::Requirement
|
122
|
+
requirements:
|
123
|
+
- - ">="
|
124
|
+
- !ruby/object:Gem::Version
|
125
|
+
version: 0.8.2
|
126
|
+
- - "<"
|
127
|
+
- !ruby/object:Gem::Version
|
128
|
+
version: '2'
|
129
|
+
description: 'Provide Array #slice_by_share, #slice_by_size'
|
41
130
|
email: sixarm@sixarm.com
|
42
131
|
executables: []
|
43
132
|
extensions: []
|
44
133
|
extra_rdoc_files: []
|
45
134
|
files:
|
46
|
-
- .gemtest
|
47
135
|
- Rakefile
|
48
|
-
- README.md
|
49
|
-
- VERSION
|
50
136
|
- lib/sixarm_ruby_array_slice.rb
|
137
|
+
- lib/sixarm_ruby_array_slice/array.rb
|
51
138
|
- test/sixarm_ruby_array_slice_test.rb
|
139
|
+
- test/sixarm_ruby_array_slice_test/array_test.rb
|
52
140
|
homepage: http://sixarm.com/
|
53
|
-
licenses:
|
141
|
+
licenses:
|
142
|
+
- BSD
|
143
|
+
- GPL
|
144
|
+
- MIT
|
145
|
+
- PAL
|
146
|
+
- Various
|
147
|
+
metadata: {}
|
54
148
|
post_install_message:
|
55
149
|
rdoc_options: []
|
56
150
|
require_paths:
|
57
151
|
- lib
|
58
152
|
required_ruby_version: !ruby/object:Gem::Requirement
|
59
|
-
none: false
|
60
153
|
requirements:
|
61
|
-
- -
|
154
|
+
- - ">="
|
62
155
|
- !ruby/object:Gem::Version
|
63
156
|
version: '0'
|
64
157
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
65
|
-
none: false
|
66
158
|
requirements:
|
67
|
-
- -
|
159
|
+
- - ">="
|
68
160
|
- !ruby/object:Gem::Version
|
69
161
|
version: '0'
|
70
162
|
requirements: []
|
71
163
|
rubyforge_project:
|
72
|
-
rubygems_version:
|
164
|
+
rubygems_version: 2.4.8
|
73
165
|
signing_key:
|
74
|
-
specification_version:
|
166
|
+
specification_version: 4
|
75
167
|
summary: SixArm.com » Ruby » Array slice methods
|
76
168
|
test_files:
|
77
169
|
- test/sixarm_ruby_array_slice_test.rb
|
170
|
+
- test/sixarm_ruby_array_slice_test/array_test.rb
|
78
171
|
has_rdoc: true
|
metadata.gz.sig
CHANGED
Binary file
|
data/.gemtest
DELETED
File without changes
|
data/README.md
DELETED
@@ -1,78 +0,0 @@
|
|
1
|
-
# SixArm.com » Ruby » <br> Array slice methods by size and share
|
2
|
-
|
3
|
-
* Docs: <http://sixarm.com/sixarm_ruby_array_slice/doc>
|
4
|
-
* Repo: <http://github.com/sixarm/sixarm_ruby_array_slice>
|
5
|
-
* Email: Joel Parker Henderson, <joel@sixarm.com>
|
6
|
-
|
7
|
-
|
8
|
-
## Introduction
|
9
|
-
|
10
|
-
Array slice methods:
|
11
|
-
|
12
|
-
* #slice_by_share: divides an array into a given number of slices
|
13
|
-
* #slice_by_size: divides an array into a slices of a given size
|
14
|
-
|
15
|
-
For docs go to <http://sixarm.com/sixarm_ruby_array_slice/doc>
|
16
|
-
|
17
|
-
Want to help? We're happy to get pull requests.
|
18
|
-
|
19
|
-
|
20
|
-
## Quickstart
|
21
|
-
|
22
|
-
Install:
|
23
|
-
|
24
|
-
gem install sixarm_ruby_array_slice
|
25
|
-
|
26
|
-
Bundler:
|
27
|
-
|
28
|
-
gem "sixarm_ruby_array_slice", "=2.1.4"
|
29
|
-
|
30
|
-
Require:
|
31
|
-
|
32
|
-
require "sixarm_ruby_array_slice"
|
33
|
-
|
34
|
-
|
35
|
-
## Example
|
36
|
-
|
37
|
-
Example of both ways to slice:
|
38
|
-
|
39
|
-
[1,2,3,4,5,6,7,8].slice_by_size(2)
|
40
|
-
=> [[1,2],[3,4],[5,6],[7,8]]
|
41
|
-
|
42
|
-
[1,2,3,4,5,6,7,8].slice_by_share(2)
|
43
|
-
=> [[1,2,3,4],[5,6,7,8]]
|
44
|
-
|
45
|
-
|
46
|
-
## Changes
|
47
|
-
|
48
|
-
* 2012-03-16 2.1.4 1.9.3; minitest/spec; update docs, tests.
|
49
|
-
* 2012-02-01 1.0.0 Publish.
|
50
|
-
|
51
|
-
|
52
|
-
## License
|
53
|
-
|
54
|
-
You may choose any of these open source licenses:
|
55
|
-
|
56
|
-
* Apache License
|
57
|
-
* BSD License
|
58
|
-
* CreativeCommons License, Non-commercial Share Alike
|
59
|
-
* GNU General Public License Version 2 (GPL 2)
|
60
|
-
* GNU Lesser General Public License (LGPL)
|
61
|
-
* MIT License
|
62
|
-
* Perl Artistic License
|
63
|
-
* Ruby License
|
64
|
-
|
65
|
-
The software is provided "as is", without warranty of any kind,
|
66
|
-
express or implied, including but not limited to the warranties of
|
67
|
-
merchantability, fitness for a particular purpose and noninfringement.
|
68
|
-
|
69
|
-
In no event shall the authors or copyright holders be liable for any
|
70
|
-
claim, damages or other liability, whether in an action of contract,
|
71
|
-
tort or otherwise, arising from, out of or in connection with the
|
72
|
-
software or the use or other dealings in the software.
|
73
|
-
|
74
|
-
This license is for the included software that is created by SixArm;
|
75
|
-
some of the included software may have its own licenses, copyrights,
|
76
|
-
authors, etc. and these do take precedence over the SixArm license.
|
77
|
-
|
78
|
-
Copyright (c) 2005-2013 Joel Parker Henderson
|
data/VERSION
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
2.1.4
|