facets 3.0.0 → 3.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.index +11 -7
- data/CONTRIBUTING.md +112 -0
- data/HISTORY.md +38 -0
- data/{README.rdoc → README.md} +59 -59
- data/demo/core/array/after.md +13 -0
- data/demo/core/array/arrange.md +17 -0
- data/demo/core/array/before.md +14 -0
- data/demo/core/array/collapse.md +15 -0
- data/demo/core/array/collisions.md +30 -0
- data/demo/core/array/commonality.md +31 -0
- data/demo/core/array/conjoin.md +47 -0
- data/demo/core/array/contains.md +9 -0
- data/demo/core/array/delete_unless.md +13 -0
- data/demo/core/array/delete_values.md +10 -0
- data/demo/core/array/delete_values_at.md +15 -0
- data/demo/core/array/divide.md +14 -0
- data/demo/core/array/duplicates.md +14 -0
- data/demo/core/array/each_overlap.md +12 -0
- data/demo/core/array/each_pair.md +13 -0
- data/demo/core/array/each_value.md +12 -0
- data/demo/core/array/entropy.md +13 -0
- data/demo/core/array/extract_options.md +13 -0
- data/demo/core/array/first.md +11 -0
- data/demo/core/array/from.md +11 -0
- data/demo/core/array/ideal_entropy.md +11 -0
- data/demo/core/array/intersection.md +11 -0
- data/demo/core/array/last.md +11 -0
- data/demo/core/array/median.md +23 -0
- data/demo/core/array/merge.md +15 -0
- data/demo/core/array/missing.md +10 -0
- data/demo/core/array/mode.md +9 -0
- data/demo/core/array/nonuniq.md +16 -0
- data/demo/core/array/not_empty.md +8 -0
- data/demo/core/array/occur.md +18 -0
- data/demo/core/array/occurrence.md +13 -0
- data/demo/core/array/only.md +9 -0
- data/demo/core/array/op_pow.md +10 -0
- data/demo/core/array/pad.md +28 -0
- data/demo/core/array/peek.md +10 -0
- data/demo/core/array/poke.md +15 -0
- data/demo/core/array/probability +8 -0
- data/demo/core/array/pull.md +10 -0
- data/demo/core/array/recurse.md +10 -0
- data/demo/core/array/recursively.md +20 -0
- data/demo/core/array/reject_values.md +10 -0
- data/demo/core/array/splice.md +14 -0
- data/demo/core/array/split.md +13 -0
- data/demo/core/array/squeeze.md +14 -0
- data/demo/core/array/step.md +16 -0
- data/demo/core/array/store.md +9 -0
- data/demo/core/array/thru.md +12 -0
- data/demo/core/array/to_h.md +11 -0
- data/demo/core/array/traverse.md +20 -0
- data/demo/core/array/uniq_by.md +16 -0
- data/demo/core/array/unique_permutation.md +14 -0
- data/demo/core/array/zip.md +8 -0
- data/demo/core/binding/caller.md +57 -0
- data/demo/core/binding/defined.md +10 -0
- data/demo/core/binding/opvars.md +16 -0
- data/demo/core/binding/self.md +6 -0
- data/demo/core/class/descendants.md +13 -0
- data/demo/core/class/to_proc.md +11 -0
- data/demo/core/comparable/at_least.md +11 -0
- data/demo/core/comparable/at_most.md +11 -0
- data/demo/core/comparable/bound.md +13 -0
- data/demo/core/comparable/cap.md +11 -0
- data/demo/core/comparable/clip.md +29 -0
- data/demo/core/comparable/cmp.md +18 -0
- data/demo/core/comparable/op_get.md +32 -0
- data/demo/core/dir/ascend.md +24 -0
- data/demo/core/dir/descend.md +16 -0
- data/demo/core/dir/multiglob.md +41 -0
- data/demo/core/dir/parent.md +6 -0
- data/demo/core/dir/recurse.md +41 -0
- data/demo/core/exception/detail.md +19 -0
- data/demo/core/{facets.rdoc → facets.md} +1 -1
- data/demo/core/filetest/root.md +13 -0
- data/demo/core/hash/recursively.md +21 -0
- data/demo/core/indexable.md +95 -0
- data/demo/core/integer/bitmask.md +46 -0
- data/demo/core/integer/{factorial.rdoc → factorial.md} +1 -1
- data/demo/core/integer/{length.rdoc → length.md} +1 -1
- data/demo/core/integer/{multiple.rdoc → multiple.md} +3 -1
- data/demo/core/integer/of.md +11 -0
- data/demo/core/integer/{ordinal.rdoc → ordinal.md} +3 -1
- data/demo/core/integer/{of.rdoc → times_collect.md} +2 -7
- data/demo/core/matchdata/match.md +7 -0
- data/demo/core/matchdata/matchset.md +7 -0
- data/demo/core/matchdata/matchtree.md +10 -0
- data/demo/core/module/cattr.md +43 -0
- data/demo/core/module/class_extend.md +64 -0
- data/demo/core/module/{class_inheritor.rdoc → class_inheritor.md} +2 -2
- data/demo/core/module/{copy_inheritor.rdoc → copy_inheritor.md} +4 -4
- data/demo/core/module/include_as.md +31 -0
- data/demo/core/module/method_space.md +24 -0
- data/demo/core/string/acronym.md +9 -0
- data/demo/core/string/{align.rdoc → align.md} +10 -10
- data/demo/core/string/ascii_only.md +37 -0
- data/demo/core/string/{bracket.rdoc → bracket.md} +10 -10
- data/demo/core/string/camelcase.md +47 -0
- data/demo/core/string/{capitalized.rdoc → capitalized.md} +9 -9
- data/demo/core/string/characters.md +11 -0
- data/demo/core/string/{cleanlines.rdoc → cleanlines.md} +3 -3
- data/demo/core/string/cleave.md +49 -0
- data/demo/core/string/compress_lines.md +22 -0
- data/demo/core/string/crypt.md +15 -0
- data/demo/core/string/divide.md +9 -0
- data/demo/core/string/each_word.md +11 -0
- data/demo/core/string/edit_distance.md +15 -0
- data/demo/core/string/exclude.md +15 -0
- data/demo/core/string/expand_tabs.md +69 -0
- data/demo/core/string/fold.md +14 -0
- data/demo/core/string/indent.md +65 -0
- data/demo/core/string/index_all.md +14 -0
- data/demo/core/string/interpolate.md +8 -0
- data/demo/core/string/lchomp.md +14 -0
- data/demo/core/string/line_wrap.md +7 -0
- data/demo/core/string/lowercase.md +12 -0
- data/demo/core/string/methodize.md +22 -0
- data/demo/core/string/modulize.md +22 -0
- data/demo/core/string/mscan.md +10 -0
- data/demo/core/string/natcmp.md +10 -0
- data/demo/core/string/nchar.md +9 -0
- data/demo/core/string/{newlines.rdoc → newlines.md} +3 -3
- data/demo/core/string/number.md +27 -0
- data/demo/core/string/op_div.md +10 -0
- data/demo/core/string/op_sub.md +7 -0
- data/demo/core/string/pathize.md +22 -0
- data/demo/core/string/quote.md +20 -0
- data/demo/core/string/random.md +25 -0
- data/demo/core/string/range.md +19 -0
- data/demo/core/string/remove.md +33 -0
- data/demo/core/string/rewrite.md +9 -0
- data/demo/core/string/shatter.md +9 -0
- data/demo/core/string/similarity.md +12 -0
- data/demo/core/string/snakecase.md +14 -0
- data/demo/core/string/splice.md +28 -0
- data/demo/core/string/squish.md +27 -0
- data/demo/core/string/store.md +10 -0
- data/demo/core/string/subtract.md +8 -0
- data/demo/core/string/titlecase.md +8 -0
- data/demo/core/string/to_re.md +22 -0
- data/demo/core/string/{margin.rdoc → trim.md} +14 -14
- data/demo/core/string/unbracket.md +24 -0
- data/demo/core/string/underscore.md +17 -0
- data/demo/core/string/unfold.md +9 -0
- data/demo/core/string/unindent.md +65 -0
- data/demo/core/string/unquote.md +6 -0
- data/demo/core/string/uppercase.md +15 -0
- data/demo/core/string/variablize.md +7 -0
- data/demo/core/string/word_wrap.md +54 -0
- data/demo/core/string/words.md +13 -0
- data/demo/core/string/xor.md +8 -0
- data/lib/core/facets.yml +11 -7
- data/lib/core/facets/array.rb +1 -0
- data/lib/core/facets/array/average.rb +16 -0
- data/lib/core/facets/array/collapse.rb +4 -0
- data/lib/core/facets/array/delete_values_at.rb +1 -0
- data/lib/core/facets/array/divide.rb +7 -0
- data/lib/core/facets/array/duplicates.rb +2 -0
- data/lib/core/facets/array/each_pair.rb +1 -4
- data/lib/core/facets/array/first.rb +1 -0
- data/lib/core/facets/array/from.rb +11 -16
- data/lib/core/facets/array/intersection.rb +1 -1
- data/lib/core/facets/array/last.rb +1 -0
- data/lib/core/facets/array/mode.rb +2 -2
- data/lib/core/facets/array/occurrence.rb +4 -3
- data/lib/core/facets/array/op_pow.rb +0 -2
- data/lib/core/facets/array/probability.rb +1 -1
- data/lib/core/facets/array/recursively.rb +2 -2
- data/lib/core/facets/array/splice.rb +1 -1
- data/lib/core/facets/array/standard_deviation.rb +23 -0
- data/lib/core/facets/array/to_h.rb +0 -3
- data/lib/core/facets/array/uniq_by.rb +4 -0
- data/lib/core/facets/array/variance.rb +20 -0
- data/lib/core/facets/binding.rb +0 -1
- data/lib/core/facets/enumerable/cluster.rb +6 -4
- data/lib/core/facets/enumerable/hashify.rb +27 -31
- data/lib/core/facets/enumerable/sum.rb +12 -2
- data/lib/core/facets/file/atomic_open.rb +1 -1
- data/lib/core/facets/hash/except.rb +13 -1
- data/lib/core/facets/indexable.rb +1 -1
- data/lib/core/facets/kernel/ergo.rb +3 -3
- data/lib/core/facets/kernel/like.rb +1 -1
- data/lib/core/facets/matchdata/matchtree.rb +2 -0
- data/lib/core/facets/numeric/delimit.rb +20 -0
- data/lib/core/facets/range/nudge.rb +29 -0
- data/lib/core/facets/string.rb +0 -2
- data/lib/core/facets/string/indent.rb +0 -8
- data/lib/core/facets/string/margin.rb +0 -4
- data/lib/core/facets/string/random.rb +13 -3
- data/lib/core/facets/string/similarity.rb +7 -6
- data/lib/standard/facets/enumargs.rb +5 -0
- data/lib/standard/facets/math/percentile.rb +1 -1
- data/lib/standard/facets/net/http.rb +33 -14
- data/lib/standard/facets/timer.rb +3 -3
- data/test/core/array/test_average.rb +16 -0
- data/test/core/array/test_before.rb +21 -0
- data/test/core/array/test_collapse.rb +10 -1
- data/test/core/array/test_delete_unless.rb +17 -0
- data/test/core/array/test_delete_values.rb +31 -0
- data/test/core/array/test_divide.rb +10 -0
- data/test/core/array/test_each_pair.rb +16 -0
- data/test/core/array/test_each_value.rb +16 -0
- data/test/core/array/test_from.rb +42 -0
- data/test/core/array/test_op_pow.rb +13 -0
- data/test/core/array/test_standard_deviation.rb +18 -0
- data/test/core/array/test_to_h.rb +14 -0
- data/test/core/array/test_uniq_by.rb +7 -0
- data/test/core/array/test_variance.rb +17 -0
- data/test/core/array/test_zip.rb +13 -0
- data/test/core/dir/test_each_child.rb +1 -1
- data/test/core/dir/test_multiglob.rb +1 -1
- data/test/core/enumerable/test_cluster.rb +36 -0
- data/test/core/enumerable/test_hashify.rb +113 -0
- data/test/core/hash/test_expect.rb +11 -1
- data/test/core/kernel/test_ergo.rb +7 -5
- data/test/core/{object/test_replace.rb → kernel/test_instance_replace.rb} +6 -28
- data/test/core/numeric/test_delimit.rb +68 -0
- data/test/core/numeric/{test_round.rb → test_round_to.rb} +27 -27
- data/test/core/range/test_nudge.rb +32 -0
- data/test/core/range/{test_to_r.rb → test_to_rng.rb} +3 -3
- data/test/core/string/test_acronym.rb +14 -0
- data/test/core/string/test_ascii_only.rb +21 -0
- data/test/core/string/test_compress_lines.rb +9 -0
- data/test/core/string/test_crypt.rb +17 -0
- data/test/core/string/test_index_all.rb +4 -0
- data/test/core/string/test_random.rb +25 -0
- data/test/core/string/test_remove.rb +14 -0
- data/test/core/string/test_similarity.rb +9 -1
- data/test/core/struct/test_replace.rb +18 -0
- data/test/standard/test_enumargs.rb +26 -10
- data/test/standard/test_timer.rb +1 -1
- metadata +634 -588
- data/CONTRIBUTE.md +0 -78
- data/demo/core/array/combination.rdoc +0 -19
- data/demo/core/array/delete.rdoc +0 -23
- data/demo/core/array/index.rdoc +0 -14
- data/demo/core/array/merge.rdoc +0 -15
- data/demo/core/array/only.rdoc +0 -9
- data/demo/core/array/pad.rdoc +0 -28
- data/demo/core/array/permutation.rdoc +0 -10
- data/demo/core/array/product.rdoc +0 -26
- data/demo/core/array/recursively.rdoc +0 -16
- data/demo/core/array/rotate.rdoc +0 -30
- data/demo/core/array/select.rdoc +0 -8
- data/demo/core/array/uniq_by.rdoc +0 -9
- data/demo/core/binding/caller.rdoc +0 -57
- data/demo/core/binding/defined.rdoc +0 -10
- data/demo/core/binding/eval.rdoc +0 -8
- data/demo/core/binding/local_variables.rdoc +0 -26
- data/demo/core/binding/opvars.rdoc +0 -16
- data/demo/core/binding/self.rdoc +0 -6
- data/demo/core/class/descendants.rdoc +0 -10
- data/demo/core/class/to_proc.rdoc +0 -8
- data/demo/core/comparable/cap.rdoc +0 -20
- data/demo/core/comparable/clip.rdoc +0 -37
- data/demo/core/comparable/cmp.rdoc +0 -18
- data/demo/core/comparable/op_get.rdoc +0 -29
- data/demo/core/dir/ascend.rdoc +0 -24
- data/demo/core/dir/descend.rdoc +0 -14
- data/demo/core/dir/multiglob.rdoc +0 -41
- data/demo/core/dir/parent.rdoc +0 -6
- data/demo/core/dir/recurse.rdoc +0 -41
- data/demo/core/exception/detail.rdoc +0 -12
- data/demo/core/filetest/root.rdoc +0 -6
- data/demo/core/hash/recursively.rdoc +0 -21
- data/demo/core/indexable.rdoc +0 -95
- data/demo/core/integer/bitmask.rdoc +0 -46
- data/demo/core/integer/even.rdoc +0 -12
- data/demo/core/integer/odd.rdoc +0 -12
- data/demo/core/matchdata/match.rdoc +0 -7
- data/demo/core/matchdata/matchset.rdoc +0 -15
- data/demo/core/module/cattr.rdoc +0 -43
- data/demo/core/module/class_extend.rdoc +0 -64
- data/demo/core/module/method_space.rdoc +0 -55
- data/demo/core/string/bytes.rdoc +0 -8
- data/demo/core/string/camelcase.rdoc +0 -47
- data/demo/core/string/characters.rdoc +0 -11
- data/demo/core/string/cleave.rdoc +0 -49
- data/demo/core/string/divide.rdoc +0 -9
- data/demo/core/string/each_char.rdoc +0 -9
- data/demo/core/string/each_word.rdoc +0 -9
- data/demo/core/string/end_with.rdoc +0 -6
- data/demo/core/string/expand_tabs.rdoc +0 -69
- data/demo/core/string/fold.rdoc +0 -14
- data/demo/core/string/indent.rdoc +0 -65
- data/demo/core/string/interpolate.rdoc +0 -7
- data/demo/core/string/lchomp.rdoc +0 -14
- data/demo/core/string/line_wrap.rdoc +0 -7
- data/demo/core/string/lines.rdoc +0 -8
- data/demo/core/string/methodize.rdoc +0 -22
- data/demo/core/string/modulize.rdoc +0 -22
- data/demo/core/string/mscan.rdoc +0 -10
- data/demo/core/string/natcmp.rdoc +0 -10
- data/demo/core/string/nchar.rdoc +0 -9
- data/demo/core/string/op_sub.rdoc +0 -7
- data/demo/core/string/pathize.rdoc +0 -22
- data/demo/core/string/quote.rdoc +0 -20
- data/demo/core/string/range.rdoc +0 -19
- data/demo/core/string/rewrite.rdoc +0 -9
- data/demo/core/string/shatter.rdoc +0 -9
- data/demo/core/string/snakecase.rdoc +0 -10
- data/demo/core/string/splice.rdoc +0 -28
- data/demo/core/string/start_with.rdoc +0 -7
- data/demo/core/string/subtract.rdoc +0 -8
- data/demo/core/string/tab.rdoc +0 -16
- data/demo/core/string/tabto.rdoc +0 -29
- data/demo/core/string/titlecase.rdoc +0 -8
- data/demo/core/string/to_re.rdoc +0 -22
- data/demo/core/string/unfold.rdoc +0 -9
- data/demo/core/string/unindent.rdoc +0 -65
- data/demo/core/string/unquote.rdoc +0 -6
- data/demo/core/string/variablize.rdoc +0 -7
- data/demo/core/string/word_wrap.rdoc +0 -54
- data/demo/core/string/words.rdoc +0 -13
- data/demo/core/string/xor.rdoc +0 -8
- data/lib/core/facets/binding/local_variables.rb +0 -16
- data/lib/core/facets/string/tab.rb +0 -2
- data/lib/core/facets/string/tabto.rb +0 -2
- data/test/core/array/test_after.rb +0 -27
- data/test/core/array/test_combination.rb +0 -25
- data/test/core/array/test_index.rb +0 -20
- data/test/core/array/test_permutation.rb +0 -20
- data/test/core/array/test_product.rb +0 -64
- data/test/core/array/test_rotate.rb +0 -38
- data/test/core/array/test_select.rb +0 -16
- data/test/core/binding/test_eval.rb +0 -15
- data/test/core/binding/test_local_variables.rb +0 -36
- data/test/core/enumerable/test_cluster_by.rb +0 -30
- data/test/core/enumerable/test_count.rb +0 -32
- data/test/core/enumerable/test_each_with_object.rb +0 -18
- data/test/core/enumerable/test_group_by.rb +0 -36
- data/test/core/enumerable/test_none.rb +0 -29
- data/test/core/enumerable/test_one.rb +0 -34
- data/test/core/enumerable/test_take.rb +0 -15
- data/test/core/hash/test_select.rb +0 -44
- data/test/core/hash/test_url_params.rb +0 -26
- data/test/core/integer/test_even.rb +0 -24
- data/test/core/integer/test_odd.rb +0 -24
- data/test/core/kernel/test_require_relative.rb +0 -12
- data/test/core/nilclass/test_to_f.rb +0 -13
- data/test/core/proc/test_curry.rb +0 -38
- data/test/core/string/test_bytes.rb +0 -13
- data/test/core/string/test_each_char.rb +0 -17
- data/test/core/string/test_end_with.rb +0 -24
- data/test/core/string/test_lines.rb +0 -15
- data/test/core/string/test_start_with.rb +0 -24
- data/test/core/string/test_tab.rb +0 -16
- data/test/core/symbol/test_to_proc.rb +0 -35
- data/test/core/to_hash_tc.rb +0 -210
- data/test/core/unboundmethod/test_name.rb +0 -19
@@ -0,0 +1,13 @@
|
|
1
|
+
## Array#after
|
2
|
+
|
3
|
+
require 'facets/array/after'
|
4
|
+
|
5
|
+
`Array#after` returns the first value that comes after a given value. The
|
6
|
+
value after the last is the first. Returns `nil` if the given value is not
|
7
|
+
in the array.
|
8
|
+
|
9
|
+
sequence = ['a', 'b', 'c']
|
10
|
+
sequence.after('a').assert == 'b'
|
11
|
+
sequence.after('b').assert == 'c'
|
12
|
+
sequence.after('c').assert == 'a'
|
13
|
+
sequence.after('d').assert == nil
|
@@ -0,0 +1,17 @@
|
|
1
|
+
## Array#arrange
|
2
|
+
|
3
|
+
require 'facets/array/arrange'
|
4
|
+
|
5
|
+
The `arrange` method produces appropriate ranges from the objects in the array.
|
6
|
+
It assumes inclusive ranges (i.e. `1..4`) and `range.first <= range.last`.
|
7
|
+
|
8
|
+
Works with integers, dates and strings. However, all the objects in the array must
|
9
|
+
be of the same class.
|
10
|
+
|
11
|
+
[1,2,3,6,7,8].arrange.assert == [1..3, 6..8]
|
12
|
+
|
13
|
+
[10..15, 16..20, 21, 22].arrange.assert == [10..22]
|
14
|
+
|
15
|
+
a = %w{a b c g h i j k m o}
|
16
|
+
a.arrange.assert == ['a'..'c','g'..'k', 'm' , 'o']
|
17
|
+
|
@@ -0,0 +1,14 @@
|
|
1
|
+
## Array#before
|
2
|
+
|
3
|
+
require 'facets/array/before'
|
4
|
+
|
5
|
+
Returns the value prior to the given value. The value previous
|
6
|
+
to the first is the last. Returns nil if the given value is not
|
7
|
+
in the array.
|
8
|
+
|
9
|
+
sequence = ['a', 'b', 'c']
|
10
|
+
sequence.before('a').assert == 'c'
|
11
|
+
sequence.before('b').assert == 'a'
|
12
|
+
sequence.before('c').assert == 'b'
|
13
|
+
sequence.before('d').assert == nil
|
14
|
+
|
@@ -0,0 +1,15 @@
|
|
1
|
+
## Array#collapse
|
2
|
+
|
3
|
+
require 'facets/array/collapse'
|
4
|
+
|
5
|
+
Simplify an array by flattening it then compacting it.
|
6
|
+
|
7
|
+
[1,[2,nil,[3]],nil,4].collapse.assert == [1,2,3,4]
|
8
|
+
|
9
|
+
## Array#collapse!
|
10
|
+
|
11
|
+
Simplify an array by flattening it in place then compacting it in place.
|
12
|
+
|
13
|
+
a = [1, nil, [1, 2], nil, [[3]]]
|
14
|
+
a.collapse!
|
15
|
+
a.assert == [1, 1, 2, 3]
|
@@ -0,0 +1,30 @@
|
|
1
|
+
## Array#collisions
|
2
|
+
|
3
|
+
_alias for Array#commonality_.
|
4
|
+
|
5
|
+
require 'facets/array/collisions'
|
6
|
+
|
7
|
+
Get a list of all items that have something in common in terms of the
|
8
|
+
supplied block. If no block is given objects are considered to be in
|
9
|
+
common if they return the same value for Object#hash and if obj1 == obj2.
|
10
|
+
|
11
|
+
This can be useful, for instance, in determining all persons that share
|
12
|
+
their last name with another person.
|
13
|
+
|
14
|
+
Person = Struct.new(:name)
|
15
|
+
persons = %w{Wayne Pennyworth Grayson Wayne Pennyworth}.map{|n| Person.new(n)}
|
16
|
+
persons.collisions { |person| person.name }.keys.assert == ["Wayne","Pennyworth"]
|
17
|
+
|
18
|
+
The method is similar to #group_by which is a standard Ruby method as of 1.9.
|
19
|
+
To get effectively the same results with #group_by use `select{ |k,v| v.size > 1 }`.
|
20
|
+
|
21
|
+
expected = { 2 => [2, 2], 4 => [4, 4] }
|
22
|
+
|
23
|
+
[1, 2, 2, 3, 4, 4].group_by{ |e| e }.
|
24
|
+
select{ |k,v| v.size > 1 }.assert == expected
|
25
|
+
|
26
|
+
[1, 2, 2, 3, 4, 4].collisions.assert == expected
|
27
|
+
|
28
|
+
%w{foo bar baz}.collisions{|str| str[0]}.assert == {'b' =>["bar", "baz"] }
|
29
|
+
|
30
|
+
Returns a Hash mapping common attribute to those elements.
|
@@ -0,0 +1,31 @@
|
|
1
|
+
## Array#commonality
|
2
|
+
|
3
|
+
require 'facets/array/commonality'
|
4
|
+
|
5
|
+
Get a list of all items that have something in common in terms of the
|
6
|
+
supplied block. If no block is given objects are considered to be in
|
7
|
+
common if they return the same value for Object#hash and if obj1 == obj2.
|
8
|
+
|
9
|
+
This can be useful, for instance, in determining all persons that share
|
10
|
+
their last name with another person.
|
11
|
+
|
12
|
+
Person = Struct.new(:name)
|
13
|
+
persons = %w{Wayne Pennyworth Grayson Wayne Pennyworth}.map{|n| Person.new(n)}
|
14
|
+
persons.commonality { |person| person.name }.keys # => ["Wayne","Pennyworth"]
|
15
|
+
|
16
|
+
The method is similar to #group_by which is a standard Ruby method as of 1.9.
|
17
|
+
To get effectively the same results with #group_by use `select{ |k,v| v.size > 1 }`.
|
18
|
+
|
19
|
+
expected = { 2 => [2, 2], 4 => [4, 4] }
|
20
|
+
|
21
|
+
[1, 2, 2, 3, 4, 4].group_by{ |e| e }.
|
22
|
+
select{ |k,v| v.size > 1 }.assert == expected
|
23
|
+
|
24
|
+
[1, 2, 2, 3, 4, 4].commonality.assert == expected
|
25
|
+
|
26
|
+
|
27
|
+
%w{foo bar baz}.commonality{|str| str[0]}.assert == {'b' =>["bar", "baz"] }
|
28
|
+
|
29
|
+
Returns a Hash mapping common attribute to those elements.
|
30
|
+
|
31
|
+
|
@@ -0,0 +1,47 @@
|
|
1
|
+
## Array#conjoin
|
2
|
+
|
3
|
+
require 'facets/array/conjoin'
|
4
|
+
|
5
|
+
This is more advanced form of #join. It allows for fine control
|
6
|
+
of separators.
|
7
|
+
|
8
|
+
NOTE: The old version used to default its separator to ", " and
|
9
|
+
default the terminating separator to " and ". This is no longer
|
10
|
+
the case. You must specifically provide these parameters.
|
11
|
+
|
12
|
+
If no parameters are given, it acts like #join but will a space
|
13
|
+
separator.
|
14
|
+
|
15
|
+
[1,2,3].conjoin.assert == "1 2 3"
|
16
|
+
|
17
|
+
Use comma+space and 'and' on tail.
|
18
|
+
|
19
|
+
[1,2,3].conjoin(', ', ' and ').assert == "1, 2 and 3"
|
20
|
+
|
21
|
+
Use comma+space and 'or' on tail using :last option.
|
22
|
+
|
23
|
+
[1,2,3].conjoin(', ', :last => ' or ').assert == "1, 2 or 3"
|
24
|
+
|
25
|
+
Use semicolon+space and ampersand on tail using index.
|
26
|
+
|
27
|
+
[1,2,3].conjoin('; ', -1 => ' & ').assert == "1; 2 & 3"
|
28
|
+
|
29
|
+
Can take a block to determine separator.
|
30
|
+
|
31
|
+
[1,2,3,4].conjoin{ |i, a, b| i % 2 == 0 ? '.' : '-' }.assert == "1.2-3.4"
|
32
|
+
|
33
|
+
This makes very esoteric transformation possible.
|
34
|
+
|
35
|
+
[1,1,2,2].conjoin{ |i, a, b| a == b ? '=' : ' != ' }.assert == "1=1 != 2=2"
|
36
|
+
|
37
|
+
[1,2,3,4].conjoin{ |i, x, y| "<#{i} #{x} #{y}>" }.assert == "1<0 1 2>2<1 2 3>3<2 3 4>4"
|
38
|
+
|
39
|
+
There are also spacing options. Providing the :space option
|
40
|
+
pads the separators.
|
41
|
+
|
42
|
+
[1,2,3].conjoin(',', '&', :space=>2).assert == "1 , 2 & 3"
|
43
|
+
|
44
|
+
And the :spacer option can set an alternate spacing string.
|
45
|
+
|
46
|
+
[1,2,3].conjoin('|', '>', :space=>2, :spacer=>'-').assert == "1--|--2-->--3"
|
47
|
+
|
@@ -0,0 +1,13 @@
|
|
1
|
+
## Array#delete_unless
|
2
|
+
|
3
|
+
require 'facets/array/delete_unless'
|
4
|
+
|
5
|
+
The method `#delete_unless` is the inverse of `#delete_if`.
|
6
|
+
|
7
|
+
a = [1,2,3]
|
8
|
+
a.delete_unless{ |e| e == 2 }
|
9
|
+
a.assert == [2]
|
10
|
+
|
11
|
+
[1,2,3].delete_unless{ |x| x < 2 }.assert == [1]
|
12
|
+
[1,2,3].delete_unless(&:even?).assert == [2]
|
13
|
+
|
@@ -0,0 +1,15 @@
|
|
1
|
+
## Array#delete_values_at
|
2
|
+
|
3
|
+
require 'facets/array/delete_values_at'
|
4
|
+
|
5
|
+
Delete multiple values from array given
|
6
|
+
indexes or index range.
|
7
|
+
|
8
|
+
a = [1,2,3,4]
|
9
|
+
a.delete_values_at(1,2).assert == [2,3]
|
10
|
+
a.assert == [1,4]
|
11
|
+
|
12
|
+
a = [1,2,3,4]
|
13
|
+
a.delete_values_at(0..2).assert == [1,2,3]
|
14
|
+
a.assert == [4]
|
15
|
+
|
@@ -0,0 +1,14 @@
|
|
1
|
+
## Array#divide
|
2
|
+
|
3
|
+
require 'facets/array/divide'
|
4
|
+
|
5
|
+
Divide into sub arrays at elemetns matching given pattern
|
6
|
+
|
7
|
+
r = ['a1','b1','a2','b2'].divide(/^a/)
|
8
|
+
r.assert == [['a1','b1'],['a2','b2']]
|
9
|
+
|
10
|
+
r = ['a1','b1','a2','b2'].divide(/^b/)
|
11
|
+
r.assert == [['a1'],['b1','a2'],['b2']]
|
12
|
+
|
13
|
+
r = ['a1','b1','a2','b2'].divide(/c/)
|
14
|
+
r.assert = [['a1','b1','a2','b2']]
|
@@ -0,0 +1,12 @@
|
|
1
|
+
## Array#each_overlap
|
2
|
+
|
3
|
+
require 'facets/array/each_overlap'
|
4
|
+
|
5
|
+
Iterate over each slice where the last n values of a preceding slice
|
6
|
+
overlap with the first n values of the following slice. The value of n
|
7
|
+
is specified by the second `overlap` argument.
|
8
|
+
|
9
|
+
a, r = [1,2,3,4,5], []
|
10
|
+
a.each_overlap(2,1) { |x,y| r << [x,y] }
|
11
|
+
r.assert == [[1,2],[2,3],[3,4],[4,5]]
|
12
|
+
|
@@ -0,0 +1,13 @@
|
|
1
|
+
## Array#each_pair
|
2
|
+
|
3
|
+
require 'facets/array/each_pair'
|
4
|
+
|
5
|
+
Iterate over an array yielding with index and value.
|
6
|
+
|
7
|
+
result = {}
|
8
|
+
a = [:a,:b,:c,:d]
|
9
|
+
a.each_pair{|i,e| result[e] = i + 1}
|
10
|
+
result.assert == {a: 1, b: 2, c: 3, d: 4}
|
11
|
+
|
12
|
+
*NOTE* this is the inverse of `Array#each_with_index`, and is intended to provide
|
13
|
+
polymorphism with `Hash#each_pair`.
|
@@ -0,0 +1,12 @@
|
|
1
|
+
## Array#each_value
|
2
|
+
|
3
|
+
require 'facets/array/each_value'
|
4
|
+
|
5
|
+
This is an alias of Alias#each, and is provided to provide polymorphism with
|
6
|
+
Hash#each_value.
|
7
|
+
|
8
|
+
a = [ "a", "b", "c" ]
|
9
|
+
out = ''
|
10
|
+
a.each_value {|x| out += "#{x} -- " }
|
11
|
+
out.assert == 'a -- b -- c -- '
|
12
|
+
|
@@ -0,0 +1,13 @@
|
|
1
|
+
## Array#entropy
|
2
|
+
|
3
|
+
require 'facets/array/entropy'
|
4
|
+
|
5
|
+
Shannon's entropy for an array - returns the average
|
6
|
+
bits per symbol required to encode the array.
|
7
|
+
Lower values mean less "entropy" - i.e. less unique
|
8
|
+
information in the array.
|
9
|
+
|
10
|
+
e = %w{ a b c d e e e }.entropy
|
11
|
+
|
12
|
+
("%.3f" % e) #=> "2.128"
|
13
|
+
|
@@ -0,0 +1,13 @@
|
|
1
|
+
## Array#extract_options!
|
2
|
+
|
3
|
+
require 'facets/array/extract_options'
|
4
|
+
|
5
|
+
Extracts options from a set of arguments. Removes and returns the last
|
6
|
+
element in the array if it's a hash, otherwise returns a blank hash.
|
7
|
+
|
8
|
+
def options(*args)
|
9
|
+
args.extract_options!
|
10
|
+
end
|
11
|
+
|
12
|
+
options(1, 2).assert == {}
|
13
|
+
options(1, 2, :a => :b).assert == {:a=>:b}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
## Array#ideal_entropy
|
2
|
+
|
3
|
+
require 'facets/array/entropy'
|
4
|
+
|
5
|
+
Returns the maximum possible Shannon entropy of the array
|
6
|
+
with given size assuming that it is an "order-0" source
|
7
|
+
(each element is selected independently of the next).
|
8
|
+
|
9
|
+
%w{ a b }.ideal_entropy.assert == 1.0
|
10
|
+
%w{ a a b b }.ideal_entropy.assert == 2.0
|
11
|
+
|
@@ -0,0 +1,11 @@
|
|
1
|
+
## Array#intersection
|
2
|
+
|
3
|
+
require 'facets/array/intersection'
|
4
|
+
|
5
|
+
Returns the values in common for an array set (nil, single value/object, or range).
|
6
|
+
|
7
|
+
[1,2].intersection.assert == nil
|
8
|
+
[1..10,11..20].intersection.assert == nil
|
9
|
+
[10,1..10].intersection.assert == 10
|
10
|
+
[1..10,5,5..8,4..8].intersection.assert == 5
|
11
|
+
[1..10, 5..8, 5..10 ].intersection.assert == (5..8)
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# Array#median
|
2
|
+
|
3
|
+
require 'facets/array/median'
|
4
|
+
|
5
|
+
Determines the _sorted_ middle element.
|
6
|
+
|
7
|
+
a = %w{a a b b c c c}
|
8
|
+
a.median #=> "b"
|
9
|
+
|
10
|
+
When there are an even number of elements, the greater
|
11
|
+
of the two middle elements is given.
|
12
|
+
|
13
|
+
a = %w{a a b b c c c d}
|
14
|
+
a.median #=> "c"
|
15
|
+
|
16
|
+
An offset can be supplied to get an element relative
|
17
|
+
to the middle.
|
18
|
+
|
19
|
+
a = %w{a a b b c c c d}
|
20
|
+
a.median(-1) #=> "b"
|
21
|
+
|
22
|
+
The the array is empty, +nil+ is returned.
|
23
|
+
|
@@ -0,0 +1,10 @@
|
|
1
|
+
## Array#missing
|
2
|
+
|
3
|
+
require 'facets/array/missing'
|
4
|
+
|
5
|
+
Determine the 'holes' in the values of an array. Returns the missing elements
|
6
|
+
in an array set.
|
7
|
+
|
8
|
+
[1,3..3].missing.assert == [2]
|
9
|
+
[1..5,10..12].missing.assert == [6..9]
|
10
|
+
[100, 9..11, 14, 1..5, 16, 10..12, 17..17].missing.assert == [6..8, 13, 15, 18..99]
|