pione 0.2.2 → 0.3.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +1 -0
- data/.simplecov +1 -0
- data/History.txt +9 -0
- data/Rakefile +1 -71
- data/example/Fib/Fib.pione +9 -8
- data/example/HelloWorld/HelloWorld.pione +2 -0
- data/example/HelloWorld/pione-package.json +15 -0
- data/example/HelloWorld/scenario/Scenario.pione +2 -0
- data/example/HelloWorld/scenario/pione-scenario.json +10 -0
- data/example/SerialProcessing/SerialProcessing.pione +2 -0
- data/example/SerialProcessing/pione-package.json +15 -0
- data/example/SerialProcessing/scenario/Scenario.pione +1 -0
- data/example/SerialProcessing/scenario/pione-scenario.json +10 -0
- data/lib/pione.rb +28 -35
- data/lib/pione/agent.rb +4 -4
- data/lib/pione/agent/agent-exception.rb +52 -0
- data/lib/pione/agent/basic-agent.rb +246 -239
- data/lib/pione/agent/broker.rb +232 -216
- data/lib/pione/agent/input-generator.rb +113 -133
- data/lib/pione/agent/job-terminator.rb +38 -0
- data/lib/pione/agent/logger.rb +24 -54
- data/lib/pione/agent/messenger.rb +11 -16
- data/lib/pione/agent/process-manager.rb +50 -19
- data/lib/pione/agent/task-worker.rb +126 -236
- data/lib/pione/agent/tuple-space-client.rb +16 -39
- data/lib/pione/agent/tuple-space-provider.rb +66 -0
- data/lib/pione/agent/tuple-space-receiver.rb +137 -0
- data/lib/pione/command.rb +2 -3
- data/lib/pione/command/basic-command.rb +347 -207
- data/lib/pione/command/command-exception.rb +38 -0
- data/lib/pione/command/option.rb +112 -104
- data/lib/pione/command/pione-broker.rb +85 -43
- data/lib/pione/command/pione-clean.rb +51 -8
- data/lib/pione/command/pione-client.rb +321 -292
- data/lib/pione/command/pione-log.rb +92 -53
- data/lib/pione/command/pione-package.rb +112 -59
- data/lib/pione/command/pione-relay-account-db.rb +107 -78
- data/lib/pione/command/pione-relay-client-db.rb +93 -72
- data/lib/pione/command/pione-relay.rb +37 -32
- data/lib/pione/command/pione-syntax-checker.rb +112 -87
- data/lib/pione/command/pione-task-worker.rb +135 -118
- data/lib/pione/command/pione-tuple-space-provider.rb +83 -50
- data/lib/pione/command/pione-tuple-space-receiver.rb +89 -50
- data/lib/pione/command/pione-tuple-space-viewer.rb +101 -99
- data/lib/pione/command/pione-val.rb +50 -29
- data/lib/pione/command/spawner.rb +74 -0
- data/lib/pione/front.rb +0 -2
- data/lib/pione/front/basic-front.rb +48 -26
- data/lib/pione/front/broker-front.rb +8 -16
- data/lib/pione/front/client-front.rb +10 -18
- data/lib/pione/front/front-exception.rb +12 -0
- data/lib/pione/front/relay-front.rb +6 -6
- data/lib/pione/front/task-worker-front.rb +3 -9
- data/lib/pione/front/tuple-space-provider-front.rb +6 -14
- data/lib/pione/front/tuple-space-receiver-front.rb +4 -11
- data/lib/pione/global.rb +135 -0
- data/lib/pione/global/broker-variable.rb +20 -0
- data/lib/pione/global/client-variable.rb +18 -0
- data/lib/pione/global/input-generator-variable.rb +7 -0
- data/lib/pione/global/log-variable.rb +53 -0
- data/lib/pione/global/network-variable.rb +7 -0
- data/lib/pione/global/package-variable.rb +28 -0
- data/lib/pione/global/path-variable.rb +52 -0
- data/lib/pione/global/relay-variable.rb +86 -0
- data/lib/pione/global/system-variable.rb +39 -0
- data/lib/pione/global/task-worker-variable.rb +17 -0
- data/lib/pione/global/tuple-space-notifier-variable.rb +60 -0
- data/lib/pione/lang.rb +55 -0
- data/lib/pione/lang/basic-model.rb +45 -0
- data/lib/pione/lang/boolean.rb +86 -0
- data/lib/pione/lang/common-parser.rb +202 -0
- data/lib/pione/lang/conditional-branch-parser.rb +57 -0
- data/lib/pione/lang/conditional-branch-transformer.rb +36 -0
- data/lib/pione/lang/conditional-branch.rb +73 -0
- data/lib/pione/lang/context-parser.rb +39 -0
- data/lib/pione/lang/context-transformer.rb +41 -0
- data/lib/pione/lang/context.rb +229 -0
- data/lib/pione/lang/data-expr.rb +265 -0
- data/lib/pione/lang/declaration-parser.rb +174 -0
- data/lib/pione/lang/declaration-transformer.rb +153 -0
- data/lib/pione/lang/declaration.rb +322 -0
- data/lib/pione/lang/definition.rb +88 -0
- data/lib/pione/lang/document-parser.rb +19 -0
- data/lib/pione/lang/document-transformer.rb +12 -0
- data/lib/pione/lang/environment.rb +344 -0
- data/lib/pione/{parser → lang}/error-message.yml +0 -0
- data/lib/pione/lang/expr-parser.rb +228 -0
- data/lib/pione/{transformer → lang}/expr-transformer.rb +32 -44
- data/lib/pione/lang/expr.rb +70 -0
- data/lib/pione/lang/feature-expr.rb +425 -0
- data/lib/pione/lang/float.rb +104 -0
- data/lib/pione/lang/integer.rb +159 -0
- data/lib/pione/lang/interpolator-parser.rb +44 -0
- data/lib/pione/lang/interpolator-transformer.rb +13 -0
- data/lib/pione/lang/keyed-sequence.rb +98 -0
- data/lib/pione/lang/lang-exception.rb +224 -0
- data/lib/pione/lang/literal-parser.rb +134 -0
- data/lib/pione/lang/literal-transformer.rb +171 -0
- data/lib/pione/lang/message.rb +41 -0
- data/lib/pione/lang/ordinal-sequence.rb +203 -0
- data/lib/pione/lang/package-expr.rb +86 -0
- data/lib/pione/lang/parameters.rb +121 -0
- data/lib/pione/lang/piece.rb +42 -0
- data/lib/pione/{model → lang}/pione-method.rb +26 -63
- data/lib/pione/lang/rule-expr.rb +70 -0
- data/lib/pione/lang/sequence.rb +215 -0
- data/lib/pione/lang/string.rb +116 -0
- data/lib/pione/lang/ticket-expr.rb +48 -0
- data/lib/pione/{model → lang}/type.rb +70 -99
- data/lib/pione/lang/variable.rb +35 -0
- data/lib/pione/location.rb +13 -1
- data/lib/pione/{uri-scheme → location}/broadcast-scheme.rb +2 -2
- data/lib/pione/location/data-location.rb +22 -5
- data/lib/pione/location/dropbox-location.rb +10 -8
- data/lib/pione/{uri-scheme → location}/dropbox-scheme.rb +2 -2
- data/lib/pione/location/ftp-location.rb +6 -0
- data/lib/pione/location/git-repository-location.rb +6 -17
- data/lib/pione/{uri-scheme → location}/git-scheme.rb +2 -2
- data/lib/pione/location/http-location.rb +8 -1
- data/lib/pione/location/local-location.rb +57 -4
- data/lib/pione/{uri-scheme → location}/local-scheme.rb +2 -2
- data/lib/pione/location/{exception.rb → location-exception.rb} +13 -1
- data/lib/pione/{uri-scheme/basic-scheme.rb → location/location-scheme.rb} +7 -6
- data/lib/pione/{uri-scheme → location}/myftp-scheme.rb +2 -2
- data/lib/pione/log.rb +7 -6
- data/lib/pione/log/debug.rb +75 -0
- data/lib/pione/log/domain-log.rb +4 -5
- data/lib/pione/log/message-log.rb +2 -2
- data/lib/pione/log/process-log.rb +16 -25
- data/lib/pione/log/process-record.rb +1 -0
- data/lib/pione/log/system-log.rb +165 -55
- data/lib/pione/package.rb +21 -0
- data/lib/pione/package/document.rb +27 -0
- data/lib/pione/package/package-archiver.rb +152 -0
- data/lib/pione/package/package-cache.rb +79 -0
- data/lib/pione/package/package-database.rb +121 -0
- data/lib/pione/package/package-exception.rb +38 -0
- data/lib/pione/{component → package}/package-expander.rb +13 -7
- data/lib/pione/package/package-filename.rb +46 -0
- data/lib/pione/package/package-handler.rb +106 -0
- data/lib/pione/package/package-info.rb +72 -0
- data/lib/pione/package/package-reader.rb +202 -0
- data/lib/pione/package/package-scanner.rb +133 -0
- data/lib/pione/package/scenario-handler.rb +95 -0
- data/lib/pione/package/scenario-info.rb +34 -0
- data/lib/pione/package/scenario-reader.rb +29 -0
- data/lib/pione/package/scenario-scanner.rb +96 -0
- data/lib/pione/patch.rb +0 -1
- data/lib/pione/patch/drb-patch.rb +377 -298
- data/lib/pione/patch/rinda-patch.rb +4 -3
- data/lib/pione/relay/relay-socket.rb +1 -4
- data/lib/pione/rule-engine.rb +27 -0
- data/lib/pione/{rule-handler → rule-engine}/action-handler.rb +41 -40
- data/lib/pione/rule-engine/basic-handler.rb +266 -0
- data/lib/pione/rule-engine/data-finder.rb +97 -0
- data/lib/pione/{rule-handler → rule-engine}/empty-handler.rb +2 -3
- data/lib/pione/rule-engine/engine-exception.rb +33 -0
- data/lib/pione/rule-engine/flow-handler.rb +490 -0
- data/lib/pione/{rule-handler → rule-engine}/root-handler.rb +5 -14
- data/lib/pione/{rule-handler → rule-engine}/system-handler.rb +1 -1
- data/lib/pione/rule-engine/update-criteria.rb +111 -0
- data/lib/pione/system.rb +3 -1
- data/lib/pione/system/config.rb +12 -45
- data/lib/pione/system/domain-info.rb +3 -12
- data/lib/pione/system/init.rb +2 -8
- data/lib/pione/system/system-exception.rb +29 -0
- data/lib/pione/test-helper.rb +43 -0
- data/lib/pione/test-helper/command-helper.rb +65 -0
- data/lib/pione/test-helper/extension.rb +9 -0
- data/lib/pione/test-helper/lang-helper.rb +196 -0
- data/lib/pione/test-helper/location-helper.rb +27 -0
- data/lib/pione/test-helper/package-helper.rb +11 -0
- data/lib/pione/test-helper/parser-helper.rb +45 -0
- data/lib/pione/test-helper/transformer-helper.rb +136 -0
- data/lib/pione/test-helper/tuple-helper.rb +13 -0
- data/lib/pione/test-helper/tuple-space-helper.rb +31 -0
- data/lib/pione/test-helper/webserver.rb +50 -0
- data/lib/pione/tuple-space.rb +4 -6
- data/lib/pione/{tuple → tuple-space}/basic-tuple.rb +63 -50
- data/lib/pione/tuple-space/tuple-definition.yml +165 -0
- data/lib/pione/tuple-space/tuple-space-exception.rb +25 -0
- data/lib/pione/tuple-space/tuple-space-interface.rb +123 -0
- data/lib/pione/tuple-space/tuple-space-server.rb +15 -26
- data/lib/pione/util.rb +16 -11
- data/lib/pione/util/backslash-notation.rb +11 -0
- data/lib/pione/util/digest.rb +71 -0
- data/lib/pione/util/embeded-expr-expander.rb +23 -0
- data/lib/pione/util/evaluatable.rb +9 -6
- data/lib/pione/util/free-thread-generator.rb +46 -0
- data/lib/pione/util/ftp-server.rb +3 -4
- data/lib/pione/util/id.rb +28 -23
- data/lib/pione/util/misc.rb +22 -4
- data/lib/pione/util/package-parameters-list.rb +12 -9
- data/lib/pione/{parser → util}/parslet-extension.rb +75 -64
- data/lib/pione/util/positionable.rb +65 -0
- data/lib/pione/util/zip.rb +12 -11
- data/lib/pione/version.rb +1 -1
- data/{test → misc}/endurance-test/graph.plt +0 -0
- data/{test → misc}/endurance-test/run.sh +0 -0
- data/pione.gemspec +45 -37
- data/test/agent/spec_basic-agent.rb +116 -99
- data/test/agent/spec_broker.rb +41 -25
- data/test/agent/spec_input-generator.rb +66 -57
- data/test/agent/spec_job-terminator.rb +27 -0
- data/test/agent/spec_logger.rb +28 -25
- data/test/agent/spec_messenger.rb +6 -6
- data/test/agent/spec_task-worker.rb +97 -246
- data/test/agent/spec_tuple-space-client.rb +19 -15
- data/test/agent/spec_tuple-space-provider.rb +26 -0
- data/test/agent/spec_tuple-space-receiver.rb +47 -0
- data/test/command/command-behavior.rb +2 -2
- data/test/command/data/PionePackageP1/P1.pione +9 -0
- data/test/command/data/PionePackageP1/pione-package.json +15 -0
- data/test/command/data/PionePackageP2/P2.pione +10 -0
- data/test/command/data/PionePackageP2/pione-package.json +16 -0
- data/test/command/data/PionePackageP3/P3.pione +10 -0
- data/test/command/data/PionePackageP3/pione-package.json +16 -0
- data/test/command/data/PionePackageP4/P4.pione +10 -0
- data/test/command/data/PionePackageP4/pione-package.json +17 -0
- data/test/command/data/pione-process.log +471 -0
- data/test/command/data/pione-val.domain.dump +0 -0
- data/test/command/spec_pione-clean.rb +12 -0
- data/test/command/spec_pione-client.rb +6 -6
- data/test/command/spec_pione-log.rb +28 -0
- data/test/command/spec_pione-package.rb +111 -12
- data/test/command/spec_pione-val.rb +4 -4
- data/test/lang/data/boolean.yml +134 -0
- data/test/lang/data/common-parser.yml +187 -0
- data/test/{parser/spec_flow-element-parser.yml → lang/data/conditional-branch-parser.yml} +12 -50
- data/test/lang/data/context-parser.yml +148 -0
- data/test/lang/data/data-expr.yml +93 -0
- data/test/lang/data/data-expr_match.yml +59 -0
- data/test/lang/data/declaration-parser.yml +279 -0
- data/test/lang/data/document-parser.yml +29 -0
- data/test/{parser/spec_expr-parser.yml → lang/data/expr-parser.yml} +9 -11
- data/test/lang/data/feature-expr.yml +148 -0
- data/test/lang/data/float.yml +30 -0
- data/test/lang/data/integer.yml +80 -0
- data/test/lang/data/interpolator-parser.yml +61 -0
- data/test/lang/data/keyed-sequence.yml +27 -0
- data/test/lang/data/literal-parser.yml +207 -0
- data/test/lang/data/parameter-set.yml +14 -0
- data/test/lang/data/rule-expr.yml +27 -0
- data/test/lang/data/sequence.yml +66 -0
- data/test/lang/data/string.yml +92 -0
- data/test/{model/spec_ticket-expr.yml → lang/data/ticket-expr.yml} +0 -0
- data/test/lang/spec_boolean.rb +5 -0
- data/test/{parser → lang}/spec_common-parser.rb +10 -32
- data/test/lang/spec_conditional-branch-parser.rb +5 -0
- data/test/lang/spec_conditional-branch-transformer.rb +97 -0
- data/test/lang/spec_conditional-branch.rb +176 -0
- data/test/lang/spec_context-parser.rb +5 -0
- data/test/lang/spec_context-transformer.rb +206 -0
- data/test/lang/spec_context.rb +283 -0
- data/test/lang/spec_data-expr.rb +198 -0
- data/test/lang/spec_declaration-parser.rb +5 -0
- data/test/lang/spec_declaration-transformer.rb +272 -0
- data/test/lang/spec_declaration.rb +550 -0
- data/test/lang/spec_document-parser.rb +5 -0
- data/test/lang/spec_document-transformer.rb +10 -0
- data/test/lang/spec_environment.rb +129 -0
- data/test/lang/spec_expr-parser.rb +6 -0
- data/test/lang/spec_expr-transformer.rb +149 -0
- data/test/lang/spec_feature-expr.rb +5 -0
- data/test/lang/spec_float.rb +23 -0
- data/test/lang/spec_integer.rb +29 -0
- data/test/lang/spec_interpolator-parser.rb +5 -0
- data/test/lang/spec_interpolator-transformer.rb +15 -0
- data/test/lang/spec_keyed-sequence.rb +5 -0
- data/test/lang/spec_literal-parser.rb +5 -0
- data/test/lang/spec_literal-transformer.rb +111 -0
- data/test/lang/spec_message.rb +22 -0
- data/test/lang/spec_package-expr.rb +19 -0
- data/test/lang/spec_parameter-set.rb +64 -0
- data/test/lang/spec_pione-method.rb +57 -0
- data/test/lang/spec_rule-expr.rb +18 -0
- data/test/lang/spec_sequence.rb +5 -0
- data/test/lang/spec_string.rb +5 -0
- data/test/lang/spec_ticket-expr.rb +39 -0
- data/test/lang/spec_variable.rb +29 -0
- data/test/{uri-scheme/spec_myftp-scheme.yml → location/data/myftp-scheme.yml} +0 -0
- data/test/location/location-behavior.rb +2 -2
- data/test/location/spec_basic-location.rb +5 -1
- data/test/{uri-scheme → location}/spec_broadcast-scheme.rb +4 -4
- data/test/{uri-scheme → location}/spec_dropbox-scheme.rb +3 -3
- data/test/location/spec_ftp-location.rb +3 -2
- data/test/location/spec_git-repository-location.rb +19 -19
- data/test/{uri-scheme → location}/spec_git-scheme.rb +2 -2
- data/test/location/spec_http-location.rb +4 -12
- data/test/location/spec_https-location.rb +1 -3
- data/test/location/spec_local-location.rb +1 -1
- data/test/{uri-scheme → location}/spec_local-scheme.rb +3 -3
- data/test/{uri-scheme → location}/spec_myftp-scheme.rb +8 -10
- data/test/log/spec_debug.rb +53 -0
- data/test/log/spec_domain-log.rb +4 -5
- data/test/log/spec_message-log.rb +39 -33
- data/test/log/spec_process-log.rb +4 -2
- data/test/log/spec_process-record.rb +12 -10
- data/test/log/spec_system-log.rb +29 -11
- data/test/log/spec_xes-log.rb +6 -4
- data/test/package/data/HelloWorld+v0.1.1.ppg +0 -0
- data/test/package/data/HelloWorld-gitrepos.zip +0 -0
- data/test/{test-data/package → package/data}/HelloWorld/HelloWorld.pione +3 -0
- data/test/package/data/HelloWorld/pione-package.json +16 -0
- data/test/package/data/HelloWorld/scenario/Scenario.pione +2 -0
- data/test/{test-data/package → package/data}/HelloWorld/scenario/output/message.txt +0 -0
- data/test/package/data/HelloWorld/scenario/pione-scenario.json +10 -0
- data/test/{test-data/package → package/data}/HelloWorld/scenario/scenario.yml +0 -0
- data/test/package/data/PackageScannerP1/P1.pione +11 -0
- data/test/package/data/PackageScannerP2/P2.pione +9 -0
- data/test/package/data/PackageScannerP3/P3.pione +17 -0
- data/test/package/data/PackageScannerP4/.Ignore.pione +1 -0
- data/test/package/data/PackageScannerP4/Doc1.pione +8 -0
- data/test/package/data/PackageScannerP4/Doc2.pione +6 -0
- data/test/package/data/PackageScannerP4/Doc3.pione +6 -0
- data/test/package/data/PackageScannerP4/P4.pione +8 -0
- data/test/package/data/PackageScannerP4/sub1/.Ignore.pione +1 -0
- data/test/package/data/PackageScannerP4/sub1/Doc4.pione +6 -0
- data/test/package/data/PackageScannerP4/sub1/sub1-1/.Ignore.pione +1 -0
- data/test/package/data/PackageScannerP4/sub1/sub1-1/Doc5.pione +6 -0
- data/test/package/data/PackageScannerP4/sub2/.Ignore.pione +1 -0
- data/test/package/data/PackageScannerP4/sub2/sub2-1/.Ignore.pione +1 -0
- data/test/package/data/PackageScannerP4/sub2/sub2-1/sub2-1-1/.Ignore.pione +1 -0
- data/test/package/data/PackageScannerP4/sub2/sub2-1/sub2-1-1/Doc6.pione +6 -0
- data/test/package/data/PackageScannerP4/sub2/sub2-1/sub2-1-2/.Ignore.pione +1 -0
- data/test/package/data/PackageScannerP4/sub2/sub2-1/sub2-1-2/Doc7.pione +6 -0
- data/test/package/data/PackageScannerP5/P5.pione +8 -0
- data/test/{model/spec_feature-expr.yml → package/data/PackageScannerP5/scenario1/Scenario.pione} +0 -0
- data/test/package/data/PackageScannerP5/scenario2/Scenario.pione +0 -0
- data/test/package/data/PackageScannerP5/scenario3/Scenario.pione +0 -0
- data/test/package/data/PackageScannerP5/sub1/scenario4/Scenario.pione +0 -0
- data/test/package/data/PackageScannerP5/sub1/sub1-1/scenario5/Scenario.pione +0 -0
- data/test/package/data/PackageScannerP5/sub2/sub2-1/sub2-1-1/scenario6/Scenario.pione +0 -0
- data/test/package/data/PackageScannerP5/sub2/sub2-1/sub2-1-2/scenario7/Scenario.pione +0 -0
- data/test/package/data/ScenarioScannerS1/Scenario.pione +1 -0
- data/test/package/data/ScenarioScannerS1/input/i1 +0 -0
- data/test/package/data/ScenarioScannerS1/input/i2 +0 -0
- data/test/package/data/ScenarioScannerS1/input/i3 +0 -0
- data/test/package/data/ScenarioScannerS1/output/o1 +0 -0
- data/test/package/data/ScenarioScannerS1/output/o2 +0 -0
- data/test/package/data/ScenarioScannerS1/output/o3 +0 -0
- data/test/package/data/ScenarioScannerS2/Scenario.pione +1 -0
- data/test/package/data/ScenarioScannerS2/output/o1 +0 -0
- data/test/package/data/ScenarioScannerS3/Scenario.pione +2 -0
- data/test/package/data/ScenarioScannerS4/Scenario.pione +0 -0
- data/test/package/data/ScenarioScannerS5/Scenario.pione +2 -0
- data/test/package/data/ScenarioScannerS6/Scenario.pione +5 -0
- data/test/package/data/ScenarioScannerS8/Scenario.pione +1 -0
- data/test/{test-data/package → package/data}/TestPackage1+v0.1.0.ppg +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/Test.pione +3 -0
- data/test/{test-data/package → package/data}/TestPackage1/bin/count +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/package.yml +0 -0
- data/test/package/data/TestPackage1/pione-package.json +18 -0
- data/test/package/data/TestPackage1/scenario/case1/Scenario.pione +1 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case1/input/1.txt +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case1/output/1.count +0 -0
- data/test/package/data/TestPackage1/scenario/case1/pione-scenario.json +10 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case1/scenario.yml +0 -0
- data/test/package/data/TestPackage1/scenario/case2/Scenario.pione +1 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/input/1.txt +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/input/2.txt +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/input/3.txt +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/output/1.count +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/output/2.count +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/output/3.count +0 -0
- data/test/package/data/TestPackage1/scenario/case2/pione-scenario.json +14 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/scenario.yml +0 -0
- data/test/package/data/TestPackage1/scenario/case3/Scenario.pione +1 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/input/a.txt +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/input/b.txt +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/output/a.count +0 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/output/b.count +0 -0
- data/test/package/data/TestPackage1/scenario/case3/pione-scenario.json +12 -0
- data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/scenario.yml +0 -0
- data/test/{component → package}/spec_document.pione +0 -0
- data/test/package/spec_document.rb +52 -0
- data/test/package/spec_package-archiver.rb +31 -0
- data/test/package/spec_package-database.rb +42 -0
- data/test/package/spec_package-expander.rb +14 -0
- data/test/package/spec_package-filename.rb +56 -0
- data/test/package/spec_package-handler.rb +50 -0
- data/test/package/spec_package-info.rb +22 -0
- data/test/package/spec_package-reader.rb +85 -0
- data/test/package/spec_package-scanner.rb +68 -0
- data/test/package/spec_scenario-handler.rb +46 -0
- data/test/package/spec_scenario-info.rb +16 -0
- data/test/package/spec_scenario-scanner.rb +92 -0
- data/test/patch/spec_rinda-patch.rb +1 -1
- data/test/patch/spec_uri-patch.rb +1 -1
- data/test/{rule-handler → rule-engine}/spec_action-handler.pione +0 -0
- data/test/rule-engine/spec_action-handler.rb +94 -0
- data/test/rule-engine/spec_data-finder.rb +94 -0
- data/test/{tuple-space → rule-engine}/spec_data-finder.yml +39 -28
- data/test/rule-engine/spec_empty-handler.rb +170 -0
- data/test/{rule-handler → rule-engine}/spec_flow-handler.pione +0 -0
- data/test/rule-engine/spec_flow-handler.rb +421 -0
- data/test/{rule-handler → rule-engine}/spec_update-criteria.pione +0 -0
- data/test/{rule-handler → rule-engine}/spec_update-criteria.rb +16 -12
- data/test/{rule-handler → rule-engine}/spec_update-criteria.yml +0 -0
- data/test/system/spec_domain-info.rb +13 -9
- data/test/system/spec_file-cache.rb +9 -9
- data/test/tuple-space/spec_tuple-space-server.rb +42 -40
- data/test/tuple/spec_basic-tuple.rb +77 -75
- data/test/tuple/spec_data-tuple.rb +4 -4
- data/test/tuple/spec_finished-tuple.rb +5 -6
- data/test/tuple/spec_message-tuple.rb +3 -3
- data/test/tuple/spec_task-tuple.rb +11 -9
- data/test/tuple/spec_touch-tuple.rb +3 -3
- data/test/tuple/spec_working-tuple.rb +8 -12
- data/test/tuple/tuple-behavior.rb +1 -1
- data/test/util/data/HelloWorld+v0.1.1.ppg +0 -0
- data/test/util/spec_cpu.rb +1 -1
- data/test/util/spec_digest.rb +15 -0
- data/test/util/spec_evaluatable.rb +3 -3
- data/test/util/spec_free-thread-generator.rb +42 -0
- data/test/util/spec_ftp-server.rb +4 -9
- data/test/util/spec_id.rb +53 -36
- data/test/util/spec_indentation.rb +1 -1
- data/test/util/spec_ip-address.rb +1 -1
- data/test/util/spec_package-parameters-list.rb +10 -9
- data/test/util/spec_process-info.rb +2 -2
- data/test/util/spec_uuid.rb +1 -1
- data/test/util/spec_variable-holdable.rb +1 -1
- data/test/util/spec_zip.rb +1 -1
- metadata +508 -364
- data/example/SerialProcessing/package.yml +0 -5
- data/example/SerialProcessing/scenario/scenario.yml +0 -10
- data/lib/pione/agent/command-listener.rb +0 -47
- data/lib/pione/agent/rule-provider.rb +0 -59
- data/lib/pione/agent/trivial-routine-worker.rb +0 -29
- data/lib/pione/agent/tuple-space-server-client-life-checker.rb +0 -31
- data/lib/pione/command/child-process.rb +0 -56
- data/lib/pione/command/daemon-process.rb +0 -10
- data/lib/pione/command/front-owner-command.rb +0 -25
- data/lib/pione/component.rb +0 -13
- data/lib/pione/component/document.rb +0 -88
- data/lib/pione/component/package-archiver.rb +0 -92
- data/lib/pione/component/package-filename.rb +0 -38
- data/lib/pione/component/package-reader.rb +0 -276
- data/lib/pione/component/package.rb +0 -199
- data/lib/pione/component/rule.rb +0 -206
- data/lib/pione/front/task-worker-owner.rb +0 -43
- data/lib/pione/front/tuple-space-provider-owner.rb +0 -11
- data/lib/pione/model.rb +0 -32
- data/lib/pione/model/assignment.rb +0 -120
- data/lib/pione/model/basic-model.rb +0 -228
- data/lib/pione/model/block.rb +0 -262
- data/lib/pione/model/boolean.rb +0 -168
- data/lib/pione/model/call-rule.rb +0 -86
- data/lib/pione/model/constraints.rb +0 -46
- data/lib/pione/model/data-expr.rb +0 -548
- data/lib/pione/model/feature-expr.rb +0 -875
- data/lib/pione/model/float.rb +0 -105
- data/lib/pione/model/integer.rb +0 -166
- data/lib/pione/model/keyed-sequence.rb +0 -150
- data/lib/pione/model/message.rb +0 -95
- data/lib/pione/model/ordinal-sequence.rb +0 -73
- data/lib/pione/model/package-expr.rb +0 -53
- data/lib/pione/model/parameters.rb +0 -374
- data/lib/pione/model/rule-expr.rb +0 -234
- data/lib/pione/model/sequence.rb +0 -273
- data/lib/pione/model/string.rb +0 -127
- data/lib/pione/model/ticket-expr.rb +0 -71
- data/lib/pione/model/variable-table.rb +0 -344
- data/lib/pione/model/variable.rb +0 -116
- data/lib/pione/parser.rb +0 -14
- data/lib/pione/parser/block-parser.rb +0 -107
- data/lib/pione/parser/common-parser.rb +0 -173
- data/lib/pione/parser/document-parser.rb +0 -141
- data/lib/pione/parser/expr-parser.rb +0 -354
- data/lib/pione/parser/feature-expr-parser.rb +0 -105
- data/lib/pione/parser/flow-element-parser.rb +0 -181
- data/lib/pione/parser/literal-parser.rb +0 -196
- data/lib/pione/parser/rule-definition-parser.rb +0 -158
- data/lib/pione/patch/monitor-patch.rb +0 -16
- data/lib/pione/rule-handler.rb +0 -14
- data/lib/pione/rule-handler/basic-handler.rb +0 -326
- data/lib/pione/rule-handler/flow-handler.rb +0 -414
- data/lib/pione/rule-handler/update-criteria.rb +0 -175
- data/lib/pione/system/global.rb +0 -433
- data/lib/pione/transformer.rb +0 -24
- data/lib/pione/transformer/block-transformer.rb +0 -28
- data/lib/pione/transformer/document-transformer.rb +0 -58
- data/lib/pione/transformer/feature-expr-transformer.rb +0 -60
- data/lib/pione/transformer/flow-element-transformer.rb +0 -66
- data/lib/pione/transformer/literal-transformer.rb +0 -91
- data/lib/pione/transformer/rule-definition-transformer.rb +0 -80
- data/lib/pione/transformer/transformer-module.rb +0 -39
- data/lib/pione/tuple-space/data-finder.rb +0 -155
- data/lib/pione/tuple-space/presence-notifier.rb +0 -84
- data/lib/pione/tuple-space/tuple-space-provider.rb +0 -85
- data/lib/pione/tuple-space/tuple-space-receiver.rb +0 -141
- data/lib/pione/tuple-space/tuple-space-server-interface.rb +0 -123
- data/lib/pione/tuple.rb +0 -30
- data/lib/pione/tuple/agent-tuple.rb +0 -10
- data/lib/pione/tuple/attribute-tuple.rb +0 -7
- data/lib/pione/tuple/base-location-tuple.rb +0 -9
- data/lib/pione/tuple/bye-tuple.rb +0 -9
- data/lib/pione/tuple/command-tuple.rb +0 -9
- data/lib/pione/tuple/data-null-tuple.rb +0 -14
- data/lib/pione/tuple/data-tuple.rb +0 -21
- data/lib/pione/tuple/dry-run-tuple.rb +0 -8
- data/lib/pione/tuple/exception-tuple.rb +0 -11
- data/lib/pione/tuple/finished-tuple.rb +0 -17
- data/lib/pione/tuple/foreground-tuple.rb +0 -7
- data/lib/pione/tuple/lift-tuple.rb +0 -14
- data/lib/pione/tuple/message-tuple.rb +0 -7
- data/lib/pione/tuple/process-info-tuple.rb +0 -9
- data/lib/pione/tuple/process-log-tuple.rb +0 -13
- data/lib/pione/tuple/request-rule-tuple.rb +0 -9
- data/lib/pione/tuple/rule-tuple.rb +0 -10
- data/lib/pione/tuple/task-tuple.rb +0 -40
- data/lib/pione/tuple/task-worker-resource-tuple.rb +0 -9
- data/lib/pione/tuple/ticket-tuple.rb +0 -8
- data/lib/pione/tuple/touch-tuple.rb +0 -14
- data/lib/pione/tuple/working-tuple.rb +0 -13
- data/lib/pione/uri-scheme.rb +0 -11
- data/lib/pione/util/error-report.rb +0 -27
- data/test/agent/spec_command-listener.rb +0 -30
- data/test/agent/spec_rule-provider.rb +0 -78
- data/test/command/spec_pione-val.domain.dump +0 -0
- data/test/component/spec_document.rb +0 -67
- data/test/component/spec_package-archiver.rb +0 -27
- data/test/component/spec_package-expander.rb +0 -11
- data/test/component/spec_package-filename.rb +0 -79
- data/test/component/spec_package-reader.rb +0 -100
- data/test/component/spec_package.rb +0 -109
- data/test/component/spec_rule.rb +0 -140
- data/test/model/spec_assignment.rb +0 -52
- data/test/model/spec_block.rb +0 -108
- data/test/model/spec_boolean.rb +0 -39
- data/test/model/spec_boolean.yml +0 -134
- data/test/model/spec_call-rule.rb +0 -23
- data/test/model/spec_data-expr.rb +0 -361
- data/test/model/spec_data-expr.yml +0 -24
- data/test/model/spec_data-expr_match.yml +0 -45
- data/test/model/spec_feature-expr.rb +0 -333
- data/test/model/spec_feature-expr_decide.yml +0 -28
- data/test/model/spec_float.rb +0 -23
- data/test/model/spec_float.yml +0 -30
- data/test/model/spec_integer.rb +0 -23
- data/test/model/spec_integer.yml +0 -68
- data/test/model/spec_keyed-sequence.rb +0 -5
- data/test/model/spec_keyed-sequence.yml +0 -27
- data/test/model/spec_message.rb +0 -40
- data/test/model/spec_package-expr.rb +0 -19
- data/test/model/spec_parameters.rb +0 -103
- data/test/model/spec_pione-method.rb +0 -57
- data/test/model/spec_rule-expr.rb +0 -28
- data/test/model/spec_rule-expr.yml +0 -11
- data/test/model/spec_sequence.rb +0 -5
- data/test/model/spec_sequence.yml +0 -66
- data/test/model/spec_string.rb +0 -47
- data/test/model/spec_string.yml +0 -91
- data/test/model/spec_ticket-expr.rb +0 -39
- data/test/model/spec_variable-table.rb +0 -116
- data/test/model/spec_variable.rb +0 -82
- data/test/parser/spec_block-parser.rb +0 -5
- data/test/parser/spec_block-parser.yml +0 -94
- data/test/parser/spec_document-parser.rb +0 -5
- data/test/parser/spec_document-parser.yml +0 -77
- data/test/parser/spec_expr-parser.rb +0 -6
- data/test/parser/spec_feature-expr-parser.rb +0 -32
- data/test/parser/spec_feature-expr-parser.yml +0 -25
- data/test/parser/spec_flow-element-parser.rb +0 -5
- data/test/parser/spec_literal-parser.rb +0 -5
- data/test/parser/spec_literal-parser.yml +0 -134
- data/test/parser/spec_rule-definition-parser.rb +0 -5
- data/test/parser/spec_rule-definition-parser.yml +0 -94
- data/test/rule-handler/spec_action-handler.rb +0 -79
- data/test/rule-handler/spec_flow-handler.rb +0 -61
- data/test/spec_common.rb +0 -14
- data/test/spec_object.rb +0 -20
- data/test/test-data/package/HelloWorld+v0.1.0.ppg +0 -0
- data/test/test-data/package/HelloWorld-gitrepos.zip +0 -0
- data/test/test-data/package/HelloWorld/package.yml +0 -6
- data/test/test-util.rb +0 -211
- data/test/test-util/command.rb +0 -53
- data/test/test-util/package.rb +0 -9
- data/test/test-util/parser.rb +0 -45
- data/test/test-util/transformer.rb +0 -50
- data/test/test-util/webserver.rb +0 -43
- data/test/transformer/spec_block-transformer.rb +0 -33
- data/test/transformer/spec_document-transformer.rb +0 -50
- data/test/transformer/spec_expr-transformer.rb +0 -126
- data/test/transformer/spec_feature-expr-transformer.rb +0 -21
- data/test/transformer/spec_flow-element-transformer.rb +0 -154
- data/test/transformer/spec_literal-transformer.rb +0 -64
- data/test/transformer/spec_rule-definition-transformer.rb +0 -172
- data/test/tuple-space/spec_data-finder.rb +0 -94
- data/test/tuple-space/spec_tuple-space-provider.rb +0 -36
- data/test/tuple-space/spec_tuple-space-receiver.rb +0 -32
- data/test/util/spec_error-report.rb +0 -51
@@ -1,875 +0,0 @@
|
|
1
|
-
# -*- coding: utf-8 -*-
|
2
|
-
|
3
|
-
module Pione::Model
|
4
|
-
# Feature is selection system between task and task worker.
|
5
|
-
module Feature
|
6
|
-
class << self
|
7
|
-
# Return feature conjunction.
|
8
|
-
#
|
9
|
-
# @param exprs [Array<Expr>]
|
10
|
-
# feature expression list
|
11
|
-
# @return [Expr]
|
12
|
-
# conjuncted expression
|
13
|
-
#
|
14
|
-
# @example
|
15
|
-
# x = RequisiteExpr.new("X")
|
16
|
-
# y = RequisiteExpr.new("Y")
|
17
|
-
# Feature.and(x, y) #=> +X & +Y
|
18
|
-
def and(*exprs)
|
19
|
-
AndExpr.new(*exprs)
|
20
|
-
end
|
21
|
-
|
22
|
-
# Return feature disjunction.
|
23
|
-
#
|
24
|
-
# @param exprs [Array<Expr>]
|
25
|
-
# feature expression list
|
26
|
-
# @return [Expr]
|
27
|
-
# disjuncted expression
|
28
|
-
#
|
29
|
-
# @example
|
30
|
-
# x = RequisiteExpr.new("X")
|
31
|
-
# y = RequisiteExpr.new("Y")
|
32
|
-
# Feature.or(x, y) #=> +X | +Y
|
33
|
-
def or(*exprs)
|
34
|
-
OrExpr.new(*exprs)
|
35
|
-
end
|
36
|
-
|
37
|
-
# Return empty feature.
|
38
|
-
#
|
39
|
-
# @return [Expr]
|
40
|
-
# empty feature
|
41
|
-
def empty
|
42
|
-
empty ||= EmptyFeature.new
|
43
|
-
end
|
44
|
-
|
45
|
-
# Return boundless feature.
|
46
|
-
#
|
47
|
-
# @return [Expr]
|
48
|
-
# boundless feature
|
49
|
-
def boundless
|
50
|
-
boundless ||= BoundlessFeature.new
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
# Expr is a super class for all feature expressions.
|
55
|
-
class Expr < Callable
|
56
|
-
set_pione_model_type TypeFeature
|
57
|
-
|
58
|
-
# Return simplified expression.
|
59
|
-
#
|
60
|
-
# @return [Expr]
|
61
|
-
# simplified expression
|
62
|
-
def simplify
|
63
|
-
return self
|
64
|
-
end
|
65
|
-
|
66
|
-
# Return true if the feature is empty.
|
67
|
-
#
|
68
|
-
# @return [Boolean]
|
69
|
-
# true if the feature is empty
|
70
|
-
def empty?
|
71
|
-
return false
|
72
|
-
end
|
73
|
-
|
74
|
-
# Return true if the other matches the feature.
|
75
|
-
#
|
76
|
-
# @return [Boolean]
|
77
|
-
# true if the other matches the feature
|
78
|
-
def match(other)
|
79
|
-
raise ArgumentError.new(other) unless other.kind_of?(Expr)
|
80
|
-
Sentence.new(self, other).decide
|
81
|
-
end
|
82
|
-
alias :=== :match
|
83
|
-
end
|
84
|
-
|
85
|
-
# SpecialFeature is a class for empty feature and boundless feature.
|
86
|
-
class SpecialFeature < Expr
|
87
|
-
# @api private
|
88
|
-
def textize
|
89
|
-
symbol
|
90
|
-
end
|
91
|
-
|
92
|
-
# @api private
|
93
|
-
def ==(other)
|
94
|
-
other.kind_of?(self.class)
|
95
|
-
end
|
96
|
-
alias :eql? :==
|
97
|
-
|
98
|
-
# @api private
|
99
|
-
def hash
|
100
|
-
true.hash
|
101
|
-
end
|
102
|
-
end
|
103
|
-
|
104
|
-
# EmptyFeature is a class for empty feature that is one of special
|
105
|
-
# features. This is written as '*', that means the worker has no specific
|
106
|
-
# ability in provider expression and the task has no specific request in
|
107
|
-
# request expression.
|
108
|
-
class EmptyFeature < SpecialFeature
|
109
|
-
# Return the symbol of empty feature.
|
110
|
-
#
|
111
|
-
# return [String]
|
112
|
-
# "*"
|
113
|
-
def symbol
|
114
|
-
"*"
|
115
|
-
end
|
116
|
-
|
117
|
-
# Return true because empty feature is empty.
|
118
|
-
#
|
119
|
-
# @return [Boolean]
|
120
|
-
# true
|
121
|
-
def empty?
|
122
|
-
true
|
123
|
-
end
|
124
|
-
|
125
|
-
# @api private
|
126
|
-
def ==(other)
|
127
|
-
return false unless other.kind_of?(Expr)
|
128
|
-
other.empty?
|
129
|
-
end
|
130
|
-
end
|
131
|
-
|
132
|
-
# BoundlessFeature is a class for whole feature that is one of special
|
133
|
-
# features. This is written as '@', that means the worker has boundless
|
134
|
-
# ability in provider expression and the task has boundless ability request
|
135
|
-
# in request expression.
|
136
|
-
class BoundlessFeature < SpecialFeature
|
137
|
-
# Return the symbol of bundless feature.
|
138
|
-
#
|
139
|
-
# return [String]
|
140
|
-
# "@"
|
141
|
-
def symbol
|
142
|
-
"@"
|
143
|
-
end
|
144
|
-
|
145
|
-
# @api private
|
146
|
-
def ==(other)
|
147
|
-
other.kind_of?(BoundlessFeature)
|
148
|
-
end
|
149
|
-
end
|
150
|
-
|
151
|
-
# Operator is superclass of all operator classes.
|
152
|
-
class Operator < Expr; end
|
153
|
-
|
154
|
-
# UnaryOperator is a class for provider opeators and request operator.
|
155
|
-
class UnaryOperator < Operator
|
156
|
-
attr_reader :symbol
|
157
|
-
|
158
|
-
# Return the operator symbol.
|
159
|
-
#
|
160
|
-
# @return [String]
|
161
|
-
# operator symbol
|
162
|
-
# @example
|
163
|
-
# # requisite feature
|
164
|
-
# +
|
165
|
-
# @example
|
166
|
-
# # blocking feature
|
167
|
-
# -
|
168
|
-
# @example
|
169
|
-
# # preferred feature
|
170
|
-
# ?
|
171
|
-
# @example
|
172
|
-
# # possible operator
|
173
|
-
# ^
|
174
|
-
# @example
|
175
|
-
# # restrictive opeator
|
176
|
-
# !
|
177
|
-
def self.operator
|
178
|
-
@operator
|
179
|
-
end
|
180
|
-
|
181
|
-
# Create a new operator.
|
182
|
-
#
|
183
|
-
# @param [Symbol] symbol
|
184
|
-
# feature symbol
|
185
|
-
def initialize(symbol)
|
186
|
-
@symbol = symbol
|
187
|
-
super()
|
188
|
-
end
|
189
|
-
|
190
|
-
# @api private
|
191
|
-
def textize
|
192
|
-
"%s%s" % [self.operator, @symbol]
|
193
|
-
end
|
194
|
-
|
195
|
-
# @api private
|
196
|
-
def as_string
|
197
|
-
self.class.operator + @symbol.to_s
|
198
|
-
end
|
199
|
-
|
200
|
-
# @api private
|
201
|
-
def ==(other)
|
202
|
-
other.kind_of?(self.class) and @symbol == other.symbol
|
203
|
-
end
|
204
|
-
alias :eql? :==
|
205
|
-
|
206
|
-
# @api private
|
207
|
-
def hash
|
208
|
-
@symbol.hash
|
209
|
-
end
|
210
|
-
end
|
211
|
-
|
212
|
-
# ProviderOperator is a class for provider operators.
|
213
|
-
class ProviderExpr < UnaryOperator; end
|
214
|
-
|
215
|
-
# PossibleOperator is a class for possible feature expressions. Possible
|
216
|
-
# feature are written like as "^X", these represent feature's possible
|
217
|
-
# ability.
|
218
|
-
class PossibleExpr < ProviderExpr
|
219
|
-
@operator = "^"
|
220
|
-
end
|
221
|
-
|
222
|
-
# RestrictiveExpr is a class for restrictive feature expression.
|
223
|
-
#
|
224
|
-
# @example
|
225
|
-
# !X
|
226
|
-
class RestrictiveExpr < ProviderExpr
|
227
|
-
@operator = "!"
|
228
|
-
end
|
229
|
-
|
230
|
-
# RequestOperator is a class for task's feature expression operators.
|
231
|
-
class RequestExpr < UnaryOperator; end
|
232
|
-
|
233
|
-
# Requisite Operator is a class for requisite feature expressions. Requisite
|
234
|
-
# Feature are written like as "+X", these represent feature's requiste
|
235
|
-
# ability.
|
236
|
-
#
|
237
|
-
# @example
|
238
|
-
# +X
|
239
|
-
class RequisiteExpr < RequestExpr
|
240
|
-
@operator = "+"
|
241
|
-
end
|
242
|
-
|
243
|
-
# BlockingExpr is a class for blocking feature expressions. Blocking Feature
|
244
|
-
# are written like as "-X", these represent the ability that block to
|
245
|
-
# execute the task.
|
246
|
-
#
|
247
|
-
# @example
|
248
|
-
# BlockingExpr.new("X") #=> -X
|
249
|
-
class BlockingExpr < RequestExpr
|
250
|
-
@operator = "-"
|
251
|
-
end
|
252
|
-
|
253
|
-
# PreferredExpr is a class for preferred feature expressions. Preferred
|
254
|
-
# Feature are written like as "?X", these represent that task workers what
|
255
|
-
# the feature have take the task.
|
256
|
-
#
|
257
|
-
# @example
|
258
|
-
# PreferredExpr.new("X") #=> ?X
|
259
|
-
class PreferredExpr < RequestExpr
|
260
|
-
@operator = "?"
|
261
|
-
end
|
262
|
-
|
263
|
-
# Connective is a superclass of AndExpr and OrExpr. This represents
|
264
|
-
# connection of feature expressions.
|
265
|
-
class Connective < Expr
|
266
|
-
# @return [Set]
|
267
|
-
# feature expressions included in the connective
|
268
|
-
attr_reader :elements
|
269
|
-
|
270
|
-
# Create a new connective.
|
271
|
-
#
|
272
|
-
# @param elements [Array<Expr>]
|
273
|
-
# feature expressions
|
274
|
-
def initialize(*elements)
|
275
|
-
@elements = Set.new
|
276
|
-
elements.each {|elt| add(elt) }
|
277
|
-
super()
|
278
|
-
end
|
279
|
-
|
280
|
-
# Add the feature expression as elements of the connective and unify it.
|
281
|
-
#
|
282
|
-
# @param expr [Expr]
|
283
|
-
# feature element
|
284
|
-
# @return [void]
|
285
|
-
#
|
286
|
-
# @example AND expression
|
287
|
-
# x = RequisiteExpr.new("X")
|
288
|
-
# y = RequisiteExpr.new("Y")
|
289
|
-
# AndExpr.new(x).add(y) #=> +X & +Y
|
290
|
-
# @example OR expression
|
291
|
-
# x = RequisiteExpr.new("X")
|
292
|
-
# y = RequisiteExpr.new("Y")
|
293
|
-
# OrExpr.new(x, y).add(x) #=> +X | +Y
|
294
|
-
def add(expr)
|
295
|
-
if expr.kind_of?(self.class)
|
296
|
-
expr.elements.each {|e| unify(e) }
|
297
|
-
else
|
298
|
-
unify(expr)
|
299
|
-
end
|
300
|
-
end
|
301
|
-
|
302
|
-
# Delete the element from the connective set.
|
303
|
-
#
|
304
|
-
# @param elt [Expr]
|
305
|
-
# feature element
|
306
|
-
# @return [void]
|
307
|
-
def delete(elt)
|
308
|
-
@elements.delete(elt)
|
309
|
-
if @elements.empty?
|
310
|
-
@elements.add(EmptyFeature.new)
|
311
|
-
end
|
312
|
-
end
|
313
|
-
|
314
|
-
# Unify connective set by the element.
|
315
|
-
#
|
316
|
-
# @param [Expr] elt
|
317
|
-
# feature element
|
318
|
-
# @return [void]
|
319
|
-
def unify(elt)
|
320
|
-
unless self.class::UNIFICATIONS.any?{|name| __send__(name, elt)}
|
321
|
-
@elements.add(elt)
|
322
|
-
end
|
323
|
-
end
|
324
|
-
|
325
|
-
# Simplify the connective by unifing and up-rising single element.
|
326
|
-
#
|
327
|
-
# @return [Expr]
|
328
|
-
# simplified feature
|
329
|
-
#
|
330
|
-
# @example
|
331
|
-
# AndExpr.new(RequisiteExpr.new("X")).simplify #=> +X
|
332
|
-
def simplify
|
333
|
-
if @elements.size == 1
|
334
|
-
return @elements.first.simplify
|
335
|
-
else
|
336
|
-
elements = @elements.map{|e| e.simplify}
|
337
|
-
@elements.clear
|
338
|
-
elements.each {|e| add(e)}
|
339
|
-
return self
|
340
|
-
end
|
341
|
-
end
|
342
|
-
|
343
|
-
# Return true if the connective set is empty.
|
344
|
-
#
|
345
|
-
# @return [Boolean]
|
346
|
-
# true if the connective set is empty
|
347
|
-
def empty?
|
348
|
-
return true if @elements.empty?
|
349
|
-
return true if @elements == Set.new([Feature.empty])
|
350
|
-
return false unless @elements.size == 1
|
351
|
-
return @elements.first.empty?
|
352
|
-
end
|
353
|
-
|
354
|
-
# @api private
|
355
|
-
def textize
|
356
|
-
"#{self.class.name}(%s)" % @elements.map{|elt| elt.textize}.join(",")
|
357
|
-
end
|
358
|
-
|
359
|
-
# @api private
|
360
|
-
def ==(other)
|
361
|
-
return true if empty? and other.kind_of?(Expr) and other.empty?
|
362
|
-
other.kind_of?(self.class) and @elements == other.elements
|
363
|
-
end
|
364
|
-
alias :eql? :"=="
|
365
|
-
|
366
|
-
# @api private
|
367
|
-
def hash
|
368
|
-
@elements.hash
|
369
|
-
end
|
370
|
-
|
371
|
-
# Clone with cloning the elements set.
|
372
|
-
#
|
373
|
-
# @api private
|
374
|
-
def clone
|
375
|
-
obj = super
|
376
|
-
elements = @elements.clone
|
377
|
-
obj.instance_eval { @elements = elements }
|
378
|
-
return obj
|
379
|
-
end
|
380
|
-
end
|
381
|
-
|
382
|
-
# AndExpr represents conjunction of feature expressions.
|
383
|
-
#
|
384
|
-
# @example
|
385
|
-
# AndExpr.new(RequisiteExpr.new("X"), RequisiteExpr.new("Y")) #=> +X & +Y
|
386
|
-
class AndExpr < Connective
|
387
|
-
UNIFICATIONS =
|
388
|
-
[ :unify_redundant_feature,
|
389
|
-
:summarize_or,
|
390
|
-
:background_preferred_feature,
|
391
|
-
:unify_by_restrictive_feature
|
392
|
-
]
|
393
|
-
|
394
|
-
module UnificationMethod
|
395
|
-
# Unify redundant feature. This unification rule is described as
|
396
|
-
# follows:
|
397
|
-
#
|
398
|
-
# - Γ & Γ -> Γ
|
399
|
-
# - Δ & Δ -> Δ
|
400
|
-
#
|
401
|
-
# @param expr [Expr]
|
402
|
-
# feature expression
|
403
|
-
#
|
404
|
-
# @example
|
405
|
-
# x = RequisiteExpr.new("X")
|
406
|
-
# y = RequisiteExpr.new("Y")
|
407
|
-
# AndExpr.new(x,y).unify_redundant_feature(x) #=> true
|
408
|
-
def unify_redundant_feature(expr)
|
409
|
-
return @elements.include?(expr)
|
410
|
-
end
|
411
|
-
|
412
|
-
def summarize_or(elt)
|
413
|
-
if elt.kind_of?(OrExpr)
|
414
|
-
if target = @elements.find {|e|
|
415
|
-
if e.kind_of?(OrExpr)
|
416
|
-
not((e.elements & elt.elements).empty?)
|
417
|
-
end
|
418
|
-
}
|
419
|
-
# (Γ1 | Γ2) & (Γ1 | Γ3) -> Γ1 | (Γ2 & Γ3)
|
420
|
-
@elements.delete(target)
|
421
|
-
union = target.elements & elt.elements
|
422
|
-
union_expr = if union.length > 1
|
423
|
-
OrExpr.new(*union.to_a)
|
424
|
-
else
|
425
|
-
union.to_a.first
|
426
|
-
end
|
427
|
-
add(
|
428
|
-
OrExpr.new(
|
429
|
-
union_expr,
|
430
|
-
AndExpr.new(
|
431
|
-
OrExpr.new(*(target.elements - union).to_a),
|
432
|
-
OrExpr.new(*(elt.elements - union).to_a)
|
433
|
-
)
|
434
|
-
)
|
435
|
-
)
|
436
|
-
return true
|
437
|
-
else
|
438
|
-
# Γ1 & (Γ1 | Γ3) -> Γ1
|
439
|
-
return not((@elements & elt.elements).empty?)
|
440
|
-
end
|
441
|
-
else
|
442
|
-
# (Γ1 | Γ2) & Γ1 -> Γ1
|
443
|
-
if @elements.reject!{|e| e == elt }
|
444
|
-
add(elt)
|
445
|
-
return true
|
446
|
-
end
|
447
|
-
end
|
448
|
-
return false
|
449
|
-
end
|
450
|
-
|
451
|
-
def background_preferred_feature(elt)
|
452
|
-
case elt
|
453
|
-
when PreferredExpr
|
454
|
-
# !X & ?X -> !X
|
455
|
-
# ^X & ?X -> ^X
|
456
|
-
return @elements.any? {|e|
|
457
|
-
e.symbol == elt.symbol &&
|
458
|
-
(e.kind_of?(RequisiteExpr) || e.kind_of?(BlockingExpr))
|
459
|
-
}
|
460
|
-
when RequisiteExpr, BlockingExpr
|
461
|
-
# ?X & !X -> !X
|
462
|
-
# ?X & ^X -> ^X
|
463
|
-
if @elements.reject! {|e|
|
464
|
-
if e.kind_of?(PreferredExpr)
|
465
|
-
e.symbol == elt.symbol
|
466
|
-
end
|
467
|
-
}
|
468
|
-
add(elt)
|
469
|
-
return true
|
470
|
-
end
|
471
|
-
end
|
472
|
-
return false
|
473
|
-
end
|
474
|
-
|
475
|
-
def unify_by_restrictive_feature(elt)
|
476
|
-
case elt
|
477
|
-
when RestrictiveExpr
|
478
|
-
# ^X & !X -> !X
|
479
|
-
if @elements.reject! {|e|
|
480
|
-
if e.kind_of?(PossibleExpr)
|
481
|
-
e.symbol == elt.symbol
|
482
|
-
end
|
483
|
-
}
|
484
|
-
add(elt)
|
485
|
-
return true
|
486
|
-
end
|
487
|
-
when PossibleExpr
|
488
|
-
# !X & ^X -> !X
|
489
|
-
return @elements.any? {|e|
|
490
|
-
if e.kind_of?(RestrictiveExpr)
|
491
|
-
e.symbol == elt.symbol
|
492
|
-
end
|
493
|
-
}
|
494
|
-
end
|
495
|
-
return false
|
496
|
-
end
|
497
|
-
end
|
498
|
-
|
499
|
-
include UnificationMethod
|
500
|
-
|
501
|
-
# Make an expander for response test.
|
502
|
-
def expander
|
503
|
-
# convert or-clause into expander
|
504
|
-
elements = @elements.map do |elt|
|
505
|
-
elt.kind_of?(OrExpr) ? elt.expander : elt
|
506
|
-
end
|
507
|
-
# return an enumerator
|
508
|
-
return Enumerator.new {|y| choose_concrete_expr(y, elements, [], nil, 0) }
|
509
|
-
end
|
510
|
-
|
511
|
-
private
|
512
|
-
|
513
|
-
require 'fiber'
|
514
|
-
|
515
|
-
# Choose a concrete expression that expand or-clause.
|
516
|
-
def choose_concrete_expr(y, orig, list, fiber, i)
|
517
|
-
if orig.size == i
|
518
|
-
# when reach the terminateion of elements, yield a concrete expression
|
519
|
-
y << AndExpr.new(*convert_cons_list_into_array(list))
|
520
|
-
else
|
521
|
-
# or-clause
|
522
|
-
if orig[i].kind_of?(Enumerator)
|
523
|
-
# create a new fiber
|
524
|
-
_fiber = Fiber.new do
|
525
|
-
loop do
|
526
|
-
# rewind unreached enumerators
|
527
|
-
orig.each_with_index do |e, ii|
|
528
|
-
e.rewind if ii > i && e.kind_of?(Enumerator)
|
529
|
-
end
|
530
|
-
# choose next
|
531
|
-
choose_concrete_expr(y, orig, [orig[i].next, list], _fiber, i+1)
|
532
|
-
# retrun fiber loop
|
533
|
-
Fiber.yield
|
534
|
-
end
|
535
|
-
end
|
536
|
-
# fiber loop
|
537
|
-
begin
|
538
|
-
_fiber.transfer while true
|
539
|
-
rescue FiberError => e
|
540
|
-
fiber.transfer if fiber
|
541
|
-
end
|
542
|
-
else
|
543
|
-
# other elements
|
544
|
-
choose_concrete_expr(y, orig, [orig[i], list], fiber, i+1)
|
545
|
-
end
|
546
|
-
end
|
547
|
-
end
|
548
|
-
|
549
|
-
# Returns an array by converting from cons list.
|
550
|
-
def convert_cons_list_into_array(input)
|
551
|
-
input == [] ? [] : convert_cons_list_into_array(input[1]) << input.first
|
552
|
-
end
|
553
|
-
end
|
554
|
-
|
555
|
-
# OrExpr represents disjunction of feature expressions.
|
556
|
-
#
|
557
|
-
# @example
|
558
|
-
# OrExpr.new(RequisiteExpr.new("X"), RequisiteExpr.new("Y")) #=> +X | +Y
|
559
|
-
class OrExpr < Connective
|
560
|
-
# unification list
|
561
|
-
UNIFICATIONS =
|
562
|
-
[ :unify_redundant_feature,
|
563
|
-
:summarize_and,
|
564
|
-
:foreground_preferred_feature,
|
565
|
-
:unify_by_possible_feature,
|
566
|
-
:neutralize
|
567
|
-
]
|
568
|
-
|
569
|
-
# OrExpr's unification methods.
|
570
|
-
module UnificationMethod
|
571
|
-
# Return true if elements include the feature. This unification rule is
|
572
|
-
# described as follows:
|
573
|
-
#
|
574
|
-
# - Γ | Γ -> Γ
|
575
|
-
# - Δ | Δ -> Δ
|
576
|
-
#
|
577
|
-
# @param expr [Expr]
|
578
|
-
# feature expression
|
579
|
-
#
|
580
|
-
# @example
|
581
|
-
# x = RequisiteExpr.new("X")
|
582
|
-
# y = RequisiteExpr.new("Y")
|
583
|
-
# OrExpr.new(x, y).unify_redundant_feature(x) #=> true
|
584
|
-
def unify_redundant_feature(expr)
|
585
|
-
return @elements.include?(expr)
|
586
|
-
end
|
587
|
-
|
588
|
-
# Return true if the expression is summarized by AND connective. This
|
589
|
-
# rule is described as follows:
|
590
|
-
#
|
591
|
-
# - (Γ1 & Γ2) | (Γ1 & Γ3) -> Γ1 & (Γ2 | Γ3)
|
592
|
-
# - Γ1 | (Γ1 & Γ3) -> Γ1
|
593
|
-
# - (Γ1 & Γ2) | Γ1 -> Γ1
|
594
|
-
def summarize_and(elt)
|
595
|
-
if elt.kind_of?(AndExpr)
|
596
|
-
# (Γ1 & Γ2) | (Γ1 & Γ3) -> Γ1 & (Γ2 | Γ3)
|
597
|
-
if target = @elements.find {|e|
|
598
|
-
e.kind_of?(AndExpr) && not((e.elements & elt.elements).empty?)
|
599
|
-
}
|
600
|
-
@elements.delete(target)
|
601
|
-
union = target.elements & elt.elements
|
602
|
-
union_expr = if union.length > 1
|
603
|
-
AndExpr.new(*union.to_a)
|
604
|
-
else
|
605
|
-
union.to_a.first
|
606
|
-
end
|
607
|
-
add(AndExpr.new(union_expr,
|
608
|
-
OrExpr.new(AndExpr.new(*(target.elements - union).to_a),
|
609
|
-
AndExpr.new(*(elt.elements - union).to_a))))
|
610
|
-
return true
|
611
|
-
else
|
612
|
-
# Γ1 | (Γ1 & Γ3) -> Γ1
|
613
|
-
# return not((@elements & elt.elements).empty?)
|
614
|
-
end
|
615
|
-
else
|
616
|
-
# (Γ1 & Γ2) | Γ1 -> Γ1
|
617
|
-
# if @elements.reject!{|e| e == elt }
|
618
|
-
# add(elt)
|
619
|
-
# return true
|
620
|
-
# end
|
621
|
-
end
|
622
|
-
return false
|
623
|
-
end
|
624
|
-
|
625
|
-
def foreground_preferred_feature(elt)
|
626
|
-
case elt
|
627
|
-
when PreferredExpr
|
628
|
-
# !X | ?X -> ?X
|
629
|
-
# ^X | ?X -> ?X
|
630
|
-
if @elements.reject! {|e|
|
631
|
-
e.symbol == elt.symbol &&
|
632
|
-
(e.kind_of?(RequisiteExpr) || e.kind_of?(BlockingExpr))
|
633
|
-
}
|
634
|
-
add(elt)
|
635
|
-
return true
|
636
|
-
end
|
637
|
-
when RequisiteExpr, BlockingExpr
|
638
|
-
# ?X | !X -> ?X
|
639
|
-
# ?X | ^X -> ?X
|
640
|
-
return @elements.any? {|e|
|
641
|
-
e.symbol == elt.symbol && e.kind_of?(PreferredExpr)
|
642
|
-
}
|
643
|
-
end
|
644
|
-
return false
|
645
|
-
end
|
646
|
-
|
647
|
-
def unify_by_possible_feature(elt)
|
648
|
-
case elt
|
649
|
-
when PossibleExpr
|
650
|
-
# !X | ^X -> ^X
|
651
|
-
if @elements.reject! {|e|
|
652
|
-
e.symbol == elt.symbol && e.kind_of?(RestrictiveExpr)
|
653
|
-
}
|
654
|
-
add(elt)
|
655
|
-
return true
|
656
|
-
end
|
657
|
-
when RestrictiveExpr
|
658
|
-
# ^X | !X -> ^X
|
659
|
-
return @elements.any? {|e|
|
660
|
-
e.symbol == elt.symbol && e.kind_of?(PossibleExpr)
|
661
|
-
}
|
662
|
-
end
|
663
|
-
return false
|
664
|
-
end
|
665
|
-
|
666
|
-
def neutralize(elt)
|
667
|
-
case elt
|
668
|
-
when BlockingExpr
|
669
|
-
# +X | -X -> *
|
670
|
-
if @elements.reject!{|e|
|
671
|
-
e.symbol == elt.symbol && e.kind_of?(RequisiteExpr)
|
672
|
-
}
|
673
|
-
add(EmptyFeature.new)
|
674
|
-
return true
|
675
|
-
end
|
676
|
-
when RequisiteExpr
|
677
|
-
# -X | +X -> *
|
678
|
-
if @elements.reject!{|e|
|
679
|
-
e.symbol == elt.symbol && e.kind_of?(BlockingExpr)
|
680
|
-
}
|
681
|
-
add(EmptyFeature.new)
|
682
|
-
return true
|
683
|
-
end
|
684
|
-
end
|
685
|
-
return false
|
686
|
-
end
|
687
|
-
end
|
688
|
-
|
689
|
-
include UnificationMethod
|
690
|
-
|
691
|
-
# Make an expander for response test.
|
692
|
-
def expander
|
693
|
-
Enumerator.new do |y|
|
694
|
-
@elements.each do |elt|
|
695
|
-
elt.kind_of?(AndExpr) ? elt.expander.each {|e| y << e } : y << elt
|
696
|
-
end
|
697
|
-
end
|
698
|
-
end
|
699
|
-
end
|
700
|
-
|
701
|
-
class Sentence < Expr
|
702
|
-
ELIMINATIONS =
|
703
|
-
[ :eliminate_requisite_feature,
|
704
|
-
:eliminate_blocking_feature,
|
705
|
-
:eliminate_preferred_feature,
|
706
|
-
:eliminate_or_clause_including_empty_feature,
|
707
|
-
:eliminate_possible_feature
|
708
|
-
]
|
709
|
-
|
710
|
-
module EliminationMethod
|
711
|
-
def eliminate_requisite_feature(provider, request)
|
712
|
-
# (^X & Γ <- +X & Δ) -> Γ & Δ
|
713
|
-
# (!X & Γ <- +X & Δ) -> Γ & Δ
|
714
|
-
request.elements.each do |r|
|
715
|
-
next unless r.kind_of?(RequisiteExpr)
|
716
|
-
provider.elements.each do |p|
|
717
|
-
next unless p.symbol == r.symbol
|
718
|
-
next unless p.kind_of?(PossibleExpr) || p.kind_of?(RestrictiveExpr)
|
719
|
-
# eliminate only if Γ dosen't include same symbol feature
|
720
|
-
next if provider.elements.any? {|e|
|
721
|
-
p.symbol == e.symbol && not(e.kind_of?(p.class))
|
722
|
-
}
|
723
|
-
# eliminate only if Δ dosen't include same symbol feature
|
724
|
-
next if request.elements.any? {|e|
|
725
|
-
r.symbol == e.symbol && not(e.kind_of?(r.class))
|
726
|
-
}
|
727
|
-
# eliminate
|
728
|
-
_provider = provider.clone.tap{|x| x.delete(p)}
|
729
|
-
_request = request.clone.tap{|x| x.delete(r)}
|
730
|
-
return true, _provider, _request
|
731
|
-
end
|
732
|
-
end
|
733
|
-
return false
|
734
|
-
end
|
735
|
-
module_function :eliminate_requisite_feature
|
736
|
-
|
737
|
-
def eliminate_blocking_feature(provider, request)
|
738
|
-
# (Γ <- -X & Δ) -> Γ & Δ
|
739
|
-
request.elements.each do |r|
|
740
|
-
next unless r.kind_of?(BlockingExpr)
|
741
|
-
# eliminate only if Γ dosen't include same symbol feature
|
742
|
-
next if request.elements.any? {|e|
|
743
|
-
r.symbol == e.symbol && not(e.kind_of?(r.class))
|
744
|
-
}
|
745
|
-
# eliminate only if Δ dosen't include same symbol feature
|
746
|
-
next if provider.elements.any? {|e|
|
747
|
-
r.symbol == e.symbol && not(e.kind_of?(p.class))
|
748
|
-
}
|
749
|
-
# eliminate
|
750
|
-
_request = request.clone.tap{|x| x.delete(r)}
|
751
|
-
return true, provider, _request
|
752
|
-
end
|
753
|
-
return false
|
754
|
-
end
|
755
|
-
module_function :eliminate_blocking_feature
|
756
|
-
|
757
|
-
def eliminate_preferred_feature(provider, request)
|
758
|
-
# (Γ <- ?X & Δ) -> (Γ <- Δ)
|
759
|
-
if request.elements.any? {|e| e.kind_of?(PreferredExpr)}
|
760
|
-
_request = request.clone.tap do |x|
|
761
|
-
x.elements.reject! {|e| e.kind_of?(PreferredExpr)}
|
762
|
-
end
|
763
|
-
return true, provider, _request
|
764
|
-
end
|
765
|
-
return false
|
766
|
-
end
|
767
|
-
module_function :eliminate_preferred_feature
|
768
|
-
|
769
|
-
def eliminate_or_clause_including_empty_feature(provider, request)
|
770
|
-
# ((* | Γ1) & Γ2 <- *) -> (Γ2 <- *)
|
771
|
-
return false unless request.empty?
|
772
|
-
provider.elements.each do |elt|
|
773
|
-
next unless elt.kind_of?(OrExpr)
|
774
|
-
next unless elt.elements.include?(EmptyFeature.new)
|
775
|
-
_provider = provider.clone.tap{|x| x.delete(elt)}
|
776
|
-
return true, _provider, request
|
777
|
-
end
|
778
|
-
return false
|
779
|
-
end
|
780
|
-
module_function :eliminate_or_clause_including_empty_feature
|
781
|
-
|
782
|
-
def eliminate_possible_feature(provider, request)
|
783
|
-
# (^X & Γ <- Δ) -> (Γ <- Δ)
|
784
|
-
provider.elements.each do |p|
|
785
|
-
next unless p.kind_of?(PossibleExpr)
|
786
|
-
# eliminate only if Γ dosen't include same symbol feature
|
787
|
-
next if provider.elements.any? {|e|
|
788
|
-
p.symbol == e.symbol && not(e.kind_of?(p.class))
|
789
|
-
}
|
790
|
-
# eliminate only if Δ dosen't include same symbol feature
|
791
|
-
next if request.elements.any? {|e|
|
792
|
-
p.symbol == e.symbol && not(e.kind_of?(p.class))
|
793
|
-
}
|
794
|
-
# eliminate
|
795
|
-
_provider = provider.clone.tap{|x| x.delete(p)}
|
796
|
-
return true, _provider, request
|
797
|
-
end
|
798
|
-
return false
|
799
|
-
end
|
800
|
-
module_function :eliminate_possible_feature
|
801
|
-
end
|
802
|
-
|
803
|
-
include EliminationMethod
|
804
|
-
|
805
|
-
def initialize(provider, request)
|
806
|
-
@provider = AndExpr.new(provider.simplify)
|
807
|
-
@request = AndExpr.new(request.simplify)
|
808
|
-
super()
|
809
|
-
end
|
810
|
-
|
811
|
-
# Return true if the provider expression can respond to the request.
|
812
|
-
def decide
|
813
|
-
result = false
|
814
|
-
begin
|
815
|
-
@provider.expander.each do |provider|
|
816
|
-
@request.expander.each do |request|
|
817
|
-
if match(provider, request)
|
818
|
-
result = true
|
819
|
-
raise StopIteration
|
820
|
-
end
|
821
|
-
end
|
822
|
-
end
|
823
|
-
rescue StopIteration
|
824
|
-
end
|
825
|
-
return result
|
826
|
-
end
|
827
|
-
|
828
|
-
private
|
829
|
-
|
830
|
-
def match(provider, request)
|
831
|
-
_provider, _request = provider, request
|
832
|
-
ELIMINATIONS.each do |elim|
|
833
|
-
result, new_provider, new_request = __send__(elim, provider, request)
|
834
|
-
if result
|
835
|
-
_provider = new_provider
|
836
|
-
_request = new_request
|
837
|
-
break
|
838
|
-
end
|
839
|
-
end
|
840
|
-
if _provider.simplify.empty? && _request.simplify.empty?
|
841
|
-
return true
|
842
|
-
else
|
843
|
-
if provider == _provider and request == _request
|
844
|
-
return false
|
845
|
-
else
|
846
|
-
return match(_provider, _request)
|
847
|
-
end
|
848
|
-
end
|
849
|
-
end
|
850
|
-
end
|
851
|
-
|
852
|
-
# class FeatureSequence < Sequence
|
853
|
-
# set_pione_model_type TypeFeature
|
854
|
-
# set_element_class Feature::Expr
|
855
|
-
# end
|
856
|
-
end
|
857
|
-
|
858
|
-
TypeFeature.instance_eval do
|
859
|
-
define_pione_method("==", [TypeFeature], TypeBoolean) do |vtable, rec, other|
|
860
|
-
PioneBoolean.new(rec == other).to_seq
|
861
|
-
end
|
862
|
-
|
863
|
-
define_pione_method("!=", [TypeFeature], TypeBoolean) do |vtable, rec, other|
|
864
|
-
PioneBoolean.not(rec.call_pione_method(vtable, "==", other)).to_seq
|
865
|
-
end
|
866
|
-
|
867
|
-
define_pione_method("as_string", [], TypeString) do |vtable, rec|
|
868
|
-
PioneString.new(rec.as_string).to_seq
|
869
|
-
end
|
870
|
-
|
871
|
-
define_pione_method("str", [], TypeString) do |vtable, rec|
|
872
|
-
rec.call_pione_method(vtable, "as_string")
|
873
|
-
end
|
874
|
-
end
|
875
|
-
end
|