facets 3.0.0 → 3.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (353) hide show
  1. checksums.yaml +4 -4
  2. data/.index +11 -7
  3. data/CONTRIBUTING.md +112 -0
  4. data/HISTORY.md +38 -0
  5. data/{README.rdoc → README.md} +59 -59
  6. data/demo/core/array/after.md +13 -0
  7. data/demo/core/array/arrange.md +17 -0
  8. data/demo/core/array/before.md +14 -0
  9. data/demo/core/array/collapse.md +15 -0
  10. data/demo/core/array/collisions.md +30 -0
  11. data/demo/core/array/commonality.md +31 -0
  12. data/demo/core/array/conjoin.md +47 -0
  13. data/demo/core/array/contains.md +9 -0
  14. data/demo/core/array/delete_unless.md +13 -0
  15. data/demo/core/array/delete_values.md +10 -0
  16. data/demo/core/array/delete_values_at.md +15 -0
  17. data/demo/core/array/divide.md +14 -0
  18. data/demo/core/array/duplicates.md +14 -0
  19. data/demo/core/array/each_overlap.md +12 -0
  20. data/demo/core/array/each_pair.md +13 -0
  21. data/demo/core/array/each_value.md +12 -0
  22. data/demo/core/array/entropy.md +13 -0
  23. data/demo/core/array/extract_options.md +13 -0
  24. data/demo/core/array/first.md +11 -0
  25. data/demo/core/array/from.md +11 -0
  26. data/demo/core/array/ideal_entropy.md +11 -0
  27. data/demo/core/array/intersection.md +11 -0
  28. data/demo/core/array/last.md +11 -0
  29. data/demo/core/array/median.md +23 -0
  30. data/demo/core/array/merge.md +15 -0
  31. data/demo/core/array/missing.md +10 -0
  32. data/demo/core/array/mode.md +9 -0
  33. data/demo/core/array/nonuniq.md +16 -0
  34. data/demo/core/array/not_empty.md +8 -0
  35. data/demo/core/array/occur.md +18 -0
  36. data/demo/core/array/occurrence.md +13 -0
  37. data/demo/core/array/only.md +9 -0
  38. data/demo/core/array/op_pow.md +10 -0
  39. data/demo/core/array/pad.md +28 -0
  40. data/demo/core/array/peek.md +10 -0
  41. data/demo/core/array/poke.md +15 -0
  42. data/demo/core/array/probability +8 -0
  43. data/demo/core/array/pull.md +10 -0
  44. data/demo/core/array/recurse.md +10 -0
  45. data/demo/core/array/recursively.md +20 -0
  46. data/demo/core/array/reject_values.md +10 -0
  47. data/demo/core/array/splice.md +14 -0
  48. data/demo/core/array/split.md +13 -0
  49. data/demo/core/array/squeeze.md +14 -0
  50. data/demo/core/array/step.md +16 -0
  51. data/demo/core/array/store.md +9 -0
  52. data/demo/core/array/thru.md +12 -0
  53. data/demo/core/array/to_h.md +11 -0
  54. data/demo/core/array/traverse.md +20 -0
  55. data/demo/core/array/uniq_by.md +16 -0
  56. data/demo/core/array/unique_permutation.md +14 -0
  57. data/demo/core/array/zip.md +8 -0
  58. data/demo/core/binding/caller.md +57 -0
  59. data/demo/core/binding/defined.md +10 -0
  60. data/demo/core/binding/opvars.md +16 -0
  61. data/demo/core/binding/self.md +6 -0
  62. data/demo/core/class/descendants.md +13 -0
  63. data/demo/core/class/to_proc.md +11 -0
  64. data/demo/core/comparable/at_least.md +11 -0
  65. data/demo/core/comparable/at_most.md +11 -0
  66. data/demo/core/comparable/bound.md +13 -0
  67. data/demo/core/comparable/cap.md +11 -0
  68. data/demo/core/comparable/clip.md +29 -0
  69. data/demo/core/comparable/cmp.md +18 -0
  70. data/demo/core/comparable/op_get.md +32 -0
  71. data/demo/core/dir/ascend.md +24 -0
  72. data/demo/core/dir/descend.md +16 -0
  73. data/demo/core/dir/multiglob.md +41 -0
  74. data/demo/core/dir/parent.md +6 -0
  75. data/demo/core/dir/recurse.md +41 -0
  76. data/demo/core/exception/detail.md +19 -0
  77. data/demo/core/{facets.rdoc → facets.md} +1 -1
  78. data/demo/core/filetest/root.md +13 -0
  79. data/demo/core/hash/recursively.md +21 -0
  80. data/demo/core/indexable.md +95 -0
  81. data/demo/core/integer/bitmask.md +46 -0
  82. data/demo/core/integer/{factorial.rdoc → factorial.md} +1 -1
  83. data/demo/core/integer/{length.rdoc → length.md} +1 -1
  84. data/demo/core/integer/{multiple.rdoc → multiple.md} +3 -1
  85. data/demo/core/integer/of.md +11 -0
  86. data/demo/core/integer/{ordinal.rdoc → ordinal.md} +3 -1
  87. data/demo/core/integer/{of.rdoc → times_collect.md} +2 -7
  88. data/demo/core/matchdata/match.md +7 -0
  89. data/demo/core/matchdata/matchset.md +7 -0
  90. data/demo/core/matchdata/matchtree.md +10 -0
  91. data/demo/core/module/cattr.md +43 -0
  92. data/demo/core/module/class_extend.md +64 -0
  93. data/demo/core/module/{class_inheritor.rdoc → class_inheritor.md} +2 -2
  94. data/demo/core/module/{copy_inheritor.rdoc → copy_inheritor.md} +4 -4
  95. data/demo/core/module/include_as.md +31 -0
  96. data/demo/core/module/method_space.md +24 -0
  97. data/demo/core/string/acronym.md +9 -0
  98. data/demo/core/string/{align.rdoc → align.md} +10 -10
  99. data/demo/core/string/ascii_only.md +37 -0
  100. data/demo/core/string/{bracket.rdoc → bracket.md} +10 -10
  101. data/demo/core/string/camelcase.md +47 -0
  102. data/demo/core/string/{capitalized.rdoc → capitalized.md} +9 -9
  103. data/demo/core/string/characters.md +11 -0
  104. data/demo/core/string/{cleanlines.rdoc → cleanlines.md} +3 -3
  105. data/demo/core/string/cleave.md +49 -0
  106. data/demo/core/string/compress_lines.md +22 -0
  107. data/demo/core/string/crypt.md +15 -0
  108. data/demo/core/string/divide.md +9 -0
  109. data/demo/core/string/each_word.md +11 -0
  110. data/demo/core/string/edit_distance.md +15 -0
  111. data/demo/core/string/exclude.md +15 -0
  112. data/demo/core/string/expand_tabs.md +69 -0
  113. data/demo/core/string/fold.md +14 -0
  114. data/demo/core/string/indent.md +65 -0
  115. data/demo/core/string/index_all.md +14 -0
  116. data/demo/core/string/interpolate.md +8 -0
  117. data/demo/core/string/lchomp.md +14 -0
  118. data/demo/core/string/line_wrap.md +7 -0
  119. data/demo/core/string/lowercase.md +12 -0
  120. data/demo/core/string/methodize.md +22 -0
  121. data/demo/core/string/modulize.md +22 -0
  122. data/demo/core/string/mscan.md +10 -0
  123. data/demo/core/string/natcmp.md +10 -0
  124. data/demo/core/string/nchar.md +9 -0
  125. data/demo/core/string/{newlines.rdoc → newlines.md} +3 -3
  126. data/demo/core/string/number.md +27 -0
  127. data/demo/core/string/op_div.md +10 -0
  128. data/demo/core/string/op_sub.md +7 -0
  129. data/demo/core/string/pathize.md +22 -0
  130. data/demo/core/string/quote.md +20 -0
  131. data/demo/core/string/random.md +25 -0
  132. data/demo/core/string/range.md +19 -0
  133. data/demo/core/string/remove.md +33 -0
  134. data/demo/core/string/rewrite.md +9 -0
  135. data/demo/core/string/shatter.md +9 -0
  136. data/demo/core/string/similarity.md +12 -0
  137. data/demo/core/string/snakecase.md +14 -0
  138. data/demo/core/string/splice.md +28 -0
  139. data/demo/core/string/squish.md +27 -0
  140. data/demo/core/string/store.md +10 -0
  141. data/demo/core/string/subtract.md +8 -0
  142. data/demo/core/string/titlecase.md +8 -0
  143. data/demo/core/string/to_re.md +22 -0
  144. data/demo/core/string/{margin.rdoc → trim.md} +14 -14
  145. data/demo/core/string/unbracket.md +24 -0
  146. data/demo/core/string/underscore.md +17 -0
  147. data/demo/core/string/unfold.md +9 -0
  148. data/demo/core/string/unindent.md +65 -0
  149. data/demo/core/string/unquote.md +6 -0
  150. data/demo/core/string/uppercase.md +15 -0
  151. data/demo/core/string/variablize.md +7 -0
  152. data/demo/core/string/word_wrap.md +54 -0
  153. data/demo/core/string/words.md +13 -0
  154. data/demo/core/string/xor.md +8 -0
  155. data/lib/core/facets.yml +11 -7
  156. data/lib/core/facets/array.rb +1 -0
  157. data/lib/core/facets/array/average.rb +16 -0
  158. data/lib/core/facets/array/collapse.rb +4 -0
  159. data/lib/core/facets/array/delete_values_at.rb +1 -0
  160. data/lib/core/facets/array/divide.rb +7 -0
  161. data/lib/core/facets/array/duplicates.rb +2 -0
  162. data/lib/core/facets/array/each_pair.rb +1 -4
  163. data/lib/core/facets/array/first.rb +1 -0
  164. data/lib/core/facets/array/from.rb +11 -16
  165. data/lib/core/facets/array/intersection.rb +1 -1
  166. data/lib/core/facets/array/last.rb +1 -0
  167. data/lib/core/facets/array/mode.rb +2 -2
  168. data/lib/core/facets/array/occurrence.rb +4 -3
  169. data/lib/core/facets/array/op_pow.rb +0 -2
  170. data/lib/core/facets/array/probability.rb +1 -1
  171. data/lib/core/facets/array/recursively.rb +2 -2
  172. data/lib/core/facets/array/splice.rb +1 -1
  173. data/lib/core/facets/array/standard_deviation.rb +23 -0
  174. data/lib/core/facets/array/to_h.rb +0 -3
  175. data/lib/core/facets/array/uniq_by.rb +4 -0
  176. data/lib/core/facets/array/variance.rb +20 -0
  177. data/lib/core/facets/binding.rb +0 -1
  178. data/lib/core/facets/enumerable/cluster.rb +6 -4
  179. data/lib/core/facets/enumerable/hashify.rb +27 -31
  180. data/lib/core/facets/enumerable/sum.rb +12 -2
  181. data/lib/core/facets/file/atomic_open.rb +1 -1
  182. data/lib/core/facets/hash/except.rb +13 -1
  183. data/lib/core/facets/indexable.rb +1 -1
  184. data/lib/core/facets/kernel/ergo.rb +3 -3
  185. data/lib/core/facets/kernel/like.rb +1 -1
  186. data/lib/core/facets/matchdata/matchtree.rb +2 -0
  187. data/lib/core/facets/numeric/delimit.rb +20 -0
  188. data/lib/core/facets/range/nudge.rb +29 -0
  189. data/lib/core/facets/string.rb +0 -2
  190. data/lib/core/facets/string/indent.rb +0 -8
  191. data/lib/core/facets/string/margin.rb +0 -4
  192. data/lib/core/facets/string/random.rb +13 -3
  193. data/lib/core/facets/string/similarity.rb +7 -6
  194. data/lib/standard/facets/enumargs.rb +5 -0
  195. data/lib/standard/facets/math/percentile.rb +1 -1
  196. data/lib/standard/facets/net/http.rb +33 -14
  197. data/lib/standard/facets/timer.rb +3 -3
  198. data/test/core/array/test_average.rb +16 -0
  199. data/test/core/array/test_before.rb +21 -0
  200. data/test/core/array/test_collapse.rb +10 -1
  201. data/test/core/array/test_delete_unless.rb +17 -0
  202. data/test/core/array/test_delete_values.rb +31 -0
  203. data/test/core/array/test_divide.rb +10 -0
  204. data/test/core/array/test_each_pair.rb +16 -0
  205. data/test/core/array/test_each_value.rb +16 -0
  206. data/test/core/array/test_from.rb +42 -0
  207. data/test/core/array/test_op_pow.rb +13 -0
  208. data/test/core/array/test_standard_deviation.rb +18 -0
  209. data/test/core/array/test_to_h.rb +14 -0
  210. data/test/core/array/test_uniq_by.rb +7 -0
  211. data/test/core/array/test_variance.rb +17 -0
  212. data/test/core/array/test_zip.rb +13 -0
  213. data/test/core/dir/test_each_child.rb +1 -1
  214. data/test/core/dir/test_multiglob.rb +1 -1
  215. data/test/core/enumerable/test_cluster.rb +36 -0
  216. data/test/core/enumerable/test_hashify.rb +113 -0
  217. data/test/core/hash/test_expect.rb +11 -1
  218. data/test/core/kernel/test_ergo.rb +7 -5
  219. data/test/core/{object/test_replace.rb → kernel/test_instance_replace.rb} +6 -28
  220. data/test/core/numeric/test_delimit.rb +68 -0
  221. data/test/core/numeric/{test_round.rb → test_round_to.rb} +27 -27
  222. data/test/core/range/test_nudge.rb +32 -0
  223. data/test/core/range/{test_to_r.rb → test_to_rng.rb} +3 -3
  224. data/test/core/string/test_acronym.rb +14 -0
  225. data/test/core/string/test_ascii_only.rb +21 -0
  226. data/test/core/string/test_compress_lines.rb +9 -0
  227. data/test/core/string/test_crypt.rb +17 -0
  228. data/test/core/string/test_index_all.rb +4 -0
  229. data/test/core/string/test_random.rb +25 -0
  230. data/test/core/string/test_remove.rb +14 -0
  231. data/test/core/string/test_similarity.rb +9 -1
  232. data/test/core/struct/test_replace.rb +18 -0
  233. data/test/standard/test_enumargs.rb +26 -10
  234. data/test/standard/test_timer.rb +1 -1
  235. metadata +634 -588
  236. data/CONTRIBUTE.md +0 -78
  237. data/demo/core/array/combination.rdoc +0 -19
  238. data/demo/core/array/delete.rdoc +0 -23
  239. data/demo/core/array/index.rdoc +0 -14
  240. data/demo/core/array/merge.rdoc +0 -15
  241. data/demo/core/array/only.rdoc +0 -9
  242. data/demo/core/array/pad.rdoc +0 -28
  243. data/demo/core/array/permutation.rdoc +0 -10
  244. data/demo/core/array/product.rdoc +0 -26
  245. data/demo/core/array/recursively.rdoc +0 -16
  246. data/demo/core/array/rotate.rdoc +0 -30
  247. data/demo/core/array/select.rdoc +0 -8
  248. data/demo/core/array/uniq_by.rdoc +0 -9
  249. data/demo/core/binding/caller.rdoc +0 -57
  250. data/demo/core/binding/defined.rdoc +0 -10
  251. data/demo/core/binding/eval.rdoc +0 -8
  252. data/demo/core/binding/local_variables.rdoc +0 -26
  253. data/demo/core/binding/opvars.rdoc +0 -16
  254. data/demo/core/binding/self.rdoc +0 -6
  255. data/demo/core/class/descendants.rdoc +0 -10
  256. data/demo/core/class/to_proc.rdoc +0 -8
  257. data/demo/core/comparable/cap.rdoc +0 -20
  258. data/demo/core/comparable/clip.rdoc +0 -37
  259. data/demo/core/comparable/cmp.rdoc +0 -18
  260. data/demo/core/comparable/op_get.rdoc +0 -29
  261. data/demo/core/dir/ascend.rdoc +0 -24
  262. data/demo/core/dir/descend.rdoc +0 -14
  263. data/demo/core/dir/multiglob.rdoc +0 -41
  264. data/demo/core/dir/parent.rdoc +0 -6
  265. data/demo/core/dir/recurse.rdoc +0 -41
  266. data/demo/core/exception/detail.rdoc +0 -12
  267. data/demo/core/filetest/root.rdoc +0 -6
  268. data/demo/core/hash/recursively.rdoc +0 -21
  269. data/demo/core/indexable.rdoc +0 -95
  270. data/demo/core/integer/bitmask.rdoc +0 -46
  271. data/demo/core/integer/even.rdoc +0 -12
  272. data/demo/core/integer/odd.rdoc +0 -12
  273. data/demo/core/matchdata/match.rdoc +0 -7
  274. data/demo/core/matchdata/matchset.rdoc +0 -15
  275. data/demo/core/module/cattr.rdoc +0 -43
  276. data/demo/core/module/class_extend.rdoc +0 -64
  277. data/demo/core/module/method_space.rdoc +0 -55
  278. data/demo/core/string/bytes.rdoc +0 -8
  279. data/demo/core/string/camelcase.rdoc +0 -47
  280. data/demo/core/string/characters.rdoc +0 -11
  281. data/demo/core/string/cleave.rdoc +0 -49
  282. data/demo/core/string/divide.rdoc +0 -9
  283. data/demo/core/string/each_char.rdoc +0 -9
  284. data/demo/core/string/each_word.rdoc +0 -9
  285. data/demo/core/string/end_with.rdoc +0 -6
  286. data/demo/core/string/expand_tabs.rdoc +0 -69
  287. data/demo/core/string/fold.rdoc +0 -14
  288. data/demo/core/string/indent.rdoc +0 -65
  289. data/demo/core/string/interpolate.rdoc +0 -7
  290. data/demo/core/string/lchomp.rdoc +0 -14
  291. data/demo/core/string/line_wrap.rdoc +0 -7
  292. data/demo/core/string/lines.rdoc +0 -8
  293. data/demo/core/string/methodize.rdoc +0 -22
  294. data/demo/core/string/modulize.rdoc +0 -22
  295. data/demo/core/string/mscan.rdoc +0 -10
  296. data/demo/core/string/natcmp.rdoc +0 -10
  297. data/demo/core/string/nchar.rdoc +0 -9
  298. data/demo/core/string/op_sub.rdoc +0 -7
  299. data/demo/core/string/pathize.rdoc +0 -22
  300. data/demo/core/string/quote.rdoc +0 -20
  301. data/demo/core/string/range.rdoc +0 -19
  302. data/demo/core/string/rewrite.rdoc +0 -9
  303. data/demo/core/string/shatter.rdoc +0 -9
  304. data/demo/core/string/snakecase.rdoc +0 -10
  305. data/demo/core/string/splice.rdoc +0 -28
  306. data/demo/core/string/start_with.rdoc +0 -7
  307. data/demo/core/string/subtract.rdoc +0 -8
  308. data/demo/core/string/tab.rdoc +0 -16
  309. data/demo/core/string/tabto.rdoc +0 -29
  310. data/demo/core/string/titlecase.rdoc +0 -8
  311. data/demo/core/string/to_re.rdoc +0 -22
  312. data/demo/core/string/unfold.rdoc +0 -9
  313. data/demo/core/string/unindent.rdoc +0 -65
  314. data/demo/core/string/unquote.rdoc +0 -6
  315. data/demo/core/string/variablize.rdoc +0 -7
  316. data/demo/core/string/word_wrap.rdoc +0 -54
  317. data/demo/core/string/words.rdoc +0 -13
  318. data/demo/core/string/xor.rdoc +0 -8
  319. data/lib/core/facets/binding/local_variables.rb +0 -16
  320. data/lib/core/facets/string/tab.rb +0 -2
  321. data/lib/core/facets/string/tabto.rb +0 -2
  322. data/test/core/array/test_after.rb +0 -27
  323. data/test/core/array/test_combination.rb +0 -25
  324. data/test/core/array/test_index.rb +0 -20
  325. data/test/core/array/test_permutation.rb +0 -20
  326. data/test/core/array/test_product.rb +0 -64
  327. data/test/core/array/test_rotate.rb +0 -38
  328. data/test/core/array/test_select.rb +0 -16
  329. data/test/core/binding/test_eval.rb +0 -15
  330. data/test/core/binding/test_local_variables.rb +0 -36
  331. data/test/core/enumerable/test_cluster_by.rb +0 -30
  332. data/test/core/enumerable/test_count.rb +0 -32
  333. data/test/core/enumerable/test_each_with_object.rb +0 -18
  334. data/test/core/enumerable/test_group_by.rb +0 -36
  335. data/test/core/enumerable/test_none.rb +0 -29
  336. data/test/core/enumerable/test_one.rb +0 -34
  337. data/test/core/enumerable/test_take.rb +0 -15
  338. data/test/core/hash/test_select.rb +0 -44
  339. data/test/core/hash/test_url_params.rb +0 -26
  340. data/test/core/integer/test_even.rb +0 -24
  341. data/test/core/integer/test_odd.rb +0 -24
  342. data/test/core/kernel/test_require_relative.rb +0 -12
  343. data/test/core/nilclass/test_to_f.rb +0 -13
  344. data/test/core/proc/test_curry.rb +0 -38
  345. data/test/core/string/test_bytes.rb +0 -13
  346. data/test/core/string/test_each_char.rb +0 -17
  347. data/test/core/string/test_end_with.rb +0 -24
  348. data/test/core/string/test_lines.rb +0 -15
  349. data/test/core/string/test_start_with.rb +0 -24
  350. data/test/core/string/test_tab.rb +0 -16
  351. data/test/core/symbol/test_to_proc.rb +0 -35
  352. data/test/core/to_hash_tc.rb +0 -210
  353. data/test/core/unboundmethod/test_name.rb +0 -19
