alf-shell 0.14.0 → 0.15.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (276) hide show
  1. data/Gemfile +5 -2
  2. data/Gemfile.lock +29 -10
  3. data/bin/alf +2 -0
  4. data/doc/man/alf-explain.man +22 -0
  5. data/doc/man/alf-metadata.man +13 -0
  6. data/doc/man/alf-show.man +16 -0
  7. data/doc/man/alf.man +77 -0
  8. data/doc/man/allbut.man +39 -0
  9. data/doc/man/among.man +25 -0
  10. data/doc/man/avg.man +37 -0
  11. data/doc/man/between.man +24 -0
  12. data/doc/man/concat.man +55 -0
  13. data/doc/man/contradiction.man +26 -0
  14. data/doc/man/count.man +20 -0
  15. data/doc/man/eq.man +29 -0
  16. data/doc/man/extend.man +33 -0
  17. data/doc/man/frame.man +60 -0
  18. data/doc/man/group.man +51 -0
  19. data/doc/man/gt.man +30 -0
  20. data/doc/man/gte.man +30 -0
  21. data/doc/man/intersect.man +54 -0
  22. data/doc/man/join.man +84 -0
  23. data/doc/man/lt.man +30 -0
  24. data/doc/man/lte.man +30 -0
  25. data/doc/man/matching.man +73 -0
  26. data/doc/man/max.man +36 -0
  27. data/doc/man/min.man +36 -0
  28. data/doc/man/minus.man +54 -0
  29. data/doc/man/native.man +32 -0
  30. data/doc/man/neq.man +29 -0
  31. data/doc/man/not_matching.man +51 -0
  32. data/doc/man/page.man +60 -0
  33. data/doc/man/project.man +36 -0
  34. data/doc/man/rank.man +42 -0
  35. data/doc/man/rename.man +29 -0
  36. data/doc/man/restrict.man +38 -0
  37. data/doc/man/stddev.man +37 -0
  38. data/doc/man/sum.man +37 -0
  39. data/doc/man/summarize.man +45 -0
  40. data/doc/man/tautology.man +26 -0
  41. data/doc/man/ungroup.man +30 -0
  42. data/doc/man/union.man +55 -0
  43. data/doc/man/unwrap.man +37 -0
  44. data/doc/man/variance.man +37 -0
  45. data/doc/man/wrap.man +37 -0
  46. data/doc/txt/alf-explain.man +22 -0
  47. data/doc/txt/alf-metadata.man +16 -0
  48. data/doc/txt/alf-show.man +19 -0
  49. data/doc/txt/alf.man +80 -0
  50. data/doc/txt/allbut.txt +31 -0
  51. data/doc/txt/among.txt +20 -0
  52. data/doc/txt/avg.txt +22 -0
  53. data/doc/txt/between.txt +19 -0
  54. data/doc/txt/concat.txt +31 -0
  55. data/doc/txt/contradiction.txt +15 -0
  56. data/doc/txt/count.txt +14 -0
  57. data/doc/txt/eq.txt +19 -0
  58. data/doc/txt/extend.txt +29 -0
  59. data/doc/txt/frame.txt +48 -0
  60. data/doc/txt/group.txt +37 -0
  61. data/doc/txt/gt.txt +20 -0
  62. data/doc/txt/gte.txt +20 -0
  63. data/doc/txt/intersect.txt +42 -0
  64. data/doc/txt/join.txt +65 -0
  65. data/doc/txt/lt.txt +20 -0
  66. data/doc/txt/lte.txt +20 -0
  67. data/doc/txt/matching.txt +54 -0
  68. data/doc/txt/max.txt +21 -0
  69. data/doc/txt/min.txt +21 -0
  70. data/doc/txt/minus.txt +42 -0
  71. data/doc/txt/native.txt +27 -0
  72. data/doc/txt/neq.txt +19 -0
  73. data/doc/txt/not_matching.txt +39 -0
  74. data/doc/txt/page.txt +48 -0
  75. data/doc/txt/project.txt +28 -0
  76. data/doc/txt/rank.txt +34 -0
  77. data/doc/txt/rename.txt +25 -0
  78. data/doc/txt/restrict.txt +26 -0
  79. data/doc/txt/stddev.txt +22 -0
  80. data/doc/txt/sum.txt +22 -0
  81. data/doc/txt/summarize.txt +33 -0
  82. data/doc/txt/tautology.txt +15 -0
  83. data/doc/txt/ungroup.txt +26 -0
  84. data/doc/txt/union.txt +43 -0
  85. data/doc/txt/unwrap.txt +29 -0
  86. data/doc/txt/variance.txt +22 -0
  87. data/doc/txt/wrap.txt +29 -0
  88. data/lib/alf/shell.rb +2 -32
  89. data/lib/alf/shell/alfrc.rb +3 -0
  90. data/lib/alf/shell/command.rb +2 -18
  91. data/lib/alf/shell/command/explain.rb +37 -0
  92. data/lib/alf/shell/command/help.rb +3 -21
  93. data/lib/alf/shell/command/main.rb +20 -78
  94. data/lib/alf/shell/command/metadata.rb +32 -0
  95. data/lib/alf/shell/command/show.rb +17 -5
  96. data/lib/alf/shell/support.rb +21 -13
  97. data/lib/alf/shell/version.rb +1 -1
  98. data/spec/integration/explain/explain.cmd +1 -0
  99. data/spec/integration/explain/explain.stdout +11 -0
  100. data/spec/integration/show/group.alf +2 -0
  101. data/spec/integration/show/show_alf.cmd +1 -0
  102. data/spec/integration/{group/group_0.stdout → show/show_alf.stdout} +0 -0
  103. data/tasks/doc.rake +4 -0
  104. metadata +116 -178
  105. data/doc/commands/exec.md +0 -16
  106. data/doc/commands/help.md +0 -11
  107. data/doc/commands/main.md +0 -33
  108. data/doc/commands/show.md +0 -12
  109. data/doc/operators/non_relational/autonum.md +0 -23
  110. data/doc/operators/non_relational/clip.md +0 -31
  111. data/doc/operators/non_relational/coerce.md +0 -15
  112. data/doc/operators/non_relational/compact.md +0 -20
  113. data/doc/operators/non_relational/defaults.md +0 -32
  114. data/doc/operators/non_relational/generator.md +0 -20
  115. data/doc/operators/non_relational/sort.md +0 -24
  116. data/doc/operators/non_relational/type-safe.md +0 -20
  117. data/doc/operators/relational/extend.md +0 -18
  118. data/doc/operators/relational/frame.md +0 -26
  119. data/doc/operators/relational/group.md +0 -27
  120. data/doc/operators/relational/hierarchize.md +0 -14
  121. data/doc/operators/relational/infer-heading.md +0 -20
  122. data/doc/operators/relational/intersect.md +0 -13
  123. data/doc/operators/relational/join.md +0 -28
  124. data/doc/operators/relational/matching.md +0 -24
  125. data/doc/operators/relational/minus.md +0 -12
  126. data/doc/operators/relational/not-matching.md +0 -20
  127. data/doc/operators/relational/page.md +0 -31
  128. data/doc/operators/relational/project.md +0 -28
  129. data/doc/operators/relational/quota.md +0 -21
  130. data/doc/operators/relational/rank.md +0 -27
  131. data/doc/operators/relational/rename.md +0 -17
  132. data/doc/operators/relational/restrict.md +0 -25
  133. data/doc/operators/relational/summarize.md +0 -25
  134. data/doc/operators/relational/ungroup.md +0 -20
  135. data/doc/operators/relational/union.md +0 -14
  136. data/doc/operators/relational/unwrap.md +0 -20
  137. data/doc/operators/relational/wrap.md +0 -24
  138. data/lib/alf/shell/command/exec.rb +0 -16
  139. data/lib/alf/shell/doc_manager.rb +0 -84
  140. data/lib/alf/shell/ext/signature.rb +0 -45
  141. data/lib/alf/shell/from_argv.rb +0 -84
  142. data/lib/alf/shell/operator.rb +0 -63
  143. data/spec/integration/__database__/group.alf +0 -3
  144. data/spec/integration/alf/alf_e.cmd +0 -1
  145. data/spec/integration/alf/alf_e.stdout +0 -4
  146. data/spec/integration/alf/alf_help.cmd +0 -1
  147. data/spec/integration/alf/alf_help.stdout +0 -76
  148. data/spec/integration/alf/alf_r.cmd +0 -1
  149. data/spec/integration/alf/alf_r.stdout +0 -5
  150. data/spec/integration/autonum/autonum_0.cmd +0 -1
  151. data/spec/integration/autonum/autonum_0.stdout +0 -9
  152. data/spec/integration/autonum/autonum_1.cmd +0 -1
  153. data/spec/integration/autonum/autonum_1.stdout +0 -9
  154. data/spec/integration/clip/clip_0.cmd +0 -1
  155. data/spec/integration/clip/clip_0.stdout +0 -9
  156. data/spec/integration/clip/clip_1.cmd +0 -1
  157. data/spec/integration/clip/clip_1.stdout +0 -9
  158. data/spec/integration/coerce/coerce_1.cmd +0 -1
  159. data/spec/integration/coerce/coerce_1.stdout +0 -5
  160. data/spec/integration/compact/compact_0.cmd +0 -1
  161. data/spec/integration/compact/compact_0.stdout +0 -9
  162. data/spec/integration/defaults/defaults_0.cmd +0 -1
  163. data/spec/integration/defaults/defaults_0.stdout +0 -9
  164. data/spec/integration/defaults/defaults_1.cmd +0 -1
  165. data/spec/integration/defaults/defaults_1.stdout +0 -9
  166. data/spec/integration/defaults/defaults_2.cmd +0 -1
  167. data/spec/integration/defaults/defaults_2.stdout +0 -9
  168. data/spec/integration/extend/extend_0.cmd +0 -1
  169. data/spec/integration/extend/extend_0.stdout +0 -16
  170. data/spec/integration/frame/frame_0.cmd +0 -1
  171. data/spec/integration/frame/frame_0.stdout +0 -6
  172. data/spec/integration/generator/generator_1.cmd +0 -1
  173. data/spec/integration/generator/generator_1.stdout +0 -10
  174. data/spec/integration/generator/generator_2.cmd +0 -1
  175. data/spec/integration/generator/generator_2.stdout +0 -5
  176. data/spec/integration/generator/generator_3.cmd +0 -1
  177. data/spec/integration/generator/generator_3.stdout +0 -5
  178. data/spec/integration/group/group_0.cmd +0 -1
  179. data/spec/integration/group/group_1.cmd +0 -1
  180. data/spec/integration/group/group_1.stdout +0 -32
  181. data/spec/integration/help/help_1.cmd +0 -1
  182. data/spec/integration/help/help_1.stdout +0 -12
  183. data/spec/integration/intersect/intersect_0.cmd +0 -1
  184. data/spec/integration/intersect/intersect_0.stdout +0 -9
  185. data/spec/integration/join/join_0.cmd +0 -1
  186. data/spec/integration/join/join_0.stdout +0 -16
  187. data/spec/integration/matching/matching_0.cmd +0 -1
  188. data/spec/integration/matching/matching_0.stdout +0 -8
  189. data/spec/integration/minus/minus_0.cmd +0 -1
  190. data/spec/integration/minus/minus_0.stdout +0 -4
  191. data/spec/integration/not-matching/not-matching_0.cmd +0 -1
  192. data/spec/integration/not-matching/not-matching_0.stdout +0 -5
  193. data/spec/integration/page/page_0.cmd +0 -1
  194. data/spec/integration/page/page_0.stdout +0 -6
  195. data/spec/integration/project/project_0.cmd +0 -1
  196. data/spec/integration/project/project_0.stdout +0 -9
  197. data/spec/integration/project/project_1.cmd +0 -1
  198. data/spec/integration/project/project_1.stdout +0 -9
  199. data/spec/integration/quota/quota_0.cmd +0 -1
  200. data/spec/integration/quota/quota_0.stdout +0 -16
  201. data/spec/integration/rank/rank_1.cmd +0 -1
  202. data/spec/integration/rank/rank_1.stdout +0 -10
  203. data/spec/integration/rank/rank_2.cmd +0 -1
  204. data/spec/integration/rank/rank_2.stdout +0 -10
  205. data/spec/integration/rank/rank_3.cmd +0 -1
  206. data/spec/integration/rank/rank_3.stdout +0 -10
  207. data/spec/integration/rank/rank_4.cmd +0 -1
  208. data/spec/integration/rank/rank_4.stdout +0 -6
  209. data/spec/integration/rank/rank_5.cmd +0 -1
  210. data/spec/integration/rank/rank_5.stdout +0 -6
  211. data/spec/integration/rename/rename_0.cmd +0 -1
  212. data/spec/integration/rename/rename_0.stdout +0 -9
  213. data/spec/integration/restrict/restrict_0.cmd +0 -1
  214. data/spec/integration/restrict/restrict_0.stdout +0 -6
  215. data/spec/integration/restrict/restrict_1.cmd +0 -1
  216. data/spec/integration/restrict/restrict_1.stdout +0 -6
  217. data/spec/integration/sort/sort_0.cmd +0 -1
  218. data/spec/integration/sort/sort_0.stdout +0 -9
  219. data/spec/integration/sort/sort_1.cmd +0 -1
  220. data/spec/integration/sort/sort_1.stdout +0 -9
  221. data/spec/integration/sort/sort_2.cmd +0 -1
  222. data/spec/integration/sort/sort_2.stdout +0 -9
  223. data/spec/integration/sort/sort_3.cmd +0 -1
  224. data/spec/integration/sort/sort_3.stdout +0 -9
  225. data/spec/integration/summarize/summarize_0.cmd +0 -1
  226. data/spec/integration/summarize/summarize_0.stdout +0 -8
  227. data/spec/integration/union/union_0.cmd +0 -1
  228. data/spec/integration/union/union_0.stdout +0 -9
  229. data/spec/integration/unwrap/unwrap_0.cmd +0 -1
  230. data/spec/integration/unwrap/unwrap_0.stdout +0 -9
  231. data/spec/integration/wrap/wrap_0.cmd +0 -1
  232. data/spec/integration/wrap/wrap_0.stdout +0 -9
  233. data/spec/unit/doc_manager/dynamic.md +0 -1
  234. data/spec/unit/doc_manager/example.md +0 -1
  235. data/spec/unit/doc_manager/example_1.txt +0 -11
  236. data/spec/unit/doc_manager/static.md +0 -1
  237. data/spec/unit/doc_manager/test_call.rb +0 -41
  238. data/spec/unit/ext/signature/test_argv2args.rb +0 -82
  239. data/spec/unit/ext/signature/test_to_shell.rb +0 -103
  240. data/spec/unit/from_argv/test_to_attr_list.rb +0 -30
  241. data/spec/unit/from_argv/test_to_attr_name.rb +0 -27
  242. data/spec/unit/from_argv/test_to_boolean.rb +0 -32
  243. data/spec/unit/from_argv/test_to_heading.rb +0 -37
  244. data/spec/unit/from_argv/test_to_ordering.rb +0 -28
  245. data/spec/unit/from_argv/test_to_predicate.rb +0 -26
  246. data/spec/unit/from_argv/test_to_renaming.rb +0 -23
  247. data/spec/unit/from_argv/test_to_size.rb +0 -32
  248. data/spec/unit/from_argv/test_to_summarization.rb +0 -19
  249. data/spec/unit/from_argv/test_to_tuple_computation.rb +0 -18
  250. data/spec/unit/from_argv/test_to_tuple_expression.rb +0 -38
  251. data/spec/unit/main/test_class_methods.rb +0 -44
  252. data/spec/unit/operator/test_autonum.rb +0 -28
  253. data/spec/unit/operator/test_clip.rb +0 -29
  254. data/spec/unit/operator/test_coerce.rb +0 -22
  255. data/spec/unit/operator/test_compact.rb +0 -16
  256. data/spec/unit/operator/test_defaults.rb +0 -29
  257. data/spec/unit/operator/test_extend.rb +0 -21
  258. data/spec/unit/operator/test_generator.rb +0 -37
  259. data/spec/unit/operator/test_group.rb +0 -32
  260. data/spec/unit/operator/test_infer_heading.rb +0 -16
  261. data/spec/unit/operator/test_intersect.rb +0 -18
  262. data/spec/unit/operator/test_join.rb +0 -18
  263. data/spec/unit/operator/test_matching.rb +0 -18
  264. data/spec/unit/operator/test_minus.rb +0 -18
  265. data/spec/unit/operator/test_not_matching.rb +0 -18
  266. data/spec/unit/operator/test_project.rb +0 -38
  267. data/spec/unit/operator/test_quota.rb +0 -23
  268. data/spec/unit/operator/test_rank.rb +0 -30
  269. data/spec/unit/operator/test_rename.rb +0 -21
  270. data/spec/unit/operator/test_restrict.rb +0 -36
  271. data/spec/unit/operator/test_sort.rb +0 -49
  272. data/spec/unit/operator/test_summarize.rb +0 -30
  273. data/spec/unit/operator/test_ungroup.rb +0 -28
  274. data/spec/unit/operator/test_union.rb +0 -18
  275. data/spec/unit/operator/test_unwrap.rb +0 -28
  276. data/spec/unit/operator/test_wrap.rb +0 -30
