alf 0.12.2 → 0.13.0
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG.md +186 -80
- data/Gemfile +16 -32
- data/Gemfile.lock +35 -34
- data/LICENCE.md +1 -1
- data/Manifest.txt +7 -9
- data/README.md +139 -809
- data/alf.gemspec +6 -15
- data/alf.noespec +16 -34
- data/lib/alf.rb +3 -73
- data/lib/alf/loader.rb +3 -3
- data/lib/alf/version.rb +2 -2
- data/spec/spec_helper.rb +3 -18
- data/spec/test_alf.rb +8 -0
- data/tasks/test.rake +6 -0
- data/test/migrations/test_folder_migration.rb +18 -0
- data/test/migrations/test_sequel_migration.rb +34 -0
- data/test/seeding/test_seeding.rb +49 -0
- data/test/test_alf.rb +8 -0
- data/test/test_helpers.rb +24 -0
- metadata +54 -952
- data/TODO.md +0 -21
- data/bin/alf +0 -27
- data/doc/commands/exec.md +0 -16
- data/doc/commands/help.md +0 -11
- data/doc/commands/main.md +0 -33
- data/doc/commands/show.md +0 -19
- data/doc/operators/non_relational/autonum.md +0 -23
- data/doc/operators/non_relational/clip.md +0 -31
- data/doc/operators/non_relational/coerce.md +0 -15
- data/doc/operators/non_relational/compact.md +0 -20
- data/doc/operators/non_relational/defaults.md +0 -32
- data/doc/operators/non_relational/generator.md +0 -20
- data/doc/operators/non_relational/sort.md +0 -24
- data/doc/operators/relational/extend.md +0 -18
- data/doc/operators/relational/group.md +0 -27
- data/doc/operators/relational/heading.md +0 -20
- data/doc/operators/relational/intersect.md +0 -13
- data/doc/operators/relational/join.md +0 -28
- data/doc/operators/relational/matching.md +0 -24
- data/doc/operators/relational/minus.md +0 -12
- data/doc/operators/relational/not-matching.md +0 -20
- data/doc/operators/relational/project.md +0 -28
- data/doc/operators/relational/quota.md +0 -21
- data/doc/operators/relational/rank.md +0 -27
- data/doc/operators/relational/rename.md +0 -17
- data/doc/operators/relational/restrict.md +0 -25
- data/doc/operators/relational/summarize.md +0 -25
- data/doc/operators/relational/ungroup.md +0 -20
- data/doc/operators/relational/union.md +0 -14
- data/doc/operators/relational/unwrap.md +0 -20
- data/doc/operators/relational/wrap.md +0 -24
- data/examples/csv/suppliers.csv +0 -6
- data/examples/logs/access.log +0 -1000
- data/examples/logs/combined.alf +0 -2
- data/examples/logs/hits.alf +0 -14
- data/examples/logs/not_found.alf +0 -7
- data/examples/logs/robots-cheating.alf +0 -11
- data/examples/logs/robots.alf +0 -8
- data/examples/operators/autonum.alf +0 -6
- data/examples/operators/cities.rash +0 -4
- data/examples/operators/clip.alf +0 -3
- data/examples/operators/compact.alf +0 -2
- data/examples/operators/database.alf +0 -5
- data/examples/operators/defaults.alf +0 -3
- data/examples/operators/extend.alf +0 -3
- data/examples/operators/group.alf +0 -3
- data/examples/operators/intersect.alf +0 -4
- data/examples/operators/join.alf +0 -2
- data/examples/operators/matching.alf +0 -2
- data/examples/operators/minus.alf +0 -8
- data/examples/operators/not_matching.alf +0 -2
- data/examples/operators/nulls.rash +0 -3
- data/examples/operators/parts.rash +0 -6
- data/examples/operators/project.alf +0 -3
- data/examples/operators/pseudo-with.alf +0 -7
- data/examples/operators/quota.alf +0 -4
- data/examples/operators/rank.alf +0 -4
- data/examples/operators/rename.alf +0 -3
- data/examples/operators/restrict.alf +0 -2
- data/examples/operators/schema.yaml +0 -28
- data/examples/operators/sort.alf +0 -4
- data/examples/operators/summarize.alf +0 -16
- data/examples/operators/suppliers.rash +0 -5
- data/examples/operators/supplies.rash +0 -12
- data/examples/operators/ungroup.alf +0 -4
- data/examples/operators/union.alf +0 -3
- data/examples/operators/unwrap.alf +0 -4
- data/examples/operators/wrap.alf +0 -2
- data/lib/alf-csv/alf/csv.rb +0 -3
- data/lib/alf-csv/alf/csv/commons.rb +0 -36
- data/lib/alf-csv/alf/csv/reader.rb +0 -33
- data/lib/alf-csv/alf/csv/renderer.rb +0 -38
- data/lib/alf-engine/alf/engine.rb +0 -25
- data/lib/alf-engine/alf/engine/aggregate.rb +0 -44
- data/lib/alf-engine/alf/engine/autonum.rb +0 -45
- data/lib/alf-engine/alf/engine/cesure.rb +0 -45
- data/lib/alf-engine/alf/engine/clip.rb +0 -53
- data/lib/alf-engine/alf/engine/coerce.rb +0 -46
- data/lib/alf-engine/alf/engine/cog.rb +0 -7
- data/lib/alf-engine/alf/engine/compact.rb +0 -26
- data/lib/alf-engine/alf/engine/compact/set.rb +0 -23
- data/lib/alf-engine/alf/engine/compact/uniq.rb +0 -23
- data/lib/alf-engine/alf/engine/concat.rb +0 -25
- data/lib/alf-engine/alf/engine/defaults.rb +0 -43
- data/lib/alf-engine/alf/engine/filter.rb +0 -41
- data/lib/alf-engine/alf/engine/generator.rb +0 -50
- data/lib/alf-engine/alf/engine/group.rb +0 -7
- data/lib/alf-engine/alf/engine/group/hash.rb +0 -40
- data/lib/alf-engine/alf/engine/join.rb +0 -7
- data/lib/alf-engine/alf/engine/join/hash.rb +0 -35
- data/lib/alf-engine/alf/engine/materialize.rb +0 -8
- data/lib/alf-engine/alf/engine/materialize/array.rb +0 -78
- data/lib/alf-engine/alf/engine/materialize/hash.rb +0 -122
- data/lib/alf-engine/alf/engine/quota.rb +0 -7
- data/lib/alf-engine/alf/engine/quota/cesure.rb +0 -46
- data/lib/alf-engine/alf/engine/rank.rb +0 -7
- data/lib/alf-engine/alf/engine/rank/cesure.rb +0 -48
- data/lib/alf-engine/alf/engine/rename.rb +0 -39
- data/lib/alf-engine/alf/engine/semi.rb +0 -7
- data/lib/alf-engine/alf/engine/semi/hash.rb +0 -39
- data/lib/alf-engine/alf/engine/set_attr.rb +0 -46
- data/lib/alf-engine/alf/engine/sort.rb +0 -28
- data/lib/alf-engine/alf/engine/sort/in_memory.rb +0 -39
- data/lib/alf-engine/alf/engine/summarize.rb +0 -8
- data/lib/alf-engine/alf/engine/summarize/cesure.rb +0 -51
- data/lib/alf-engine/alf/engine/summarize/hash.rb +0 -35
- data/lib/alf-engine/alf/engine/ungroup.rb +0 -29
- data/lib/alf-engine/alf/engine/unwrap.rb +0 -31
- data/lib/alf-engine/alf/engine/wrap.rb +0 -39
- data/lib/alf-logs/alf/logs.rb +0 -1
- data/lib/alf-logs/alf/logs/reader.rb +0 -98
- data/lib/alf-sequel/alf/sequel.rb +0 -2
- data/lib/alf-sequel/alf/sequel/environment.rb +0 -61
- data/lib/alf-sequel/alf/sequel/iterator.rb +0 -21
- data/lib/alf-shell/alf/shell.rb +0 -40
- data/lib/alf-shell/alf/shell/command.rb +0 -26
- data/lib/alf-shell/alf/shell/command/exec.rb +0 -11
- data/lib/alf-shell/alf/shell/command/help.rb +0 -30
- data/lib/alf-shell/alf/shell/command/main.rb +0 -136
- data/lib/alf-shell/alf/shell/command/main/class_methods.rb +0 -46
- data/lib/alf-shell/alf/shell/command/show.rb +0 -63
- data/lib/alf-shell/alf/shell/doc_manager.rb +0 -72
- data/lib/alf-shell/alf/shell/operator.rb +0 -86
- data/lib/alf-yaml/alf/yaml.rb +0 -1
- data/lib/alf-yaml/alf/yaml/renderer.rb +0 -22
- data/lib/alf/aggregator.rb +0 -51
- data/lib/alf/aggregator/avg.rb +0 -39
- data/lib/alf/aggregator/class_methods.rb +0 -77
- data/lib/alf/aggregator/collect.rb +0 -32
- data/lib/alf/aggregator/concat.rb +0 -47
- data/lib/alf/aggregator/count.rb +0 -32
- data/lib/alf/aggregator/instance_methods.rb +0 -119
- data/lib/alf/aggregator/max.rb +0 -32
- data/lib/alf/aggregator/min.rb +0 -32
- data/lib/alf/aggregator/stddev.rb +0 -25
- data/lib/alf/aggregator/sum.rb +0 -32
- data/lib/alf/aggregator/variance.rb +0 -45
- data/lib/alf/environment.rb +0 -34
- data/lib/alf/environment/class_methods.rb +0 -95
- data/lib/alf/environment/folder.rb +0 -60
- data/lib/alf/environment/instance_methods.rb +0 -26
- data/lib/alf/errors.rb +0 -5
- data/lib/alf/ext.rb +0 -4
- data/lib/alf/ext/relation.rb +0 -4
- data/lib/alf/iterator.rb +0 -28
- data/lib/alf/iterator/class_methods.rb +0 -20
- data/lib/alf/iterator/proxy.rb +0 -27
- data/lib/alf/lispy.rb +0 -24
- data/lib/alf/lispy/instance_methods.rb +0 -157
- data/lib/alf/operator.rb +0 -68
- data/lib/alf/operator/binary.rb +0 -21
- data/lib/alf/operator/class_methods.rb +0 -82
- data/lib/alf/operator/experimental.rb +0 -9
- data/lib/alf/operator/instance_methods.rb +0 -29
- data/lib/alf/operator/non_relational/autonum.rb +0 -19
- data/lib/alf/operator/non_relational/clip.rb +0 -20
- data/lib/alf/operator/non_relational/coerce.rb +0 -19
- data/lib/alf/operator/non_relational/compact.rb +0 -18
- data/lib/alf/operator/non_relational/defaults.rb +0 -22
- data/lib/alf/operator/non_relational/generator.rb +0 -20
- data/lib/alf/operator/non_relational/sort.rb +0 -19
- data/lib/alf/operator/nullary.rb +0 -11
- data/lib/alf/operator/relational/extend.rb +0 -19
- data/lib/alf/operator/relational/group.rb +0 -21
- data/lib/alf/operator/relational/heading.rb +0 -20
- data/lib/alf/operator/relational/intersect.rb +0 -18
- data/lib/alf/operator/relational/join.rb +0 -18
- data/lib/alf/operator/relational/matching.rb +0 -18
- data/lib/alf/operator/relational/minus.rb +0 -18
- data/lib/alf/operator/relational/not_matching.rb +0 -18
- data/lib/alf/operator/relational/project.rb +0 -22
- data/lib/alf/operator/relational/quota.rb +0 -23
- data/lib/alf/operator/relational/rank.rb +0 -22
- data/lib/alf/operator/relational/rename.rb +0 -18
- data/lib/alf/operator/relational/restrict.rb +0 -18
- data/lib/alf/operator/relational/summarize.rb +0 -27
- data/lib/alf/operator/relational/ungroup.rb +0 -19
- data/lib/alf/operator/relational/union.rb +0 -20
- data/lib/alf/operator/relational/unwrap.rb +0 -19
- data/lib/alf/operator/relational/wrap.rb +0 -20
- data/lib/alf/operator/signature.rb +0 -233
- data/lib/alf/operator/unary.rb +0 -16
- data/lib/alf/reader.rb +0 -37
- data/lib/alf/reader/alf_file.rb +0 -24
- data/lib/alf/reader/class_methods.rb +0 -91
- data/lib/alf/reader/instance_methods.rb +0 -97
- data/lib/alf/reader/rash.rb +0 -28
- data/lib/alf/relation.rb +0 -28
- data/lib/alf/relation/class_methods.rb +0 -28
- data/lib/alf/relation/instance_methods.rb +0 -119
- data/lib/alf/renderer.rb +0 -32
- data/lib/alf/renderer/class_methods.rb +0 -58
- data/lib/alf/renderer/instance_methods.rb +0 -55
- data/lib/alf/renderer/rash.rb +0 -33
- data/lib/alf/renderer/text.rb +0 -198
- data/lib/alf/tools.rb +0 -15
- data/lib/alf/tools/coerce.rb +0 -25
- data/lib/alf/tools/miscellaneous.rb +0 -111
- data/lib/alf/tools/to_lispy.rb +0 -96
- data/lib/alf/tools/to_relation.rb +0 -54
- data/lib/alf/tools/to_ruby_literal.rb +0 -31
- data/lib/alf/tools/tuple_handle.rb +0 -60
- data/lib/alf/types.rb +0 -49
- data/lib/alf/types/attr_list.rb +0 -160
- data/lib/alf/types/attr_name.rb +0 -66
- data/lib/alf/types/boolean.rb +0 -25
- data/lib/alf/types/heading.rb +0 -135
- data/lib/alf/types/ordering.rb +0 -146
- data/lib/alf/types/renaming.rb +0 -97
- data/lib/alf/types/size.rb +0 -57
- data/lib/alf/types/summarization.rb +0 -138
- data/lib/alf/types/tuple_computation.rb +0 -136
- data/lib/alf/types/tuple_expression.rb +0 -152
- data/lib/alf/types/tuple_predicate.rb +0 -73
- data/spec/integration/__database__/group.alf +0 -3
- data/spec/integration/__database__/parts.rash +0 -6
- data/spec/integration/__database__/suppliers.rash +0 -5
- data/spec/integration/__database__/suppliers_csv.csv +0 -6
- data/spec/integration/__database__/supplies.rash +0 -12
- data/spec/integration/alf/example.rash +0 -1
- data/spec/integration/alf/test_Relation.rb +0 -32
- data/spec/integration/ext/test_relation.rb +0 -16
- data/spec/integration/lispy/test_relation.rb +0 -37
- data/spec/integration/lispy/test_run.rb +0 -40
- data/spec/integration/lispy/test_tuple.rb +0 -36
- data/spec/integration/semantics/test_join.alf +0 -9
- data/spec/integration/semantics/test_minus.alf +0 -5
- data/spec/integration/semantics/test_project.alf +0 -8
- data/spec/integration/semantics/test_rank.alf +0 -34
- data/spec/integration/shell/alf/alf.db +0 -0
- data/spec/integration/shell/alf/alf_e.cmd +0 -1
- data/spec/integration/shell/alf/alf_e.stdout +0 -4
- data/spec/integration/shell/alf/alf_env.cmd +0 -1
- data/spec/integration/shell/alf/alf_env.stdout +0 -5
- data/spec/integration/shell/alf/alf_env_sqlite.cmd +0 -1
- data/spec/integration/shell/alf/alf_env_sqlite.stdout +0 -9
- data/spec/integration/shell/alf/alf_help.cmd +0 -1
- data/spec/integration/shell/alf/alf_help.stdout +0 -69
- data/spec/integration/shell/alf/alf_implicit.alf +0 -1
- data/spec/integration/shell/alf/alf_implicit_exec.cmd +0 -1
- data/spec/integration/shell/alf/alf_implicit_exec.stdout +0 -4
- data/spec/integration/shell/alf/alf_r.cmd +0 -1
- data/spec/integration/shell/alf/alf_r.stdout +0 -5
- data/spec/integration/shell/alf/alf_version.cmd +0 -1
- data/spec/integration/shell/alf/alf_version.stdout +0 -2
- data/spec/integration/shell/alf/alf_yaml.cmd +0 -1
- data/spec/integration/shell/alf/alf_yaml.stdout +0 -22
- data/spec/integration/shell/alf/rel.rash +0 -1
- data/spec/integration/shell/autonum/autonum_0.cmd +0 -1
- data/spec/integration/shell/autonum/autonum_0.stdout +0 -9
- data/spec/integration/shell/autonum/autonum_1.cmd +0 -1
- data/spec/integration/shell/autonum/autonum_1.stdout +0 -9
- data/spec/integration/shell/clip/clip_0.cmd +0 -1
- data/spec/integration/shell/clip/clip_0.stdout +0 -9
- data/spec/integration/shell/clip/clip_1.cmd +0 -1
- data/spec/integration/shell/clip/clip_1.stdout +0 -9
- data/spec/integration/shell/coerce/coerce_1.cmd +0 -1
- data/spec/integration/shell/coerce/coerce_1.stdout +0 -5
- data/spec/integration/shell/compact/compact_0.cmd +0 -1
- data/spec/integration/shell/compact/compact_0.stdout +0 -9
- data/spec/integration/shell/defaults/defaults_0.cmd +0 -1
- data/spec/integration/shell/defaults/defaults_0.stdout +0 -9
- data/spec/integration/shell/defaults/defaults_1.cmd +0 -1
- data/spec/integration/shell/defaults/defaults_1.stdout +0 -9
- data/spec/integration/shell/defaults/defaults_2.cmd +0 -1
- data/spec/integration/shell/defaults/defaults_2.stdout +0 -9
- data/spec/integration/shell/extend/extend_0.cmd +0 -1
- data/spec/integration/shell/extend/extend_0.stdout +0 -16
- data/spec/integration/shell/generator/generator_1.cmd +0 -1
- data/spec/integration/shell/generator/generator_1.stdout +0 -10
- data/spec/integration/shell/generator/generator_2.cmd +0 -1
- data/spec/integration/shell/generator/generator_2.stdout +0 -5
- data/spec/integration/shell/generator/generator_3.cmd +0 -1
- data/spec/integration/shell/generator/generator_3.stdout +0 -5
- data/spec/integration/shell/group/group_0.cmd +0 -1
- data/spec/integration/shell/group/group_0.stdout +0 -32
- data/spec/integration/shell/group/group_1.cmd +0 -1
- data/spec/integration/shell/group/group_1.stdout +0 -32
- data/spec/integration/shell/help/help_1.cmd +0 -1
- data/spec/integration/shell/help/help_1.stdout +0 -24
- data/spec/integration/shell/intersect/intersect_0.cmd +0 -1
- data/spec/integration/shell/intersect/intersect_0.stdout +0 -9
- data/spec/integration/shell/join/join_0.cmd +0 -1
- data/spec/integration/shell/join/join_0.stdout +0 -16
- data/spec/integration/shell/matching/matching_0.cmd +0 -1
- data/spec/integration/shell/matching/matching_0.stdout +0 -8
- data/spec/integration/shell/minus/minus_0.cmd +0 -1
- data/spec/integration/shell/minus/minus_0.stdout +0 -4
- data/spec/integration/shell/not-matching/not-matching_0.cmd +0 -1
- data/spec/integration/shell/not-matching/not-matching_0.stdout +0 -5
- data/spec/integration/shell/project/project_0.cmd +0 -1
- data/spec/integration/shell/project/project_0.stdout +0 -9
- data/spec/integration/shell/project/project_1.cmd +0 -1
- data/spec/integration/shell/project/project_1.stdout +0 -9
- data/spec/integration/shell/quota/quota_0.cmd +0 -1
- data/spec/integration/shell/quota/quota_0.stdout +0 -16
- data/spec/integration/shell/rank/rank_1.cmd +0 -1
- data/spec/integration/shell/rank/rank_1.stdout +0 -10
- data/spec/integration/shell/rank/rank_2.cmd +0 -1
- data/spec/integration/shell/rank/rank_2.stdout +0 -10
- data/spec/integration/shell/rank/rank_3.cmd +0 -1
- data/spec/integration/shell/rank/rank_3.stdout +0 -10
- data/spec/integration/shell/rank/rank_4.cmd +0 -1
- data/spec/integration/shell/rank/rank_4.stdout +0 -6
- data/spec/integration/shell/rank/rank_5.cmd +0 -1
- data/spec/integration/shell/rank/rank_5.stdout +0 -6
- data/spec/integration/shell/rename/rename_0.cmd +0 -1
- data/spec/integration/shell/rename/rename_0.stdout +0 -9
- data/spec/integration/shell/restrict/restrict_0.cmd +0 -1
- data/spec/integration/shell/restrict/restrict_0.stdout +0 -6
- data/spec/integration/shell/restrict/restrict_1.cmd +0 -1
- data/spec/integration/shell/restrict/restrict_1.stdout +0 -6
- data/spec/integration/shell/show/show_base.cmd +0 -1
- data/spec/integration/shell/show/show_base.stdout +0 -9
- data/spec/integration/shell/show/show_base_sort_1.cmd +0 -1
- data/spec/integration/shell/show/show_base_sort_1.stdout +0 -9
- data/spec/integration/shell/show/show_base_sort_2.cmd +0 -1
- data/spec/integration/shell/show/show_base_sort_2.stdout +0 -9
- data/spec/integration/shell/show/show_conflictual.cmd +0 -1
- data/spec/integration/shell/show/show_conflictual.stdout +0 -5
- data/spec/integration/shell/show/show_csv.cmd +0 -1
- data/spec/integration/shell/show/show_csv.stdout +0 -6
- data/spec/integration/shell/show/show_ff.cmd +0 -1
- data/spec/integration/shell/show/show_ff.stdout +0 -10
- data/spec/integration/shell/show/show_rash.cmd +0 -1
- data/spec/integration/shell/show/show_rash.stdout +0 -5
- data/spec/integration/shell/show/show_rash_pretty.cmd +0 -1
- data/spec/integration/shell/show/show_rash_pretty.stdout +0 -30
- data/spec/integration/shell/show/show_yaml.cmd +0 -1
- data/spec/integration/shell/show/show_yaml.stdout +0 -22
- data/spec/integration/shell/sort/sort_0.cmd +0 -1
- data/spec/integration/shell/sort/sort_0.stdout +0 -9
- data/spec/integration/shell/sort/sort_1.cmd +0 -1
- data/spec/integration/shell/sort/sort_1.stdout +0 -9
- data/spec/integration/shell/sort/sort_2.cmd +0 -1
- data/spec/integration/shell/sort/sort_2.stdout +0 -9
- data/spec/integration/shell/sort/sort_3.cmd +0 -1
- data/spec/integration/shell/sort/sort_3.stdout +0 -9
- data/spec/integration/shell/summarize/summarize_0.cmd +0 -1
- data/spec/integration/shell/summarize/summarize_0.stdout +0 -8
- data/spec/integration/shell/ungroup/ungroup_0.cmd +0 -1
- data/spec/integration/shell/ungroup/ungroup_0.stdout +0 -16
- data/spec/integration/shell/union/union_0.cmd +0 -1
- data/spec/integration/shell/union/union_0.stdout +0 -9
- data/spec/integration/shell/unwrap/unwrap_0.cmd +0 -1
- data/spec/integration/shell/unwrap/unwrap_0.stdout +0 -9
- data/spec/integration/shell/wrap/wrap_0.cmd +0 -1
- data/spec/integration/shell/wrap/wrap_0.stdout +0 -9
- data/spec/integration/test_alf.rb +0 -34
- data/spec/integration/test_examples.rb +0 -15
- data/spec/integration/test_lispy.rb +0 -31
- data/spec/integration/test_semantics.rb +0 -40
- data/spec/integration/test_shell.rb +0 -47
- data/spec/regression/alf_file/__FILE__.alf +0 -2
- data/spec/regression/alf_file/suppliers.rash +0 -5
- data/spec/regression/alf_file/test___FILE__.rb +0 -17
- data/spec/regression/heading/test_heading_with_date.rb +0 -12
- data/spec/regression/lispy/test_compile.rb +0 -14
- data/spec/regression/logs/apache_combined.log +0 -5
- data/spec/regression/logs/test_path_attribute.rb +0 -25
- data/spec/regression/relation/test_relation_allbut_all.rb +0 -14
- data/spec/regression/relation/test_relation_with_date.rb +0 -12
- data/spec/regression/restrict/test_restrict_with_keywords.rb +0 -17
- data/spec/shared/a_valid_type_implementation.rb +0 -47
- data/spec/shared/a_value.rb +0 -12
- data/spec/shared/an_operator_class.rb +0 -36
- data/spec/unit/alf-core/aggregator/test_avg.rb +0 -22
- data/spec/unit/alf-core/aggregator/test_collect.rb +0 -25
- data/spec/unit/alf-core/aggregator/test_concat.rb +0 -31
- data/spec/unit/alf-core/aggregator/test_count.rb +0 -17
- data/spec/unit/alf-core/aggregator/test_max.rb +0 -23
- data/spec/unit/alf-core/aggregator/test_min.rb +0 -23
- data/spec/unit/alf-core/aggregator/test_stddev.rb +0 -27
- data/spec/unit/alf-core/aggregator/test_sum.rb +0 -23
- data/spec/unit/alf-core/aggregator/test_variance.rb +0 -29
- data/spec/unit/alf-core/assumptions/test_file.rb +0 -17
- data/spec/unit/alf-core/assumptions/test_instance_eval.rb +0 -15
- data/spec/unit/alf-core/assumptions/test_scoping.rb +0 -29
- data/spec/unit/alf-core/assumptions/test_set.rb +0 -64
- data/spec/unit/alf-core/environment/examples/suppliers.rash +0 -5
- data/spec/unit/alf-core/environment/test_folder.rb +0 -53
- data/spec/unit/alf-core/operator/non_relational/test_autonum.rb +0 -48
- data/spec/unit/alf-core/operator/non_relational/test_clip.rb +0 -35
- data/spec/unit/alf-core/operator/non_relational/test_coerce.rb +0 -29
- data/spec/unit/alf-core/operator/non_relational/test_compact.rb +0 -32
- data/spec/unit/alf-core/operator/non_relational/test_defaults.rb +0 -53
- data/spec/unit/alf-core/operator/non_relational/test_generator.rb +0 -60
- data/spec/unit/alf-core/operator/non_relational/test_sort.rb +0 -60
- data/spec/unit/alf-core/operator/relational/test_extend.rb +0 -28
- data/spec/unit/alf-core/operator/relational/test_group.rb +0 -39
- data/spec/unit/alf-core/operator/relational/test_heading.rb +0 -27
- data/spec/unit/alf-core/operator/relational/test_intersect.rb +0 -58
- data/spec/unit/alf-core/operator/relational/test_join.rb +0 -36
- data/spec/unit/alf-core/operator/relational/test_minus.rb +0 -56
- data/spec/unit/alf-core/operator/relational/test_project.rb +0 -62
- data/spec/unit/alf-core/operator/relational/test_quota.rb +0 -36
- data/spec/unit/alf-core/operator/relational/test_rank.rb +0 -48
- data/spec/unit/alf-core/operator/relational/test_rename.rb +0 -26
- data/spec/unit/alf-core/operator/relational/test_restrict.rb +0 -45
- data/spec/unit/alf-core/operator/relational/test_summarize.rb +0 -44
- data/spec/unit/alf-core/operator/relational/test_ungroup.rb +0 -29
- data/spec/unit/alf-core/operator/relational/test_union.rb +0 -35
- data/spec/unit/alf-core/operator/relational/test_unwrap.rb +0 -26
- data/spec/unit/alf-core/operator/relational/test_wrap.rb +0 -26
- data/spec/unit/alf-core/operator/signature/test_argv2args.rb +0 -82
- data/spec/unit/alf-core/operator/signature/test_collect_on.rb +0 -38
- data/spec/unit/alf-core/operator/signature/test_initialize.rb +0 -17
- data/spec/unit/alf-core/operator/signature/test_install.rb +0 -56
- data/spec/unit/alf-core/operator/signature/test_option_parser.rb +0 -36
- data/spec/unit/alf-core/operator/signature/test_parse_args.rb +0 -90
- data/spec/unit/alf-core/operator/signature/test_to_lispy.rb +0 -102
- data/spec/unit/alf-core/operator/signature/test_to_shell.rb +0 -103
- data/spec/unit/alf-core/operator/test_non_relational.rb +0 -20
- data/spec/unit/alf-core/operator/test_relational.rb +0 -31
- data/spec/unit/alf-core/reader/input.rb +0 -2
- data/spec/unit/alf-core/reader/test_alf_file.rb +0 -30
- data/spec/unit/alf-core/reader/test_initialize.rb +0 -60
- data/spec/unit/alf-core/reader/test_looks_a_path.rb +0 -20
- data/spec/unit/alf-core/reader/test_rash.rb +0 -31
- data/spec/unit/alf-core/relation/test_coerce.rb +0 -53
- data/spec/unit/alf-core/relation/test_inspect.rb +0 -20
- data/spec/unit/alf-core/relation/test_relops.rb +0 -55
- data/spec/unit/alf-core/relation/test_to_a.rb +0 -41
- data/spec/unit/alf-core/renderer/test_initialize.rb +0 -60
- data/spec/unit/alf-core/test_aggregator.rb +0 -58
- data/spec/unit/alf-core/test_environment.rb +0 -30
- data/spec/unit/alf-core/test_operator.rb +0 -16
- data/spec/unit/alf-core/test_reader.rb +0 -40
- data/spec/unit/alf-core/test_relation.rb +0 -75
- data/spec/unit/alf-core/test_renderer.rb +0 -53
- data/spec/unit/alf-core/text/test_cell.rb +0 -35
- data/spec/unit/alf-core/text/test_row.rb +0 -30
- data/spec/unit/alf-core/text/test_table.rb +0 -39
- data/spec/unit/alf-core/tools/test_class_name.rb +0 -16
- data/spec/unit/alf-core/tools/test_coalesce.rb +0 -19
- data/spec/unit/alf-core/tools/test_coerce.rb +0 -16
- data/spec/unit/alf-core/tools/test_ruby_case.rb +0 -16
- data/spec/unit/alf-core/tools/test_to_lispy.rb +0 -145
- data/spec/unit/alf-core/tools/test_to_relation.rb +0 -39
- data/spec/unit/alf-core/tools/test_to_ruby_literal.rb +0 -10
- data/spec/unit/alf-core/tools/test_tuple_handle.rb +0 -52
- data/spec/unit/alf-core/tools/test_tuple_heading.rb +0 -15
- data/spec/unit/alf-core/tools/test_varargs.rb +0 -19
- data/spec/unit/alf-core/types/test_attr_list.rb +0 -188
- data/spec/unit/alf-core/types/test_attr_name.rb +0 -78
- data/spec/unit/alf-core/types/test_boolean.rb +0 -42
- data/spec/unit/alf-core/types/test_class_methods.rb +0 -24
- data/spec/unit/alf-core/types/test_heading.rb +0 -146
- data/spec/unit/alf-core/types/test_ordering.rb +0 -185
- data/spec/unit/alf-core/types/test_renaming.rb +0 -72
- data/spec/unit/alf-core/types/test_size.rb +0 -74
- data/spec/unit/alf-core/types/test_summarization.rb +0 -95
- data/spec/unit/alf-core/types/test_tuple_computation.rb +0 -96
- data/spec/unit/alf-core/types/test_tuple_expression.rb +0 -122
- data/spec/unit/alf-core/types/test_tuple_predicate.rb +0 -108
- data/spec/unit/alf-csv/input.csv +0 -3
- data/spec/unit/alf-csv/test_reader.rb +0 -66
- data/spec/unit/alf-csv/test_renderer.rb +0 -73
- data/spec/unit/alf-engine/compact/test_set.rb +0 -33
- data/spec/unit/alf-engine/compact/test_uniq.rb +0 -33
- data/spec/unit/alf-engine/group/test_hash.rb +0 -34
- data/spec/unit/alf-engine/join/test_hash.rb +0 -55
- data/spec/unit/alf-engine/materialize/test_array.rb +0 -28
- data/spec/unit/alf-engine/materialize/test_hash.rb +0 -76
- data/spec/unit/alf-engine/quota/test_cesure.rb +0 -34
- data/spec/unit/alf-engine/rank/test_cesure.rb +0 -47
- data/spec/unit/alf-engine/semi/test_hash.rb +0 -58
- data/spec/unit/alf-engine/sort/test_in_memory.rb +0 -32
- data/spec/unit/alf-engine/summarize/test_cesure.rb +0 -36
- data/spec/unit/alf-engine/summarize/test_hash.rb +0 -36
- data/spec/unit/alf-engine/test_aggregate.rb +0 -26
- data/spec/unit/alf-engine/test_autonum.rb +0 -24
- data/spec/unit/alf-engine/test_clip.rb +0 -34
- data/spec/unit/alf-engine/test_coerce.rb +0 -35
- data/spec/unit/alf-engine/test_compact.rb +0 -33
- data/spec/unit/alf-engine/test_concat.rb +0 -38
- data/spec/unit/alf-engine/test_defaults.rb +0 -37
- data/spec/unit/alf-engine/test_filter.rb +0 -23
- data/spec/unit/alf-engine/test_generator.rb +0 -25
- data/spec/unit/alf-engine/test_rename.rb +0 -24
- data/spec/unit/alf-engine/test_set_attr.rb +0 -38
- data/spec/unit/alf-engine/test_sort.rb +0 -32
- data/spec/unit/alf-engine/test_ungroup.rb +0 -28
- data/spec/unit/alf-engine/test_unwrap.rb +0 -20
- data/spec/unit/alf-engine/test_wrap.rb +0 -26
- data/spec/unit/alf-logs/apache_combined.log +0 -5
- data/spec/unit/alf-logs/postgresql.log +0 -29
- data/spec/unit/alf-logs/test_reader.rb +0 -57
- data/spec/unit/alf-sequel/alf.db +0 -0
- data/spec/unit/alf-sequel/test_environment.rb +0 -74
- data/spec/unit/alf-shell/doc_manager/dynamic.md +0 -1
- data/spec/unit/alf-shell/doc_manager/example.md +0 -1
- data/spec/unit/alf-shell/doc_manager/example_1.txt +0 -11
- data/spec/unit/alf-shell/doc_manager/static.md +0 -1
- data/spec/unit/alf-shell/doc_manager/test_call.rb +0 -48
- data/spec/unit/alf-shell/main/test_class_methods.rb +0 -44
- data/spec/unit/alf-shell/operator/test_autonum.rb +0 -28
- data/spec/unit/alf-shell/operator/test_clip.rb +0 -29
- data/spec/unit/alf-shell/operator/test_coerce.rb +0 -21
- data/spec/unit/alf-shell/operator/test_compact.rb +0 -16
- data/spec/unit/alf-shell/operator/test_defaults.rb +0 -29
- data/spec/unit/alf-shell/operator/test_extend.rb +0 -21
- data/spec/unit/alf-shell/operator/test_generator.rb +0 -37
- data/spec/unit/alf-shell/operator/test_group.rb +0 -32
- data/spec/unit/alf-shell/operator/test_heading.rb +0 -16
- data/spec/unit/alf-shell/operator/test_intersect.rb +0 -18
- data/spec/unit/alf-shell/operator/test_join.rb +0 -18
- data/spec/unit/alf-shell/operator/test_matching.rb +0 -18
- data/spec/unit/alf-shell/operator/test_minus.rb +0 -18
- data/spec/unit/alf-shell/operator/test_not_matching.rb +0 -18
- data/spec/unit/alf-shell/operator/test_project.rb +0 -38
- data/spec/unit/alf-shell/operator/test_quota.rb +0 -23
- data/spec/unit/alf-shell/operator/test_rank.rb +0 -30
- data/spec/unit/alf-shell/operator/test_rename.rb +0 -21
- data/spec/unit/alf-shell/operator/test_restrict.rb +0 -35
- data/spec/unit/alf-shell/operator/test_sort.rb +0 -49
- data/spec/unit/alf-shell/operator/test_summarize.rb +0 -30
- data/spec/unit/alf-shell/operator/test_ungroup.rb +0 -28
- data/spec/unit/alf-shell/operator/test_union.rb +0 -18
- data/spec/unit/alf-shell/operator/test_unwrap.rb +0 -28
- data/spec/unit/alf-shell/operator/test_wrap.rb +0 -30
- data/tasks/clean.rake +0 -3
- data/tasks/debug_mail.rake +0 -75
- data/tasks/debug_mail.txt +0 -18
- data/tasks/gh-pages.rake +0 -68
- data/tasks/integration_test.rake +0 -43
- data/tasks/regression_test.rake +0 -44
- data/tasks/unit_test.rake +0 -44
- data/tasks/yard.rake +0 -51
@@ -1,40 +0,0 @@
|
|
1
|
-
module Alf
|
2
|
-
module Engine
|
3
|
-
#
|
4
|
-
# Provides hash-based grouping.
|
5
|
-
#
|
6
|
-
class Group::Hash < Cog
|
7
|
-
|
8
|
-
# @return [Enumerable] The operand
|
9
|
-
attr_reader :operand
|
10
|
-
|
11
|
-
# @return [AttrList] Attributes to group
|
12
|
-
attr_reader :attributes
|
13
|
-
|
14
|
-
# @return [AttrName] Name of the new attribute
|
15
|
-
attr_reader :as
|
16
|
-
|
17
|
-
# @return [Boolean] Group all but specified attributes?
|
18
|
-
attr_reader :allbut
|
19
|
-
|
20
|
-
# Creates a Group::Hash instance
|
21
|
-
def initialize(operand, attributes, as, allbut)
|
22
|
-
@operand = operand
|
23
|
-
@attributes = attributes
|
24
|
-
@as = as
|
25
|
-
@allbut = allbut
|
26
|
-
end
|
27
|
-
|
28
|
-
# (see Cog#each)
|
29
|
-
def each(&block)
|
30
|
-
atr, alb = @attributes, @allbut
|
31
|
-
index = Materialize::Hash.new(operand, atr, !alb)
|
32
|
-
index.each_pair do |k,v|
|
33
|
-
grouped = Relation.new(Clip.new(v, atr, alb).to_set)
|
34
|
-
yield k.merge(@as => grouped)
|
35
|
-
end
|
36
|
-
end
|
37
|
-
|
38
|
-
end # class Group::Hash
|
39
|
-
end # module Engine
|
40
|
-
end # module Alf
|
@@ -1,35 +0,0 @@
|
|
1
|
-
module Alf
|
2
|
-
module Engine
|
3
|
-
#
|
4
|
-
# Provides hash-based join.
|
5
|
-
#
|
6
|
-
class Join::Hash < Cog
|
7
|
-
|
8
|
-
# @return [Enumerable] The left operand
|
9
|
-
attr_reader :left
|
10
|
-
|
11
|
-
# @return [Enumerable] The right operand
|
12
|
-
attr_reader :right
|
13
|
-
|
14
|
-
# Creates a Join::Hash instance
|
15
|
-
def initialize(left, right)
|
16
|
-
@left = left
|
17
|
-
@right = right
|
18
|
-
end
|
19
|
-
|
20
|
-
# (see Cog#each)
|
21
|
-
def each(&block)
|
22
|
-
index = nil
|
23
|
-
left.each do |left_tuple|
|
24
|
-
index ||= Materialize::Hash.new(right, lambda{|t|
|
25
|
-
AttrList.new(left_tuple.keys & t.keys)
|
26
|
-
}).prepare
|
27
|
-
index[left_tuple, true].each do |right_tuple|
|
28
|
-
yield left_tuple.merge(right_tuple)
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
32
|
-
|
33
|
-
end # class Hash
|
34
|
-
end # module Engine
|
35
|
-
end # module Alf
|
@@ -1,78 +0,0 @@
|
|
1
|
-
module Alf
|
2
|
-
module Engine
|
3
|
-
#
|
4
|
-
# Provides in-memory materialization through a ruby Array.
|
5
|
-
#
|
6
|
-
# This class acts as a Cog, that it, it is an enumerable of tuples. An
|
7
|
-
# optional ordering can be passed at construction.
|
8
|
-
#
|
9
|
-
# Materialization occurs at prepare time, with auto-prepare on first
|
10
|
-
# access.
|
11
|
-
#
|
12
|
-
# Example:
|
13
|
-
#
|
14
|
-
# rel = [
|
15
|
-
# {:name => "Jones", :city => "London"},
|
16
|
-
# {:name => "Smith", :city => "Paris"},
|
17
|
-
# {:name => "Blake", :city => "London"}
|
18
|
-
# ]
|
19
|
-
#
|
20
|
-
# Materialize::Array.new(rel).to_a
|
21
|
-
# # => same as rel, in same order as the source
|
22
|
-
#
|
23
|
-
# Materialize::Array.new(rel, Ordering[[:name, :asc]]).to_a
|
24
|
-
# # => [
|
25
|
-
# {:name => "Blake", :city => "London"},
|
26
|
-
# {:name => "Jones", :city => "London"},
|
27
|
-
# {:name => "Smith", :city => "Paris"}
|
28
|
-
# ]
|
29
|
-
#
|
30
|
-
class Materialize::Array < Cog
|
31
|
-
|
32
|
-
# @return [Enumerable] The operand
|
33
|
-
attr_reader :operand
|
34
|
-
|
35
|
-
# @return [Ordering] Ordering to ensure (optional)
|
36
|
-
attr_reader :ordering
|
37
|
-
|
38
|
-
# Creates a Materialize::Array instance
|
39
|
-
def initialize(operand, ordering = nil)
|
40
|
-
@operand = operand
|
41
|
-
@ordering = ordering
|
42
|
-
@materialized = nil
|
43
|
-
end
|
44
|
-
|
45
|
-
# (see Cog#each)
|
46
|
-
def each(&block)
|
47
|
-
materialized.each(&block)
|
48
|
-
end
|
49
|
-
|
50
|
-
# (see Cog#prepare)
|
51
|
-
#
|
52
|
-
# Prepare through materialization of the operand as an ordered array
|
53
|
-
def prepare
|
54
|
-
@materialized ||= begin
|
55
|
-
arr = operand.to_a
|
56
|
-
arr.sort!(&ordering.sorter) if ordering
|
57
|
-
arr
|
58
|
-
end
|
59
|
-
end
|
60
|
-
|
61
|
-
# (see Cog#free)
|
62
|
-
#
|
63
|
-
# Frees the materizalied hash
|
64
|
-
def clean
|
65
|
-
@materialized = nil
|
66
|
-
end
|
67
|
-
|
68
|
-
private
|
69
|
-
|
70
|
-
# @return [Array] the materialized array
|
71
|
-
def materialized
|
72
|
-
prepare
|
73
|
-
@materialized
|
74
|
-
end
|
75
|
-
|
76
|
-
end # class Materialize::Array
|
77
|
-
end # module Engine
|
78
|
-
end # module Alf
|
@@ -1,122 +0,0 @@
|
|
1
|
-
module Alf
|
2
|
-
module Engine
|
3
|
-
#
|
4
|
-
# Provides in-memory materialization through a ruby Hash.
|
5
|
-
#
|
6
|
-
# This class acts as a Cog, that it, it is an enumerable of tuples. No
|
7
|
-
# particular ordering is guaranteed. In addition, the class provides
|
8
|
-
# indexed access through the `[]` method.
|
9
|
-
#
|
10
|
-
# Materialization occurs at prepare time, with auto-prepare on first
|
11
|
-
# access.
|
12
|
-
#
|
13
|
-
# Example:
|
14
|
-
#
|
15
|
-
# rel = [
|
16
|
-
# {:name => "Jones", :city => "London"},
|
17
|
-
# {:name => "Smith", :city => "Paris"},
|
18
|
-
# {:name => "Blake", :city => "London"}
|
19
|
-
# ]
|
20
|
-
# op = Materialize::Hash.new(rel, AttrList[:city])
|
21
|
-
#
|
22
|
-
# op.to_a
|
23
|
-
# # => same as rel, no ordering guaranteed
|
24
|
-
#
|
25
|
-
# op[:city => "London"].to_a
|
26
|
-
# # => [
|
27
|
-
# {:name => "Jones", :city => "London"},
|
28
|
-
# {:name => "Blake", :city => "London"}
|
29
|
-
# ]
|
30
|
-
#
|
31
|
-
# op[:city => "London"].to_a
|
32
|
-
# # => [
|
33
|
-
# {:name => "Jones", :city => "London"},
|
34
|
-
# {:name => "Blake", :city => "London"}
|
35
|
-
# ]
|
36
|
-
#
|
37
|
-
# op[:city => "Athens"].to_a
|
38
|
-
# # => []
|
39
|
-
#
|
40
|
-
class Materialize::Hash < Cog
|
41
|
-
|
42
|
-
# @return [Enumerable] The operand
|
43
|
-
attr_reader :operand
|
44
|
-
|
45
|
-
# @return [AttrList] Attributes for the hash key
|
46
|
-
attr_reader :key
|
47
|
-
|
48
|
-
# @return [Boolean] Hash on all but specified attributes?
|
49
|
-
attr_reader :allbut
|
50
|
-
|
51
|
-
# Creates a Materialize::Hash instance
|
52
|
-
def initialize(operand, key, allbut = false)
|
53
|
-
@operand = operand
|
54
|
-
@key = key
|
55
|
-
@allbut = allbut
|
56
|
-
@materialized = nil
|
57
|
-
end
|
58
|
-
|
59
|
-
# (see Cog#each)
|
60
|
-
def each(&block)
|
61
|
-
materialized.each_value do |rel|
|
62
|
-
rel.each(&block)
|
63
|
-
end
|
64
|
-
end
|
65
|
-
|
66
|
-
# Yields indexed (key, tuples) pairs in turn.
|
67
|
-
def each_pair(&block)
|
68
|
-
materialized.each_pair(&block)
|
69
|
-
end
|
70
|
-
|
71
|
-
# Returns tuples that match a given key.
|
72
|
-
#
|
73
|
-
# This method returns a Cog instance in all case. En empty Cog is
|
74
|
-
# returned if no tuples match the key.
|
75
|
-
#
|
76
|
-
# @param [Tuple] key_tuple a key tuple
|
77
|
-
# @param [Boolean] project project `key_tuple` on key first?
|
78
|
-
# @return [Cog] the tuples from operand that match `key_tuple`
|
79
|
-
def [](key_tuple, project = false)
|
80
|
-
key_tuple = key_for(key_tuple) if project
|
81
|
-
m = materialized
|
82
|
-
m.has_key?(key_tuple) ? m[key_tuple] : []
|
83
|
-
end
|
84
|
-
|
85
|
-
# (see Cog#prepare)
|
86
|
-
#
|
87
|
-
# Prepare through materialization of the operand as a hash
|
88
|
-
def prepare
|
89
|
-
@materialized ||= begin
|
90
|
-
h = ::Hash.new{|h,k| h[k] = []}
|
91
|
-
operand.each do |tuple|
|
92
|
-
h[key_for(tuple)] << tuple
|
93
|
-
end
|
94
|
-
h
|
95
|
-
end
|
96
|
-
self
|
97
|
-
end
|
98
|
-
|
99
|
-
# (see Cog#free)
|
100
|
-
#
|
101
|
-
# Frees the materizalied hash
|
102
|
-
def clean
|
103
|
-
@materialized = nil
|
104
|
-
end
|
105
|
-
|
106
|
-
private
|
107
|
-
|
108
|
-
# Projects `tuple` to get the indexing key
|
109
|
-
def key_for(tuple)
|
110
|
-
@key = @key.call(tuple) unless @key.is_a?(AttrList)
|
111
|
-
@key.project_tuple(tuple, @allbut)
|
112
|
-
end
|
113
|
-
|
114
|
-
# @return [Hash] the materialized hash
|
115
|
-
def materialized
|
116
|
-
prepare
|
117
|
-
@materialized
|
118
|
-
end
|
119
|
-
|
120
|
-
end # class Materialize::Hash
|
121
|
-
end # module Engine
|
122
|
-
end # module Alf
|
@@ -1,46 +0,0 @@
|
|
1
|
-
module Alf
|
2
|
-
module Engine
|
3
|
-
class Quota::Cesure < Cog
|
4
|
-
include Engine::Cesure
|
5
|
-
|
6
|
-
# @return [Enumerable] The operand
|
7
|
-
attr_reader :operand
|
8
|
-
|
9
|
-
# @return [AttrList] List of attributes for 'quota by'
|
10
|
-
attr_reader :by
|
11
|
-
|
12
|
-
# @return [Summarization] Quota computations as a summarization
|
13
|
-
attr_reader :summarization
|
14
|
-
|
15
|
-
# Creates an Aggregate instance
|
16
|
-
def initialize(operand, by, summarization)
|
17
|
-
@operand = operand
|
18
|
-
@by = by.to_attr_list
|
19
|
-
@summarization = summarization
|
20
|
-
end
|
21
|
-
|
22
|
-
protected
|
23
|
-
|
24
|
-
# (see Operator::Cesure#project)
|
25
|
-
def project(tuple)
|
26
|
-
@by.project_tuple(tuple, false)
|
27
|
-
end
|
28
|
-
|
29
|
-
# (see Operator::Cesure#start_cesure)
|
30
|
-
def start_cesure(key, receiver)
|
31
|
-
@aggs = @summarization.least
|
32
|
-
end
|
33
|
-
|
34
|
-
# (see Operator::Cesure#accumulate_cesure)
|
35
|
-
def accumulate_cesure(tuple, receiver)
|
36
|
-
@aggs = @summarization.happens(@aggs, tuple)
|
37
|
-
receiver.call tuple.merge(@summarization.finalize(@aggs))
|
38
|
-
end
|
39
|
-
|
40
|
-
# (see Cesure#flush_cesure)
|
41
|
-
def flush_cesure(key, receiver)
|
42
|
-
end
|
43
|
-
|
44
|
-
end # class Quota::Cesure
|
45
|
-
end # module Engine
|
46
|
-
end # module Alf
|
@@ -1,48 +0,0 @@
|
|
1
|
-
module Alf
|
2
|
-
module Engine
|
3
|
-
class Rank::Cesure < Cog
|
4
|
-
include Engine::Cesure
|
5
|
-
|
6
|
-
# @return [Enumerable] The operand
|
7
|
-
attr_reader :operand
|
8
|
-
|
9
|
-
# @return [AttrList] List of attributes that form the operand ordering
|
10
|
-
attr_reader :by
|
11
|
-
|
12
|
-
# @return [AttrName] Name of the introduced attribute
|
13
|
-
attr_reader :as
|
14
|
-
|
15
|
-
# Creates an Aggregate instance
|
16
|
-
def initialize(operand, by, as)
|
17
|
-
@operand = operand
|
18
|
-
@by = by.to_attr_list
|
19
|
-
@as = as
|
20
|
-
end
|
21
|
-
|
22
|
-
protected
|
23
|
-
|
24
|
-
# (see Cesure#project)
|
25
|
-
def project(tuple)
|
26
|
-
@by.project_tuple(tuple, false)
|
27
|
-
end
|
28
|
-
|
29
|
-
# (see Cesure#start_cesure)
|
30
|
-
def start_cesure(key, receiver)
|
31
|
-
@rank ||= 0
|
32
|
-
@last_block = 0
|
33
|
-
end
|
34
|
-
|
35
|
-
# (see Cesure#accumulate_cesure)
|
36
|
-
def accumulate_cesure(tuple, receiver)
|
37
|
-
receiver.call tuple.merge(@as => @rank)
|
38
|
-
@last_block += 1
|
39
|
-
end
|
40
|
-
|
41
|
-
# (see Cesure#flush_cesure)
|
42
|
-
def flush_cesure(key, receiver)
|
43
|
-
@rank += @last_block
|
44
|
-
end
|
45
|
-
|
46
|
-
end # class Rank::Cesure
|
47
|
-
end # module Engine
|
48
|
-
end # module Alf
|
@@ -1,39 +0,0 @@
|
|
1
|
-
module Alf
|
2
|
-
module Engine
|
3
|
-
#
|
4
|
-
# Renames tuples from the operand according to a Renaming info.
|
5
|
-
#
|
6
|
-
# Example:
|
7
|
-
#
|
8
|
-
# rel = [
|
9
|
-
# {:name => "Jones", :city => "London"}
|
10
|
-
# ]
|
11
|
-
# Rename.new(rel, Renaming[:name => :last_name]).to_a
|
12
|
-
# # => [
|
13
|
-
# # {:last_name => "Jones", :city => "London"}
|
14
|
-
# # ]
|
15
|
-
#
|
16
|
-
class Rename < Cog
|
17
|
-
|
18
|
-
# @return [Enumerable] The operand
|
19
|
-
attr_reader :operand
|
20
|
-
|
21
|
-
# @return [Renaming] Renaming info
|
22
|
-
attr_reader :renaming
|
23
|
-
|
24
|
-
# Creates a Rename instance
|
25
|
-
def initialize(operand, renaming)
|
26
|
-
@operand = operand
|
27
|
-
@renaming = renaming
|
28
|
-
end
|
29
|
-
|
30
|
-
# (see Cog#each)
|
31
|
-
def each
|
32
|
-
operand.each do |tuple|
|
33
|
-
yield @renaming.rename_tuple(tuple)
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
37
|
-
end # class Rename
|
38
|
-
end # module Engine
|
39
|
-
end # module Alf
|