@@ -0,0 +1,16 @@
1
+ ## Binding#[]
2
+
3
+ require 'facets/binding/op'
4
+
5
+ a = 1
6
+ b = 2
7
+ x = "hello"
8
+
9
+ binding["x"].assert == "hello"
10
+
11
+ ## Binding#[]=
12
+
13
+ binding["x"] = "goodbye"
14
+
15
+ binding["x"].assert == "goodbye"
16
+
@@ -0,0 +1,6 @@
1
+ ## Binding#self
2
+
3
+ require 'facets/binding/self'
4
+
5
+ binding.self == self
6
+
@@ -0,0 +1,13 @@
1
+ ## Class#descendants
2
+
3
+ require 'facets/class/descendants'
4
+
5
+ The `Class#descendants` method returns a list of classes that are subclasses
6
+ of a class.
7
+
8
+ a = Class.new
9
+ b = Class.new(a)
10
+ c = Class.new(b)
11
+
12
+ a.descendants.assert == [b,c]
13
+
@@ -0,0 +1,11 @@
1
+ ## Class#to_proc
2
+
3
+ require 'facets/class/to_proc'
4
+
5
+ The `Class#to_proc` method provides a convenient way to create new
6
+ instances from a set of initialization data.
7
+
8
+ person = Struct.new(:name)
9
+ people = ["joe"].map(&person)
10
+ people[0].name.assert == "joe"
11
+
@@ -0,0 +1,11 @@
1
+ ## Comparable#at_least
2
+
3
+ require 'facets/comparable/at_least'
4
+
5
+ Limits a number to at least a given amount.
6
+
7
+ 3.at_least(4).assert == 4
8
+ 4.at_least(4).assert == 4
9
+ 5.at_least(4).assert == 5
10
+
11
+ This is similar to `#clip`.
@@ -0,0 +1,11 @@
1
+ ## Comparable#at_most
2
+
3
+ require 'facets/comparable/at_most'
4
+
5
+ Limits a number to at most a given amount.
6
+
7
+ 3.at_most(4).assert == 3
8
+ 4.at_most(4).assert == 4
9
+ 5.at_most(4).assert == 4
10
+
11
+ This is similar to `#cap`.
@@ -0,0 +1,13 @@
1
+ ## Comparable#bound
2
+
3
+ require 'facets/comparable/bound'
4
+
5
+ The `#bound` method is an alias for `#clip`. It is the original name
6
+ of the method before the `clip`/`cap` duo was decided upon.
7
+
8
+ 3.bound(4).assert == 4
9
+
10
+ 4.bound(3,5).assert == 4
11
+
12
+ 'd'.bound('c','e').assert == 'd'
13
+
@@ -0,0 +1,11 @@
1
+ ## Comparable#cap
2
+
3
+ require 'facets/comparable/cap'
4
+
5
+ Put a cap on what a number can be.
6
+
7
+ 3.cap(4).assert == 3
8
+ 4.cap(4).assert == 4
9
+ 5.cap(4).assert == 4
10
+
11
+ This is very similar to `#at_most`.
@@ -0,0 +1,29 @@
1
+ ## Comparable#clip
2
+
3
+ require 'facets/comparable/clip'
4
+
5
+ Given a single argument `#clip` behaves like `#at_least`.
6
+
7
+ 3.clip(4).assert == 4
8
+ 4.clip(4).assert == 4
9
+ 5.clip(4).assert == 5
10
+
11
+ With two arguments `#clip` puts both a lower and an upper limit
12
+ on the return value.
13
+
14
+ 4.clip(3,5).assert == 4
15
+ 3.clip(3,5).assert == 3
16
+ 5.clip(3,5).assert == 5
17
+ 2.clip(3,5).assert == 3
18
+ 6.clip(3,5).assert == 5
19
+
20
+ This almost works on characters (using ASCII order).
21
+
22
+ 'd'.clip('c','e').assert == 'd'
23
+ 'c'.clip('c','e').assert == 'c'
24
+ 'e'.clip('c','e').assert == 'e'
25
+ 'b'.clip('c','e').assert == 'c'
26
+ 'f'.clip('c','e').assert == 'e'
27
+
28
+ This method is aliases as `bound`.
29
+
@@ -0,0 +1,18 @@
1
+ ## Comparable#cmp
2
+
3
+ require 'facets/comparable/cmp'
4
+
5
+ On integers
6
+
7
+ 3.cmp(4).assert == -1
8
+ 3.cmp(3).assert == 0
9
+ 3.cmp(2).assert == 1
10
+
11
+ On strings
12
+
13
+ "abc".cmp("abc").assert == 0
14
+ "abc".cmp("abcd").assert == -1
15
+ "abcd".cmp("abc").assert == 1
16
+ "abc".cmp("bcd").assert == -1
17
+ "bcd".cmp("abc").assert == 1
18
+
@@ -0,0 +1,32 @@
1
+ ## Comparable.[]
2
+
3
+ require 'facets/comparable/op_get'
4
+
5
+ Allows `Comparable` to be included as a *parmetric mixin*. This makes it easy to define
6
+ a class as comparable on a limited set of attributes.
7
+
8
+ c = Class.new do
9
+ include Comparable[:a,:b]
10
+
11
+ attr_accessor :a, :b
12
+
13
+ def initialize(a,b)
14
+ @a=a; @b=b
15
+ end
16
+ end
17
+
18
+ a = [c.new(10,20),c.new(10,30)]
19
+ a.sort.assert == a
20
+
21
+ a = [c.new(10,30),c.new(10,20)]
22
+ a.sort.assert == a.reverse
23
+
24
+ a = [c.new(10,10),c.new(20,10)]
25
+ a.sort.assert == a
26
+
27
+ a = [c.new(20,10),c.new(10,10)]
28
+ a.sort.assert == a.reverse
29
+
30
+ a = [c.new(10,30),c.new(20,10)]
31
+ a.sort.assert == a
32
+
@@ -0,0 +1,24 @@
1
+ ## Dir#ascend
2
+
3
+ require 'facets/dir/ascend'
4
+
5
+ path = 'A/B/C'
6
+
7
+ tmp = []
8
+
9
+ Dir.ascend(path) do |d|
10
+ tmp << d
11
+ end
12
+
13
+ tmp.assert == %w{A/B/C A/B A}
14
+
15
+ Exclude current path.
16
+
17
+ tmp = []
18
+
19
+ Dir.ascend(path, false) do |d|
20
+ tmp << d
21
+ end
22
+
23
+ tmp.assert == %w{A/B A}
24
+
@@ -0,0 +1,16 @@
1
+ ## Dir#descend
2
+
3
+ require 'facets/dir/descend'
4
+
5
+ Descend thru a file path.
6
+
7
+ path = 'A/B/C'
8
+
9
+ tmp = []
10
+
11
+ Dir.descend(path) do |d|
12
+ tmp << d
13
+ end
14
+
15
+ tmp.assert == %w{A A/B A/B/C}
16
+
@@ -0,0 +1,41 @@
1
+ ## Dir#multiglob
2
+
3
+ Dir#multglob is like Dir#glob but it can handle more than one match
4
+ parameter at a time.
5
+
6
+ Given a directory 'multiglob' containing:
7
+
8
+ A.txt
9
+ A/B.txt
10
+ A/B/C.txt
11
+
12
+ We can use #multglob to find multiple matches.
13
+
14
+ require 'facets/dir/multiglob'
15
+
16
+ x = %w{
17
+ multiglob/A
18
+ multiglob/A.txt
19
+ }
20
+
21
+ r = Dir.multiglob('multiglob/A', 'multiglob/A.*').sort
22
+
23
+ r.assert == x
24
+
25
+ ## Dir#multiglob_r
26
+
27
+ Dir#multiglob_r is like #multiglob but automatically searches
28
+ directories recrusively.
29
+
30
+ x = %w{
31
+ multiglob/A
32
+ multiglob/A/B
33
+ multiglob/A.txt
34
+ multiglob/A/B.txt
35
+ multiglob/A/B/C.txt
36
+ }.sort
37
+
38
+ r = Dir.multiglob_r('multiglob/*').sort
39
+
40
+ r.assert == x
41
+
@@ -0,0 +1,6 @@
1
+ ## Dir#parent
2
+
3
+ require 'facets/dir/parent'
4
+
5
+ Dir.assert.parent?("a/b/c", "a/b/c/d")
6
+
@@ -0,0 +1,41 @@
1
+ ## Dir#recurse
2
+
3
+ Given a directory 'recurse' containing:
4
+
5
+ A.txt
6
+ A/B.txt
7
+ A/B/C.txt
8
+
9
+ We can use #recurse to gather a complete recursive
10
+ list of all the entries.
11
+
12
+ require 'facets/dir/recurse'
13
+
14
+ x = %w{
15
+ recurse/A
16
+ recurse/A.txt
17
+ recurse/A/B
18
+ recurse/A/B.txt
19
+ recurse/A/B/C.txt
20
+ }.sort
21
+
22
+ r = Dir.recurse('recurse').sort
23
+
24
+ r.assert == x
25
+
26
+ ## Dir#ls_r
27
+
28
+ Dir#ls_r is an alias for #recurse which can also be used to gather
29
+ a complete recursive list of all the entries.
30
+
31
+ x = %w{
32
+ recurse/A
33
+ recurse/A.txt
34
+ recurse/A/B
35
+ recurse/A/B.txt
36
+ recurse/A/B/C.txt
37
+ }.sort
38
+
39
+ r = Dir.ls_r('recurse').sort
40
+
41
+ r.assert == x
@@ -0,0 +1,19 @@
1
+ ## Exception#detail
2
+
3
+ require 'facets/exception/detail'
4
+
5
+ Provides a more detailed error message.
6
+
7
+ begin
8
+ raise ArgumentError
9
+ rescue ArgumentError => err
10
+ r = err.detail
11
+ r.assert.include?('ArgumentError')
12
+ end
13
+
14
+ The output of `#detail` looks something like this:
15
+
16
+ ArgumentError: ArgumentError
17
+ example.rb:4:in `<main>'
18
+ LOGGED FROM: example.rb:6:in `rescue in <main>'
19
+
@@ -1,4 +1,4 @@
1
- = Requiring Facets
1
+ # Requiring Facets
2
2
 
