pione 0.2.2 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (593) hide show
  1. data/.gitignore +1 -0
  2. data/.simplecov +1 -0
  3. data/History.txt +9 -0
  4. data/Rakefile +1 -71
  5. data/example/Fib/Fib.pione +9 -8
  6. data/example/HelloWorld/HelloWorld.pione +2 -0
  7. data/example/HelloWorld/pione-package.json +15 -0
  8. data/example/HelloWorld/scenario/Scenario.pione +2 -0
  9. data/example/HelloWorld/scenario/pione-scenario.json +10 -0
  10. data/example/SerialProcessing/SerialProcessing.pione +2 -0
  11. data/example/SerialProcessing/pione-package.json +15 -0
  12. data/example/SerialProcessing/scenario/Scenario.pione +1 -0
  13. data/example/SerialProcessing/scenario/pione-scenario.json +10 -0
  14. data/lib/pione.rb +28 -35
  15. data/lib/pione/agent.rb +4 -4
  16. data/lib/pione/agent/agent-exception.rb +52 -0
  17. data/lib/pione/agent/basic-agent.rb +246 -239
  18. data/lib/pione/agent/broker.rb +232 -216
  19. data/lib/pione/agent/input-generator.rb +113 -133
  20. data/lib/pione/agent/job-terminator.rb +38 -0
  21. data/lib/pione/agent/logger.rb +24 -54
  22. data/lib/pione/agent/messenger.rb +11 -16
  23. data/lib/pione/agent/process-manager.rb +50 -19
  24. data/lib/pione/agent/task-worker.rb +126 -236
  25. data/lib/pione/agent/tuple-space-client.rb +16 -39
  26. data/lib/pione/agent/tuple-space-provider.rb +66 -0
  27. data/lib/pione/agent/tuple-space-receiver.rb +137 -0
  28. data/lib/pione/command.rb +2 -3
  29. data/lib/pione/command/basic-command.rb +347 -207
  30. data/lib/pione/command/command-exception.rb +38 -0
  31. data/lib/pione/command/option.rb +112 -104
  32. data/lib/pione/command/pione-broker.rb +85 -43
  33. data/lib/pione/command/pione-clean.rb +51 -8
  34. data/lib/pione/command/pione-client.rb +321 -292
  35. data/lib/pione/command/pione-log.rb +92 -53
  36. data/lib/pione/command/pione-package.rb +112 -59
  37. data/lib/pione/command/pione-relay-account-db.rb +107 -78
  38. data/lib/pione/command/pione-relay-client-db.rb +93 -72
  39. data/lib/pione/command/pione-relay.rb +37 -32
  40. data/lib/pione/command/pione-syntax-checker.rb +112 -87
  41. data/lib/pione/command/pione-task-worker.rb +135 -118
  42. data/lib/pione/command/pione-tuple-space-provider.rb +83 -50
  43. data/lib/pione/command/pione-tuple-space-receiver.rb +89 -50
  44. data/lib/pione/command/pione-tuple-space-viewer.rb +101 -99
  45. data/lib/pione/command/pione-val.rb +50 -29
  46. data/lib/pione/command/spawner.rb +74 -0
  47. data/lib/pione/front.rb +0 -2
  48. data/lib/pione/front/basic-front.rb +48 -26
  49. data/lib/pione/front/broker-front.rb +8 -16
  50. data/lib/pione/front/client-front.rb +10 -18
  51. data/lib/pione/front/front-exception.rb +12 -0
  52. data/lib/pione/front/relay-front.rb +6 -6
  53. data/lib/pione/front/task-worker-front.rb +3 -9
  54. data/lib/pione/front/tuple-space-provider-front.rb +6 -14
  55. data/lib/pione/front/tuple-space-receiver-front.rb +4 -11
  56. data/lib/pione/global.rb +135 -0
  57. data/lib/pione/global/broker-variable.rb +20 -0
  58. data/lib/pione/global/client-variable.rb +18 -0
  59. data/lib/pione/global/input-generator-variable.rb +7 -0
  60. data/lib/pione/global/log-variable.rb +53 -0
  61. data/lib/pione/global/network-variable.rb +7 -0
  62. data/lib/pione/global/package-variable.rb +28 -0
  63. data/lib/pione/global/path-variable.rb +52 -0
  64. data/lib/pione/global/relay-variable.rb +86 -0
  65. data/lib/pione/global/system-variable.rb +39 -0
  66. data/lib/pione/global/task-worker-variable.rb +17 -0
  67. data/lib/pione/global/tuple-space-notifier-variable.rb +60 -0
  68. data/lib/pione/lang.rb +55 -0
  69. data/lib/pione/lang/basic-model.rb +45 -0
  70. data/lib/pione/lang/boolean.rb +86 -0
  71. data/lib/pione/lang/common-parser.rb +202 -0
  72. data/lib/pione/lang/conditional-branch-parser.rb +57 -0
  73. data/lib/pione/lang/conditional-branch-transformer.rb +36 -0
  74. data/lib/pione/lang/conditional-branch.rb +73 -0
  75. data/lib/pione/lang/context-parser.rb +39 -0
  76. data/lib/pione/lang/context-transformer.rb +41 -0
  77. data/lib/pione/lang/context.rb +229 -0
  78. data/lib/pione/lang/data-expr.rb +265 -0
  79. data/lib/pione/lang/declaration-parser.rb +174 -0
  80. data/lib/pione/lang/declaration-transformer.rb +153 -0
  81. data/lib/pione/lang/declaration.rb +322 -0
  82. data/lib/pione/lang/definition.rb +88 -0
  83. data/lib/pione/lang/document-parser.rb +19 -0
  84. data/lib/pione/lang/document-transformer.rb +12 -0
  85. data/lib/pione/lang/environment.rb +344 -0
  86. data/lib/pione/{parser → lang}/error-message.yml +0 -0
  87. data/lib/pione/lang/expr-parser.rb +228 -0
  88. data/lib/pione/{transformer → lang}/expr-transformer.rb +32 -44
  89. data/lib/pione/lang/expr.rb +70 -0
  90. data/lib/pione/lang/feature-expr.rb +425 -0
  91. data/lib/pione/lang/float.rb +104 -0
  92. data/lib/pione/lang/integer.rb +159 -0
  93. data/lib/pione/lang/interpolator-parser.rb +44 -0
  94. data/lib/pione/lang/interpolator-transformer.rb +13 -0
  95. data/lib/pione/lang/keyed-sequence.rb +98 -0
  96. data/lib/pione/lang/lang-exception.rb +224 -0
  97. data/lib/pione/lang/literal-parser.rb +134 -0
  98. data/lib/pione/lang/literal-transformer.rb +171 -0
  99. data/lib/pione/lang/message.rb +41 -0
  100. data/lib/pione/lang/ordinal-sequence.rb +203 -0
  101. data/lib/pione/lang/package-expr.rb +86 -0
  102. data/lib/pione/lang/parameters.rb +121 -0
  103. data/lib/pione/lang/piece.rb +42 -0
  104. data/lib/pione/{model → lang}/pione-method.rb +26 -63
  105. data/lib/pione/lang/rule-expr.rb +70 -0
  106. data/lib/pione/lang/sequence.rb +215 -0
  107. data/lib/pione/lang/string.rb +116 -0
  108. data/lib/pione/lang/ticket-expr.rb +48 -0
  109. data/lib/pione/{model → lang}/type.rb +70 -99
  110. data/lib/pione/lang/variable.rb +35 -0
  111. data/lib/pione/location.rb +13 -1
  112. data/lib/pione/{uri-scheme → location}/broadcast-scheme.rb +2 -2
  113. data/lib/pione/location/data-location.rb +22 -5
  114. data/lib/pione/location/dropbox-location.rb +10 -8
  115. data/lib/pione/{uri-scheme → location}/dropbox-scheme.rb +2 -2
  116. data/lib/pione/location/ftp-location.rb +6 -0
  117. data/lib/pione/location/git-repository-location.rb +6 -17
  118. data/lib/pione/{uri-scheme → location}/git-scheme.rb +2 -2
  119. data/lib/pione/location/http-location.rb +8 -1
  120. data/lib/pione/location/local-location.rb +57 -4
  121. data/lib/pione/{uri-scheme → location}/local-scheme.rb +2 -2
  122. data/lib/pione/location/{exception.rb → location-exception.rb} +13 -1
  123. data/lib/pione/{uri-scheme/basic-scheme.rb → location/location-scheme.rb} +7 -6
  124. data/lib/pione/{uri-scheme → location}/myftp-scheme.rb +2 -2
  125. data/lib/pione/log.rb +7 -6
  126. data/lib/pione/log/debug.rb +75 -0
  127. data/lib/pione/log/domain-log.rb +4 -5
  128. data/lib/pione/log/message-log.rb +2 -2
  129. data/lib/pione/log/process-log.rb +16 -25
  130. data/lib/pione/log/process-record.rb +1 -0
  131. data/lib/pione/log/system-log.rb +165 -55
  132. data/lib/pione/package.rb +21 -0
  133. data/lib/pione/package/document.rb +27 -0
  134. data/lib/pione/package/package-archiver.rb +152 -0
  135. data/lib/pione/package/package-cache.rb +79 -0
  136. data/lib/pione/package/package-database.rb +121 -0
  137. data/lib/pione/package/package-exception.rb +38 -0
  138. data/lib/pione/{component → package}/package-expander.rb +13 -7
  139. data/lib/pione/package/package-filename.rb +46 -0
  140. data/lib/pione/package/package-handler.rb +106 -0
  141. data/lib/pione/package/package-info.rb +72 -0
  142. data/lib/pione/package/package-reader.rb +202 -0
  143. data/lib/pione/package/package-scanner.rb +133 -0
  144. data/lib/pione/package/scenario-handler.rb +95 -0
  145. data/lib/pione/package/scenario-info.rb +34 -0
  146. data/lib/pione/package/scenario-reader.rb +29 -0
  147. data/lib/pione/package/scenario-scanner.rb +96 -0
  148. data/lib/pione/patch.rb +0 -1
  149. data/lib/pione/patch/drb-patch.rb +377 -298
  150. data/lib/pione/patch/rinda-patch.rb +4 -3
  151. data/lib/pione/relay/relay-socket.rb +1 -4
  152. data/lib/pione/rule-engine.rb +27 -0
  153. data/lib/pione/{rule-handler → rule-engine}/action-handler.rb +41 -40
  154. data/lib/pione/rule-engine/basic-handler.rb +266 -0
  155. data/lib/pione/rule-engine/data-finder.rb +97 -0
  156. data/lib/pione/{rule-handler → rule-engine}/empty-handler.rb +2 -3
  157. data/lib/pione/rule-engine/engine-exception.rb +33 -0
  158. data/lib/pione/rule-engine/flow-handler.rb +490 -0
  159. data/lib/pione/{rule-handler → rule-engine}/root-handler.rb +5 -14
  160. data/lib/pione/{rule-handler → rule-engine}/system-handler.rb +1 -1
  161. data/lib/pione/rule-engine/update-criteria.rb +111 -0
  162. data/lib/pione/system.rb +3 -1
  163. data/lib/pione/system/config.rb +12 -45
  164. data/lib/pione/system/domain-info.rb +3 -12
  165. data/lib/pione/system/init.rb +2 -8
  166. data/lib/pione/system/system-exception.rb +29 -0
  167. data/lib/pione/test-helper.rb +43 -0
  168. data/lib/pione/test-helper/command-helper.rb +65 -0
  169. data/lib/pione/test-helper/extension.rb +9 -0
  170. data/lib/pione/test-helper/lang-helper.rb +196 -0
  171. data/lib/pione/test-helper/location-helper.rb +27 -0
  172. data/lib/pione/test-helper/package-helper.rb +11 -0
  173. data/lib/pione/test-helper/parser-helper.rb +45 -0
  174. data/lib/pione/test-helper/transformer-helper.rb +136 -0
  175. data/lib/pione/test-helper/tuple-helper.rb +13 -0
  176. data/lib/pione/test-helper/tuple-space-helper.rb +31 -0
  177. data/lib/pione/test-helper/webserver.rb +50 -0
  178. data/lib/pione/tuple-space.rb +4 -6
  179. data/lib/pione/{tuple → tuple-space}/basic-tuple.rb +63 -50
  180. data/lib/pione/tuple-space/tuple-definition.yml +165 -0
  181. data/lib/pione/tuple-space/tuple-space-exception.rb +25 -0
  182. data/lib/pione/tuple-space/tuple-space-interface.rb +123 -0
  183. data/lib/pione/tuple-space/tuple-space-server.rb +15 -26
  184. data/lib/pione/util.rb +16 -11
  185. data/lib/pione/util/backslash-notation.rb +11 -0
  186. data/lib/pione/util/digest.rb +71 -0
  187. data/lib/pione/util/embeded-expr-expander.rb +23 -0
  188. data/lib/pione/util/evaluatable.rb +9 -6
  189. data/lib/pione/util/free-thread-generator.rb +46 -0
  190. data/lib/pione/util/ftp-server.rb +3 -4
  191. data/lib/pione/util/id.rb +28 -23
  192. data/lib/pione/util/misc.rb +22 -4
  193. data/lib/pione/util/package-parameters-list.rb +12 -9
  194. data/lib/pione/{parser → util}/parslet-extension.rb +75 -64
  195. data/lib/pione/util/positionable.rb +65 -0
  196. data/lib/pione/util/zip.rb +12 -11
  197. data/lib/pione/version.rb +1 -1
  198. data/{test → misc}/endurance-test/graph.plt +0 -0
  199. data/{test → misc}/endurance-test/run.sh +0 -0
  200. data/pione.gemspec +45 -37
  201. data/test/agent/spec_basic-agent.rb +116 -99
  202. data/test/agent/spec_broker.rb +41 -25
  203. data/test/agent/spec_input-generator.rb +66 -57
  204. data/test/agent/spec_job-terminator.rb +27 -0
  205. data/test/agent/spec_logger.rb +28 -25
  206. data/test/agent/spec_messenger.rb +6 -6
  207. data/test/agent/spec_task-worker.rb +97 -246
  208. data/test/agent/spec_tuple-space-client.rb +19 -15
  209. data/test/agent/spec_tuple-space-provider.rb +26 -0
  210. data/test/agent/spec_tuple-space-receiver.rb +47 -0
  211. data/test/command/command-behavior.rb +2 -2
  212. data/test/command/data/PionePackageP1/P1.pione +9 -0
  213. data/test/command/data/PionePackageP1/pione-package.json +15 -0
  214. data/test/command/data/PionePackageP2/P2.pione +10 -0
  215. data/test/command/data/PionePackageP2/pione-package.json +16 -0
  216. data/test/command/data/PionePackageP3/P3.pione +10 -0
  217. data/test/command/data/PionePackageP3/pione-package.json +16 -0
  218. data/test/command/data/PionePackageP4/P4.pione +10 -0
  219. data/test/command/data/PionePackageP4/pione-package.json +17 -0
  220. data/test/command/data/pione-process.log +471 -0
  221. data/test/command/data/pione-val.domain.dump +0 -0
  222. data/test/command/spec_pione-clean.rb +12 -0
  223. data/test/command/spec_pione-client.rb +6 -6
  224. data/test/command/spec_pione-log.rb +28 -0
  225. data/test/command/spec_pione-package.rb +111 -12
  226. data/test/command/spec_pione-val.rb +4 -4
  227. data/test/lang/data/boolean.yml +134 -0
  228. data/test/lang/data/common-parser.yml +187 -0
  229. data/test/{parser/spec_flow-element-parser.yml → lang/data/conditional-branch-parser.yml} +12 -50
  230. data/test/lang/data/context-parser.yml +148 -0
  231. data/test/lang/data/data-expr.yml +93 -0
  232. data/test/lang/data/data-expr_match.yml +59 -0
  233. data/test/lang/data/declaration-parser.yml +279 -0
  234. data/test/lang/data/document-parser.yml +29 -0
  235. data/test/{parser/spec_expr-parser.yml → lang/data/expr-parser.yml} +9 -11
  236. data/test/lang/data/feature-expr.yml +148 -0
  237. data/test/lang/data/float.yml +30 -0
  238. data/test/lang/data/integer.yml +80 -0
  239. data/test/lang/data/interpolator-parser.yml +61 -0
  240. data/test/lang/data/keyed-sequence.yml +27 -0
  241. data/test/lang/data/literal-parser.yml +207 -0
  242. data/test/lang/data/parameter-set.yml +14 -0
  243. data/test/lang/data/rule-expr.yml +27 -0
  244. data/test/lang/data/sequence.yml +66 -0
  245. data/test/lang/data/string.yml +92 -0
  246. data/test/{model/spec_ticket-expr.yml → lang/data/ticket-expr.yml} +0 -0
  247. data/test/lang/spec_boolean.rb +5 -0
  248. data/test/{parser → lang}/spec_common-parser.rb +10 -32
  249. data/test/lang/spec_conditional-branch-parser.rb +5 -0
  250. data/test/lang/spec_conditional-branch-transformer.rb +97 -0
  251. data/test/lang/spec_conditional-branch.rb +176 -0
  252. data/test/lang/spec_context-parser.rb +5 -0
  253. data/test/lang/spec_context-transformer.rb +206 -0
  254. data/test/lang/spec_context.rb +283 -0
  255. data/test/lang/spec_data-expr.rb +198 -0
  256. data/test/lang/spec_declaration-parser.rb +5 -0
  257. data/test/lang/spec_declaration-transformer.rb +272 -0
  258. data/test/lang/spec_declaration.rb +550 -0
  259. data/test/lang/spec_document-parser.rb +5 -0
  260. data/test/lang/spec_document-transformer.rb +10 -0
  261. data/test/lang/spec_environment.rb +129 -0
  262. data/test/lang/spec_expr-parser.rb +6 -0
  263. data/test/lang/spec_expr-transformer.rb +149 -0
  264. data/test/lang/spec_feature-expr.rb +5 -0
  265. data/test/lang/spec_float.rb +23 -0
  266. data/test/lang/spec_integer.rb +29 -0
  267. data/test/lang/spec_interpolator-parser.rb +5 -0
  268. data/test/lang/spec_interpolator-transformer.rb +15 -0
  269. data/test/lang/spec_keyed-sequence.rb +5 -0
  270. data/test/lang/spec_literal-parser.rb +5 -0
  271. data/test/lang/spec_literal-transformer.rb +111 -0
  272. data/test/lang/spec_message.rb +22 -0
  273. data/test/lang/spec_package-expr.rb +19 -0
  274. data/test/lang/spec_parameter-set.rb +64 -0
  275. data/test/lang/spec_pione-method.rb +57 -0
  276. data/test/lang/spec_rule-expr.rb +18 -0
  277. data/test/lang/spec_sequence.rb +5 -0
  278. data/test/lang/spec_string.rb +5 -0
  279. data/test/lang/spec_ticket-expr.rb +39 -0
  280. data/test/lang/spec_variable.rb +29 -0
  281. data/test/{uri-scheme/spec_myftp-scheme.yml → location/data/myftp-scheme.yml} +0 -0
  282. data/test/location/location-behavior.rb +2 -2
  283. data/test/location/spec_basic-location.rb +5 -1
  284. data/test/{uri-scheme → location}/spec_broadcast-scheme.rb +4 -4
  285. data/test/{uri-scheme → location}/spec_dropbox-scheme.rb +3 -3
  286. data/test/location/spec_ftp-location.rb +3 -2
  287. data/test/location/spec_git-repository-location.rb +19 -19
  288. data/test/{uri-scheme → location}/spec_git-scheme.rb +2 -2
  289. data/test/location/spec_http-location.rb +4 -12
  290. data/test/location/spec_https-location.rb +1 -3
  291. data/test/location/spec_local-location.rb +1 -1
  292. data/test/{uri-scheme → location}/spec_local-scheme.rb +3 -3
  293. data/test/{uri-scheme → location}/spec_myftp-scheme.rb +8 -10
  294. data/test/log/spec_debug.rb +53 -0
  295. data/test/log/spec_domain-log.rb +4 -5
  296. data/test/log/spec_message-log.rb +39 -33
  297. data/test/log/spec_process-log.rb +4 -2
  298. data/test/log/spec_process-record.rb +12 -10
  299. data/test/log/spec_system-log.rb +29 -11
  300. data/test/log/spec_xes-log.rb +6 -4
  301. data/test/package/data/HelloWorld+v0.1.1.ppg +0 -0
  302. data/test/package/data/HelloWorld-gitrepos.zip +0 -0
  303. data/test/{test-data/package → package/data}/HelloWorld/HelloWorld.pione +3 -0
  304. data/test/package/data/HelloWorld/pione-package.json +16 -0
  305. data/test/package/data/HelloWorld/scenario/Scenario.pione +2 -0
  306. data/test/{test-data/package → package/data}/HelloWorld/scenario/output/message.txt +0 -0
  307. data/test/package/data/HelloWorld/scenario/pione-scenario.json +10 -0
  308. data/test/{test-data/package → package/data}/HelloWorld/scenario/scenario.yml +0 -0
  309. data/test/package/data/PackageScannerP1/P1.pione +11 -0
  310. data/test/package/data/PackageScannerP2/P2.pione +9 -0
  311. data/test/package/data/PackageScannerP3/P3.pione +17 -0
  312. data/test/package/data/PackageScannerP4/.Ignore.pione +1 -0
  313. data/test/package/data/PackageScannerP4/Doc1.pione +8 -0
  314. data/test/package/data/PackageScannerP4/Doc2.pione +6 -0
  315. data/test/package/data/PackageScannerP4/Doc3.pione +6 -0
  316. data/test/package/data/PackageScannerP4/P4.pione +8 -0
  317. data/test/package/data/PackageScannerP4/sub1/.Ignore.pione +1 -0
  318. data/test/package/data/PackageScannerP4/sub1/Doc4.pione +6 -0
  319. data/test/package/data/PackageScannerP4/sub1/sub1-1/.Ignore.pione +1 -0
  320. data/test/package/data/PackageScannerP4/sub1/sub1-1/Doc5.pione +6 -0
  321. data/test/package/data/PackageScannerP4/sub2/.Ignore.pione +1 -0
  322. data/test/package/data/PackageScannerP4/sub2/sub2-1/.Ignore.pione +1 -0
  323. data/test/package/data/PackageScannerP4/sub2/sub2-1/sub2-1-1/.Ignore.pione +1 -0
  324. data/test/package/data/PackageScannerP4/sub2/sub2-1/sub2-1-1/Doc6.pione +6 -0
  325. data/test/package/data/PackageScannerP4/sub2/sub2-1/sub2-1-2/.Ignore.pione +1 -0
  326. data/test/package/data/PackageScannerP4/sub2/sub2-1/sub2-1-2/Doc7.pione +6 -0
  327. data/test/package/data/PackageScannerP5/P5.pione +8 -0
  328. data/test/{model/spec_feature-expr.yml → package/data/PackageScannerP5/scenario1/Scenario.pione} +0 -0
  329. data/test/package/data/PackageScannerP5/scenario2/Scenario.pione +0 -0
  330. data/test/package/data/PackageScannerP5/scenario3/Scenario.pione +0 -0
  331. data/test/package/data/PackageScannerP5/sub1/scenario4/Scenario.pione +0 -0
  332. data/test/package/data/PackageScannerP5/sub1/sub1-1/scenario5/Scenario.pione +0 -0
  333. data/test/package/data/PackageScannerP5/sub2/sub2-1/sub2-1-1/scenario6/Scenario.pione +0 -0
  334. data/test/package/data/PackageScannerP5/sub2/sub2-1/sub2-1-2/scenario7/Scenario.pione +0 -0
  335. data/test/package/data/ScenarioScannerS1/Scenario.pione +1 -0
  336. data/test/package/data/ScenarioScannerS1/input/i1 +0 -0
  337. data/test/package/data/ScenarioScannerS1/input/i2 +0 -0
  338. data/test/package/data/ScenarioScannerS1/input/i3 +0 -0
  339. data/test/package/data/ScenarioScannerS1/output/o1 +0 -0
  340. data/test/package/data/ScenarioScannerS1/output/o2 +0 -0
  341. data/test/package/data/ScenarioScannerS1/output/o3 +0 -0
  342. data/test/package/data/ScenarioScannerS2/Scenario.pione +1 -0
  343. data/test/package/data/ScenarioScannerS2/output/o1 +0 -0
  344. data/test/package/data/ScenarioScannerS3/Scenario.pione +2 -0
  345. data/test/package/data/ScenarioScannerS4/Scenario.pione +0 -0
  346. data/test/package/data/ScenarioScannerS5/Scenario.pione +2 -0
  347. data/test/package/data/ScenarioScannerS6/Scenario.pione +5 -0
  348. data/test/package/data/ScenarioScannerS8/Scenario.pione +1 -0
  349. data/test/{test-data/package → package/data}/TestPackage1+v0.1.0.ppg +0 -0
  350. data/test/{test-data/package → package/data}/TestPackage1/Test.pione +3 -0
  351. data/test/{test-data/package → package/data}/TestPackage1/bin/count +0 -0
  352. data/test/{test-data/package → package/data}/TestPackage1/package.yml +0 -0
  353. data/test/package/data/TestPackage1/pione-package.json +18 -0
  354. data/test/package/data/TestPackage1/scenario/case1/Scenario.pione +1 -0
  355. data/test/{test-data/package → package/data}/TestPackage1/scenario/case1/input/1.txt +0 -0
  356. data/test/{test-data/package → package/data}/TestPackage1/scenario/case1/output/1.count +0 -0
  357. data/test/package/data/TestPackage1/scenario/case1/pione-scenario.json +10 -0
  358. data/test/{test-data/package → package/data}/TestPackage1/scenario/case1/scenario.yml +0 -0
  359. data/test/package/data/TestPackage1/scenario/case2/Scenario.pione +1 -0
  360. data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/input/1.txt +0 -0
  361. data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/input/2.txt +0 -0
  362. data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/input/3.txt +0 -0
  363. data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/output/1.count +0 -0
  364. data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/output/2.count +0 -0
  365. data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/output/3.count +0 -0
  366. data/test/package/data/TestPackage1/scenario/case2/pione-scenario.json +14 -0
  367. data/test/{test-data/package → package/data}/TestPackage1/scenario/case2/scenario.yml +0 -0
  368. data/test/package/data/TestPackage1/scenario/case3/Scenario.pione +1 -0
  369. data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/input/a.txt +0 -0
  370. data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/input/b.txt +0 -0
  371. data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/output/a.count +0 -0
  372. data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/output/b.count +0 -0
  373. data/test/package/data/TestPackage1/scenario/case3/pione-scenario.json +12 -0
  374. data/test/{test-data/package → package/data}/TestPackage1/scenario/case3/scenario.yml +0 -0
  375. data/test/{component → package}/spec_document.pione +0 -0
  376. data/test/package/spec_document.rb +52 -0
  377. data/test/package/spec_package-archiver.rb +31 -0
  378. data/test/package/spec_package-database.rb +42 -0
  379. data/test/package/spec_package-expander.rb +14 -0
  380. data/test/package/spec_package-filename.rb +56 -0
  381. data/test/package/spec_package-handler.rb +50 -0
  382. data/test/package/spec_package-info.rb +22 -0
  383. data/test/package/spec_package-reader.rb +85 -0
  384. data/test/package/spec_package-scanner.rb +68 -0
  385. data/test/package/spec_scenario-handler.rb +46 -0
  386. data/test/package/spec_scenario-info.rb +16 -0
  387. data/test/package/spec_scenario-scanner.rb +92 -0
  388. data/test/patch/spec_rinda-patch.rb +1 -1
  389. data/test/patch/spec_uri-patch.rb +1 -1
  390. data/test/{rule-handler → rule-engine}/spec_action-handler.pione +0 -0
  391. data/test/rule-engine/spec_action-handler.rb +94 -0
  392. data/test/rule-engine/spec_data-finder.rb +94 -0
  393. data/test/{tuple-space → rule-engine}/spec_data-finder.yml +39 -28
  394. data/test/rule-engine/spec_empty-handler.rb +170 -0
  395. data/test/{rule-handler → rule-engine}/spec_flow-handler.pione +0 -0
  396. data/test/rule-engine/spec_flow-handler.rb +421 -0
  397. data/test/{rule-handler → rule-engine}/spec_update-criteria.pione +0 -0
  398. data/test/{rule-handler → rule-engine}/spec_update-criteria.rb +16 -12
  399. data/test/{rule-handler → rule-engine}/spec_update-criteria.yml +0 -0
  400. data/test/system/spec_domain-info.rb +13 -9
  401. data/test/system/spec_file-cache.rb +9 -9
  402. data/test/tuple-space/spec_tuple-space-server.rb +42 -40
  403. data/test/tuple/spec_basic-tuple.rb +77 -75
  404. data/test/tuple/spec_data-tuple.rb +4 -4
  405. data/test/tuple/spec_finished-tuple.rb +5 -6
  406. data/test/tuple/spec_message-tuple.rb +3 -3
  407. data/test/tuple/spec_task-tuple.rb +11 -9
  408. data/test/tuple/spec_touch-tuple.rb +3 -3
  409. data/test/tuple/spec_working-tuple.rb +8 -12
  410. data/test/tuple/tuple-behavior.rb +1 -1
  411. data/test/util/data/HelloWorld+v0.1.1.ppg +0 -0
  412. data/test/util/spec_cpu.rb +1 -1
  413. data/test/util/spec_digest.rb +15 -0
  414. data/test/util/spec_evaluatable.rb +3 -3
  415. data/test/util/spec_free-thread-generator.rb +42 -0
  416. data/test/util/spec_ftp-server.rb +4 -9
  417. data/test/util/spec_id.rb +53 -36
  418. data/test/util/spec_indentation.rb +1 -1
  419. data/test/util/spec_ip-address.rb +1 -1
  420. data/test/util/spec_package-parameters-list.rb +10 -9
  421. data/test/util/spec_process-info.rb +2 -2
  422. data/test/util/spec_uuid.rb +1 -1
  423. data/test/util/spec_variable-holdable.rb +1 -1
  424. data/test/util/spec_zip.rb +1 -1
  425. metadata +508 -364
  426. data/example/SerialProcessing/package.yml +0 -5
  427. data/example/SerialProcessing/scenario/scenario.yml +0 -10
  428. data/lib/pione/agent/command-listener.rb +0 -47
  429. data/lib/pione/agent/rule-provider.rb +0 -59
  430. data/lib/pione/agent/trivial-routine-worker.rb +0 -29
  431. data/lib/pione/agent/tuple-space-server-client-life-checker.rb +0 -31
  432. data/lib/pione/command/child-process.rb +0 -56
  433. data/lib/pione/command/daemon-process.rb +0 -10
  434. data/lib/pione/command/front-owner-command.rb +0 -25
  435. data/lib/pione/component.rb +0 -13
  436. data/lib/pione/component/document.rb +0 -88
  437. data/lib/pione/component/package-archiver.rb +0 -92
  438. data/lib/pione/component/package-filename.rb +0 -38
  439. data/lib/pione/component/package-reader.rb +0 -276
  440. data/lib/pione/component/package.rb +0 -199
  441. data/lib/pione/component/rule.rb +0 -206
  442. data/lib/pione/front/task-worker-owner.rb +0 -43
  443. data/lib/pione/front/tuple-space-provider-owner.rb +0 -11
  444. data/lib/pione/model.rb +0 -32
  445. data/lib/pione/model/assignment.rb +0 -120
  446. data/lib/pione/model/basic-model.rb +0 -228
  447. data/lib/pione/model/block.rb +0 -262
  448. data/lib/pione/model/boolean.rb +0 -168
  449. data/lib/pione/model/call-rule.rb +0 -86
  450. data/lib/pione/model/constraints.rb +0 -46
  451. data/lib/pione/model/data-expr.rb +0 -548
  452. data/lib/pione/model/feature-expr.rb +0 -875
  453. data/lib/pione/model/float.rb +0 -105
  454. data/lib/pione/model/integer.rb +0 -166
  455. data/lib/pione/model/keyed-sequence.rb +0 -150
  456. data/lib/pione/model/message.rb +0 -95
  457. data/lib/pione/model/ordinal-sequence.rb +0 -73
  458. data/lib/pione/model/package-expr.rb +0 -53
  459. data/lib/pione/model/parameters.rb +0 -374
  460. data/lib/pione/model/rule-expr.rb +0 -234
  461. data/lib/pione/model/sequence.rb +0 -273
  462. data/lib/pione/model/string.rb +0 -127
  463. data/lib/pione/model/ticket-expr.rb +0 -71
  464. data/lib/pione/model/variable-table.rb +0 -344
  465. data/lib/pione/model/variable.rb +0 -116
  466. data/lib/pione/parser.rb +0 -14
  467. data/lib/pione/parser/block-parser.rb +0 -107
  468. data/lib/pione/parser/common-parser.rb +0 -173
  469. data/lib/pione/parser/document-parser.rb +0 -141
  470. data/lib/pione/parser/expr-parser.rb +0 -354
  471. data/lib/pione/parser/feature-expr-parser.rb +0 -105
  472. data/lib/pione/parser/flow-element-parser.rb +0 -181
  473. data/lib/pione/parser/literal-parser.rb +0 -196
  474. data/lib/pione/parser/rule-definition-parser.rb +0 -158
  475. data/lib/pione/patch/monitor-patch.rb +0 -16
  476. data/lib/pione/rule-handler.rb +0 -14
  477. data/lib/pione/rule-handler/basic-handler.rb +0 -326
  478. data/lib/pione/rule-handler/flow-handler.rb +0 -414
  479. data/lib/pione/rule-handler/update-criteria.rb +0 -175
  480. data/lib/pione/system/global.rb +0 -433
  481. data/lib/pione/transformer.rb +0 -24
  482. data/lib/pione/transformer/block-transformer.rb +0 -28
  483. data/lib/pione/transformer/document-transformer.rb +0 -58
  484. data/lib/pione/transformer/feature-expr-transformer.rb +0 -60
  485. data/lib/pione/transformer/flow-element-transformer.rb +0 -66
  486. data/lib/pione/transformer/literal-transformer.rb +0 -91
  487. data/lib/pione/transformer/rule-definition-transformer.rb +0 -80
  488. data/lib/pione/transformer/transformer-module.rb +0 -39
  489. data/lib/pione/tuple-space/data-finder.rb +0 -155
  490. data/lib/pione/tuple-space/presence-notifier.rb +0 -84
  491. data/lib/pione/tuple-space/tuple-space-provider.rb +0 -85
  492. data/lib/pione/tuple-space/tuple-space-receiver.rb +0 -141
  493. data/lib/pione/tuple-space/tuple-space-server-interface.rb +0 -123
  494. data/lib/pione/tuple.rb +0 -30
  495. data/lib/pione/tuple/agent-tuple.rb +0 -10
  496. data/lib/pione/tuple/attribute-tuple.rb +0 -7
  497. data/lib/pione/tuple/base-location-tuple.rb +0 -9
  498. data/lib/pione/tuple/bye-tuple.rb +0 -9
  499. data/lib/pione/tuple/command-tuple.rb +0 -9
  500. data/lib/pione/tuple/data-null-tuple.rb +0 -14
  501. data/lib/pione/tuple/data-tuple.rb +0 -21
  502. data/lib/pione/tuple/dry-run-tuple.rb +0 -8
  503. data/lib/pione/tuple/exception-tuple.rb +0 -11
  504. data/lib/pione/tuple/finished-tuple.rb +0 -17
  505. data/lib/pione/tuple/foreground-tuple.rb +0 -7
  506. data/lib/pione/tuple/lift-tuple.rb +0 -14
  507. data/lib/pione/tuple/message-tuple.rb +0 -7
  508. data/lib/pione/tuple/process-info-tuple.rb +0 -9
  509. data/lib/pione/tuple/process-log-tuple.rb +0 -13
  510. data/lib/pione/tuple/request-rule-tuple.rb +0 -9
  511. data/lib/pione/tuple/rule-tuple.rb +0 -10
  512. data/lib/pione/tuple/task-tuple.rb +0 -40
  513. data/lib/pione/tuple/task-worker-resource-tuple.rb +0 -9
  514. data/lib/pione/tuple/ticket-tuple.rb +0 -8
  515. data/lib/pione/tuple/touch-tuple.rb +0 -14
  516. data/lib/pione/tuple/working-tuple.rb +0 -13
  517. data/lib/pione/uri-scheme.rb +0 -11
  518. data/lib/pione/util/error-report.rb +0 -27
  519. data/test/agent/spec_command-listener.rb +0 -30
  520. data/test/agent/spec_rule-provider.rb +0 -78
  521. data/test/command/spec_pione-val.domain.dump +0 -0
  522. data/test/component/spec_document.rb +0 -67
  523. data/test/component/spec_package-archiver.rb +0 -27
  524. data/test/component/spec_package-expander.rb +0 -11
  525. data/test/component/spec_package-filename.rb +0 -79
  526. data/test/component/spec_package-reader.rb +0 -100
  527. data/test/component/spec_package.rb +0 -109
  528. data/test/component/spec_rule.rb +0 -140
  529. data/test/model/spec_assignment.rb +0 -52
  530. data/test/model/spec_block.rb +0 -108
  531. data/test/model/spec_boolean.rb +0 -39
  532. data/test/model/spec_boolean.yml +0 -134
  533. data/test/model/spec_call-rule.rb +0 -23
  534. data/test/model/spec_data-expr.rb +0 -361
  535. data/test/model/spec_data-expr.yml +0 -24
  536. data/test/model/spec_data-expr_match.yml +0 -45
  537. data/test/model/spec_feature-expr.rb +0 -333
  538. data/test/model/spec_feature-expr_decide.yml +0 -28
  539. data/test/model/spec_float.rb +0 -23
  540. data/test/model/spec_float.yml +0 -30
  541. data/test/model/spec_integer.rb +0 -23
  542. data/test/model/spec_integer.yml +0 -68
  543. data/test/model/spec_keyed-sequence.rb +0 -5
  544. data/test/model/spec_keyed-sequence.yml +0 -27
  545. data/test/model/spec_message.rb +0 -40
  546. data/test/model/spec_package-expr.rb +0 -19
  547. data/test/model/spec_parameters.rb +0 -103
  548. data/test/model/spec_pione-method.rb +0 -57
  549. data/test/model/spec_rule-expr.rb +0 -28
  550. data/test/model/spec_rule-expr.yml +0 -11
  551. data/test/model/spec_sequence.rb +0 -5
  552. data/test/model/spec_sequence.yml +0 -66
  553. data/test/model/spec_string.rb +0 -47
  554. data/test/model/spec_string.yml +0 -91
  555. data/test/model/spec_ticket-expr.rb +0 -39
  556. data/test/model/spec_variable-table.rb +0 -116
  557. data/test/model/spec_variable.rb +0 -82
  558. data/test/parser/spec_block-parser.rb +0 -5
  559. data/test/parser/spec_block-parser.yml +0 -94
  560. data/test/parser/spec_document-parser.rb +0 -5
  561. data/test/parser/spec_document-parser.yml +0 -77
  562. data/test/parser/spec_expr-parser.rb +0 -6
  563. data/test/parser/spec_feature-expr-parser.rb +0 -32
  564. data/test/parser/spec_feature-expr-parser.yml +0 -25
  565. data/test/parser/spec_flow-element-parser.rb +0 -5
  566. data/test/parser/spec_literal-parser.rb +0 -5
  567. data/test/parser/spec_literal-parser.yml +0 -134
  568. data/test/parser/spec_rule-definition-parser.rb +0 -5
  569. data/test/parser/spec_rule-definition-parser.yml +0 -94
  570. data/test/rule-handler/spec_action-handler.rb +0 -79
  571. data/test/rule-handler/spec_flow-handler.rb +0 -61
  572. data/test/spec_common.rb +0 -14
  573. data/test/spec_object.rb +0 -20
  574. data/test/test-data/package/HelloWorld+v0.1.0.ppg +0 -0
  575. data/test/test-data/package/HelloWorld-gitrepos.zip +0 -0
  576. data/test/test-data/package/HelloWorld/package.yml +0 -6
  577. data/test/test-util.rb +0 -211
  578. data/test/test-util/command.rb +0 -53
  579. data/test/test-util/package.rb +0 -9
  580. data/test/test-util/parser.rb +0 -45
  581. data/test/test-util/transformer.rb +0 -50
  582. data/test/test-util/webserver.rb +0 -43
  583. data/test/transformer/spec_block-transformer.rb +0 -33
  584. data/test/transformer/spec_document-transformer.rb +0 -50
  585. data/test/transformer/spec_expr-transformer.rb +0 -126
  586. data/test/transformer/spec_feature-expr-transformer.rb +0 -21
  587. data/test/transformer/spec_flow-element-transformer.rb +0 -154
  588. data/test/transformer/spec_literal-transformer.rb +0 -64
  589. data/test/transformer/spec_rule-definition-transformer.rb +0 -172
  590. data/test/tuple-space/spec_data-finder.rb +0 -94
  591. data/test/tuple-space/spec_tuple-space-provider.rb +0 -36
  592. data/test/tuple-space/spec_tuple-space-receiver.rb +0 -32
  593. 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