facets 2.9.3 → 3.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.index +76 -0
- data/CONTRIBUTE.md +78 -0
- data/HISTORY.md +2459 -0
- data/{RUBY.txt → LICENSE.txt} +0 -0
- data/README.rdoc +29 -7
- data/demo/applique/assertion_framework.rb +1 -0
- data/{qed → demo}/applique/file_helpers.rb +0 -0
- data/{qed → demo}/core/array/combination.rdoc +0 -0
- data/{qed → demo}/core/array/delete.rdoc +0 -0
- data/{qed → demo}/core/array/index.rdoc +0 -0
- data/{qed → demo}/core/array/merge.rdoc +0 -0
- data/{qed → demo}/core/array/only.rdoc +0 -0
- data/{qed → demo}/core/array/pad.rdoc +0 -0
- data/{qed → demo}/core/array/permutation.rdoc +0 -0
- data/{qed → demo}/core/array/product.rdoc +0 -0
- data/{qed → demo}/core/array/recursively.rdoc +0 -0
- data/{qed → demo}/core/array/rotate.rdoc +0 -0
- data/{qed → demo}/core/array/select.rdoc +0 -0
- data/{qed → demo}/core/array/uniq_by.rdoc +0 -0
- data/{qed → demo}/core/binding/caller.rdoc +0 -0
- data/{qed → demo}/core/binding/defined.rdoc +0 -0
- data/{qed → demo}/core/binding/eval.rdoc +0 -0
- data/{qed → demo}/core/binding/local_variables.rdoc +0 -0
- data/{qed → demo}/core/binding/opvars.rdoc +0 -0
- data/{qed → demo}/core/binding/self.rdoc +0 -0
- data/{qed → demo}/core/class/descendants.rdoc +0 -0
- data/{qed → demo}/core/class/to_proc.rdoc +0 -0
- data/{qed → demo}/core/comparable/cap.rdoc +0 -0
- data/{qed → demo}/core/comparable/clip.rdoc +0 -0
- data/{qed → demo}/core/comparable/cmp.rdoc +0 -0
- data/{qed → demo}/core/comparable/op_get.rdoc +0 -0
- data/{qed → demo}/core/dir/ascend.rdoc +0 -0
- data/{qed → demo}/core/dir/descend.rdoc +0 -0
- data/{qed → demo}/core/dir/multiglob.rdoc +0 -0
- data/{qed → demo}/core/dir/parent.rdoc +0 -0
- data/{qed → demo}/core/dir/recurse.rdoc +0 -0
- data/{qed → demo}/core/exception/detail.rdoc +0 -0
- data/{qed → demo}/core/facets.rdoc +0 -0
- data/{qed → demo}/core/filetest/root.rdoc +0 -0
- data/{qed → demo}/core/hash/recursively.rdoc +0 -0
- data/{qed → demo}/core/indexable.rdoc +0 -0
- data/{qed → demo}/core/integer/bitmask.rdoc +0 -0
- data/{qed → demo}/core/integer/even.rdoc +0 -0
- data/{qed → demo}/core/integer/factorial.rdoc +0 -0
- data/{qed → demo}/core/integer/length.rdoc +0 -0
- data/{qed → demo}/core/integer/multiple.rdoc +0 -0
- data/{qed → demo}/core/integer/odd.rdoc +0 -0
- data/{qed → demo}/core/integer/of.rdoc +0 -0
- data/{qed → demo}/core/integer/ordinal.rdoc +0 -0
- data/{qed → demo}/core/matchdata/match.rdoc +0 -0
- data/{qed → demo}/core/matchdata/matchset.rdoc +0 -0
- data/{qed → demo}/core/module/cattr.rdoc +0 -0
- data/{qed → demo}/core/module/class_extend.rdoc +0 -0
- data/{qed → demo}/core/module/class_inheritor.rdoc +0 -0
- data/{qed → demo}/core/module/copy_inheritor.rdoc +0 -0
- data/{qed → demo}/core/module/method_space.rdoc +0 -0
- data/{qed → demo}/core/string/align.rdoc +0 -0
- data/{qed → demo}/core/string/bracket.rdoc +0 -0
- data/{qed → demo}/core/string/bytes.rdoc +0 -0
- data/{qed → demo}/core/string/camelcase.rdoc +0 -0
- data/{qed → demo}/core/string/capitalized.rdoc +0 -0
- data/{qed → demo}/core/string/characters.rdoc +0 -0
- data/{qed → demo}/core/string/cleanlines.rdoc +0 -0
- data/{qed → demo}/core/string/cleave.rdoc +0 -0
- data/{qed → demo}/core/string/divide.rdoc +0 -0
- data/{qed → demo}/core/string/each_char.rdoc +0 -0
- data/{qed → demo}/core/string/each_word.rdoc +0 -0
- data/{qed → demo}/core/string/end_with.rdoc +0 -0
- data/{qed → demo}/core/string/expand_tabs.rdoc +0 -0
- data/{qed → demo}/core/string/fold.rdoc +0 -0
- data/{qed → demo}/core/string/indent.rdoc +0 -0
- data/{qed → demo}/core/string/interpolate.rdoc +0 -0
- data/{qed → demo}/core/string/lchomp.rdoc +0 -0
- data/{qed → demo}/core/string/line_wrap.rdoc +0 -0
- data/{qed → demo}/core/string/lines.rdoc +0 -0
- data/{qed → demo}/core/string/margin.rdoc +0 -0
- data/{qed → demo}/core/string/methodize.rdoc +0 -0
- data/{qed → demo}/core/string/modulize.rdoc +0 -0
- data/{qed → demo}/core/string/mscan.rdoc +0 -0
- data/{qed → demo}/core/string/natcmp.rdoc +0 -0
- data/{qed → demo}/core/string/nchar.rdoc +0 -0
- data/{qed → demo}/core/string/newlines.rdoc +0 -0
- data/{qed → demo}/core/string/op_sub.rdoc +0 -0
- data/{qed → demo}/core/string/pathize.rdoc +0 -0
- data/{qed → demo}/core/string/quote.rdoc +0 -0
- data/{qed → demo}/core/string/range.rdoc +0 -0
- data/{qed → demo}/core/string/rewrite.rdoc +0 -0
- data/{qed → demo}/core/string/shatter.rdoc +0 -0
- data/{qed → demo}/core/string/snakecase.rdoc +0 -0
- data/{qed → demo}/core/string/splice.rdoc +0 -0
- data/{qed → demo}/core/string/start_with.rdoc +0 -0
- data/{qed → demo}/core/string/subtract.rdoc +0 -0
- data/{qed → demo}/core/string/tab.rdoc +0 -0
- data/{qed → demo}/core/string/tabto.rdoc +0 -0
- data/{qed → demo}/core/string/titlecase.rdoc +0 -0
- data/{qed → demo}/core/string/to_re.rdoc +0 -0
- data/{qed → demo}/core/string/unfold.rdoc +0 -0
- data/{qed → demo}/core/string/unindent.rdoc +0 -0
- data/{qed → demo}/core/string/unquote.rdoc +0 -0
- data/{qed → demo}/core/string/variablize.rdoc +0 -0
- data/{qed → demo}/core/string/word_wrap.rdoc +0 -0
- data/{qed → demo}/core/string/words.rdoc +0 -0
- data/{qed → demo}/core/string/xor.rdoc +0 -0
- data/{qed → demo}/standard/02_cloneable.rdoc +0 -0
- data/{qed → demo}/standard/03_enumargs.rdoc +0 -0
- data/{qed → demo}/standard/04_equitable.rdoc +0 -0
- data/{qed → demo}/standard/05_instantiable.rdoc +0 -0
- data/{qed → demo}/standard/basic_object.rdoc +0 -0
- data/{qed → demo}/standard/memoizable.rdoc +0 -0
- data/{qed → demo}/standard/mulititon.rdoc +0 -0
- data/lib/core/facets.rb +1 -2
- data/lib/core/facets.yml +61 -42
- data/lib/core/facets/array.rb +8 -28
- data/lib/core/facets/array/arrange.rb +42 -0
- data/lib/core/facets/array/before.rb +2 -0
- data/lib/core/facets/array/collapse.rb +2 -0
- data/lib/core/facets/array/commonality.rb +24 -12
- data/lib/core/facets/array/duplicates.rb +22 -1
- data/lib/core/facets/array/each_overlap.rb +25 -0
- data/lib/core/facets/array/intersection.rb +25 -0
- data/lib/core/facets/array/missing.rb +29 -0
- data/lib/core/facets/array/nonuniq.rb +7 -53
- data/lib/core/facets/array/occur.rb +38 -0
- data/lib/core/facets/array/occurrence.rb +28 -0
- data/lib/core/facets/array/only.rb +12 -1
- data/lib/core/facets/array/recursively.rb +11 -5
- data/lib/core/facets/array/reject_values.rb +21 -0
- data/lib/core/facets/array/splice.rb +5 -1
- data/lib/core/facets/array/split.rb +5 -2
- data/lib/core/facets/array/squeeze.rb +23 -0
- data/lib/core/facets/array/step.rb +31 -0
- data/lib/core/facets/array/store.rb +4 -0
- data/lib/core/facets/array/to_h.rb +22 -0
- data/lib/core/facets/array/traverse.rb +11 -5
- data/lib/core/facets/array/uniq_by.rb +5 -1
- data/lib/core/facets/array/unique_permutation.rb +29 -0
- data/lib/core/facets/array/zip.rb +21 -0
- data/lib/core/facets/binding.rb +0 -3
- data/lib/core/facets/binding/call_stack.rb +1 -1
- data/lib/core/facets/binding/caller.rb +1 -3
- data/lib/core/facets/binding/callstack.rb +1 -1
- data/lib/core/facets/binding/defined.rb +0 -2
- data/lib/core/facets/binding/local_variables.rb +0 -2
- data/lib/core/facets/binding/op_get.rb +0 -2
- data/lib/core/facets/binding/self.rb +1 -3
- data/lib/core/facets/cattr.rb +1 -0
- data/lib/core/facets/class.rb +0 -2
- data/lib/core/facets/class/cattr.rb +1 -0
- data/lib/core/facets/class/singleton.rb +1 -13
- data/lib/core/facets/class/singleton_class.rb +16 -0
- data/lib/core/facets/comparable.rb +0 -2
- data/lib/core/facets/dir.rb +0 -2
- data/lib/core/facets/dir/ascend.rb +2 -2
- data/lib/core/facets/dir/lookup.rb +20 -0
- data/lib/core/facets/enumerable.rb +10 -9
- data/lib/core/facets/enumerable/accumulate.rb +18 -16
- data/lib/core/facets/enumerable/apply.rb +20 -0
- data/lib/core/facets/enumerable/associate.rb +6 -0
- data/lib/core/facets/enumerable/cluster.rb +24 -0
- data/lib/core/facets/enumerable/every.rb +1 -1
- data/lib/core/facets/enumerable/ewise.rb +2 -0
- data/lib/core/facets/enumerable/graph.rb +0 -3
- data/lib/core/facets/enumerable/hashify.rb +222 -19
- data/lib/core/facets/enumerable/hinge.rb +18 -0
- data/lib/core/facets/enumerable/key_by.rb +27 -0
- data/lib/core/facets/enumerable/map_to.rb +13 -0
- data/lib/core/facets/enumerable/mash.rb +34 -1
- data/lib/core/facets/enumerable/occur.rb +12 -9
- data/lib/core/facets/enumerable/only.rb +56 -0
- data/lib/core/facets/enumerable/{cluster_by.rb → organize_by.rb} +5 -4
- data/lib/core/facets/enumerable/pair.rb +20 -0
- data/lib/core/facets/enumerable/per.rb +27 -35
- data/lib/core/facets/enumerable/recursively.rb +3 -3
- data/lib/core/facets/enumerable/squeeze.rb +36 -0
- data/lib/core/facets/enumerable/sum.rb +18 -6
- data/lib/core/facets/enumerable/unassociate.rb +23 -0
- data/lib/core/facets/enumerable/value_by.rb +25 -0
- data/lib/core/facets/enumerator/fx.rb +16 -25
- data/lib/core/facets/enumerator/lazy/squeeze.rb +33 -0
- data/lib/core/facets/essentials.rb +65 -0
- data/lib/core/facets/exception.rb +0 -2
- data/lib/core/facets/exception/set_message.rb +10 -0
- data/lib/core/facets/file.rb +1 -2
- data/lib/core/facets/file/common_path.rb +17 -0
- data/lib/core/facets/file/rootname.rb +1 -1
- data/lib/core/facets/filetest.rb +0 -2
- data/lib/core/facets/filetest/relative.rb +1 -1
- data/lib/core/facets/filetest/safe.rb +14 -10
- data/lib/core/facets/float.rb +1 -3
- data/lib/core/facets/float/round_to.rb +1 -0
- data/lib/core/facets/functor.rb +8 -10
- data/lib/core/facets/hash.rb +2 -5
- data/lib/core/facets/hash/collate.rb +22 -8
- data/lib/core/facets/hash/count.rb +8 -4
- data/lib/core/facets/hash/data.rb +5 -2
- data/lib/core/facets/hash/dearray_values.rb +1 -1
- data/lib/core/facets/hash/deep_rekey.rb +54 -0
- data/lib/core/facets/hash/each_with_key.rb +12 -0
- data/lib/core/facets/hash/fetch_nested.rb +20 -0
- data/lib/core/facets/hash/keys.rb +4 -13
- data/lib/core/facets/hash/only_keys.rb +1 -0
- data/lib/core/facets/hash/op_push.rb +9 -1
- data/lib/core/facets/hash/op_sub.rb +1 -1
- data/lib/core/facets/hash/recursively.rb +6 -6
- data/lib/core/facets/hash/rekey.rb +26 -34
- data/lib/core/facets/hash/revalue.rb +61 -0
- data/lib/core/facets/hash/slice.rb +16 -3
- data/lib/core/facets/hash/subset.rb +11 -8
- data/lib/core/facets/hash/update_each.rb +1 -1
- data/lib/core/facets/hash/weave.rb +1 -1
- data/lib/core/facets/indexable.rb +6 -6
- data/lib/core/facets/integer.rb +0 -4
- data/lib/core/facets/kernel.rb +4 -7
- data/lib/core/facets/kernel/__dir__.rb +2 -0
- data/lib/core/facets/kernel/as.rb +2 -1
- data/lib/core/facets/kernel/call_stack.rb +1 -56
- data/lib/core/facets/kernel/callstack.rb +56 -1
- data/lib/core/facets/kernel/constant.rb +2 -0
- data/lib/core/facets/kernel/deep_clone.rb +27 -1
- data/lib/core/facets/kernel/deep_copy.rb +0 -24
- data/lib/core/facets/kernel/eigen.rb +2 -33
- data/lib/core/facets/kernel/eigenclass.rb +1 -1
- data/lib/core/facets/kernel/ergo.rb +1 -1
- data/lib/core/facets/kernel/extend.rb +4 -6
- data/lib/core/facets/kernel/instance_assign.rb +8 -6
- data/lib/core/facets/kernel/instance_extract.rb +22 -0
- data/lib/core/facets/kernel/instance_replace.rb +40 -0
- data/lib/core/facets/kernel/{equate.rb → like.rb} +7 -4
- data/lib/core/facets/kernel/load_relative.rb +25 -1
- data/lib/core/facets/kernel/meta.rb +35 -0
- data/lib/core/facets/kernel/meta_def.rb +4 -0
- data/lib/core/facets/kernel/object_send.rb +11 -14
- data/lib/core/facets/kernel/respond.rb +3 -13
- data/lib/core/facets/kernel/tap.rb +27 -39
- data/lib/core/facets/load_path.rb +1 -0
- data/lib/core/facets/load_path/search.rb +16 -0
- data/lib/core/facets/matchdata.rb +0 -2
- data/lib/core/facets/method.rb +0 -2
- data/lib/core/facets/method/composition.rb +32 -16
- data/lib/core/facets/method/curry.rb +13 -0
- data/lib/core/facets/method/partial.rb +10 -0
- data/lib/core/facets/method/public.rb +33 -0
- data/lib/core/facets/module.rb +0 -2
- data/lib/core/facets/module/alias_class_method.rb +11 -0
- data/lib/core/facets/module/basename.rb +1 -31
- data/lib/core/facets/module/cattr.rb +1 -0
- data/lib/core/facets/module/lastname.rb +30 -0
- data/lib/core/facets/module/mattr.rb +4 -4
- data/lib/core/facets/nilclass.rb +0 -3
- data/lib/core/facets/numeric.rb +0 -4
- data/lib/core/facets/numeric/approx.rb +3 -2
- data/lib/core/facets/numeric/range.rb +12 -0
- data/lib/core/facets/numeric/round_to.rb +32 -1
- data/lib/core/facets/object.rb +2 -3
- data/lib/core/facets/object/itself.rb +16 -0
- data/lib/core/facets/objectspace.rb +0 -3
- data/lib/core/facets/proc.rb +0 -3
- data/lib/core/facets/proc/bind_to.rb +3 -3
- data/lib/core/facets/proc/wrap.rb +17 -0
- data/lib/core/facets/process.rb +0 -2
- data/lib/core/facets/range.rb +4 -4
- data/lib/core/facets/range/op_add.rb +15 -0
- data/lib/core/facets/range/op_sub.rb +45 -0
- data/lib/core/facets/range/{to_r.rb → to_rng.rb} +1 -1
- data/lib/core/facets/regexp.rb +0 -2
- data/lib/core/facets/regexp/to_proc.rb +13 -0
- data/lib/core/facets/string.rb +8 -9
- data/lib/core/facets/string/ascii_only.rb +52 -0
- data/lib/core/facets/string/each_match.rb +1 -0
- data/lib/core/facets/string/ends_with.rb +1 -0
- data/lib/core/facets/string/file.rb +6 -20
- data/lib/core/facets/string/fold.rb +5 -5
- data/lib/core/facets/string/indent.rb +37 -20
- data/lib/core/facets/string/indexable.rb +7 -0
- data/lib/core/facets/string/interpolate.rb +6 -2
- data/lib/core/facets/string/linear.rb +19 -0
- data/lib/core/facets/string/margin.rb +47 -19
- data/lib/core/facets/string/mscan.rb +3 -0
- data/lib/core/facets/string/number.rb +14 -0
- data/lib/core/facets/string/op_sub.rb +1 -14
- data/lib/core/facets/string/random.rb +34 -0
- data/lib/core/facets/string/remove.rb +30 -0
- data/lib/core/facets/string/rotate.rb +24 -0
- data/lib/core/facets/string/similarity.rb +2 -2
- data/lib/core/facets/string/starts_with.rb +5 -0
- data/lib/core/facets/string/tab.rb +2 -17
- data/lib/core/facets/string/tabto.rb +2 -19
- data/lib/core/facets/string/to_rx.rb +1 -0
- data/lib/core/facets/string/trim.rb +45 -0
- data/lib/core/facets/string/unfold.rb +7 -2
- data/lib/core/facets/struct.rb +1 -2
- data/lib/core/facets/struct/replace.rb +8 -0
- data/lib/core/facets/symbol.rb +1 -3
- data/lib/core/facets/symbol/as_s.rb +3 -1
- data/lib/core/facets/symbol/call.rb +29 -0
- data/lib/core/facets/symbol/thrown.rb +9 -5
- data/lib/core/facets/time.rb +0 -2
- data/lib/core/facets/time/future.rb +6 -4
- data/lib/core/facets/unboundmethod.rb +0 -3
- data/lib/core/facets/version.rb +5 -5
- data/lib/standard/facets/against.rb +53 -0
- data/lib/standard/facets/binding/block_exec.rb +44 -0
- data/lib/standard/facets/cgi.rb +2 -40
- data/lib/standard/facets/cgi/esc.rb +11 -0
- data/lib/standard/facets/cgi/escape_html.rb +63 -0
- data/lib/standard/facets/cgi/marshal.rb +20 -0
- data/lib/standard/facets/cli.rb +54 -0
- data/lib/standard/facets/cloneable.rb +12 -9
- data/lib/standard/facets/enumargs.rb +159 -168
- data/lib/standard/facets/find.rb +1 -15
- data/lib/standard/facets/find/select.rb +16 -0
- data/lib/standard/facets/gem/search.rb +18 -0
- data/lib/standard/facets/gem/specification/current_specs.rb +21 -0
- data/lib/standard/facets/gem/specification/find_requireable_file.rb +21 -0
- data/lib/standard/facets/hash_builder.rb +46 -0
- data/lib/standard/facets/load_monitor.rb +26 -0
- data/lib/standard/facets/math.rb +57 -57
- data/lib/standard/facets/math/acosec.rb +1 -0
- data/lib/standard/facets/math/acsc.rb +6 -1
- data/lib/standard/facets/math/beta.rb +8 -3
- data/lib/standard/facets/math/cosec.rb +1 -0
- data/lib/standard/facets/math/cosech.rb +1 -0
- data/lib/standard/facets/math/csc.rb +6 -1
- data/lib/standard/facets/math/csch.rb +6 -1
- data/lib/standard/facets/math/distance.rb +19 -0
- data/lib/standard/facets/math/ec.rb +5 -0
- data/lib/standard/facets/math/lgamma.rb +21 -21
- data/lib/standard/facets/math/lngamma.rb +18 -0
- data/lib/standard/facets/math/pow.rb +6 -1
- data/lib/standard/facets/math/root.rb +1 -1
- data/lib/standard/facets/math/sign.rb +15 -4
- data/lib/standard/facets/math/tau.rb +5 -0
- data/lib/standard/facets/math/tgamma.rb +1 -1
- data/lib/standard/facets/memoizer.rb +63 -0
- data/lib/standard/facets/ostruct.rb +37 -156
- data/lib/standard/facets/ostruct/each.rb +11 -0
- data/lib/standard/facets/ostruct/initialize.rb +48 -0
- data/lib/standard/facets/ostruct/merge.rb +21 -0
- data/lib/standard/facets/ostruct/op_fetch.rb +29 -0
- data/lib/standard/facets/ostruct/op_store.rb +1 -0
- data/lib/standard/facets/ostruct/to_h.rb +10 -0
- data/lib/standard/facets/ostruct/to_ostruct.rb +65 -0
- data/lib/standard/facets/pathname.rb +18 -215
- data/lib/standard/facets/pathname/chdir.rb +15 -0
- data/lib/standard/facets/pathname/empty.rb +10 -0
- data/lib/standard/facets/pathname/exists.rb +6 -0
- data/lib/standard/facets/pathname/glob.rb +57 -0
- data/lib/standard/facets/pathname/home.rb +12 -0
- data/lib/standard/facets/pathname/null.rb +20 -0
- data/lib/standard/facets/pathname/op_div.rb +15 -0
- data/lib/standard/facets/pathname/op_fetch.rb +13 -0
- data/lib/standard/facets/pathname/outofdate.rb +13 -0
- data/lib/standard/facets/pathname/readline.rb +13 -0
- data/lib/standard/facets/pathname/root.rb +10 -0
- data/lib/standard/facets/pathname/rootname.rb +10 -0
- data/lib/standard/facets/pathname/safe.rb +15 -0
- data/lib/standard/facets/pathname/split_root.rb +9 -0
- data/lib/standard/facets/pathname/to_path.rb +28 -0
- data/lib/standard/facets/pathname/to_str.rb +8 -0
- data/lib/standard/facets/pathname/uptodate.rb +11 -0
- data/lib/standard/facets/pathname/visit.rb +38 -0
- data/lib/standard/facets/pathname/work.rb +10 -0
- data/lib/standard/facets/platform.rb +2 -2
- data/lib/standard/facets/random.rb +32 -2
- data/lib/standard/facets/shellwords.rb +5 -2
- data/lib/standard/facets/thread.rb +2 -2
- data/lib/standard/facets/uri.rb +7 -178
- data/lib/standard/facets/uri/cgi_escape.rb +46 -0
- data/lib/standard/facets/uri/cgi_parse.rb +1 -0
- data/lib/standard/facets/uri/cgi_unescape.rb +1 -0
- data/lib/standard/facets/uri/decode.rb +32 -0
- data/lib/standard/facets/uri/parameters.rb +63 -0
- data/lib/standard/facets/uri/query.rb +148 -0
- data/lib/standard/facets/yaml.rb +3 -56
- data/lib/standard/facets/yaml/file.rb +41 -0
- data/lib/standard/facets/yaml/kernel.rb +29 -0
- data/lib/standard/facets/yaml/read.rb +12 -0
- data/test/core/array/test_arrange.rb +37 -0
- data/test/core/array/test_each_overlap.rb +31 -0
- data/test/core/array/test_intersection.rb +19 -0
- data/test/core/array/test_missing.rb +12 -0
- data/test/core/array/test_occur.rb +52 -0
- data/test/core/array/test_occurrence.rb +20 -0
- data/test/core/array/test_reject_values.rb +17 -0
- data/test/core/array/test_squeeze.rb +22 -0
- data/test/core/array/test_step.rb +28 -0
- data/test/core/array/test_unique_permutation.rb +23 -0
- data/test/core/enumerable/test_key_by.rb +22 -0
- data/test/core/enumerable/test_occur.rb +18 -5
- data/test/core/enumerable/test_only.rb +40 -0
- data/test/core/enumerable/test_squeeze.rb +35 -0
- data/test/core/enumerable/test_sum.rb +8 -3
- data/test/core/enumerator/lazy/test_squeeze.rb +33 -0
- data/test/core/hash/test_count.rb +10 -1
- data/test/core/hash/test_deep_rekey.rb +131 -0
- data/test/core/hash/test_each_with_key.rb +16 -0
- data/test/core/hash/test_fetch_nested.rb +24 -0
- data/test/core/hash/test_keys.rb +0 -11
- data/test/core/hash/test_rekey.rb +41 -1
- data/test/core/hash/test_revalue.rb +98 -0
- data/test/core/hash/test_slice.rb +12 -1
- data/test/core/kernel/test_deep_clone.rb +31 -0
- data/test/core/kernel/test_deep_copy.rb +2 -28
- data/test/core/kernel/test_instance_extract.rb +28 -0
- data/test/core/method/test_composition.rb +42 -0
- data/test/core/range/test_op_add.rb +24 -0
- data/test/core/range/test_op_sub.rb +34 -0
- data/test/core/string/test_ascii_only.rb +30 -0
- data/test/core/string/test_margin.rb +4 -104
- data/test/core/string/test_number.rb +44 -0
- data/test/core/string/test_remove.rb +36 -0
- data/test/core/string/test_rotate.rb +31 -0
- data/test/core/string/test_trim.rb +116 -0
- data/test/core/symbol/test_thrown.rb +22 -0
- data/test/standard/binding/test_block_exec.rb +21 -0
- data/test/standard/math/test_acot.rb +23 -0
- data/test/standard/math/test_acoth.rb +22 -0
- data/test/standard/math/test_beta.rb +19 -0
- data/test/standard/math/test_ceil.rb +22 -0
- data/test/standard/math/test_cosec.rb +19 -0
- data/test/standard/math/test_cosech.rb +19 -0
- data/test/standard/math/test_cot.rb +13 -0
- data/test/standard/math/test_coth.rb +13 -0
- data/test/standard/math/test_distance.rb +16 -0
- data/test/standard/math/test_exp10.rb +14 -0
- data/test/standard/math/test_exp2.rb +14 -0
- data/test/standard/math/test_factorial.rb +13 -0
- data/test/standard/math/test_floor.rb +23 -0
- data/test/standard/math/test_gcd.rb +18 -0
- data/test/standard/math/test_lcm.rb +13 -0
- data/test/standard/math/test_pow.rb +30 -0
- data/test/standard/math/test_root.rb +15 -0
- data/test/standard/math/test_sec.rb +19 -0
- data/test/standard/math/test_sech.rb +19 -0
- data/test/standard/math/test_sign.rb +6 -0
- data/test/standard/math/test_sinc.rb +15 -0
- data/test/standard/math/test_srq.rb +20 -0
- data/test/standard/pathname/test_chdir.rb +16 -0
- data/test/standard/pathname/test_readline.rb +23 -0
- data/test/standard/test_enumargs.rb +1 -1
- data/test/standard/test_math.rb +3 -0
- data/test/standard/test_ostruct.rb +26 -21
- data/test/standard/test_uri.rb +9 -0
- metadata +802 -183
- data/.ruby +0 -54
- data/HISTORY.rdoc +0 -2386
- data/lib/core/facets/array/combination.rb +0 -43
- data/lib/core/facets/array/index.rb +0 -23
- data/lib/core/facets/array/occurent.rb +0 -1
- data/lib/core/facets/array/permutation.rb +0 -32
- data/lib/core/facets/array/product.rb +0 -30
- data/lib/core/facets/array/rotate.rb +0 -48
- data/lib/core/facets/array/select.rb +0 -20
- data/lib/core/facets/binding/eval.rb +0 -14
- data/lib/core/facets/enumerable/count.rb +0 -53
- data/lib/core/facets/enumerable/each_with_object.rb +0 -38
- data/lib/core/facets/enumerable/group_by.rb +0 -33
- data/lib/core/facets/enumerable/none.rb +0 -32
- data/lib/core/facets/enumerable/one.rb +0 -39
- data/lib/core/facets/enumerable/take.rb +0 -16
- data/lib/core/facets/float/round.rb +0 -2
- data/lib/core/facets/hash/select.rb +0 -17
- data/lib/core/facets/hash/to_h.rb +0 -1
- data/lib/core/facets/hash/url_params.rb +0 -21
- data/lib/core/facets/instance.rb +0 -157
- data/lib/core/facets/integer/even.rb +0 -1
- data/lib/core/facets/integer/odd.rb +0 -37
- data/lib/core/facets/kernel/__callee__.rb +0 -1
- data/lib/core/facets/kernel/__method__.rb +0 -48
- data/lib/core/facets/kernel/require_relative.rb +0 -52
- data/lib/core/facets/kernel/source_location.rb +0 -13
- data/lib/core/facets/nilclass/to_f.rb +0 -17
- data/lib/core/facets/numeric/round.rb +0 -69
- data/lib/core/facets/numeric/round_at.rb +0 -1
- data/lib/core/facets/object/replace.rb +0 -43
- data/lib/core/facets/objectspace/reflect.rb +0 -62
- data/lib/core/facets/proc/curry.rb +0 -32
- data/lib/core/facets/string/bytes.rb +0 -21
- data/lib/core/facets/string/each_char.rb +0 -31
- data/lib/core/facets/string/end_with.rb +0 -1
- data/lib/core/facets/string/lines.rb +0 -19
- data/lib/core/facets/string/random_binary.rb +0 -10
- data/lib/core/facets/string/start_with.rb +0 -60
- data/lib/core/facets/symbol/to_proc.rb +0 -33
- data/lib/core/facets/to_hash.rb +0 -336
- data/lib/core/facets/unboundmethod/name.rb +0 -28
- data/lib/standard/facets/math/gamma.rb +0 -12
- data/test/core/array/test_occurent.rb +0 -33
- data/test/core/kernel/test_source_location.rb +0 -25
- data/test/core/string/test_tabto.rb +0 -16
@@ -0,0 +1,42 @@
|
|
1
|
+
class Array
|
2
|
+
|
3
|
+
# The `arrange` method produces appropriate ranges from the objects in the array.
|
4
|
+
#
|
5
|
+
# Examples
|
6
|
+
#
|
7
|
+
# [1,2,3,6,7,8].arrange #=> [1..3, 6..8]
|
8
|
+
#
|
9
|
+
# [10..15, 16..20, 21, 22].arrange #=> [10..22]
|
10
|
+
#
|
11
|
+
# Assumes inclusive ranges (ie. 1..4) and range.first <= range.last.
|
12
|
+
#
|
13
|
+
# Works with integers, dates and strings. However, all the objects in the array must
|
14
|
+
# be of the same class.
|
15
|
+
#
|
16
|
+
# CREDIT: monocle
|
17
|
+
|
18
|
+
def arrange
|
19
|
+
array = uniq.sort_by { |e| Range === e ? e.first : e }
|
20
|
+
array.inject([]) do |c, value|
|
21
|
+
unless c.empty?
|
22
|
+
last = c.last
|
23
|
+
last_value = (Range === last ? last.last : last)
|
24
|
+
current_value = (Range === value ? value.first : value)
|
25
|
+
if (last_value.succ <=> current_value) == -1
|
26
|
+
c << value
|
27
|
+
else
|
28
|
+
first = (Range === last ? last.first : last)
|
29
|
+
second = [Range === last ? last.last : last, Range === value ? value.last : value].max
|
30
|
+
c[-1] = [first..second]
|
31
|
+
c.flatten!
|
32
|
+
end
|
33
|
+
else
|
34
|
+
c << value
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
alias rangify arrange
|
40
|
+
|
41
|
+
end
|
42
|
+
|
@@ -13,6 +13,7 @@ class Array
|
|
13
13
|
# sequence.before('d') #=> nil
|
14
14
|
#
|
15
15
|
# CREDIT: Tyler Rick
|
16
|
+
|
16
17
|
def before(value)
|
17
18
|
return nil unless include? value
|
18
19
|
self[(index(value).to_i - 1) % length]
|
@@ -30,6 +31,7 @@ class Array
|
|
30
31
|
# sequence.after('d') #=> nil
|
31
32
|
#
|
32
33
|
# CREDIT: Tyler Rick
|
34
|
+
|
33
35
|
def after(value)
|
34
36
|
return nil unless include? value
|
35
37
|
self[(index(value).to_i + 1) % length]
|
@@ -1,37 +1,49 @@
|
|
1
1
|
class Array
|
2
2
|
|
3
|
-
#
|
4
|
-
# If no block is given objects are considered to be
|
5
|
-
# return the same value for Object#hash and if obj1 == obj2.
|
3
|
+
# Get a list of all items that have something in common in terms of the
|
4
|
+
# supplied block. If no block is given objects are considered to be in
|
5
|
+
# common if they return the same value for Object#hash and if obj1 == obj2.
|
6
6
|
#
|
7
|
-
#
|
7
|
+
# This can be useful, for instance, in determining all persons that share
|
8
|
+
# their last name with another person.
|
8
9
|
#
|
9
|
-
#
|
10
|
-
# #=> { 3 => ["foo", "bar"] }
|
10
|
+
# persons.commonality { |person| person.last_name }
|
11
11
|
#
|
12
|
-
#
|
13
|
-
#
|
12
|
+
# The method is similar to #group_by which is a standard Ruby method as of 1.9.
|
13
|
+
# To get effectively the same results with #group_by use `select{ |k,v| v.size > 1 }`.
|
14
14
|
#
|
15
|
-
#
|
15
|
+
# [1, 2, 2, 3, 4, 4].group_by{ |e| e }.select{ |k,v| v.size > 1 }
|
16
|
+
# #=> { 2 => [2, 2], 4 => [4, 4] }
|
17
|
+
#
|
18
|
+
# Examples
|
19
|
+
#
|
20
|
+
# [1, 2, 2, 3, 4, 4].commonality #=> { 2 => [2, 2], 4 => [4, 4] }
|
21
|
+
#
|
22
|
+
# ["foo", "bar", "baz"].commonality { |str| str[0] }
|
23
|
+
# #=> { 'b' => ["bar", "baz"] }
|
24
|
+
#
|
25
|
+
# Returns [Hash] mapping common attribute to those elements.
|
16
26
|
#
|
17
27
|
# CREDIT: Florian Gross
|
18
28
|
|
19
29
|
def commonality(&block)
|
20
|
-
had_no_block = !block
|
21
30
|
block ||= lambda { |item| item }
|
31
|
+
|
22
32
|
result = Hash.new { |hash, key| hash[key] = Array.new }
|
23
33
|
each do |item|
|
24
34
|
key = block.call(item)
|
25
35
|
result[key] << item
|
26
36
|
end
|
37
|
+
|
27
38
|
result.reject! do |key, values|
|
28
39
|
values.size <= 1
|
29
40
|
end
|
30
|
-
|
41
|
+
|
31
42
|
return result
|
32
43
|
end
|
33
44
|
|
34
|
-
|
45
|
+
# Deprecated: Alias for #commonality.
|
46
|
+
alias collisions commonality
|
35
47
|
|
36
48
|
end
|
37
49
|
|
@@ -1 +1,22 @@
|
|
1
|
-
|
1
|
+
class Array
|
2
|
+
|
3
|
+
# Return list of duplicate elements.
|
4
|
+
#
|
5
|
+
# min - The minimum number of duplication necessary for inclusion. [Integer]
|
6
|
+
#
|
7
|
+
# Examples:
|
8
|
+
#
|
9
|
+
# [1,1,2,3].duplicates #=> [1]
|
10
|
+
#
|
11
|
+
# CREDIT: Rebort Dober (current implementation)
|
12
|
+
# CREDIT: Thibaut Barrère
|
13
|
+
|
14
|
+
def duplicates(min=2)
|
15
|
+
h = Hash.new( 0 )
|
16
|
+
each {|i|
|
17
|
+
h[i] += 1
|
18
|
+
}
|
19
|
+
h.delete_if{|_,v| v < min}.keys
|
20
|
+
end
|
21
|
+
|
22
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
class Array
|
2
|
+
|
3
|
+
# Iterate over each slice where the last n values of a preceding slice
|
4
|
+
# overlap with the first n values of the following slice. The value of n
|
5
|
+
# is specified by the second `overlap` argument.
|
6
|
+
#
|
7
|
+
# a, r = [1,2,3,4,5], []
|
8
|
+
# a.each_overlap(2,1) { |x,y| r << [x,y] }
|
9
|
+
# r # => [[1,2],[2,3],[3,4],[4,5]]
|
10
|
+
#
|
11
|
+
# Returns nothing.
|
12
|
+
|
13
|
+
def each_overlap(slice_size, overlap)
|
14
|
+
if block_given?
|
15
|
+
i = 0
|
16
|
+
while i + slice_size <= length
|
17
|
+
yield slice(i...i+slice_size)
|
18
|
+
i += (slice_size - overlap)
|
19
|
+
end
|
20
|
+
else
|
21
|
+
to_enum(:each_overlap, slice_size, overlap)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
class Array
|
2
|
+
|
3
|
+
# Returns the values in common for an array set (nil, singe value/object, or range).
|
4
|
+
#
|
5
|
+
# CREDIT: monocle
|
6
|
+
|
7
|
+
def intersection
|
8
|
+
array = uniq.sort_by { |e| Range === e ? e.first : e }
|
9
|
+
array.inject() do |c, e|
|
10
|
+
f = (Range === c ? c.last : c)
|
11
|
+
v = (Range === e ? e.first : e)
|
12
|
+
case f <=> v
|
13
|
+
when -1 then return nil
|
14
|
+
when 0 then f
|
15
|
+
else
|
16
|
+
if Range === e
|
17
|
+
v..([f, e.last].min)
|
18
|
+
else
|
19
|
+
v
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'facets/array/arrange'
|
2
|
+
|
3
|
+
class Array
|
4
|
+
|
5
|
+
# Determine the "holes" in the values of an array.
|
6
|
+
#
|
7
|
+
# TODO: Better name?
|
8
|
+
#
|
9
|
+
# Returns the missing elements in an array set.
|
10
|
+
#
|
11
|
+
# CREDIT: monocle
|
12
|
+
|
13
|
+
def missing
|
14
|
+
missing, array = [], arrange
|
15
|
+
i, length = 0, array.size - 1
|
16
|
+
while i < length
|
17
|
+
x0 = array[i]
|
18
|
+
x1 = array[i+1]
|
19
|
+
c = (Range === x0 ? x0.last : x0)
|
20
|
+
n = (Range === x1 ? x1.first : x1)
|
21
|
+
missing << (
|
22
|
+
c.succ.succ == n ? c.succ : ((c.succ)..(n.pred))
|
23
|
+
)
|
24
|
+
i += 1
|
25
|
+
end
|
26
|
+
return missing
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
@@ -1,10 +1,12 @@
|
|
1
1
|
class Array
|
2
2
|
|
3
|
-
# Returns a list of non-unique elements
|
3
|
+
# Returns a list of non-unique elements.
|
4
|
+
#
|
5
|
+
# Examples
|
4
6
|
#
|
5
7
|
# [1,1,2,2,3,4,5].nonuniq #=> [1,2]
|
6
8
|
#
|
7
|
-
#
|
9
|
+
# CREDIT: Martin DeMello
|
8
10
|
|
9
11
|
def nonuniq
|
10
12
|
h1 = {}
|
@@ -16,58 +18,10 @@ class Array
|
|
16
18
|
h2.keys
|
17
19
|
end
|
18
20
|
|
19
|
-
# Same as `#nonuniq` but
|
20
|
-
def nonuniq!
|
21
|
-
h1 = {}
|
22
|
-
h2 = {}
|
23
|
-
each {|i|
|
24
|
-
h2[i] = true if h1[i]
|
25
|
-
h1[i] = true
|
26
|
-
}
|
27
|
-
self.replace(h2.keys)
|
28
|
-
end
|
29
|
-
|
30
|
-
# Return list of duplictate elements.
|
31
|
-
#
|
32
|
-
# @param [Integer] min
|
33
|
-
# The minimum number of duplicatation necessary for inclusion.
|
34
|
-
#
|
35
|
-
# @author Rebort Dober (current implementation)
|
36
|
-
# @author Thibaut Barrère
|
21
|
+
# Same as `#nonuniq` but acts in place.
|
37
22
|
|
38
|
-
def
|
39
|
-
|
40
|
-
each {|i|
|
41
|
-
h[i] += 1
|
42
|
-
}
|
43
|
-
h.delete_if{|_,v| v < min}.keys
|
44
|
-
end
|
45
|
-
|
46
|
-
# Returns a list of elements that occur +n+ times.
|
47
|
-
#
|
48
|
-
# [0,1,1,1,3,0,1,2,4].occurent(3) #=> [1]
|
49
|
-
#
|
50
|
-
# If +n+ is a Range then returns elements that occur a number
|
51
|
-
# of time within the range.
|
52
|
-
#
|
53
|
-
# [0,1,1,1,3,0,1,2,4].occurent(2..4) #=> [0,1]
|
54
|
-
#
|
55
|
-
# @author Robert Dober
|
56
|
-
|
57
|
-
def occurent(n=2)
|
58
|
-
h = Hash.new( 0 )
|
59
|
-
each do |i|
|
60
|
-
h[i] += 1
|
61
|
-
end
|
62
|
-
|
63
|
-
case n
|
64
|
-
when nil
|
65
|
-
h.delete_if{ |_,v| ! yield(v) }.keys
|
66
|
-
when Range
|
67
|
-
h.delete_if{ |_,v| ! n.include?(v) }.keys
|
68
|
-
else
|
69
|
-
h.delete_if{|_,v| v != n}.keys
|
70
|
-
end
|
23
|
+
def nonuniq!
|
24
|
+
self.replace(self.nonuniq)
|
71
25
|
end
|
72
26
|
|
73
27
|
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
class Array
|
2
|
+
|
3
|
+
# Returns a list of elements that occur +n+ times.
|
4
|
+
#
|
5
|
+
# If +n+ is a Range then returns elements that occur a number
|
6
|
+
# of time within the range.
|
7
|
+
#
|
8
|
+
# Examples
|
9
|
+
#
|
10
|
+
# [0,1,1,1,3,0,1,2,4].occur(3) #=> [1]
|
11
|
+
#
|
12
|
+
# [0,1,1,1,3,0,1,2,4].occur(2..4) #=> [0,1]
|
13
|
+
#
|
14
|
+
# Returns [Array] of reoccurring elements.
|
15
|
+
#
|
16
|
+
# CREDIT: Robert Dober
|
17
|
+
|
18
|
+
def occur(n=nil) #:yield:
|
19
|
+
h = Hash.new(0)
|
20
|
+
|
21
|
+
each do |i|
|
22
|
+
h[i] += 1
|
23
|
+
end
|
24
|
+
|
25
|
+
case n
|
26
|
+
when nil
|
27
|
+
h.delete_if{ |_,v| ! yield(v) }.keys
|
28
|
+
when Range
|
29
|
+
h.delete_if{ |_,v| ! n.include?(v) }.keys
|
30
|
+
else
|
31
|
+
h.delete_if{|_,v| v != n}.keys
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
# Plural alias of #occur.
|
36
|
+
alias :occurs :occur
|
37
|
+
|
38
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
class Array
|
2
|
+
|
3
|
+
# Create a hart of counts of duplicate elements.
|
4
|
+
#
|
5
|
+
# Examples
|
6
|
+
#
|
7
|
+
# [:a,:a,:b,:c,:c,:c].occurrence
|
8
|
+
# #=> { :a => 2, :b => 1, :c => 3 }
|
9
|
+
#
|
10
|
+
# [2,2,3,4,4,4].occurence{|i| i % 2}
|
11
|
+
# #=> { 0 => 5, 1 => 1 }
|
12
|
+
#
|
13
|
+
def occurrence
|
14
|
+
h = Hash.new(0)
|
15
|
+
if block_given?
|
16
|
+
each do |e|
|
17
|
+
h[yield(e)] += 1
|
18
|
+
end
|
19
|
+
else
|
20
|
+
each do |e|
|
21
|
+
h[e] += 1
|
22
|
+
end
|
23
|
+
end
|
24
|
+
h
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
|
@@ -17,10 +17,21 @@ class Array
|
|
17
17
|
|
18
18
|
def only
|
19
19
|
unless size == 1
|
20
|
-
raise IndexError, "
|
20
|
+
raise IndexError, "not the only element of array"
|
21
21
|
end
|
22
22
|
first
|
23
23
|
end
|
24
24
|
|
25
|
+
# Does this Array have only one element?
|
26
|
+
#
|
27
|
+
# TODO: While clearly this goes along with the regular #only method,
|
28
|
+
# the name doesn't seem quite right. Perhaps rename to #lonely.
|
29
|
+
#
|
30
|
+
# CREDIT: Lavir the Whiolet
|
31
|
+
#
|
32
|
+
def only?
|
33
|
+
size == 1
|
34
|
+
end
|
35
|
+
|
25
36
|
end
|
26
37
|
|
@@ -4,20 +4,26 @@ require 'facets/enumerable/recursively'
|
|
4
4
|
class Array
|
5
5
|
|
6
6
|
# Apply a method to array, and recursively apply that method
|
7
|
-
# to each sub-array or +types+.
|
7
|
+
# to each sub-array or given +types+.
|
8
|
+
#
|
9
|
+
# By default the sub-types are passed thru uneffected. Passing
|
10
|
+
# a block to #recursively can be used to change this.
|
11
|
+
#
|
12
|
+
# types - List of class types to recurse. [Array<Class>]
|
13
|
+
# block - Optional filter procedure to apply on each recursion.
|
14
|
+
#
|
15
|
+
# Examples
|
8
16
|
#
|
9
17
|
# arr = ["a", ["b", "c"]]
|
10
18
|
# arr.recursively.map{ |v| v.to_sym }
|
11
19
|
# #=> [:a, [:b, :c]]
|
12
20
|
#
|
13
|
-
# By default the sub-types are passed thru uneffected. Passing a block
|
14
|
-
# to #recursively changes this.
|
15
|
-
#
|
16
21
|
# arr = ["a", ["b", "c"]]
|
17
22
|
# arr.recursively{ |a| a.reverse }.map{ |v| v.to_sym }
|
18
23
|
# #=> [:a, [:c, :b]]
|
19
24
|
#
|
20
|
-
#
|
25
|
+
# Returns [Recursor].
|
26
|
+
|
21
27
|
def recursively(*types, &block)
|
22
28
|
Recursor.new(self, *types, &block)
|
23
29
|
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
class Array
|
2
|
+
|
3
|
+
# Non-destructive form of `Array#delete_values`. Unlike `delete_values`
|
4
|
+
# this method returns a new array.
|
5
|
+
#
|
6
|
+
# values - List of array elements to reject.
|
7
|
+
#
|
8
|
+
# Examples
|
9
|
+
#
|
10
|
+
# [1,2,3,4,5].reject_values(2,4) # => [1,3,5]
|
11
|
+
#
|
12
|
+
# Returns [Array]
|
13
|
+
#
|
14
|
+
# CREDIT: Sean Mackesey
|
15
|
+
|
16
|
+
def reject_values(*values)
|
17
|
+
reject { |x| values.include?(x) }
|
18
|
+
end
|
19
|
+
|
20
|
+
end
|
21
|
+
|