3
3
  We should be able to require all the core libraries by simply calling,
4
4
 
@@ -0,0 +1,13 @@
1
+ ## FileTest#root?
2
+
3
+ require 'facets/filetest/root'
4
+
5
+ Returns true if the given directory is the file system root.
6
+ Obviously on a Linux system them means `/`.
7
+
8
+ FileTest.assert.root?('/')
9
+
10
+ Anything else will return false.
11
+
12
+ FileTest.refute.root?('/home')
13
+
@@ -0,0 +1,21 @@
1
+ ## Hash#recursively
2
+
3
+ require 'facets/hash/recursively'
4
+
5
+ h = {:a=>1, :b=>{:c=>3}}
6
+
7
+ Without a block passed to the `#recursively` method, the block passed to the
8
+ enumeratig method will be used for both recursive and non-recursive yields.
9
+
10
+ r = h.recursively.map{ |k,v| [k.to_s, v] }
11
+
12
+ r.assert == [['a', 1], ['b', [['c', 3]]]]
13
+
14
+ But if we pass a block to `#recursively` we can treat the recusive yield
15
+ separately, which in turn allows us to manipulate the non-recursive
16
+ yields with a different procedure.
17
+
18
+ r = h.recursively{ |k,v| [k.to_s, v] }.map{ |k,v| [k.to_s,v.to_s] }
19
+
20
+ r.assert == [['a','1'], ['b', [['c', '3']]]]
21
+
@@ -0,0 +1,95 @@
1
+ # Indexable
2
+
3
+ Indexable it a module, like Enumerable, but provides methods specific
4
+ to an indexable collection. The Indexable module can be used independently,
5
+ but Facets can also automatically use it to extend Array.
6
+
7
+ require 'facets/array/indexable'
8
+
9
+ ## Indexable#head
10
+
11
+ a = [1,2,3,4,5]
12
+ a.head.assert = [1]
13
+
14
+ ## Indexable#tail
15
+
16
+ a = [1,2,3,4,5]
17
+ a.tail.assert = [2,3,4,5]
18
+
19
+ ## Indexable#foot
20
+
21
+ a = [1,2,3,4,5]
22
+ a.foot.assert = [5]
23
+
24
+ ## Indexable#body
25
+
26
+ a = [1,2,3,4,5]
27
+ a.body.assert = [1,2,3,4]
28
+
29
+ ## Indexable#mid
30
+
31
+ a = [1,2,3,4,5]
32
+ b = [1,2,3,4,5,6]
33
+ a.mid.assert = 3
34
+ b.mid.assert = 4
35
+ a.mid(1).assert = 4
36
+ b.mid(1).assert = 5
37
+ b.mid(2).assert = 6
38
+ b.mid(-1).assert = 3
39
+
40
+ ## Indexable#middle
41
+
42
+ a = [1,2,3,4,5]
43
+ b = [1,2,3,4,5,6]
44
+ a.middle.assert = [3]
45
+ b.middle.assert = [3,4]
46
+
47
+ ## Indexable#thru
48
+
49
+ [0,1,2,3,4,5].thru(2,4).assert = [2,3,4]
50
+ [0,1,2,3,4,5].thru(0,1).assert = [0,1]
51
+
52
+ ## Indexable#first=
53
+
54
+ a = [1,2]
55
+ a.first = 0
56
+ a.assert = [0,2]
57
+
58
+ ## Indexable#last=
59
+
60
+ a = [1,2]
61
+ a.last = 3
62
+ a.assert = [1,3]
63
+
64
+ ## Indexable#ends
65
+
66
+ [1,2,3,4,5].ends.assert = 4
67
+
68
+ ## Indexable#pos
69
+
70
+ a = [1,2,3,4,5]
71
+ a.pos(1).assert = 0
72
+ a.pos(-1).assert = 4
73
+
74
+ ## Indexable#range
75
+
76
+ a = [1,2,3,4,5]
77
+ b = [1,2,3,4,5,6]
78
+ a.range.assert = (0..4)
79
+ b.range.assert = (0..5)
80
+ a.range(2,4).assert = (1..3)
81
+ b.range(2,3).assert = (1..2)
82
+ b.range(4,2).assert = (3..1)
83
+
84
+ ## Indexable#first!
85
+
86
+ a = [1,2,3]
87
+ a.first!.assert = 1
88
+ a.assert = [2,3]
89
+
90
+ ## Indexable#last!
91
+
92
+ a = [1,2,3]
93
+ a.last!.assert = 3
94
+ a.assert = [1,2]
95
+