alf 0.10.1 → 0.11.0
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG.md +25 -0
- data/Gemfile +8 -8
- data/Gemfile.lock +22 -20
- data/Rakefile +1 -1
- data/alf.gemspec +31 -30
- data/alf.noespec +11 -9
- data/bin/alf +1 -1
- data/lib/alf/aggregator/avg.rb +39 -0
- data/lib/alf/aggregator/class_methods.rb +32 -14
- data/lib/alf/aggregator/collect.rb +32 -0
- data/lib/alf/aggregator/concat.rb +47 -0
- data/lib/alf/aggregator/count.rb +32 -0
- data/lib/alf/aggregator/{base.rb → instance_methods.rb} +54 -30
- data/lib/alf/aggregator/max.rb +32 -0
- data/lib/alf/aggregator/min.rb +32 -0
- data/lib/alf/aggregator/stddev.rb +25 -0
- data/lib/alf/aggregator/sum.rb +32 -0
- data/lib/alf/aggregator/variance.rb +45 -0
- data/lib/alf/aggregator.rb +51 -0
- data/lib/alf/environment/class_methods.rb +37 -35
- data/lib/alf/environment/folder.rb +26 -28
- data/lib/alf/environment/{base.rb → instance_methods.rb} +8 -19
- data/lib/alf/environment.rb +34 -0
- data/lib/alf/errors.rb +1 -0
- data/lib/alf/iterator/class_methods.rb +0 -2
- data/lib/alf/iterator/proxy.rb +7 -13
- data/lib/alf/iterator.rb +27 -0
- data/lib/alf/lispy/instance_methods.rb +14 -14
- data/lib/alf/lispy.rb +24 -0
- data/lib/alf/loader.rb +1 -1
- data/lib/alf/operator/binary.rb +4 -15
- data/lib/alf/operator/class_methods.rb +33 -83
- data/lib/alf/operator/instance_methods.rb +29 -0
- data/lib/alf/operator/non_relational/autonum.rb +17 -22
- data/lib/alf/operator/non_relational/clip.rb +18 -18
- data/lib/alf/operator/non_relational/coerce.rb +17 -19
- data/lib/alf/operator/non_relational/compact.rb +13 -57
- data/lib/alf/operator/non_relational/defaults.rb +20 -23
- data/lib/alf/operator/non_relational/generator.rb +14 -32
- data/lib/alf/operator/non_relational/sort.rb +16 -20
- data/lib/alf/operator/nullary.rb +0 -9
- data/lib/alf/operator/relational/extend.rb +17 -22
- data/lib/alf/operator/relational/group.rb +16 -27
- data/lib/alf/operator/relational/heading.rb +15 -25
- data/lib/alf/operator/relational/intersect.rb +14 -33
- data/lib/alf/operator/relational/join.rb +15 -103
- data/lib/alf/operator/relational/matching.rb +15 -42
- data/lib/alf/operator/relational/minus.rb +14 -33
- data/lib/alf/operator/relational/not_matching.rb +15 -42
- data/lib/alf/operator/relational/project.rb +20 -20
- data/lib/alf/operator/relational/quota.rb +19 -47
- data/lib/alf/operator/relational/rank.rb +19 -52
- data/lib/alf/operator/relational/rename.rb +16 -17
- data/lib/alf/operator/relational/restrict.rb +16 -18
- data/lib/alf/operator/relational/summarize.rb +19 -75
- data/lib/alf/operator/relational/ungroup.rb +16 -22
- data/lib/alf/operator/relational/union.rb +17 -29
- data/lib/alf/operator/relational/unwrap.rb +17 -19
- data/lib/alf/operator/relational/wrap.rb +18 -20
- data/lib/alf/operator/signature.rb +67 -96
- data/lib/alf/operator/unary.rb +4 -26
- data/lib/alf/operator.rb +68 -0
- data/lib/alf/reader/alf_file.rb +5 -5
- data/lib/alf/reader/class_methods.rb +47 -38
- data/lib/alf/reader/{base.rb → instance_methods.rb} +18 -40
- data/lib/alf/reader/rash.rb +3 -3
- data/lib/alf/reader.rb +37 -0
- data/lib/alf/relation/instance_methods.rb +17 -37
- data/lib/alf/relation.rb +28 -0
- data/lib/alf/renderer/{base.rb → instance_methods.rb} +13 -30
- data/lib/alf/renderer.rb +32 -0
- data/lib/alf/tools/coerce.rb +18 -7
- data/lib/alf/tools/miscellaneous.rb +56 -29
- data/lib/alf/tools/to_lispy.rb +37 -40
- data/lib/alf/tools/to_ruby_literal.rb +24 -7
- data/lib/alf/tools/tuple_handle.rb +27 -17
- data/lib/alf/tools.rb +14 -0
- data/lib/alf/types/attr_list.rb +135 -31
- data/lib/alf/types/attr_name.rb +56 -18
- data/lib/alf/types/boolean.rb +18 -5
- data/lib/alf/types/heading.rb +83 -59
- data/lib/alf/types/ordering.rb +117 -64
- data/lib/alf/types/renaming.rb +73 -33
- data/lib/alf/types/size.rb +57 -0
- data/lib/alf/types/summarization.rb +105 -43
- data/lib/alf/types/tuple_computation.rb +113 -38
- data/lib/alf/types/tuple_expression.rb +122 -31
- data/lib/alf/types/tuple_predicate.rb +64 -40
- data/lib/alf/types.rb +49 -0
- data/lib/alf/version.rb +6 -6
- data/lib/alf-csv/alf/csv/commons.rb +36 -0
- data/lib/alf-csv/alf/csv/reader.rb +33 -0
- data/lib/alf-csv/alf/csv/renderer.rb +38 -0
- data/lib/alf-csv/alf/csv.rb +3 -0
- data/lib/alf-engine/alf/engine/aggregate.rb +44 -0
- data/lib/alf-engine/alf/engine/autonum.rb +45 -0
- data/lib/{alf/operator → alf-engine/alf/engine}/cesure.rb +13 -13
- data/lib/alf-engine/alf/engine/clip.rb +53 -0
- data/lib/alf-engine/alf/engine/coerce.rb +46 -0
- data/lib/alf-engine/alf/engine/cog.rb +7 -0
- data/lib/alf-engine/alf/engine/compact/set.rb +23 -0
- data/lib/alf-engine/alf/engine/compact/uniq.rb +23 -0
- data/lib/alf-engine/alf/engine/compact.rb +26 -0
- data/lib/alf-engine/alf/engine/concat.rb +25 -0
- data/lib/alf-engine/alf/engine/defaults.rb +43 -0
- data/lib/alf-engine/alf/engine/filter.rb +41 -0
- data/lib/alf-engine/alf/engine/generator.rb +50 -0
- data/lib/alf-engine/alf/engine/group/hash.rb +40 -0
- data/lib/alf-engine/alf/engine/group.rb +7 -0
- data/lib/alf-engine/alf/engine/join/hash.rb +35 -0
- data/lib/alf-engine/alf/engine/join.rb +7 -0
- data/lib/alf-engine/alf/engine/materialize/array.rb +78 -0
- data/lib/alf-engine/alf/engine/materialize/hash.rb +122 -0
- data/lib/alf-engine/alf/engine/materialize.rb +8 -0
- data/lib/alf-engine/alf/engine/quota/cesure.rb +46 -0
- data/lib/alf-engine/alf/engine/quota.rb +7 -0
- data/lib/alf-engine/alf/engine/rank/cesure.rb +48 -0
- data/lib/alf-engine/alf/engine/rank.rb +7 -0
- data/lib/alf-engine/alf/engine/rename.rb +39 -0
- data/lib/alf-engine/alf/engine/semi/hash.rb +39 -0
- data/lib/alf-engine/alf/engine/semi.rb +7 -0
- data/lib/alf-engine/alf/engine/set_attr.rb +46 -0
- data/lib/alf-engine/alf/engine/sort/in_memory.rb +39 -0
- data/lib/alf-engine/alf/engine/sort.rb +28 -0
- data/lib/alf-engine/alf/engine/summarize/cesure.rb +51 -0
- data/lib/alf-engine/alf/engine/summarize/hash.rb +35 -0
- data/lib/alf-engine/alf/engine/summarize.rb +8 -0
- data/lib/alf-engine/alf/engine/ungroup.rb +29 -0
- data/lib/alf-engine/alf/engine/unwrap.rb +31 -0
- data/lib/alf-engine/alf/engine/wrap.rb +39 -0
- data/lib/alf-engine/alf/engine.rb +25 -0
- data/lib/{alf/extra/logs.rb → alf-logs/alf/logs/reader.rb} +14 -16
- data/lib/alf-logs/alf/logs.rb +1 -0
- data/lib/alf-sequel/alf/sequel/environment.rb +57 -0
- data/lib/alf-sequel/alf/sequel/iterator.rb +21 -0
- data/lib/alf-sequel/alf/sequel.rb +2 -0
- data/lib/{alf → alf-shell/alf/shell}/command/exec.rb +3 -4
- data/lib/{alf → alf-shell/alf/shell}/command/help.rb +3 -4
- data/lib/alf-shell/alf/shell/command/main/class_methods.rb +46 -0
- data/lib/{alf → alf-shell/alf/shell}/command/main.rb +9 -51
- data/lib/{alf → alf-shell/alf/shell}/command/show.rb +5 -7
- data/lib/alf-shell/alf/shell/command.rb +26 -0
- data/lib/{alf/command → alf-shell/alf/shell}/doc_manager.rb +3 -3
- data/lib/alf-shell/alf/shell/operator.rb +86 -0
- data/lib/alf-shell/alf/shell.rb +40 -0
- data/lib/{alf/extra/yaml.rb → alf-yaml/alf/yaml/renderer.rb} +5 -7
- data/lib/alf-yaml/alf/yaml.rb +1 -0
- data/lib/alf.rb +17 -358
- data/spec/{unit → integration}/lispy/test_relation.rb +0 -0
- data/spec/{unit → integration}/lispy/test_run.rb +0 -0
- data/spec/{unit → integration}/lispy/test_tuple.rb +0 -0
- data/spec/integration/{command → shell}/alf/alf.db +0 -0
- data/spec/integration/{command → shell}/alf/alf_e.cmd +0 -0
- data/spec/integration/{command → shell}/alf/alf_e.stdout +0 -0
- data/spec/integration/shell/alf/alf_env.cmd +1 -0
- data/spec/integration/{command → shell}/alf/alf_env.stdout +0 -0
- data/spec/integration/shell/alf/alf_env_sqlite.cmd +1 -0
- data/spec/integration/{command → shell}/alf/alf_env_sqlite.stdout +0 -0
- data/spec/integration/{command → shell}/alf/alf_help.cmd +0 -0
- data/spec/integration/{command → shell}/alf/alf_help.stdout +0 -0
- data/spec/integration/{command → shell}/alf/alf_implicit.alf +0 -0
- data/spec/integration/shell/alf/alf_implicit_exec.cmd +1 -0
- data/spec/integration/{command → shell}/alf/alf_implicit_exec.stdout +0 -0
- data/spec/integration/{command → shell}/alf/alf_r.cmd +0 -0
- data/spec/integration/{command → shell}/alf/alf_r.stdout +0 -0
- data/spec/integration/{command → shell}/alf/alf_version.cmd +0 -0
- data/spec/integration/{command → shell}/alf/alf_version.stdout +0 -0
- data/spec/integration/{command → shell}/alf/alf_yaml.cmd +0 -0
- data/spec/integration/{command → shell}/alf/alf_yaml.stdout +0 -0
- data/spec/integration/{command → shell}/alf/rel.rash +0 -0
- data/spec/integration/{command → shell}/autonum/autonum_0.cmd +0 -0
- data/spec/integration/{command → shell}/autonum/autonum_0.stdout +0 -0
- data/spec/integration/shell/autonum/autonum_1.cmd +1 -0
- data/spec/integration/{command → shell}/autonum/autonum_1.stdout +0 -0
- data/spec/integration/shell/clip/clip_0.cmd +1 -0
- data/spec/integration/{command → shell}/clip/clip_0.stdout +0 -0
- data/spec/integration/shell/clip/clip_1.cmd +1 -0
- data/spec/integration/{command → shell}/clip/clip_1.stdout +0 -0
- data/spec/integration/{command → shell}/coerce/coerce_1.cmd +0 -0
- data/spec/integration/{command → shell}/coerce/coerce_1.stdout +0 -0
- data/spec/integration/{command → shell}/compact/compact_0.cmd +0 -0
- data/spec/integration/{command → shell}/compact/compact_0.stdout +0 -0
- data/spec/integration/{command → shell}/defaults/defaults_0.cmd +0 -0
- data/spec/integration/{command → shell}/defaults/defaults_0.stdout +0 -0
- data/spec/integration/{command → shell}/defaults/defaults_1.cmd +0 -0
- data/spec/integration/{command → shell}/defaults/defaults_1.stdout +0 -0
- data/spec/integration/{command → shell}/defaults/defaults_2.cmd +0 -0
- data/spec/integration/{command → shell}/defaults/defaults_2.stdout +0 -0
- data/spec/integration/{command → shell}/extend/extend_0.cmd +0 -0
- data/spec/integration/{command → shell}/extend/extend_0.stdout +0 -0
- data/spec/integration/{command → shell}/generator/generator_1.cmd +0 -0
- data/spec/integration/{command → shell}/generator/generator_1.stdout +0 -0
- data/spec/integration/{command → shell}/generator/generator_2.cmd +0 -0
- data/spec/integration/{command → shell}/generator/generator_2.stdout +0 -0
- data/spec/integration/{command → shell}/generator/generator_3.cmd +0 -0
- data/spec/integration/{command → shell}/generator/generator_3.stdout +0 -0
- data/spec/integration/{command → shell}/group/group_0.cmd +0 -0
- data/spec/integration/{command → shell}/group/group_0.stdout +0 -0
- data/spec/integration/{command → shell}/group/group_1.cmd +0 -0
- data/spec/integration/{command → shell}/group/group_1.stdout +0 -0
- data/spec/integration/{command → shell}/help/help_1.cmd +0 -0
- data/spec/integration/{command → shell}/help/help_1.stdout +0 -0
- data/spec/integration/{command → shell}/intersect/intersect_0.cmd +0 -0
- data/spec/integration/{command → shell}/intersect/intersect_0.stdout +0 -0
- data/spec/integration/{command → shell}/join/join_0.cmd +0 -0
- data/spec/integration/{command → shell}/join/join_0.stdout +0 -0
- data/spec/integration/{command → shell}/matching/matching_0.cmd +0 -0
- data/spec/integration/{command → shell}/matching/matching_0.stdout +0 -0
- data/spec/integration/{command → shell}/minus/minus_0.cmd +0 -0
- data/spec/integration/{command → shell}/minus/minus_0.stdout +0 -0
- data/spec/integration/{command → shell}/not-matching/not-matching_0.cmd +0 -0
- data/spec/integration/{command → shell}/not-matching/not-matching_0.stdout +0 -0
- data/spec/integration/{command → shell}/project/project_0.cmd +0 -0
- data/spec/integration/{command → shell}/project/project_0.stdout +0 -0
- data/spec/integration/{command → shell}/project/project_1.cmd +0 -0
- data/spec/integration/{command → shell}/project/project_1.stdout +0 -0
- data/spec/integration/{command → shell}/quota/quota_0.cmd +0 -0
- data/spec/integration/{command → shell}/quota/quota_0.stdout +0 -0
- data/spec/integration/{command → shell}/rank/rank_1.cmd +0 -0
- data/spec/integration/{command → shell}/rank/rank_1.stdout +1 -1
- data/spec/integration/{command → shell}/rank/rank_2.cmd +0 -0
- data/spec/integration/{command → shell}/rank/rank_2.stdout +1 -1
- data/spec/integration/{command → shell}/rank/rank_3.cmd +0 -0
- data/spec/integration/{command → shell}/rank/rank_3.stdout +0 -0
- data/spec/integration/{command → shell}/rank/rank_4.cmd +0 -0
- data/spec/integration/{command → shell}/rank/rank_4.stdout +0 -0
- data/spec/integration/{command → shell}/rank/rank_5.cmd +0 -0
- data/spec/integration/{command → shell}/rank/rank_5.stdout +0 -0
- data/spec/integration/{command → shell}/rename/rename_0.cmd +0 -0
- data/spec/integration/{command → shell}/rename/rename_0.stdout +0 -0
- data/spec/integration/{command → shell}/restrict/restrict_0.cmd +0 -0
- data/spec/integration/{command → shell}/restrict/restrict_0.stdout +0 -0
- data/spec/integration/{command → shell}/restrict/restrict_1.cmd +0 -0
- data/spec/integration/{command → shell}/restrict/restrict_1.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_base.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_base.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_base_sort_1.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_base_sort_1.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_base_sort_2.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_base_sort_2.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_conflictual.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_conflictual.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_csv.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_csv.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_ff.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_ff.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_rash.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_rash.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_rash_pretty.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_rash_pretty.stdout +0 -0
- data/spec/integration/{command → shell}/show/show_yaml.cmd +0 -0
- data/spec/integration/{command → shell}/show/show_yaml.stdout +0 -0
- data/spec/integration/{command → shell}/sort/sort_0.cmd +0 -0
- data/spec/integration/{command → shell}/sort/sort_0.stdout +0 -0
- data/spec/integration/{command → shell}/sort/sort_1.cmd +0 -0
- data/spec/integration/{command → shell}/sort/sort_1.stdout +0 -0
- data/spec/integration/{command → shell}/sort/sort_2.cmd +0 -0
- data/spec/integration/{command → shell}/sort/sort_2.stdout +0 -0
- data/spec/integration/{command → shell}/sort/sort_3.cmd +0 -0
- data/spec/integration/{command → shell}/sort/sort_3.stdout +0 -0
- data/spec/integration/{command → shell}/summarize/summarize_0.cmd +0 -0
- data/spec/integration/{command → shell}/summarize/summarize_0.stdout +0 -0
- data/spec/integration/{command → shell}/ungroup/ungroup_0.cmd +0 -0
- data/spec/integration/{command → shell}/ungroup/ungroup_0.stdout +0 -0
- data/spec/integration/{command → shell}/union/union_0.cmd +0 -0
- data/spec/integration/{command → shell}/union/union_0.stdout +0 -0
- data/spec/integration/{command → shell}/unwrap/unwrap_0.cmd +0 -0
- data/spec/integration/{command → shell}/unwrap/unwrap_0.stdout +0 -0
- data/spec/integration/{command → shell}/wrap/wrap_0.cmd +0 -0
- data/spec/integration/{command → shell}/wrap/wrap_0.stdout +0 -0
- data/spec/{unit → integration}/test_lispy.rb +0 -0
- data/spec/integration/{test_command.rb → test_shell.rb} +3 -3
- data/spec/regression/heading/test_heading_with_date.rb +1 -1
- data/spec/shared/a_valid_type_implementation.rb +47 -0
- data/spec/shared/an_operator_class.rb +2 -6
- data/spec/spec_helper.rb +9 -1
- data/spec/unit/alf-core/aggregator/test_avg.rb +22 -0
- data/spec/unit/alf-core/aggregator/test_collect.rb +25 -0
- data/spec/unit/alf-core/aggregator/test_concat.rb +31 -0
- data/spec/unit/alf-core/aggregator/test_count.rb +17 -0
- data/spec/unit/alf-core/aggregator/test_max.rb +23 -0
- data/spec/unit/alf-core/aggregator/test_min.rb +23 -0
- data/spec/unit/alf-core/aggregator/test_stddev.rb +27 -0
- data/spec/unit/alf-core/aggregator/test_sum.rb +23 -0
- data/spec/unit/alf-core/aggregator/test_variance.rb +29 -0
- data/spec/unit/{assumptions → alf-core/assumptions}/test_file.rb +0 -0
- data/spec/unit/{assumptions → alf-core/assumptions}/test_instance_eval.rb +0 -0
- data/spec/unit/{assumptions → alf-core/assumptions}/test_scoping.rb +0 -0
- data/spec/unit/{assumptions → alf-core/assumptions}/test_set.rb +0 -0
- data/spec/unit/{environment → alf-core/environment}/examples/suppliers.rash +0 -0
- data/spec/unit/alf-core/environment/test_folder.rb +53 -0
- data/spec/unit/{operator → alf-core/operator}/non_relational/test_autonum.rb +18 -31
- data/spec/unit/alf-core/operator/non_relational/test_clip.rb +35 -0
- data/spec/unit/{operator → alf-core/operator}/non_relational/test_coerce.rb +11 -17
- data/spec/unit/{operator/non_relational/compact/test_sort_based.rb → alf-core/operator/non_relational/test_compact.rb} +16 -14
- data/spec/unit/{operator → alf-core/operator}/non_relational/test_defaults.rb +17 -32
- data/spec/unit/{operator → alf-core/operator}/non_relational/test_generator.rb +21 -39
- data/spec/unit/{operator → alf-core/operator}/non_relational/test_sort.rb +20 -26
- data/spec/unit/{operator → alf-core/operator}/relational/test_extend.rb +8 -14
- data/spec/unit/{operator → alf-core/operator}/relational/test_group.rb +12 -28
- data/spec/unit/alf-core/operator/relational/test_heading.rb +27 -0
- data/spec/unit/{operator → alf-core/operator}/relational/test_intersect.rb +22 -22
- data/spec/unit/{operator → alf-core/operator}/relational/test_join.rb +7 -7
- data/spec/unit/{operator → alf-core/operator}/relational/test_minus.rb +23 -23
- data/spec/unit/alf-core/operator/relational/test_project.rb +62 -0
- data/spec/unit/{operator → alf-core/operator}/relational/test_quota.rb +8 -15
- data/spec/unit/alf-core/operator/relational/test_rank.rb +48 -0
- data/spec/unit/{operator → alf-core/operator}/relational/test_rename.rb +8 -14
- data/spec/unit/alf-core/operator/relational/test_restrict.rb +45 -0
- data/spec/unit/{operator → alf-core/operator}/relational/test_summarize.rb +13 -31
- data/spec/unit/{operator → alf-core/operator}/relational/test_ungroup.rb +9 -15
- data/spec/unit/{operator → alf-core/operator}/relational/test_union.rb +11 -11
- data/spec/unit/{operator → alf-core/operator}/relational/test_unwrap.rb +10 -16
- data/spec/unit/{operator → alf-core/operator}/relational/test_wrap.rb +10 -16
- data/spec/unit/alf-core/operator/signature/test_argv2args.rb +82 -0
- data/spec/unit/alf-core/operator/signature/test_collect_on.rb +38 -0
- data/spec/unit/{operator → alf-core/operator}/signature/test_initialize.rb +0 -0
- data/spec/unit/{operator → alf-core/operator}/signature/test_install.rb +0 -0
- data/spec/unit/{operator → alf-core/operator}/signature/test_option_parser.rb +0 -0
- data/spec/unit/alf-core/operator/signature/test_parse_args.rb +90 -0
- data/spec/unit/{operator → alf-core/operator}/signature/test_to_lispy.rb +0 -0
- data/spec/unit/{operator → alf-core/operator}/signature/test_to_shell.rb +0 -0
- data/spec/unit/{operator → alf-core/operator}/test_non_relational.rb +0 -0
- data/spec/unit/{operator → alf-core/operator}/test_relational.rb +0 -0
- data/spec/unit/{reader → alf-core/reader}/input.rb +0 -0
- data/spec/unit/{reader → alf-core/reader}/test_alf_file.rb +0 -0
- data/spec/unit/{reader → alf-core/reader}/test_initialize.rb +0 -0
- data/spec/unit/alf-core/reader/test_looks_a_path.rb +20 -0
- data/spec/unit/{reader → alf-core/reader}/test_rash.rb +0 -0
- data/spec/unit/{relation → alf-core/relation}/test_coerce.rb +0 -0
- data/spec/unit/{relation → alf-core/relation}/test_inspect.rb +0 -0
- data/spec/unit/{relation → alf-core/relation}/test_relops.rb +0 -0
- data/spec/unit/{relation → alf-core/relation}/test_to_a.rb +0 -0
- data/spec/unit/{renderer → alf-core/renderer}/test_initialize.rb +0 -0
- data/spec/unit/alf-core/test_aggregator.rb +58 -0
- data/spec/unit/{test_environment.rb → alf-core/test_environment.rb} +8 -21
- data/spec/unit/{test_operator.rb → alf-core/test_operator.rb} +0 -0
- data/spec/unit/{test_reader.rb → alf-core/test_reader.rb} +0 -0
- data/spec/unit/{test_relation.rb → alf-core/test_relation.rb} +0 -0
- data/spec/unit/{test_renderer.rb → alf-core/test_renderer.rb} +0 -0
- data/spec/unit/{text → alf-core/text}/test_cell.rb +0 -0
- data/spec/unit/{text → alf-core/text}/test_row.rb +0 -0
- data/spec/unit/{text → alf-core/text}/test_table.rb +0 -0
- data/spec/unit/alf-core/tools/test_class_name.rb +16 -0
- data/spec/unit/{tools → alf-core/tools}/test_coalesce.rb +6 -2
- data/spec/unit/alf-core/tools/test_coerce.rb +16 -0
- data/spec/unit/alf-core/tools/test_ruby_case.rb +16 -0
- data/spec/unit/{tools → alf-core/tools}/test_to_lispy.rb +14 -7
- data/spec/unit/{tools → alf-core/tools}/test_to_ruby_literal.rb +5 -5
- data/spec/unit/{tools → alf-core/tools}/test_tuple_handle.rb +14 -14
- data/spec/unit/alf-core/tools/test_tuple_heading.rb +15 -0
- data/spec/unit/{tools → alf-core/tools}/test_varargs.rb +9 -6
- data/spec/unit/alf-core/types/test_attr_list.rb +188 -0
- data/spec/unit/alf-core/types/test_attr_name.rb +78 -0
- data/spec/unit/{types/test_attr_name.rb → alf-core/types/test_boolean.rb} +18 -28
- data/spec/unit/alf-core/types/test_class_methods.rb +24 -0
- data/spec/unit/alf-core/types/test_heading.rb +146 -0
- data/spec/unit/alf-core/types/test_ordering.rb +185 -0
- data/spec/unit/alf-core/types/test_renaming.rb +72 -0
- data/spec/unit/alf-core/types/test_size.rb +74 -0
- data/spec/unit/{types → alf-core/types}/test_summarization.rb +46 -14
- data/spec/unit/{types → alf-core/types}/test_tuple_computation.rb +46 -10
- data/spec/unit/alf-core/types/test_tuple_expression.rb +122 -0
- data/spec/unit/{types → alf-core/types}/test_tuple_predicate.rb +51 -22
- data/spec/unit/{csv → alf-csv}/input.csv +0 -0
- data/spec/unit/{csv → alf-csv}/test_reader.rb +0 -0
- data/spec/unit/{csv → alf-csv}/test_renderer.rb +1 -1
- data/spec/unit/alf-engine/compact/test_set.rb +33 -0
- data/spec/unit/alf-engine/compact/test_uniq.rb +33 -0
- data/spec/unit/alf-engine/group/test_hash.rb +34 -0
- data/spec/unit/{operator/relational/join/test_hash_based.rb → alf-engine/join/test_hash.rb} +21 -29
- data/spec/unit/alf-engine/materialize/test_array.rb +28 -0
- data/spec/unit/alf-engine/materialize/test_hash.rb +76 -0
- data/spec/unit/alf-engine/quota/test_cesure.rb +34 -0
- data/spec/unit/{operator/relational/test_rank.rb → alf-engine/rank/test_cesure.rb} +21 -24
- data/spec/unit/alf-engine/semi/test_hash.rb +58 -0
- data/spec/unit/alf-engine/sort/test_in_memory.rb +32 -0
- data/spec/unit/{operator/relational/summarize/test_hash_based.rb → alf-engine/summarize/test_cesure.rb} +15 -21
- data/spec/unit/{operator/relational/summarize/test_sort_based.rb → alf-engine/summarize/test_hash.rb} +15 -21
- data/spec/unit/alf-engine/test_aggregate.rb +26 -0
- data/spec/unit/alf-engine/test_autonum.rb +24 -0
- data/spec/unit/alf-engine/test_clip.rb +34 -0
- data/spec/unit/alf-engine/test_coerce.rb +35 -0
- data/spec/unit/alf-engine/test_compact.rb +33 -0
- data/spec/unit/alf-engine/test_concat.rb +38 -0
- data/spec/unit/alf-engine/test_defaults.rb +37 -0
- data/spec/unit/alf-engine/test_filter.rb +23 -0
- data/spec/unit/alf-engine/test_generator.rb +25 -0
- data/spec/unit/alf-engine/test_rename.rb +24 -0
- data/spec/unit/alf-engine/test_set_attr.rb +38 -0
- data/spec/unit/alf-engine/test_sort.rb +32 -0
- data/spec/unit/alf-engine/test_ungroup.rb +28 -0
- data/spec/unit/alf-engine/test_unwrap.rb +20 -0
- data/spec/unit/alf-engine/test_wrap.rb +26 -0
- data/spec/unit/{logs → alf-logs}/apache_combined.log +0 -0
- data/spec/unit/{logs → alf-logs}/postgresql.log +0 -0
- data/spec/unit/{logs → alf-logs}/test_reader.rb +15 -16
- data/spec/unit/{sequel → alf-sequel}/alf.db +0 -0
- data/spec/unit/alf-sequel/test_environment.rb +69 -0
- data/spec/unit/{command → alf-shell}/doc_manager/dynamic.md +0 -0
- data/spec/unit/{command → alf-shell}/doc_manager/example.md +0 -0
- data/spec/unit/{command → alf-shell}/doc_manager/example_1.txt +0 -0
- data/spec/unit/{command → alf-shell}/doc_manager/static.md +0 -0
- data/spec/unit/{command → alf-shell}/doc_manager/test_call.rb +2 -3
- data/spec/unit/alf-shell/main/test_class_methods.rb +44 -0
- data/spec/unit/alf-shell/operator/test_autonum.rb +28 -0
- data/spec/unit/alf-shell/operator/test_clip.rb +29 -0
- data/spec/unit/alf-shell/operator/test_coerce.rb +21 -0
- data/spec/unit/alf-shell/operator/test_compact.rb +16 -0
- data/spec/unit/alf-shell/operator/test_defaults.rb +29 -0
- data/spec/unit/alf-shell/operator/test_extend.rb +21 -0
- data/spec/unit/alf-shell/operator/test_generator.rb +37 -0
- data/spec/unit/alf-shell/operator/test_group.rb +32 -0
- data/spec/unit/alf-shell/operator/test_heading.rb +16 -0
- data/spec/unit/alf-shell/operator/test_intersect.rb +18 -0
- data/spec/unit/alf-shell/operator/test_join.rb +18 -0
- data/spec/unit/alf-shell/operator/test_matching.rb +18 -0
- data/spec/unit/alf-shell/operator/test_minus.rb +18 -0
- data/spec/unit/alf-shell/operator/test_not_matching.rb +18 -0
- data/spec/unit/alf-shell/operator/test_project.rb +38 -0
- data/spec/unit/alf-shell/operator/test_quota.rb +23 -0
- data/spec/unit/alf-shell/operator/test_rank.rb +30 -0
- data/spec/unit/alf-shell/operator/test_rename.rb +21 -0
- data/spec/unit/alf-shell/operator/test_restrict.rb +35 -0
- data/spec/unit/alf-shell/operator/test_sort.rb +49 -0
- data/spec/unit/alf-shell/operator/test_summarize.rb +30 -0
- data/spec/unit/alf-shell/operator/test_ungroup.rb +28 -0
- data/spec/unit/alf-shell/operator/test_union.rb +18 -0
- data/spec/unit/alf-shell/operator/test_unwrap.rb +28 -0
- data/spec/unit/alf-shell/operator/test_wrap.rb +30 -0
- data/tasks/debug_mail.rake +42 -45
- data/tasks/gem.rake +13 -13
- data/tasks/gh-pages.rake +11 -6
- data/tasks/integration_test.rake +0 -8
- data/tasks/regression_test.rake +0 -8
- data/tasks/unit_test.rake +0 -8
- data/tasks/yard.rake +13 -13
- metadata +909 -1107
- data/examples/hitradio/compact.rb +0 -48
- data/examples/hitradio/compare1.rb +0 -28
- data/examples/hitradio/gz_reader.rb +0 -23
- data/examples/hitradio/hitradio-1.alf +0 -1
- data/examples/hitradio/hitradio.log +0 -25080
- data/examples/hitradio/hitradio.mar +0 -25081
- data/examples/hitradio/hitradio.mar.gz +0 -0
- data/examples/hitradio/hitradio.rash +0 -25080
- data/examples/hitradio/mar_reader.rb +0 -18
- data/examples/northwind/customers.csv +0 -92
- data/examples/northwind/northwind.db +0 -0
- data/examples/northwind/orders.csv +0 -831
- data/lib/alf/aggregator/aggregators.rb +0 -105
- data/lib/alf/aggregator/aggregators.rbc +0 -2640
- data/lib/alf/aggregator/base.rbc +0 -1055
- data/lib/alf/aggregator/class_methods.rbc +0 -830
- data/lib/alf/buffer/sorted.rb +0 -48
- data/lib/alf/buffer/sorted.rbc +0 -715
- data/lib/alf/command/class_methods.rb +0 -27
- data/lib/alf/command/class_methods.rbc +0 -453
- data/lib/alf/command/doc_manager.rbc +0 -1604
- data/lib/alf/command/exec.rbc +0 -408
- data/lib/alf/command/help.rbc +0 -764
- data/lib/alf/command/main.rbc +0 -3612
- data/lib/alf/command/show.rbc +0 -1327
- data/lib/alf/environment/base.rbc +0 -459
- data/lib/alf/environment/class_methods.rbc +0 -1110
- data/lib/alf/environment/explicit.rb +0 -38
- data/lib/alf/environment/explicit.rbc +0 -601
- data/lib/alf/environment/folder.rbc +0 -942
- data/lib/alf/errors.rbc +0 -155
- data/lib/alf/extra/csv.rb +0 -107
- data/lib/alf/extra/csv.rbc +0 -2021
- data/lib/alf/extra/logs.rbc +0 -1957
- data/lib/alf/extra/sequel.rb +0 -77
- data/lib/alf/extra/sequel.rbc +0 -1417
- data/lib/alf/extra/yaml.rbc +0 -435
- data/lib/alf/extra.rb +0 -5
- data/lib/alf/extra.rbc +0 -101
- data/lib/alf/iterator/base.rb +0 -38
- data/lib/alf/iterator/base.rbc +0 -437
- data/lib/alf/iterator/class_methods.rbc +0 -518
- data/lib/alf/iterator/proxy.rbc +0 -599
- data/lib/alf/lispy/instance_methods.rbc +0 -2535
- data/lib/alf/loader.rbc +0 -85
- data/lib/alf/operator/base.rb +0 -74
- data/lib/alf/operator/base.rbc +0 -860
- data/lib/alf/operator/binary.rbc +0 -595
- data/lib/alf/operator/cesure.rbc +0 -883
- data/lib/alf/operator/class_methods.rbc +0 -1915
- data/lib/alf/operator/experimental.rbc +0 -200
- data/lib/alf/operator/non_relational/autonum.rbc +0 -587
- data/lib/alf/operator/non_relational/clip.rbc +0 -522
- data/lib/alf/operator/non_relational/coerce.rbc +0 -596
- data/lib/alf/operator/non_relational/compact.rbc +0 -1283
- data/lib/alf/operator/non_relational/defaults.rbc +0 -733
- data/lib/alf/operator/non_relational/generator.rbc +0 -1015
- data/lib/alf/operator/non_relational/sort.rbc +0 -665
- data/lib/alf/operator/nullary.rbc +0 -404
- data/lib/alf/operator/relational/extend.rbc +0 -616
- data/lib/alf/operator/relational/group.rbc +0 -968
- data/lib/alf/operator/relational/heading.rbc +0 -657
- data/lib/alf/operator/relational/intersect.rbc +0 -969
- data/lib/alf/operator/relational/join.rbc +0 -1708
- data/lib/alf/operator/relational/matching.rbc +0 -1047
- data/lib/alf/operator/relational/minus.rbc +0 -965
- data/lib/alf/operator/relational/not_matching.rbc +0 -1047
- data/lib/alf/operator/relational/project.rbc +0 -669
- data/lib/alf/operator/relational/quota.rbc +0 -1193
- data/lib/alf/operator/relational/rank.rbc +0 -1217
- data/lib/alf/operator/relational/rename.rbc +0 -496
- data/lib/alf/operator/relational/restrict.rbc +0 -611
- data/lib/alf/operator/relational/summarize.rbc +0 -1922
- data/lib/alf/operator/relational/ungroup.rbc +0 -643
- data/lib/alf/operator/relational/union.rbc +0 -846
- data/lib/alf/operator/relational/unwrap.rbc +0 -540
- data/lib/alf/operator/relational/wrap.rbc +0 -560
- data/lib/alf/operator/shortcut.rb +0 -53
- data/lib/alf/operator/shortcut.rbc +0 -809
- data/lib/alf/operator/signature.rbc +0 -4640
- data/lib/alf/operator/transform.rb +0 -27
- data/lib/alf/operator/transform.rbc +0 -484
- data/lib/alf/operator/unary.rbc +0 -629
- data/lib/alf/reader/alf_file.rbc +0 -464
- data/lib/alf/reader/base.rbc +0 -1613
- data/lib/alf/reader/class_methods.rbc +0 -1099
- data/lib/alf/reader/rash.rbc +0 -583
- data/lib/alf/relation/class_methods.rbc +0 -674
- data/lib/alf/relation/instance_methods.rbc +0 -2107
- data/lib/alf/renderer/base.rbc +0 -936
- data/lib/alf/renderer/class_methods.rbc +0 -875
- data/lib/alf/renderer/rash.rbc +0 -802
- data/lib/alf/renderer/text.rbc +0 -5530
- data/lib/alf/tools/coerce.rbc +0 -352
- data/lib/alf/tools/miscellaneous.rbc +0 -1497
- data/lib/alf/tools/to_lispy.rbc +0 -2618
- data/lib/alf/tools/to_ruby_literal.rbc +0 -344
- data/lib/alf/tools/tuple_handle.rbc +0 -738
- data/lib/alf/types/attr_list.rbc +0 -1535
- data/lib/alf/types/attr_name.rbc +0 -781
- data/lib/alf/types/boolean.rbc +0 -365
- data/lib/alf/types/heading.rbc +0 -1778
- data/lib/alf/types/ordering.rbc +0 -2228
- data/lib/alf/types/renaming.rbc +0 -1064
- data/lib/alf/types/summarization.rbc +0 -1394
- data/lib/alf/types/tuple_computation.rbc +0 -1061
- data/lib/alf/types/tuple_expression.rbc +0 -1016
- data/lib/alf/types/tuple_predicate.rbc +0 -1349
- data/lib/alf/version.rbc +0 -350
- data/lib/alf.rbc +0 -3884
- data/spec/integration/command/alf/alf_env.cmd +0 -1
- data/spec/integration/command/alf/alf_env_sqlite.cmd +0 -1
- data/spec/integration/command/alf/alf_implicit_exec.cmd +0 -1
- data/spec/integration/command/autonum/autonum_1.cmd +0 -1
- data/spec/integration/command/clip/clip_0.cmd +0 -1
- data/spec/integration/command/clip/clip_1.cmd +0 -1
- data/spec/integration/command/show/show_rash_2.cmd +0 -1
- data/spec/integration/command/show/show_rash_2.stdout +0 -5
- data/spec/integration/test_alf.rbc +0 -1098
- data/spec/integration/test_command.rbc +0 -1832
- data/spec/integration/test_examples.rbc +0 -559
- data/spec/integration/test_semantics.rbc +0 -991
- data/spec/regression/alf_file/test___FILE__.rbc +0 -524
- data/spec/regression/heading/test_heading_with_date.rbc +0 -381
- data/spec/regression/lispy/test_compile.rbc +0 -404
- data/spec/regression/logs/test_path_attribute.rbc +0 -687
- data/spec/regression/relation/test_relation_allbut_all.rbc +0 -468
- data/spec/regression/relation/test_relation_with_date.rbc +0 -381
- data/spec/regression/restrict/test_restrict_with_keywords.rbc +0 -628
- data/spec/shared/a_value.rbc +0 -337
- data/spec/shared/an_operator_class.rbc +0 -908
- data/spec/spec_helper.rbc +0 -453
- data/spec/unit/assumptions/test_file.rbc +0 -668
- data/spec/unit/assumptions/test_instance_eval.rbc +0 -654
- data/spec/unit/assumptions/test_scoping.rbc +0 -755
- data/spec/unit/assumptions/test_set.rbc +0 -1928
- data/spec/unit/command/doc_manager/test_call.rbc +0 -1537
- data/spec/unit/csv/test_reader.rbc +0 -2228
- data/spec/unit/csv/test_renderer.rbc +0 -2426
- data/spec/unit/environment/test_explicit.rb +0 -15
- data/spec/unit/environment/test_explicit.rbc +0 -464
- data/spec/unit/environment/test_folder.rb +0 -35
- data/spec/unit/environment/test_folder.rbc +0 -1304
- data/spec/unit/lispy/test_relation.rbc +0 -1477
- data/spec/unit/lispy/test_run.rbc +0 -1735
- data/spec/unit/lispy/test_tuple.rbc +0 -1686
- data/spec/unit/logs/test_reader.rbc +0 -1807
- data/spec/unit/operator/non_relational/compact/test_buffer_based.rb +0 -30
- data/spec/unit/operator/non_relational/compact/test_buffer_based.rbc +0 -1127
- data/spec/unit/operator/non_relational/compact/test_sort_based.rbc +0 -1127
- data/spec/unit/operator/non_relational/test_autonum.rbc +0 -1969
- data/spec/unit/operator/non_relational/test_clip.rb +0 -49
- data/spec/unit/operator/non_relational/test_clip.rbc +0 -1850
- data/spec/unit/operator/non_relational/test_coerce.rbc +0 -1290
- data/spec/unit/operator/non_relational/test_compact.rb +0 -38
- data/spec/unit/operator/non_relational/test_compact.rbc +0 -1382
- data/spec/unit/operator/non_relational/test_defaults.rbc +0 -2319
- data/spec/unit/operator/non_relational/test_generator.rbc +0 -2361
- data/spec/unit/operator/non_relational/test_sort.rbc +0 -2583
- data/spec/unit/operator/relational/join/test_hash_based.rbc +0 -2481
- data/spec/unit/operator/relational/matching/test_hash_based.rb +0 -60
- data/spec/unit/operator/relational/matching/test_hash_based.rbc +0 -2458
- data/spec/unit/operator/relational/not_matching/test_hash_based.rb +0 -37
- data/spec/unit/operator/relational/not_matching/test_hash_based.rbc +0 -1632
- data/spec/unit/operator/relational/summarize/test_hash_based.rbc +0 -1990
- data/spec/unit/operator/relational/summarize/test_sort_based.rbc +0 -1990
- data/spec/unit/operator/relational/test_extend.rbc +0 -1300
- data/spec/unit/operator/relational/test_group.rbc +0 -2142
- data/spec/unit/operator/relational/test_intersect.rbc +0 -2069
- data/spec/unit/operator/relational/test_join.rbc +0 -1282
- data/spec/unit/operator/relational/test_minus.rbc +0 -1995
- data/spec/unit/operator/relational/test_project.rb +0 -75
- data/spec/unit/operator/relational/test_project.rbc +0 -2870
- data/spec/unit/operator/relational/test_quota.rbc +0 -1788
- data/spec/unit/operator/relational/test_rank.rbc +0 -2079
- data/spec/unit/operator/relational/test_rename.rbc +0 -1158
- data/spec/unit/operator/relational/test_restrict.rb +0 -56
- data/spec/unit/operator/relational/test_restrict.rbc +0 -2305
- data/spec/unit/operator/relational/test_summarize.rbc +0 -2570
- data/spec/unit/operator/relational/test_ungroup.rbc +0 -1425
- data/spec/unit/operator/relational/test_union.rbc +0 -1089
- data/spec/unit/operator/relational/test_unwrap.rbc +0 -1176
- data/spec/unit/operator/relational/test_wrap.rbc +0 -1203
- data/spec/unit/operator/signature/test_collect_on.rb +0 -45
- data/spec/unit/operator/signature/test_collect_on.rbc +0 -1989
- data/spec/unit/operator/signature/test_initialize.rbc +0 -544
- data/spec/unit/operator/signature/test_install.rbc +0 -1671
- data/spec/unit/operator/signature/test_option_parser.rbc +0 -1348
- data/spec/unit/operator/signature/test_parse_args.rb +0 -60
- data/spec/unit/operator/signature/test_parse_args.rbc +0 -1908
- data/spec/unit/operator/signature/test_parse_argv.rb +0 -87
- data/spec/unit/operator/signature/test_parse_argv.rbc +0 -2878
- data/spec/unit/operator/signature/test_to_lispy.rbc +0 -3305
- data/spec/unit/operator/signature/test_to_shell.rbc +0 -3327
- data/spec/unit/operator/test_non_relational.rbc +0 -571
- data/spec/unit/operator/test_relational.rbc +0 -758
- data/spec/unit/reader/test_alf_file.rbc +0 -1107
- data/spec/unit/reader/test_initialize.rbc +0 -1774
- data/spec/unit/reader/test_rash.rbc +0 -1127
- data/spec/unit/relation/test_coerce.rbc +0 -2320
- data/spec/unit/relation/test_inspect.rbc +0 -502
- data/spec/unit/relation/test_relops.rbc +0 -1585
- data/spec/unit/relation/test_to_a.rbc +0 -1112
- data/spec/unit/renderer/test_initialize.rbc +0 -1766
- data/spec/unit/sequel/test_environment.rb +0 -54
- data/spec/unit/sequel/test_environment.rbc +0 -1723
- data/spec/unit/test_aggregator.rb +0 -109
- data/spec/unit/test_aggregator.rbc +0 -4358
- data/spec/unit/test_environment.rbc +0 -1271
- data/spec/unit/test_lispy.rbc +0 -879
- data/spec/unit/test_operator.rbc +0 -531
- data/spec/unit/test_reader.rbc +0 -1249
- data/spec/unit/test_relation.rbc +0 -2588
- data/spec/unit/test_renderer.rbc +0 -2011
- data/spec/unit/text/test_cell.rbc +0 -1532
- data/spec/unit/text/test_row.rbc +0 -847
- data/spec/unit/text/test_table.rbc +0 -978
- data/spec/unit/tools/test_coalesce.rbc +0 -456
- data/spec/unit/tools/test_coerce.rb +0 -10
- data/spec/unit/tools/test_coerce.rbc +0 -279
- data/spec/unit/tools/test_to_lispy.rbc +0 -5711
- data/spec/unit/tools/test_to_ruby_literal.rbc +0 -272
- data/spec/unit/tools/test_tools.rb +0 -25
- data/spec/unit/tools/test_tools.rbc +0 -672
- data/spec/unit/tools/test_tuple_handle.rbc +0 -1591
- data/spec/unit/tools/test_tuple_heading.rb +0 -20
- data/spec/unit/tools/test_tuple_heading.rbc +0 -821
- data/spec/unit/tools/test_varargs.rbc +0 -495
- data/spec/unit/types/heading/test_union.rb +0 -21
- data/spec/unit/types/heading/test_union.rbc +0 -1043
- data/spec/unit/types/test_attr_list.rb +0 -106
- data/spec/unit/types/test_attr_list.rbc +0 -4481
- data/spec/unit/types/test_attr_name.rbc +0 -1872
- data/spec/unit/types/test_heading.rb +0 -48
- data/spec/unit/types/test_heading.rbc +0 -1735
- data/spec/unit/types/test_ordering.rb +0 -127
- data/spec/unit/types/test_ordering.rbc +0 -3695
- data/spec/unit/types/test_renaming.rb +0 -55
- data/spec/unit/types/test_renaming.rbc +0 -2426
- data/spec/unit/types/test_summarization.rbc +0 -2538
- data/spec/unit/types/test_tuple_computation.rbc +0 -2340
- data/spec/unit/types/test_tuple_expression.rb +0 -64
- data/spec/unit/types/test_tuple_expression.rbc +0 -2285
- data/spec/unit/types/test_tuple_predicate.rbc +0 -3168
data/lib/alf/types.rb
ADDED
@@ -0,0 +1,49 @@
|
|
1
|
+
module Alf
|
2
|
+
#
|
3
|
+
# This module defines a namespace for useful datatypes as well as a few
|
4
|
+
# typing tools. Defined types are automatically defined as constants on the
|
5
|
+
# Alf module itself.
|
6
|
+
#
|
7
|
+
module Types
|
8
|
+
require 'alf/types/boolean'
|
9
|
+
require 'alf/types/size'
|
10
|
+
require 'alf/types/attr_name'
|
11
|
+
require 'alf/types/attr_list'
|
12
|
+
require 'alf/types/heading'
|
13
|
+
require 'alf/types/ordering'
|
14
|
+
require 'alf/types/renaming'
|
15
|
+
require 'alf/types/summarization'
|
16
|
+
require 'alf/types/tuple_expression'
|
17
|
+
require 'alf/types/tuple_predicate'
|
18
|
+
require 'alf/types/tuple_computation'
|
19
|
+
|
20
|
+
# Returns the (least) common super type of c1 and c2.
|
21
|
+
#
|
22
|
+
# The least common super type is defined as the lowest ancestor shared
|
23
|
+
# between c1 and c2.
|
24
|
+
#
|
25
|
+
# Examples:
|
26
|
+
#
|
27
|
+
# Types.common_super_type(String, String) # => String
|
28
|
+
# Types.common_super_type(Integer, Float) # => Numeric
|
29
|
+
# Types.common_super_type(Integer, String) # => Object
|
30
|
+
#
|
31
|
+
# @param [Class] c1 a data type, respresented by a ruby class
|
32
|
+
# @param [Class] c2 a data type, respresented by a ruby class
|
33
|
+
# @return [Class] the least common super type of c1 and c2
|
34
|
+
def common_super_type(c1, c2)
|
35
|
+
return c1 if c1 == c2
|
36
|
+
ancestors = [c1, c2].map{|c|
|
37
|
+
c.ancestors.select{|a| a.is_a?(Class)}
|
38
|
+
}
|
39
|
+
(ancestors[0] & ancestors[1]).first
|
40
|
+
end
|
41
|
+
module_function :common_super_type
|
42
|
+
|
43
|
+
# Install all types on Alf now
|
44
|
+
constants.each do |s|
|
45
|
+
Alf.const_set(s, const_get(s))
|
46
|
+
end
|
47
|
+
|
48
|
+
end # module Types
|
49
|
+
end # module Alf
|
data/lib/alf/version.rb
CHANGED
@@ -0,0 +1,36 @@
|
|
1
|
+
module Alf
|
2
|
+
module CSV
|
3
|
+
#
|
4
|
+
# Provides common tooling to CSV renderer and readers
|
5
|
+
#
|
6
|
+
module Commons
|
7
|
+
|
8
|
+
DEFAULT_OPTIONS = {
|
9
|
+
:headers => true
|
10
|
+
}
|
11
|
+
|
12
|
+
private
|
13
|
+
|
14
|
+
# Returns CSV in ruby 1.9 and FasterCSV for ruby < 1.9.
|
15
|
+
# This method handles require as well.
|
16
|
+
def get_csv_class
|
17
|
+
if RUBY_VERSION >= "1.9"
|
18
|
+
require 'csv'
|
19
|
+
::CSV
|
20
|
+
else
|
21
|
+
::Alf::Tools::friendly_require('fastercsv')
|
22
|
+
::FasterCSV
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
# Returns a CSV instance bound to a given io and options
|
27
|
+
def get_csv(io)
|
28
|
+
csv_class = get_csv_class
|
29
|
+
def_opts = csv_class.const_get(:DEFAULT_OPTIONS)
|
30
|
+
csv_opts = options.delete_if{|k,v| !def_opts.has_key?(k)}
|
31
|
+
csv_class.new(io, csv_opts)
|
32
|
+
end
|
33
|
+
|
34
|
+
end # module Commons
|
35
|
+
end # module CSV
|
36
|
+
end # module Alf
|
@@ -0,0 +1,33 @@
|
|
1
|
+
module Alf
|
2
|
+
module CSV
|
3
|
+
#
|
4
|
+
# Implements Alf::Reader contract for reading CSV files.
|
5
|
+
#
|
6
|
+
class Reader < Alf::Reader
|
7
|
+
include CSV::Commons
|
8
|
+
|
9
|
+
def each
|
10
|
+
with_input_io do |io|
|
11
|
+
block = Proc.new{|row|
|
12
|
+
next if row.header_row?
|
13
|
+
yield(symbolize_keys(row.to_hash))
|
14
|
+
}
|
15
|
+
case io
|
16
|
+
when StringIO
|
17
|
+
get_csv_class.parse(io.string, options, &block)
|
18
|
+
else
|
19
|
+
get_csv(io).each(&block)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
private
|
25
|
+
|
26
|
+
def symbolize_keys(h)
|
27
|
+
Hash[h.collect{|k,v| [k.to_sym,v] }]
|
28
|
+
end
|
29
|
+
|
30
|
+
Alf::Reader.register(:csv, [".csv"], self)
|
31
|
+
end # class Reader
|
32
|
+
end # module CSV
|
33
|
+
end # module Alf
|
@@ -0,0 +1,38 @@
|
|
1
|
+
module Alf
|
2
|
+
module CSV
|
3
|
+
#
|
4
|
+
# Implements Alf::Renderer contract for outputting CSV files.
|
5
|
+
#
|
6
|
+
class Renderer < Alf::Renderer
|
7
|
+
include CSV::Commons
|
8
|
+
|
9
|
+
protected
|
10
|
+
|
11
|
+
# (see Renderer#render)
|
12
|
+
def render(input, output)
|
13
|
+
csv = get_csv(output)
|
14
|
+
header = nil
|
15
|
+
input.each do |tuple|
|
16
|
+
unless header
|
17
|
+
header = extract_header(tuple)
|
18
|
+
csv << header.collect{|k| k.to_s}
|
19
|
+
end
|
20
|
+
csv << extract_row(tuple, header)
|
21
|
+
end
|
22
|
+
output
|
23
|
+
end
|
24
|
+
|
25
|
+
private
|
26
|
+
|
27
|
+
def extract_header(tuple)
|
28
|
+
tuple.keys
|
29
|
+
end
|
30
|
+
|
31
|
+
def extract_row(tuple, header)
|
32
|
+
header.collect{|k| tuple[k]}
|
33
|
+
end
|
34
|
+
|
35
|
+
Alf::Renderer.register(:csv, "as a csv file", self)
|
36
|
+
end # class Renderer
|
37
|
+
end # module CSV
|
38
|
+
end # module Alf
|
@@ -0,0 +1,44 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Aggregates the whole operand according to a Summarization. The resulting
|
5
|
+
# iterator contains only one tuple.
|
6
|
+
#
|
7
|
+
# Example:
|
8
|
+
#
|
9
|
+
# res = [
|
10
|
+
# {:name => "Jones", :price => 12.0, :id => 1},
|
11
|
+
# {:name => "Smith", :price => 10.0, :id => 2}
|
12
|
+
# ]
|
13
|
+
# agg = Summarization[:size => "count",
|
14
|
+
# :total => "sum{ price }"]
|
15
|
+
# Aggregate.new(res, agg).to_a
|
16
|
+
# # => [
|
17
|
+
# # {:size => 2, :total => 22.0}
|
18
|
+
# # ]
|
19
|
+
#
|
20
|
+
class Aggregate < Cog
|
21
|
+
|
22
|
+
# @return [Enumerable] The operand
|
23
|
+
attr_reader :operand
|
24
|
+
|
25
|
+
# @return [Summarization] The summarization to use
|
26
|
+
attr_reader :summarization
|
27
|
+
|
28
|
+
# Creates an Aggregate instance
|
29
|
+
def initialize(operand, summarization)
|
30
|
+
@operand = operand
|
31
|
+
@summarization = summarization
|
32
|
+
end
|
33
|
+
|
34
|
+
# (see Cog#each)
|
35
|
+
def each
|
36
|
+
agg = operand.inject(@summarization.least) do |memo,tuple|
|
37
|
+
@summarization.happens(memo, tuple)
|
38
|
+
end
|
39
|
+
yield @summarization.finalize(agg)
|
40
|
+
end
|
41
|
+
|
42
|
+
end # class Aggregate
|
43
|
+
end # Engine
|
44
|
+
end # module Alf
|
@@ -0,0 +1,45 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Autonumbers input tuples under a new `as` attribute. Autonumbering starts
|
5
|
+
# at 0.
|
6
|
+
#
|
7
|
+
# Example:
|
8
|
+
#
|
9
|
+
# operand = [
|
10
|
+
# {:name => "Jones"},
|
11
|
+
# {:name => "Smith"}
|
12
|
+
# ]
|
13
|
+
# Autonum.new(operand, :id).to_a
|
14
|
+
# # => [
|
15
|
+
# # {:name => "Jones", :id => 0},
|
16
|
+
# # {:name => "Smith", :id => 1}
|
17
|
+
# # ]
|
18
|
+
#
|
19
|
+
class Autonum < Cog
|
20
|
+
|
21
|
+
# @return [Enumerable] The operand
|
22
|
+
attr_reader :operand
|
23
|
+
|
24
|
+
# @return [Symbol] Name of the autonum attribute
|
25
|
+
attr_reader :as
|
26
|
+
|
27
|
+
# Creates an Autonum instance
|
28
|
+
def initialize(operand, as)
|
29
|
+
@operand = operand
|
30
|
+
@as = as
|
31
|
+
end
|
32
|
+
|
33
|
+
# (see Cog#each)
|
34
|
+
def each
|
35
|
+
autonum = 0
|
36
|
+
@operand.each do |tuple|
|
37
|
+
yield tuple.merge(@as => autonum)
|
38
|
+
autonum += 1
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
end # class Autonum
|
43
|
+
end # module Engine
|
44
|
+
end # module Alf
|
45
|
+
|
@@ -1,27 +1,27 @@
|
|
1
1
|
module Alf
|
2
|
-
module
|
3
|
-
#
|
4
|
-
# Specialization of Operator for implementing operators that rely on a
|
5
|
-
# cesure algorithm.
|
6
|
-
#
|
2
|
+
module Engine
|
7
3
|
module Cesure
|
8
|
-
|
9
|
-
|
4
|
+
|
5
|
+
# (see Cog#each)
|
6
|
+
def each(&receiver)
|
7
|
+
dup._each(&receiver)
|
8
|
+
end
|
9
|
+
|
10
10
|
protected
|
11
11
|
|
12
|
-
# (see
|
13
|
-
def _each
|
14
|
-
|
15
|
-
|
12
|
+
# (see Cog#each)
|
13
|
+
def _each(&receiver)
|
14
|
+
prev_key = nil
|
15
|
+
operand.each do |tuple|
|
16
16
|
cur_key = project(tuple)
|
17
17
|
if cur_key != prev_key
|
18
|
-
flush_cesure(prev_key, receiver)
|
18
|
+
flush_cesure(prev_key, receiver) if prev_key
|
19
19
|
start_cesure(cur_key, receiver)
|
20
20
|
prev_key = cur_key
|
21
21
|
end
|
22
22
|
accumulate_cesure(tuple, receiver)
|
23
23
|
end
|
24
|
-
flush_cesure(prev_key, receiver)
|
24
|
+
flush_cesure(prev_key, receiver) if prev_key
|
25
25
|
end
|
26
26
|
|
27
27
|
# Projects a given tuple and returns it's cesure projection
|
@@ -0,0 +1,53 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Clips input tuples keeping (all but) specific attributes only.
|
5
|
+
#
|
6
|
+
# Example:
|
7
|
+
#
|
8
|
+
# operand = [
|
9
|
+
# {:name => "Jones", :city => "London"},
|
10
|
+
# {:name => "Smith", :city => "Paris"}
|
11
|
+
# ]
|
12
|
+
#
|
13
|
+
# Clip.new(operand, AttrList[:name], false).to_a
|
14
|
+
# # => [
|
15
|
+
# # {:name => "Jones"},
|
16
|
+
# # {:name => "Smith"}
|
17
|
+
# # ]
|
18
|
+
#
|
19
|
+
# Clip.new(operand, AttrList[:name], true).to_a
|
20
|
+
# # => [
|
21
|
+
# # {:city => "London"},
|
22
|
+
# # {:city => "Paris"}
|
23
|
+
# # ]
|
24
|
+
#
|
25
|
+
class Clip < Cog
|
26
|
+
|
27
|
+
# @return [Enumerable] The operand
|
28
|
+
attr_reader :operand
|
29
|
+
|
30
|
+
# @return [AttrList] List of attributes for clipping
|
31
|
+
attr_reader :attributes
|
32
|
+
|
33
|
+
# @return [Boolean] Clip *all but* attributes?
|
34
|
+
attr_reader :allbut
|
35
|
+
|
36
|
+
# Creates an Clip instance
|
37
|
+
def initialize(operand, attributes, allbut)
|
38
|
+
@operand = operand
|
39
|
+
@attributes = attributes
|
40
|
+
@allbut = allbut
|
41
|
+
end
|
42
|
+
|
43
|
+
# (see Cog#each)
|
44
|
+
def each
|
45
|
+
@operand.each do |tuple|
|
46
|
+
yield @attributes.project_tuple(tuple, @allbut)
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
end # class Clip
|
51
|
+
end # module Engine
|
52
|
+
end # module Alf
|
53
|
+
|
@@ -0,0 +1,46 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Coerce input tuples according to a Heading. Attributes that do not belong
|
5
|
+
# to the heading are simply ignored but are kept in the output.
|
6
|
+
#
|
7
|
+
# Example:
|
8
|
+
#
|
9
|
+
# operand = [
|
10
|
+
# {:name => "Jones", :price => "10.0"},
|
11
|
+
# {:name => "Smith", :price => "-12.0"}
|
12
|
+
# ]
|
13
|
+
#
|
14
|
+
# Coerce.new(operand, Heading[:price => Float]).to_a
|
15
|
+
# # => [
|
16
|
+
# # {:name => "Jones", :price => 10.0},
|
17
|
+
# # {:name => "Smith", :price => -12.0}
|
18
|
+
# # ]
|
19
|
+
#
|
20
|
+
class Coerce < Cog
|
21
|
+
|
22
|
+
# @return [Enumerable] The operand
|
23
|
+
attr_reader :operand
|
24
|
+
|
25
|
+
# @return [Heading] Heading for coercion
|
26
|
+
attr_reader :heading
|
27
|
+
|
28
|
+
# Creates an Coerce instance
|
29
|
+
def initialize(operand, heading)
|
30
|
+
@operand = operand
|
31
|
+
@heading = heading
|
32
|
+
end
|
33
|
+
|
34
|
+
# (see Cog#each)
|
35
|
+
def each
|
36
|
+
@operand.each do |tuple|
|
37
|
+
yield tuple.merge(Hash[@heading.map{|k,d|
|
38
|
+
[k, Tools.coerce(tuple[k], d)]
|
39
|
+
}])
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
end # class Coerce
|
44
|
+
end # module Engine
|
45
|
+
end # module Alf
|
46
|
+
|
@@ -0,0 +1,23 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Remove duplicate tuples through an in-memory `to_set` heuristics.
|
5
|
+
#
|
6
|
+
class Compact::Set < Cog
|
7
|
+
|
8
|
+
# @return [Enumerable] The operand
|
9
|
+
attr_reader :operand
|
10
|
+
|
11
|
+
# Creates a Compact::Set instance
|
12
|
+
def initialize(operand)
|
13
|
+
@operand = operand
|
14
|
+
end
|
15
|
+
|
16
|
+
# (see Cog#each)
|
17
|
+
def each(&block)
|
18
|
+
operand.to_set.each(&block)
|
19
|
+
end
|
20
|
+
|
21
|
+
end # class Compact::Set
|
22
|
+
end # module Engine
|
23
|
+
end # module Alf
|
@@ -0,0 +1,23 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Remove duplicate tuples through an in-memory `to_a.uniq` heuristics.
|
5
|
+
#
|
6
|
+
class Compact::Uniq < Cog
|
7
|
+
|
8
|
+
# @return [Enumerable] The operand
|
9
|
+
attr_reader :operand
|
10
|
+
|
11
|
+
# Creates a Compact::Uniq instance
|
12
|
+
def initialize(operand)
|
13
|
+
@operand = operand
|
14
|
+
end
|
15
|
+
|
16
|
+
# (see Cog#each)
|
17
|
+
def each(&block)
|
18
|
+
operand.to_a.uniq.each(&block)
|
19
|
+
end
|
20
|
+
|
21
|
+
end # class Compact::Uniq
|
22
|
+
end # module Engine
|
23
|
+
end # module Alf
|
@@ -0,0 +1,26 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Remove duplicate tuples from its operand.
|
5
|
+
#
|
6
|
+
class Compact < Cog
|
7
|
+
|
8
|
+
# @return [Enumerable] The operand
|
9
|
+
attr_reader :operand
|
10
|
+
|
11
|
+
# Creates a Compact instance
|
12
|
+
def initialize(operand)
|
13
|
+
@operand = operand
|
14
|
+
end
|
15
|
+
|
16
|
+
# (see Cog#each)
|
17
|
+
def each(&block)
|
18
|
+
Compact::Uniq.new(operand).each(&block)
|
19
|
+
end
|
20
|
+
|
21
|
+
end # class Compact
|
22
|
+
end # module Engine
|
23
|
+
end # module Alf
|
24
|
+
require_relative 'compact/uniq'
|
25
|
+
require_relative 'compact/set'
|
26
|
+
|
@@ -0,0 +1,25 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Concat tuples from multiple operands.
|
5
|
+
#
|
6
|
+
class Concat < Cog
|
7
|
+
|
8
|
+
# @return [Array] operands to concatenate
|
9
|
+
attr_reader :operands
|
10
|
+
|
11
|
+
# Creates a Concat instance
|
12
|
+
def initialize(operands)
|
13
|
+
@operands = operands
|
14
|
+
end
|
15
|
+
|
16
|
+
# (see Cog#each)
|
17
|
+
def each(&block)
|
18
|
+
operands.each do |op|
|
19
|
+
op.each(&block)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
end # class Concat
|
24
|
+
end # module Engine
|
25
|
+
end # module Alf
|
@@ -0,0 +1,43 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Replace missing attributes and nil by default, computed values.
|
5
|
+
#
|
6
|
+
# Example:
|
7
|
+
#
|
8
|
+
# rel = [
|
9
|
+
# {:id => 1, :name => "Jones"},
|
10
|
+
# {:id => 2, :name => nil}
|
11
|
+
# ]
|
12
|
+
# Defaults.new(rel, TupleComputation[:name => "Smith"]).to_a
|
13
|
+
# # => [
|
14
|
+
# # {:id => 1, :name => "Jones"},
|
15
|
+
# # {:id => 2, :name => "Smith"}
|
16
|
+
# # ]
|
17
|
+
#
|
18
|
+
class Defaults < Cog
|
19
|
+
|
20
|
+
# @return [Enumerable] The operand
|
21
|
+
attr_reader :operand
|
22
|
+
|
23
|
+
# @return [TupleComputation] The default values
|
24
|
+
attr_reader :defaults
|
25
|
+
|
26
|
+
# Creates a Defaults instance
|
27
|
+
def initialize(operand, defaults)
|
28
|
+
@operand = operand
|
29
|
+
@defaults = defaults
|
30
|
+
end
|
31
|
+
|
32
|
+
# (see Cog#each)
|
33
|
+
def each
|
34
|
+
handle = Tools::TupleHandle.new
|
35
|
+
operand.each do |tuple|
|
36
|
+
defs = @defaults.evaluate(handle.set(tuple))
|
37
|
+
yield tuple.merge(defs){|k,v1,v2| (v1.nil? ? v2 : v1)}
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
end # class Defaults
|
42
|
+
end # module Engine
|
43
|
+
end # module Alf
|
@@ -0,0 +1,41 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Filters operand using a tuple predicate.
|
5
|
+
#
|
6
|
+
# Example
|
7
|
+
#
|
8
|
+
# rel = [
|
9
|
+
# {:name => "Smith"},
|
10
|
+
# {:name => "Jones"}
|
11
|
+
# ]
|
12
|
+
# Filter.new(rel, TuplePredicate["name =~ /^J/"]).to_a
|
13
|
+
# # => [
|
14
|
+
# # {:name => "Jones"}
|
15
|
+
# # ]
|
16
|
+
#
|
17
|
+
class Filter < Cog
|
18
|
+
|
19
|
+
# @return [Enumerable] The operand
|
20
|
+
attr_reader :operand
|
21
|
+
|
22
|
+
# @return [TuplePredicate] Filtering predicate
|
23
|
+
attr_reader :predicate
|
24
|
+
|
25
|
+
# Creates a Filter instance
|
26
|
+
def initialize(operand, predicate)
|
27
|
+
@operand = operand
|
28
|
+
@predicate = predicate
|
29
|
+
end
|
30
|
+
|
31
|
+
# (see Cog#each)
|
32
|
+
def each
|
33
|
+
handle = Tools::TupleHandle.new
|
34
|
+
operand.each do |tuple|
|
35
|
+
yield(tuple) if @predicate.evaluate(handle.set(tuple))
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
end # class Filter
|
40
|
+
end # module Engine
|
41
|
+
end # module Alf
|
@@ -0,0 +1,50 @@
|
|
1
|
+
module Alf
|
2
|
+
module Engine
|
3
|
+
#
|
4
|
+
# Generates tuples with an integer attributes, with an initial offset and
|
5
|
+
# a step.
|
6
|
+
#
|
7
|
+
# Example:
|
8
|
+
#
|
9
|
+
# Generator.new(3, :id, 10, 5).to_a
|
10
|
+
# # => [
|
11
|
+
# # {:id => 10},
|
12
|
+
# # {:id => 15},
|
13
|
+
# # {:id => 20}
|
14
|
+
# # ]
|
15
|
+
#
|
16
|
+
class Generator < Cog
|
17
|
+
|
18
|
+
# @return [Symbol] Name of the autonum attribute
|
19
|
+
attr_reader :as
|
20
|
+
|
21
|
+
# @return [Integer] Initial offset
|
22
|
+
attr_reader :offset
|
23
|
+
|
24
|
+
# @return [Integer] Generation step
|
25
|
+
attr_reader :step
|
26
|
+
|
27
|
+
# @return [Integer] Count number of tuples to generate
|
28
|
+
attr_reader :count
|
29
|
+
|
30
|
+
# Creates an Generator instance
|
31
|
+
def initialize(as, offset, step, count)
|
32
|
+
@as = as
|
33
|
+
@offset = offset
|
34
|
+
@step = step
|
35
|
+
@count = count
|
36
|
+
end
|
37
|
+
|
38
|
+
# (see Cog#each)
|
39
|
+
def each
|
40
|
+
cur = offset
|
41
|
+
count.times do |i|
|
42
|
+
yield(@as => cur)
|
43
|
+
cur += step
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
end # class Generator
|
48
|
+
end # module Engine
|
49
|
+
end # module Alf
|
50
|
+
|