@@ -1,32 +0,0 @@
1
- +------+-----------------+
2
- | :sid | :supplying |
3
- +------+-----------------+
4
- | S1 | +------+------+ |
5
- | | | :pid | :qty | |
6
- | | +------+------+ |
7
- | | | P1 | 300 | |
8
- | | | P2 | 200 | |
9
- | | | P3 | 400 | |
10
- | | | P4 | 200 | |
11
- | | | P5 | 100 | |
12
- | | | P6 | 100 | |
13
- | | +------+------+ |
14
- | S2 | +------+------+ |
15
- | | | :pid | :qty | |
16
- | | +------+------+ |
17
- | | | P1 | 300 | |
18
- | | | P2 | 400 | |
19
- | | +------+------+ |
20
- | S3 | +------+------+ |
21
- | | | :pid | :qty | |
22
- | | +------+------+ |
23
- | | | P2 | 200 | |
24
- | | +------+------+ |
25
- | S4 | +------+------+ |
26
- | | | :pid | :qty | |
27
- | | +------+------+ |
28
- | | | P2 | 200 | |
29
- | | | P4 | 300 | |
30
- | | | P5 | 400 | |
31
- | | +------+------+ |
32
- +------+-----------------+
@@ -1 +0,0 @@
1
- alf help show
@@ -1,12 +0,0 @@
1
-
2
- Output input tuples through the default renderer in a specific order.
3
-
4
- SYNOPSIS
5
-
6
- alf show NAME -- [ORDERING]
7
-
8
- DESCRIPTION
9
-
10
- When a name is specified as commandline arg, request the database to
11
- provide the corresponding relation variable and prints its value.
12
- Otherwise, take what comes on standard input.
@@ -1 +0,0 @@
1
- alf --text intersect suppliers suppliers
@@ -1,9 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S1 | Smith | 20 | London |
5
- | S2 | Jones | 10 | Paris |
6
- | S3 | Blake | 30 | Paris |
7
- | S4 | Clark | 20 | London |
8
- | S5 | Adams | 30 | Athens |
9
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text join suppliers supplies
@@ -1,16 +0,0 @@
1
- +------+-------+---------+--------+------+------+
2
- | :sid | :name | :status | :city | :pid | :qty |
3
- +------+-------+---------+--------+------+------+
4
- | S1 | Smith | 20 | London | P1 | 300 |
5
- | S1 | Smith | 20 | London | P2 | 200 |
6
- | S1 | Smith | 20 | London | P3 | 400 |
7
- | S1 | Smith | 20 | London | P4 | 200 |
8
- | S1 | Smith | 20 | London | P5 | 100 |
9
- | S1 | Smith | 20 | London | P6 | 100 |
10
- | S2 | Jones | 10 | Paris | P1 | 300 |
11
- | S2 | Jones | 10 | Paris | P2 | 400 |
12
- | S3 | Blake | 30 | Paris | P2 | 200 |
13
- | S4 | Clark | 20 | London | P2 | 200 |
14
- | S4 | Clark | 20 | London | P4 | 300 |
15
- | S4 | Clark | 20 | London | P5 | 400 |
16
- +------+-------+---------+--------+------+------+
@@ -1 +0,0 @@
1
- alf --text matching suppliers supplies
@@ -1,8 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S1 | Smith | 20 | London |
5
- | S2 | Jones | 10 | Paris |
6
- | S3 | Blake | 30 | Paris |
7
- | S4 | Clark | 20 | London |
8
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text minus suppliers suppliers
@@ -1,4 +0,0 @@
1
- +--+
2
- | |
3
- +--+
4
- +--+
@@ -1 +0,0 @@
1
- alf --text not-matching suppliers supplies
@@ -1,5 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S5 | Adams | 30 | Athens |
5
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text page --page-size=2 suppliers -- name -- 1
@@ -1,6 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S5 | Adams | 30 | Athens |
5
- | S3 | Blake | 30 | Paris |
6
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text project suppliers -- name city
@@ -1,9 +0,0 @@
1
- +-------+--------+
2
- | :name | :city |
3
- +-------+--------+
4
- | Smith | London |
5
- | Jones | Paris |
6
- | Blake | Paris |
7
- | Clark | London |
8
- | Adams | Athens |
9
- +-------+--------+
@@ -1 +0,0 @@
1
- alf --text project --allbut suppliers -- name city
@@ -1,9 +0,0 @@
1
- +------+---------+
2
- | :sid | :status |
3
- +------+---------+
4
- | S1 | 20 |
5
- | S2 | 10 |
6
- | S3 | 30 |
7
- | S4 | 20 |
8
- | S5 | 30 |
9
- +------+---------+
@@ -1 +0,0 @@
1
- alf --text quota supplies -- sid -- qty -- position "count()" sum_qty "sum{ qty }"
@@ -1,16 +0,0 @@
1
- +------+------+------+-----------+----------+
2
- | :sid | :pid | :qty | :position | :sum_qty |
3
- +------+------+------+-----------+----------+
4
- | S1 | P6 | 100 | 1 | 100 |
5
- | S1 | P5 | 100 | 2 | 200 |
6
- | S1 | P2 | 200 | 3 | 400 |
7
- | S1 | P4 | 200 | 4 | 600 |
8
- | S1 | P1 | 300 | 5 | 900 |
9
- | S1 | P3 | 400 | 6 | 1300 |
10
- | S2 | P1 | 300 | 1 | 300 |
11
- | S2 | P2 | 400 | 2 | 700 |
12
- | S3 | P2 | 200 | 1 | 200 |
13
- | S4 | P2 | 200 | 1 | 200 |
14
- | S4 | P4 | 300 | 2 | 500 |
15
- | S4 | P5 | 400 | 3 | 900 |
16
- +------+------+------+-----------+----------+
@@ -1 +0,0 @@
1
- alf --text rank parts -- weight
@@ -1,10 +0,0 @@
1
- +------+-------+--------+---------+--------+-------+
2
- | :pid | :name | :color | :weight | :city | :rank |
3
- +------+-------+--------+---------+--------+-------+
4
- | P1 | Nut | Red | 12.000 | London | 0 |
5
- | P5 | Cam | Blue | 12.000 | Paris | 0 |
6
- | P4 | Screw | Red | 14.000 | London | 2 |
7
- | P3 | Screw | Blue | 17.000 | Oslo | 3 |
8
- | P2 | Bolt | Green | 17.000 | Paris | 3 |
9
- | P6 | Cog | Red | 19.000 | London | 5 |
10
- +------+-------+--------+---------+--------+-------+
@@ -1 +0,0 @@
1
- alf --text rank parts -- weight -- pos
@@ -1,10 +0,0 @@
1
- +------+-------+--------+---------+--------+------+
2
- | :pid | :name | :color | :weight | :city | :pos |
3
- +------+-------+--------+---------+--------+------+
4
- | P1 | Nut | Red | 12.000 | London | 0 |
5
- | P5 | Cam | Blue | 12.000 | Paris | 0 |
6
- | P4 | Screw | Red | 14.000 | London | 2 |
7
- | P3 | Screw | Blue | 17.000 | Oslo | 3 |
8
- | P2 | Bolt | Green | 17.000 | Paris | 3 |
9
- | P6 | Cog | Red | 19.000 | London | 5 |
10
- +------+-------+--------+---------+--------+------+
@@ -1 +0,0 @@
1
- alf --text rank parts -- weight pid
@@ -1,10 +0,0 @@
1
- +------+-------+--------+---------+--------+-------+
2
- | :pid | :name | :color | :weight | :city | :rank |
3
- +------+-------+--------+---------+--------+-------+
4
- | P1 | Nut | Red | 12.000 | London | 0 |
5
- | P5 | Cam | Blue | 12.000 | Paris | 1 |
6
- | P4 | Screw | Red | 14.000 | London | 2 |
7
- | P2 | Bolt | Green | 17.000 | Paris | 3 |
8
- | P3 | Screw | Blue | 17.000 | Oslo | 4 |
9
- | P6 | Cog | Red | 19.000 | London | 5 |
10
- +------+-------+--------+---------+--------+-------+
@@ -1 +0,0 @@
1
- alf rank parts -- weight desc -- position
@@ -1,6 +0,0 @@
1
- {:pid => "P6", :name => "Cog", :color => "Red", :weight => 19.0, :city => "London", :position => 0}
2
- {:pid => "P2", :name => "Bolt", :color => "Green", :weight => 17.0, :city => "Paris", :position => 1}
3
- {:pid => "P3", :name => "Screw", :color => "Blue", :weight => 17.0, :city => "Oslo", :position => 1}
4
- {:pid => "P4", :name => "Screw", :color => "Red", :weight => 14.0, :city => "London", :position => 3}
5
- {:pid => "P5", :name => "Cam", :color => "Blue", :weight => 12.0, :city => "Paris", :position => 4}
6
- {:pid => "P1", :name => "Nut", :color => "Red", :weight => 12.0, :city => "London", :position => 4}
@@ -1 +0,0 @@
1
- alf rank parts -- weight desc pid asc -- position
@@ -1,6 +0,0 @@
1
- {:pid => "P6", :name => "Cog", :color => "Red", :weight => 19.0, :city => "London", :position => 0}
2
- {:pid => "P2", :name => "Bolt", :color => "Green", :weight => 17.0, :city => "Paris", :position => 1}
3
- {:pid => "P3", :name => "Screw", :color => "Blue", :weight => 17.0, :city => "Oslo", :position => 2}
4
- {:pid => "P4", :name => "Screw", :color => "Red", :weight => 14.0, :city => "London", :position => 3}
5
- {:pid => "P1", :name => "Nut", :color => "Red", :weight => 12.0, :city => "London", :position => 4}
6
- {:pid => "P5", :name => "Cam", :color => "Blue", :weight => 12.0, :city => "Paris", :position => 5}
@@ -1 +0,0 @@
1
- alf --text rename suppliers -- name supplier_name city supplier_city
@@ -1,9 +0,0 @@
1
- +------+----------------+---------+----------------+
2
- | :sid | :supplier_name | :status | :supplier_city |
3
- +------+----------------+---------+----------------+
4
- | S1 | Smith | 20 | London |
5
- | S2 | Jones | 10 | Paris |
6
- | S3 | Blake | 30 | Paris |
7
- | S4 | Clark | 20 | London |
8
- | S5 | Adams | 30 | Athens |
9
- +------+----------------+---------+----------------+
@@ -1 +0,0 @@
1
- alf --text restrict suppliers -- "status > 20"
@@ -1,6 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S3 | Blake | 30 | Paris |
5
- | S5 | Adams | 30 | Athens |
6
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text restrict suppliers -- city "'London'"
@@ -1,6 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S1 | Smith | 20 | London |
5
- | S4 | Clark | 20 | London |
6
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text sort suppliers -- name
@@ -1,9 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S5 | Adams | 30 | Athens |
5
- | S3 | Blake | 30 | Paris |
6
- | S4 | Clark | 20 | London |
7
- | S2 | Jones | 10 | Paris |
8
- | S1 | Smith | 20 | London |
9
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text sort suppliers -- name desc
@@ -1,9 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S1 | Smith | 20 | London |
5
- | S2 | Jones | 10 | Paris |
6
- | S4 | Clark | 20 | London |
7
- | S3 | Blake | 30 | Paris |
8
- | S5 | Adams | 30 | Athens |
9
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text sort suppliers -- city name
@@ -1,9 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S5 | Adams | 30 | Athens |
5
- | S4 | Clark | 20 | London |
6
- | S1 | Smith | 20 | London |
7
- | S3 | Blake | 30 | Paris |
8
- | S2 | Jones | 10 | Paris |
9
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text sort suppliers -- city desc name asc
@@ -1,9 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S3 | Blake | 30 | Paris |
5
- | S2 | Jones | 10 | Paris |
6
- | S4 | Clark | 20 | London |
7
- | S1 | Smith | 20 | London |
8
- | S5 | Adams | 30 | Athens |
9
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text summarize supplies -- sid -- total_qty "sum{ qty }"
@@ -1,8 +0,0 @@
1
- +------+------------+
2
- | :sid | :total_qty |
3
- +------+------------+
4
- | S1 | 1300 |
5
- | S2 | 700 |
6
- | S3 | 200 |
7
- | S4 | 900 |
8
- +------+------------+
@@ -1 +0,0 @@
1
- alf --text union suppliers suppliers
@@ -1,9 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S1 | Smith | 20 | London |
5
- | S2 | Jones | 10 | Paris |
6
- | S3 | Blake | 30 | Paris |
7
- | S4 | Clark | 20 | London |
8
- | S5 | Adams | 30 | Athens |
9
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text unwrap suppliers -- loc_and_status
@@ -1,9 +0,0 @@
1
- +------+-------+---------+--------+
2
- | :sid | :name | :status | :city |
3
- +------+-------+---------+--------+
4
- | S1 | Smith | 20 | London |
5
- | S2 | Jones | 10 | Paris |
6
- | S3 | Blake | 30 | Paris |
7
- | S4 | Clark | 20 | London |
8
- | S5 | Adams | 30 | Athens |
9
- +------+-------+---------+--------+
@@ -1 +0,0 @@
1
- alf --text wrap suppliers -- city status -- loc_and_status
@@ -1,9 +0,0 @@
1
- +------+-------+--------------------------------+
2
- | :sid | :name | :loc_and_status |
3
- +------+-------+--------------------------------+
4
- | S1 | Smith | {:city=>"London", :status=>20} |
5
- | S2 | Jones | {:city=>"Paris", :status=>10} |
6
- | S3 | Blake | {:city=>"Paris", :status=>30} |
7
- | S4 | Clark | {:city=>"London", :status=>20} |
8
- | S5 | Adams | {:city=>"Athens", :status=>30} |
9
- +------+-------+--------------------------------+
@@ -1 +0,0 @@
1
- #(command_name)
@@ -1 +0,0 @@
1
- !(alf autonum suppliers -- unique_id)
@@ -1,11 +0,0 @@
1
- $ alf autonum suppliers -- unique_id
2
-
3
- +------+-------+---------+--------+------------+
4
- | :sid | :name | :status | :city | :unique_id |
5
- +------+-------+---------+--------+------------+
6
- | S1 | Smith | 20 | London | 0 |
7
- | S2 | Jones | 10 | Paris | 1 |
8
- | S3 | Blake | 30 | Paris | 2 |
9
- | S4 | Clark | 20 | London | 3 |
10
- | S5 | Adams | 30 | Athens | 4 |
11
- +------+-------+---------+--------+------------+
@@ -1 +0,0 @@
1
- Hello
@@ -1,41 +0,0 @@
1
- require 'spec_helper'
2
- module Alf
3
- module Shell
4
- describe DocManager, ".call" do
5
-
6
- let(:dm){ @dm ||= DocManager.new }
7
- let(:cmd){ Alf::Shell::Show }
8
- subject{
9
- dm.call(cmd, {})
10
- }
11
-
12
- describe "on a static file" do
13
- before{
14
- def dm.find_file(cmd);
15
- Path.dir/'static.md'
16
- end
17
- }
18
- it { should eq("Hello\n") }
19
- end
20
-
21
- describe "on a dynamic file" do
22
- before{
23
- def dm.find_file(cmd);
24
- Path.dir/'dynamic.md'
25
- end
26
- }
27
- it { should eq("show\n") }
28
- end
29
-
30
- describe "on an example file" do
31
- before{
32
- def dm.find_file(cmd);
33
- Path.dir/'example.md'
34
- end
35
- }
36
- it { should eq((Path.dir/"example_1.txt").read) }
37
- end
38
-
39
- end
40
- end
41
- end