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
@@ -1,78 +0,0 @@
1
- # CONTRIBUTING TO FACETS
2
-
3
- * Facets methods must have no external dependencies. (The only possible
4
- exception to this is if the functor gets spun-off as a separate gem along
5
- with related methods, but for now that's not happening.)
6
-
7
- * Each method must be in it's own file of the same name. If the method ends
8
- with `=` or `?` just leave it off the file name.
9
-
10
- * On rare occasion two or more methods can be very tightly related. In these
11
- cases the methods can all go in a single file under the name of the method
12
- considered most significant. Usually files for the other methods should
13
- still be created that simply require the main file.
14
-
15
- * Methods must be tested either via a Lemon unit test or a QED demo,
16
- preferably both. The Lemon unit tests are for testing a method in
17
- detail whereas the QED demos are for demonstrating usage.
18
-
19
- * Facets is divided into two parts, *core* and *standard* libraries.
20
- All of the core library is loaded by default when using `require 'facets'`
21
- (actually, almost all). The standard library (sometimes called the *more*
22
- library) must be required per-script.
23
-
24
- * Some core methods are included on a *trial* basis, and these are not
25
- necessary loaded automatically with `require 'facets'`.
26
-
27
- * Standard libraries that are not extensions of existing standard libraries
28
- do not have to be divvied up into individual method files. But note that
29
- full classes and/or modules are less likely to make it into Facets, as
30
- these sorts of additions to Facets are only for very basic sorts of things.
31
- Otherwise they'd deserve their own gem.
32
-
33
- * When submitting new methods for consideration, it is best if each method
34
- (or *tightly related* set of methods) is in it's own pull request. If you
35
- have only one method to submit then a simple commit will do the tirck. If
36
- you have more than one it best to use separate branches. Let me emphasizes
37
- this point because it makes it *much more likely* that your pull request
38
- will be merged. If you submit a bunch of methods in a single pull request,
39
- it is very likely that it will not be merged even if methods you submitted
40
- are accepted!!!
41
-
42
- * Don't be discouraged when you get feedback about a method that isn't
43
- all sunshine and roses. Facets has been around long enough now that
44
- it needs to maintain a certain degree of quality control, and that means
45
- serious discernment about what goes into the library. That includes
46
- having in depth discussions the merits of methods, even about the best
47
- name for a method --even if the functionality has been accepted the name
48
- may not!
49
-
50
- * When making a commit, if the commit is only a documentation change, then
51
- and `[doc]` to the end of the first line of commit message. If it is only
52
- a change to tests then add `[test]`. If the change only effects build files
53
- then add `[admin]`. For actual code changes, if the change is not somethng
54
- anyone would notice, use `[tweak]` or `[minor]` (minor being slightly more
55
- improtant than tweak). For typical code changes no comment tag is necessary.
56
- If the change fixes a bug that was reported via the issue system be sure to
57
- reference the issue id in the message using `#` and add `[bug]`. If a change
58
- is a significant change to the API, then end the message with `[major]`.
59
- These are all rules of thumb, and no expects them to be applied perfectly.
60
-
61
- ## Documentation
62
-
63
- Facets started when the only choice for API documentation was RDoc. So originally
64
- that's how methods were documented. Since then both YARD and Tomdoc have come
65
- along. And some of these documentation styles have creeped into a number of
66
- methods. So right now, things are a bit messy. But going forward it looks like we
67
- are going to settle on Tomdoc as the official documentation style (but using
68
- the tomparse gem's extensions). Using Tomdoc will give us reasonable
69
- interoperabiltiy with both RDoc and YARD, both of which now have support for
70
- Tomdoc (albeit support is not 100% the same, but hopefully it's close enough).
71
-
72
- Offically we publish documentation via rubydoc.info, which is the YARD server,
73
- and via the Facets website in Shomen JSON format.
74
-
75
- When writting documentation for a method it is best to give a simple summary
76
- explaination, followed by some basic examples. Follow that up with deeper
77
- explaination if needed, including *when* and *why* the method could be useful.
78
-
@@ -1,19 +0,0 @@
1
- == Array#combination
2
-
3
- require 'facets/array/combination'
4
-
5
- finds pairs of combinations
6
-
7
- e = [[1, 2], [1, 3], [1, 4], [2, 3], [2, 4], [3, 4]]
8
- a = [1,2,3,4]
9
- r = a.combination(2).to_a
10
- r.assert == e
11
-
12
- can also take a block
13
-
14
- e = [[1,2],[1,3],[1,4],[2,3],[2,4],[3,4]]
15
- r = []
16
- a = [1,2,3,4]
17
- a.combination(2){ |a,b| r << [a,b] }
18
- r.assert == e
19
-
@@ -1,23 +0,0 @@
1
- == Array#delete_unless
2
-
3
- require 'facets/array/delete'
4
-
5
- a = [1,2,3]
6
- a.delete_unless{ |e| e == 2 }
7
- a.assert == [2]
8
-
9
- == Array#delete_values
10
-
11
- a = [1,2,3,4]
12
- a.delete_values(1,2).assert == [1,2]
13
- a.assert == [3,4]
14
-
15
- == Array#delete_values_at
16
-
17
- a = [1,2,3,4]
18
- a.delete_values_at(1,2).assert == [2,3]
19
- a.assert == [1,4]
20
- a = [1,2,3,4]
21
- a.delete_values_at(0..2).assert == [1,2,3]
22
- a.assert == [4]
23
-
@@ -1,14 +0,0 @@
1
- == Array#index
2
-
3
- require 'facets/array/index'
4
-
5
- can handle a block
6
-
7
- i = [1,2,3].index{ |e| e == 2 }
8
- i.assert == 1
9
-
10
- when no element is found
11
-
12
- i = [1,2,3].index{ |e| e == 5 }
13
- i.assert.nil?
14
-
@@ -1,15 +0,0 @@
1
- == Array#merge
2
-
3
- require 'facets/array/merge'
4
-
5
- a = [1,2,3]
6
- b = [3,4,5]
7
- a.merge(b).assert == [1,2,3,4,5]
8
-
9
- == Array#merge!
10
-
11
- a = [1,2,3]
12
- b = [3,4,5]
13
- a.merge!(b)
14
- a.assert == [1,2,3,4,5]
15
-
@@ -1,9 +0,0 @@
1
- == Array#only
2
-
3
- require 'facets/array/only'
4
-
5
- [5].only.assert == 5
6
- [nil].only.assert == nil
7
- expect(IndexError){ [].only }
8
- expect(IndexError){ [1,2,3].only }
9
-
@@ -1,28 +0,0 @@
1
- == Array#pad
2
-
3
- require 'facets/array/pad'
4
-
5
- r = [0,1,2,3].pad(7,"x")
6
- x = [0,1,2,3,"x","x","x"]
7
- r.assert == x
8
-
9
- negative index
10
-
11
- r = [0,1,2,3].pad(-7,"n")
12
- x = ["n","n","n",0,1,2,3]
13
- r.assert == x
14
-
15
- == Array#pad!
16
-
17
- a = [0,1,2,3]
18
- r = a.pad!(6,"y")
19
- x = [0,1,2,3,"y","y"]
20
- r.assert == x
21
-
22
- negative index
23
-
24
- a = [0,1,2,3]
25
- r = a.pad!(-6,"q")
26
- x = ["q","q",0,1,2,3]
27
- r.assert == x
28
-
@@ -1,10 +0,0 @@
1
- == Array#permutation
2
-
3
- require 'facets/array/permutation'
4
- require 'set'
5
-
6
- r = Set.new
7
- %w[a b c].permutation{ |x| r << x.join('') }
8
- x = Set.new(['abc','acb','bac','bca','cab','cba'])
9
- r.assert == x
10
-
@@ -1,26 +0,0 @@
1
- == Array#product
2
-
3
- require 'facets/array/product'
4
-
5
- single argument
6
-
7
- r = [1,2,3].product([4,5,6])
8
- x = [[1, 4],[1, 5],[1, 6],[2, 4],[2, 5],[2, 6],[3, 4],[3, 5],[3, 6]]
9
- r.assert == x
10
-
11
- multiple arguments
12
-
13
- a = %w|a b|
14
- b = %w|a x|
15
- c = %w|x y|
16
- r = a.product(b, c)
17
- x = [ ["a", "a", "x"],
18
- ["a", "a", "y"],
19
- ["a", "x", "x"],
20
- ["a", "x", "y"],
21
- ["b", "a", "x"],
22
- ["b", "a", "y"],
23
- ["b", "x", "x"],
24
- ["b", "x", "y"] ]
25
- r.assert == x
26
-
@@ -1,16 +0,0 @@
1
- == Array#recursive
2
-
3
- require 'facets/array/recursively'
4
-
5
- each
6
-
7
- r = []
8
- [1,2,['a','b']].recursively.each{ |v| r << v }
9
- r.assert == [1,2,'a','b']
10
-
11
-
12
- map
13
-
14
- r = [1,2,['a','b']].recursively.map{ |v| v.succ }
15
- r.assert == [2,3,['b','c']]
16
-
@@ -1,30 +0,0 @@
1
- == Array#rotate
2
-
3
- require 'facets/array/rotate'
4
-
5
- clockwise
6
-
7
- a = [1,2,3]
8
- r = a.rotate
9
- r.assert == [2,3,1]
10
-
11
- counter-clockwise
12
-
13
- a = [1,2,3]
14
- r = a.rotate(-1)
15
- r.assert == [3,1,2]
16
-
17
- == Array#rotate!
18
-
19
- clockwise
20
-
21
- a = [1,2,3]
22
- a.rotate!
23
- a.assert == [2,3,1]
24
-
25
- counter-clockwise
26
-
27
- a = [1,2,3]
28
- a.rotate!(-1)
29
- a.assert == [3,1,2]
30
-
@@ -1,8 +0,0 @@
1
- == Array#select
2
-
3
- require 'facets/array/select'
4
-
5
- a = [1,2,3,4,5,6,7,8,9,10]
6
- a.select!{ |e| e % 2 == 0 }
7
- a.assert == [2,4,6,8,10]
8
-
@@ -1,9 +0,0 @@
1
- == Array#uniq_by!
2
-
3
- require 'facets/array/uniq_by'
4
-
5
- e = [-5, -4, -3, -2, -1, 0]
6
- r = (-5..5).to_a
7
- r.uniq_by!{ |i| i*i }
8
- r.assert == e
9
-
@@ -1,57 +0,0 @@
1
- The caller.rb script includes a few related methods.
2
- We will use the following code to demonstrate their use.
3
-
4
- require 'facets/binding/caller'
5
-
6
- a = 1
7
- b = 2
8
- x = "hello"
9
-
10
- @bind = binding
11
- @line = __LINE__ # the line number must be updated if it moves
12
- @file = __FILE__ # why does it equal basename only?
13
-
14
- == Binding#caller
15
-
16
- @bind.caller
17
-
18
- == Binding#callstack
19
-
20
- @bind.callstack.assert.is_a?(Array)
21
-
22
- == Binding#__LINE__
23
-
24
- @bind.__LINE__.assert == @line - 1
25
-
26
- == Binding#__FILE__
27
-
28
- @bind.__FILE__.assert == @file
29
-
30
- == Binding#__DIR__
31
-
32
- @bind.__DIR__.assert == File.dirname(@file)
33
-
34
- == Binding#__callee__
35
-
36
- This only works for certain versions.
37
-
38
- def alternate_callee
39
- binding
40
- end
41
-
42
- unless RUBY_VERSION < "1.9"
43
- alternate_callee.__callee__.assert == :alternate_callee
44
- end
45
-
46
- == Binding#__method__
47
-
48
- This only works for certain versions.
49
-
50
- def alternate_method
51
- binding
52
- end
53
-
54
- unless RUBY_VERSION < "1.8.7"
55
- alternate_method.__method__.assert == :alternate_method
56
- end
57
-
@@ -1,10 +0,0 @@
1
- == Binding#defined?
2
-
3
- require 'facets/binding/defined'
4
-
5
- a = 1
6
- b = 2
7
- x = "hello"
8
-
9
- binding.assert.defined?("x")
10
-
@@ -1,8 +0,0 @@
1
- == Binding#eval
2
-
3
- require 'facets/binding/eval'
4
-
5
- x = "hello"
6
-
7
- binding.eval("x").assert == "hello"
8
-
@@ -1,26 +0,0 @@
1
- == Binding#local_variables
2
-
3
- require 'facets/binding/local_variables'
4
-
5
- a = 1
6
- b = 2
7
- x = "hello"
8
-
9
- unless RUBY_VERSION > "1.9"
10
-
11
- lvars = binding.local_variables
12
-
13
- lvars.assert.include?('a')
14
- lvars.assert.include?('b')
15
- lvars.assert.include?('x')
16
-
17
- else
18
-
19
- lvars = binding.local_variables
20
-
21
- lvars.assert.include?(:a)
22
- lvars.assert.include?(:b)
23
- lvars.assert.include?(:x)
24
-
25
- end
26
-
@@ -1,16 +0,0 @@
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
-
@@ -1,6 +0,0 @@
1
- == Binding#self
2
-
3
- require 'facets/binding/self'
4
-
5
- binding.self == self
6
-
@@ -1,10 +0,0 @@
1
- == Class#descendants
2
-
3
- require 'facets/class/descendants'
4
-
5
- a = Class.new
6
- b = Class.new(a)
7
- c = Class.new(b)
8
-
9
- a.descendants.assert == [b,c]
10
-