pione 0.1.4 → 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (270) hide show
  1. data/.gitignore +4 -3
  2. data/.simplecov +7 -0
  3. data/.travis.yml +8 -0
  4. data/Gemfile +3 -0
  5. data/History.txt +13 -0
  6. data/README.md +2 -0
  7. data/Rakefile +16 -6
  8. data/bin/pione-val +5 -0
  9. data/example/AbstractRule/package.yml +1 -0
  10. data/example/HelloWorld/package.yml +2 -0
  11. data/example/HelloWorld/scenario/scenario.yml +2 -0
  12. data/example/LoopByTouch/LoopByTouch.pione +28 -0
  13. data/example/LoopByTouch/package.yml +1 -0
  14. data/example/MakePair/package.yml +2 -0
  15. data/example/MakePair/{data → scenario/input}/1.i +0 -0
  16. data/example/MakePair/{data → scenario/input}/2.i +0 -0
  17. data/example/MakePair/{data → scenario/input}/3.i +0 -0
  18. data/example/MakePair/{data → scenario/input}/4.i +0 -0
  19. data/example/MakePair/{data → scenario/input}/5.i +0 -0
  20. data/example/MakePair/scenario/scenario.yml +1 -0
  21. data/example/ScoreAggregation/ScoreAggregation.pione +122 -0
  22. data/example/ScoreAggregation/bin/apply-template.rb +10 -0
  23. data/example/ScoreAggregation/bin/histgram-graph.sh +18 -0
  24. data/example/ScoreAggregation/bin/mean-summary.rb +10 -0
  25. data/example/ScoreAggregation/bin/personal-bar-graph.sh +18 -0
  26. data/example/ScoreAggregation/bin/personal-pre-statistics.rb +37 -0
  27. data/example/ScoreAggregation/bin/total-mean.rb +10 -0
  28. data/example/ScoreAggregation/bin/total-statistics.rb +43 -0
  29. data/example/ScoreAggregation/generate-data.rb +63 -0
  30. data/example/ScoreAggregation/package.yml +1 -0
  31. data/example/ScoreAggregation/scenario/case1/input/A.score +15 -0
  32. data/example/ScoreAggregation/scenario/case1/input/B.score +15 -0
  33. data/example/ScoreAggregation/scenario/case1/input/C.score +15 -0
  34. data/example/ScoreAggregation/scenario/case1/input/D.score +15 -0
  35. data/example/ScoreAggregation/scenario/case1/input/E.score +15 -0
  36. data/example/ScoreAggregation/scenario/case1/input/F.score +15 -0
  37. data/example/ScoreAggregation/scenario/case1/input/G.score +15 -0
  38. data/example/ScoreAggregation/scenario/case1/input/H.score +15 -0
  39. data/example/ScoreAggregation/scenario/case1/input/I.score +15 -0
  40. data/example/ScoreAggregation/scenario/case1/input/J.score +15 -0
  41. data/example/ScoreAggregation/scenario/case1/input/K.score +15 -0
  42. data/example/ScoreAggregation/scenario/case1/input/L.score +15 -0
  43. data/example/ScoreAggregation/scenario/case1/input/M.score +15 -0
  44. data/example/ScoreAggregation/scenario/case1/input/N.score +15 -0
  45. data/example/ScoreAggregation/scenario/case1/input/O.score +15 -0
  46. data/example/ScoreAggregation/scenario/case1/input/P.score +15 -0
  47. data/example/ScoreAggregation/scenario/case1/input/Q.score +15 -0
  48. data/example/ScoreAggregation/scenario/case1/input/R.score +15 -0
  49. data/example/ScoreAggregation/scenario/case1/input/S.score +15 -0
  50. data/example/ScoreAggregation/scenario/case1/input/T.score +15 -0
  51. data/example/ScoreAggregation/scenario/case1/input/U.score +15 -0
  52. data/example/ScoreAggregation/scenario/case1/input/V.score +15 -0
  53. data/example/ScoreAggregation/scenario/case1/input/W.score +15 -0
  54. data/example/ScoreAggregation/scenario/case1/input/X.score +15 -0
  55. data/example/ScoreAggregation/scenario/case1/input/Y.score +15 -0
  56. data/example/ScoreAggregation/scenario/case1/input/Z.score +15 -0
  57. data/example/ScoreAggregation/scenario/case1/input/stat-template.erb +24 -0
  58. data/example/ScoreAggregation/scenario/case1/scenario.yml +3 -0
  59. data/example/{SequentialProcess/SequentialProcess.pione → SerialProcessing/SerialProcessing.pione} +0 -0
  60. data/example/SerialProcessing/package.yml +1 -0
  61. data/example/WorkflowPatterns/01_Sequence/Sequence.pione +21 -0
  62. data/example/WorkflowPatterns/02_PrallelSplit/ParallelSplit.pione +29 -0
  63. data/example/WorkflowPatterns/03_Synchronization/Synchronization.pione +30 -0
  64. data/example/WorkflowPatterns/04_ExclusiveChoice/ExclusiveChoice.pione +44 -0
  65. data/example/WorkflowPatterns/05_SimpleMerge/SimpleMerge.pione +44 -0
  66. data/example/WorkflowPatterns/06_MultiChoice/MultiChoice.pione +48 -0
  67. data/example/WorkflowPatterns/07_StructuredSynchronizingMerge/StructuredSynchronizingMerge.pione +71 -0
  68. data/example/WorkflowPatterns/08_MultiMerge/MultiMerge.pione +44 -0
  69. data/example/WorkflowPatterns/11_ImplicitTermination/ImplicitTermination.pione +29 -0
  70. data/example/WorkflowPatterns/12_MultipleInstancesWithoutSynchronization/MultipleInstancesWithoutSynchronization.pione +29 -0
  71. data/example/WorkflowPatterns/13_MultipleInstancesWithDesignTimeKnowledge/MultipleInstancesWithDesignTimeKnowledge.pione +28 -0
  72. data/example/WorkflowPatterns/14_MultipleInstancesWithRunTimeKnowledge/MultipleInstancesWithRunTimeKnowledge.pione +33 -0
  73. data/example/WorkflowPatterns/33_GeneralizedANDJoin/GeneralizedANDJoin.pione +21 -0
  74. data/example/WorkflowPatterns/37_LocalSynchronizingMerge/LocalSynchronizingMerge.pione +101 -0
  75. data/example/WorkflowPatterns/41_ThreadMerge/ThreadMerge.pione +43 -0
  76. data/example/WorkflowPatterns/42_ThreadSplit/ThreadSplit.pione +16 -0
  77. data/lib/pione.rb +23 -47
  78. data/lib/pione/agent/broker.rb +1 -1
  79. data/lib/pione/agent/input-generator.rb +1 -1
  80. data/lib/pione/agent/logger.rb +62 -49
  81. data/lib/pione/agent/messenger.rb +38 -0
  82. data/lib/pione/agent/rule-provider.rb +3 -3
  83. data/lib/pione/agent/task-worker.rb +14 -2
  84. data/lib/pione/agent/tuple-space-client.rb +1 -1
  85. data/lib/pione/agent/tuple-space-server-client-life-checker.rb +5 -3
  86. data/lib/pione/command.rb +2 -0
  87. data/lib/pione/command/basic-command.rb +1 -1
  88. data/lib/pione/command/pione-client.rb +57 -16
  89. data/lib/pione/command/pione-log.rb +5 -5
  90. data/lib/pione/command/pione-syntax-checker.rb +22 -7
  91. data/lib/pione/command/pione-task-worker.rb +36 -19
  92. data/lib/pione/command/pione-tuple-space-viewer.rb +3 -3
  93. data/lib/pione/command/pione-val.rb +40 -0
  94. data/lib/pione/component.rb +8 -0
  95. data/lib/pione/{system → component}/document.rb +13 -11
  96. data/lib/pione/component/package.rb +269 -0
  97. data/lib/pione/component/rule.rb +206 -0
  98. data/lib/pione/location/basic-location.rb +49 -7
  99. data/lib/pione/location/ftp-location.rb +19 -6
  100. data/lib/pione/location/local-location.rb +15 -6
  101. data/lib/pione/log.rb +4 -1
  102. data/lib/pione/log/{domain-info.rb → domain-log.rb} +23 -11
  103. data/lib/pione/{util/console-message.rb → log/message-log.rb} +16 -15
  104. data/lib/pione/log/process-log.rb +35 -86
  105. data/lib/pione/log/process-record.rb +24 -11
  106. data/lib/pione/log/system-log.rb +107 -0
  107. data/lib/pione/log/xes-log.rb +54 -48
  108. data/lib/pione/model.rb +1 -3
  109. data/lib/pione/model/assignment.rb +1 -0
  110. data/lib/pione/model/basic-model.rb +31 -15
  111. data/lib/pione/model/block.rb +1 -1
  112. data/lib/pione/model/boolean.rb +10 -23
  113. data/lib/pione/model/constraints.rb +12 -0
  114. data/lib/pione/model/data-expr.rb +31 -36
  115. data/lib/pione/model/feature-expr.rb +6 -23
  116. data/lib/pione/model/float.rb +29 -18
  117. data/lib/pione/model/integer.rb +44 -56
  118. data/lib/pione/model/keyed-sequence.rb +11 -4
  119. data/lib/pione/model/message.rb +4 -4
  120. data/lib/pione/model/ordinal-sequence.rb +12 -14
  121. data/lib/pione/model/package-expr.rb +53 -0
  122. data/lib/pione/model/parameters.rb +12 -11
  123. data/lib/pione/model/pione-method.rb +2 -2
  124. data/lib/pione/model/rule-expr.rb +30 -52
  125. data/lib/pione/model/sequence.rb +26 -26
  126. data/lib/pione/model/string.rb +13 -54
  127. data/lib/pione/model/ticket-expr.rb +12 -53
  128. data/lib/pione/model/type.rb +7 -1
  129. data/lib/pione/model/variable-table.rb +5 -4
  130. data/lib/pione/model/variable.rb +0 -5
  131. data/lib/pione/option/common-option.rb +2 -1
  132. data/lib/pione/option/task-worker-owner-option.rb +1 -1
  133. data/lib/pione/patch/drb-patch.rb +1 -1
  134. data/lib/pione/patch/em-ftpd-patch.rb +7 -0
  135. data/lib/pione/patch/rinda-patch.rb +53 -0
  136. data/lib/pione/patch/uri-patch.rb +5 -0
  137. data/lib/pione/relay/relay-socket.rb +2 -2
  138. data/lib/pione/rule-handler/action-handler.rb +71 -64
  139. data/lib/pione/rule-handler/basic-handler.rb +50 -32
  140. data/lib/pione/rule-handler/flow-handler.rb +51 -34
  141. data/lib/pione/rule-handler/update-criteria.rb +43 -20
  142. data/lib/pione/system.rb +13 -0
  143. data/lib/pione/system/domain-info.rb +34 -0
  144. data/lib/pione/system/global.rb +8 -1
  145. data/lib/pione/system/object.rb +1 -1
  146. data/lib/pione/transformer/expr-transformer.rb +3 -3
  147. data/lib/pione/transformer/literal-transformer.rb +3 -3
  148. data/lib/pione/transformer/rule-definition-transformer.rb +11 -9
  149. data/lib/pione/tuple-space/tuple-space-server-interface.rb +19 -1
  150. data/lib/pione/tuple-space/tuple-space-server.rb +9 -2
  151. data/lib/pione/tuple.rb +30 -0
  152. data/lib/pione/tuple/data-null-tuple.rb +14 -0
  153. data/lib/pione/tuple/message-tuple.rb +7 -0
  154. data/lib/pione/tuple/process-log-tuple.rb +13 -0
  155. data/lib/pione/tuple/touch-tuple.rb +14 -0
  156. data/lib/pione/uri-scheme/myftp-scheme.rb +45 -0
  157. data/lib/pione/util.rb +18 -0
  158. data/lib/pione/util/cpu.rb +20 -0
  159. data/lib/pione/util/error-report.rb +9 -1
  160. data/lib/pione/util/evaluatable.rb +47 -0
  161. data/lib/pione/util/ftp-server.rb +468 -0
  162. data/lib/pione/util/id.rb +39 -0
  163. data/lib/pione/util/indentation.rb +19 -0
  164. data/lib/pione/util/ip-address.rb +35 -0
  165. data/lib/pione/util/misc.rb +0 -47
  166. data/lib/pione/util/uuid.rb +28 -0
  167. data/lib/pione/util/variable-holdable.rb +38 -0
  168. data/lib/pione/version.rb +1 -1
  169. data/pione.gemspec +16 -14
  170. data/test/agent/spec_logger.rb +35 -44
  171. data/test/agent/spec_messenger.rb +25 -0
  172. data/test/agent/spec_rule-provider.rb +1 -1
  173. data/test/agent/spec_task-worker.rb +7 -13
  174. data/test/{system → component}/spec_document.rb +20 -20
  175. data/test/component/spec_package.rb +77 -0
  176. data/test/component/spec_package/TestPackage/Test.pione +14 -0
  177. data/test/component/spec_package/TestPackage/bin/count +3 -0
  178. data/test/component/spec_package/TestPackage/package.yml +7 -0
  179. data/test/component/spec_package/TestPackage/scenario/case1/input/1.txt +1 -0
  180. data/test/component/spec_package/TestPackage/scenario/case1/scenario.yml +1 -0
  181. data/test/component/spec_rule.rb +140 -0
  182. data/test/endurance-test/graph.plt +12 -0
  183. data/test/endurance-test/run.sh +65 -0
  184. data/test/location/location-behavior.rb +125 -0
  185. data/test/location/spec_ftp-location.rb +28 -90
  186. data/test/location/spec_local-location.rb +26 -76
  187. data/test/log/raw-process-log/pione-process.log +710 -0
  188. data/test/log/spec_domain-log.rb +57 -0
  189. data/test/log/spec_message-log.rb +44 -0
  190. data/test/log/spec_process-log.rb +88 -0
  191. data/test/log/spec_process-record.rb +148 -0
  192. data/test/log/spec_system-log.rb +142 -0
  193. data/test/log/spec_xes-log.rb +2 -2
  194. data/test/model/spec_assignment.rb +26 -25
  195. data/test/model/spec_block.rb +51 -97
  196. data/test/model/spec_boolean.rb +0 -5
  197. data/test/model/spec_call-rule.rb +6 -6
  198. data/test/model/spec_data-expr.rb +0 -7
  199. data/test/model/spec_data-expr.yml +8 -0
  200. data/test/model/spec_float.rb +1 -1
  201. data/test/model/spec_float.yml +13 -0
  202. data/test/model/spec_integer.rb +1 -1
  203. data/test/model/spec_integer.yml +12 -1
  204. data/test/model/spec_keyed-sequence.yml +5 -0
  205. data/test/model/spec_message.rb +2 -4
  206. data/test/model/spec_package-expr.rb +19 -0
  207. data/test/model/spec_parameters.rb +56 -88
  208. data/test/model/spec_pione-method.rb +15 -14
  209. data/test/model/spec_rule-expr.rb +4 -52
  210. data/test/model/spec_rule-expr.yml +11 -0
  211. data/test/model/spec_sequence.yml +6 -0
  212. data/test/model/spec_string.rb +21 -13
  213. data/test/model/spec_string.yml +10 -2
  214. data/test/model/spec_ticket-expr.rb +25 -3
  215. data/test/model/spec_variable.rb +8 -8
  216. data/test/rule-handler/spec_action-handler.pione +37 -0
  217. data/test/rule-handler/spec_action-handler.rb +41 -97
  218. data/test/rule-handler/spec_flow-handler.rb +24 -30
  219. data/test/rule-handler/spec_update-criteria.pione +16 -0
  220. data/test/rule-handler/spec_update-criteria.rb +7 -4
  221. data/test/rule-handler/spec_update-criteria.yml +191 -0
  222. data/test/system/spec_domain-info.rb +25 -0
  223. data/test/test-util.rb +38 -228
  224. data/test/transformer/spec_block-transformer.rb +1 -1
  225. data/test/transformer/spec_expr-transformer.rb +30 -39
  226. data/test/transformer/spec_flow-element-transformer.rb +17 -17
  227. data/test/transformer/spec_literal-transformer.rb +3 -3
  228. data/test/transformer/spec_rule-definition-transformer.rb +55 -76
  229. data/test/{spec_data-finder.rb → tuple-space/spec_data-finder.rb} +1 -1
  230. data/test/{spec_data-finder.yml → tuple-space/spec_data-finder.yml} +0 -0
  231. data/test/tuple/spec_data-tuple.rb +5 -76
  232. data/test/tuple/spec_finished-tuple.rb +5 -46
  233. data/test/tuple/spec_message-tuple.rb +10 -0
  234. data/test/tuple/spec_task-tuple.rb +4 -110
  235. data/test/tuple/spec_touch-tuple.rb +14 -0
  236. data/test/tuple/tuple-behavior.rb +14 -0
  237. data/test/uri-scheme/spec_local-scheme.rb +1 -1
  238. data/test/uri-scheme/spec_myftp-scheme.rb +73 -0
  239. data/test/uri-scheme/spec_myftp-scheme.yml +85 -0
  240. data/test/util/spec_cpu.rb +8 -0
  241. data/test/util/spec_error-report.rb +42 -0
  242. data/test/util/spec_evaluatable.rb +18 -0
  243. data/test/util/spec_ftp-server.rb +249 -0
  244. data/test/util/spec_id.pione +14 -0
  245. data/test/util/spec_id.rb +77 -0
  246. data/test/util/spec_indentation.rb +77 -0
  247. data/test/util/spec_ip-address.rb +15 -0
  248. data/test/util/spec_uuid.rb +11 -0
  249. data/test/util/spec_variable-holdable.rb +69 -0
  250. metadata +282 -83
  251. data/bin/pione-eval +0 -111
  252. data/demo/demo.rb +0 -311
  253. data/demo/public/base.css +0 -94
  254. data/demo/public/demo.js +0 -107
  255. data/demo/public/index.html +0 -91
  256. data/demo/public/jquery-1.8.3.min.js +0 -2
  257. data/lib/pione/model/binary-operator.rb +0 -90
  258. data/lib/pione/model/list.rb +0 -108
  259. data/lib/pione/model/package.rb +0 -56
  260. data/lib/pione/model/rule-io.rb +0 -178
  261. data/lib/pione/model/rule.rb +0 -295
  262. data/lib/pione/system/identifier.rb +0 -61
  263. data/lib/pione/tuple/log-tuple.rb +0 -14
  264. data/lib/pione/util/terminal.rb +0 -78
  265. data/test/log/data/sample.log +0 -1003
  266. data/test/model/spec_binary-operator.rb +0 -39
  267. data/test/model/spec_package.rb +0 -15
  268. data/test/model/spec_rule.rb +0 -158
  269. data/test/spec_identifier.rb +0 -29
  270. data/test/spec_log.rb +0 -52
@@ -1,6 +1,7 @@
1
1
  module Pione
2
2
  module Log
3
- # UnknownProcessRecordType is raised when we find unknown process types.
3
+ # UnknownProcessRecordType is raised when we find unknown process record
4
+ # types.
4
5
  class UnknownProcessRecordType < StandardError
5
6
  # @param type [Symbol]
6
7
  # type name
@@ -8,15 +9,18 @@ module Pione
8
9
  @type = type
9
10
  end
10
11
 
11
- # @api private
12
12
  def message
13
13
  'Unknown process type "%s"' % @type
14
14
  end
15
15
  end
16
16
 
17
17
  # ProcessRecord is a class that represents records of process log. Records
18
- # are in tuple spaces and handled by PIONE's logger agent.
18
+ # are in tuple spaces and handled by PIONE's process logger agent. If you
19
+ # want to add record type, you need to create the subclass of this.
19
20
  class ProcessRecord
21
+ include SimpleIdentity
22
+ ignore_identity :log_id
23
+
20
24
  # known process record types and classes
21
25
  TYPE_TABLE = {}
22
26
 
@@ -52,15 +56,19 @@ module Pione
52
56
  #
53
57
  # @param name [Symbol]
54
58
  # field name of the record
59
+ # @param type [Class]
60
+ # field data type
55
61
  # @return [void]
56
62
  def field(name)
57
63
  unless (@fields ||= []).include?(name)
58
64
  @fields << name
59
65
 
66
+ # field reader
60
67
  define_method(name) do
61
68
  instance_variable_get("@%s" % name)
62
69
  end
63
70
 
71
+ # field writer
64
72
  define_method("%s=" % name) do |val|
65
73
  val = Time.parse(val) if name == :timestamp and val.kind_of?(String)
66
74
  instance_variable_set("@%s" % name, val)
@@ -68,9 +76,10 @@ module Pione
68
76
  end
69
77
  end
70
78
 
71
- # @api private
72
- def inherited(klass)
73
- klass.instance_variable_set(:@fields, @fields.clone)
79
+ # Subclass inherites superclass's fields.
80
+ def inherited(subclass)
81
+ subclass.instance_variable_set(:@__ignore_identities__, @__ignore_identities__.clone)
82
+ subclass.instance_variable_set(:@fields, @fields.clone)
74
83
  end
75
84
  end
76
85
 
@@ -84,6 +93,11 @@ module Pione
84
93
  # transition name
85
94
  field :transition
86
95
 
96
+ # @!attribute [rw]
97
+ # @return [String]
98
+ # log_id
99
+ field :log_id
100
+
87
101
  forward! :class, :type, :fields
88
102
 
89
103
  # Create a new process log record.
@@ -106,15 +120,15 @@ module Pione
106
120
  end
107
121
  end
108
122
 
109
- # Format as JSON string.
123
+ # Format as a JSON string.
110
124
  #
111
125
  # @return [String]
112
126
  # JSON string
113
- def format
114
- JSON.dump(to_hash)
127
+ def format(log_id)
128
+ JSON.dump(to_hash.merge(log_id: log_id))
115
129
  end
116
130
 
117
- # Convert record into a hash table.
131
+ # Convert the record into a hash table.
118
132
  #
119
133
  # @return [Hash]
120
134
  # hash table representation of the record
@@ -129,7 +143,6 @@ module Pione
129
143
  end
130
144
  end
131
145
 
132
- # @api private
133
146
  def to_json(*args)
134
147
  to_hash.to_json(*args)
135
148
  end
@@ -0,0 +1,107 @@
1
+ module Pione
2
+ module Log
3
+ module SystemLog
4
+ # Log the fatal message.
5
+ #
6
+ # @param msg [String]
7
+ # the fatal message
8
+ def fatal(msg)
9
+ Global.system_logger.fatal(msg)
10
+ end
11
+ module_function :fatal
12
+
13
+ # Log the error message.
14
+ #
15
+ # @param msg [String]
16
+ # the error message
17
+ def error(msg)
18
+ Global.system_logger.error(msg)
19
+ end
20
+ module_function :error
21
+
22
+ # Log the warn message.
23
+ #
24
+ # @param msg [String]
25
+ # the warn message
26
+ def warn(msg)
27
+ Global.system_logger.warn(msg)
28
+ end
29
+ module_function :warn
30
+
31
+ # Log the info message.
32
+ #
33
+ # @param msg [String]
34
+ # the info message
35
+ def info(msg)
36
+ Global.system_logger.info(msg)
37
+ end
38
+ module_function :info
39
+
40
+ # Log the debug message.
41
+ #
42
+ # @param msg [String]
43
+ # the debug message
44
+ def debug(msg)
45
+ Global.system_logger.debug(msg)
46
+ end
47
+ module_function :debug
48
+ end
49
+
50
+ class SystemLogger
51
+ # Log the fatal message.
52
+ #
53
+ # @param msg [String]
54
+ # the fatal message
55
+ def fatal(msg)
56
+ raise NotImplementedError
57
+ end
58
+
59
+ # Log the error message.
60
+ #
61
+ # @param msg [String]
62
+ # the error message
63
+ def error(msg)
64
+ raise NotImplementedError
65
+ end
66
+
67
+ # Log the warn message.
68
+ #
69
+ # @param msg [String]
70
+ # the warn message
71
+ def warn(msg)
72
+ raise NotImplementedError
73
+ end
74
+
75
+ # Log the info message.
76
+ #
77
+ # @param msg [String]
78
+ # the info message
79
+ def info(msg)
80
+ raise NotImplementedError
81
+ end
82
+
83
+ # Log the debug message.
84
+ #
85
+ # @param msg [String]
86
+ # the debug message
87
+ def debug(msg)
88
+ raise NotImplementedError
89
+ end
90
+ end
91
+
92
+ # StandardSystemLogger is a logger using Ruby standard Logger.
93
+ class StandardSystemLogger
94
+ forward! :@logger, :fatal, :error, :warn, :info, :debug
95
+
96
+ def initialize(out)
97
+ @logger = Logger.new(out)
98
+ end
99
+ end
100
+
101
+ class SyslogSystemLogger < StandardSystemLogger
102
+ def initialize
103
+ @logger = Logger::Syslog.new('pione')
104
+ end
105
+ end
106
+ end
107
+ end
@@ -1,9 +1,21 @@
1
1
  module Pione
2
2
  module Log
3
3
  # XESLog is a class for XES formatted log.
4
- class XESLog < ProcessLogFormatter
4
+ class XESLog < ProcessLog
5
5
  set_format_name :xes
6
6
 
7
+ attr_reader :agent_activity_log
8
+ attr_reader :rule_process_log
9
+ attr_reader :task_process_log
10
+
11
+ # @param records [Array<ProcessRecord>]
12
+ # log records
13
+ def initialize(records)
14
+ @agent_activity_log = AgentActivityLog.new(records)
15
+ @rule_process_log = RuleProcessLog.new(records)
16
+ @task_process_log = TaskProcessLog.new(records)
17
+ end
18
+
7
19
  # Format as a XML document.
8
20
  #
9
21
  # @return [String]
@@ -14,7 +26,7 @@ module Pione
14
26
  XES::Document.new.tap do |doc|
15
27
  doc.log = XES::Log.default.tap do |log|
16
28
  log.concept_name = "PIONE process log"
17
- log.traces += [format_agent_activity + format_rule_process + format_task_process].flatten.select(&filter)
29
+ log.traces += [format_agent_activity + [format_rule_process, format_task_process]].flatten.select(&filter)
18
30
  log.traces.flatten!
19
31
  end
20
32
  if doc.formattable?
@@ -33,43 +45,39 @@ module Pione
33
45
  #
34
46
  # @return [Array<XES::Trace>]
35
47
  def format_agent_activity
36
- @bundles.map do |bundle|
37
- bundle.agent_activity_log.group_by(:agent_uuid).map do |agent_uuid, records|
38
- XES::Trace.new.tap do |trace|
39
- trace.attributes << XES.string("pione:traceType", "agent_activity")
40
- trace.identity_id = agent_uuid
41
- trace.events = records.sort{|a, b| a.timestamp <=> b.timestamp}.map do |record|
42
- XES::Event.new.tap do |event|
43
- event.concept_name = record.state
44
- event.org_resource = record.agent_type
45
- event.time_timestamp = record.timestamp
46
- event.lifecycle_transition = record.transition
47
- end
48
+ @agent_activity_log.group_by(:agent_uuid).map do |agent_uuid, records|
49
+ XES::Trace.new.tap do |trace|
50
+ trace.attributes << XES.string("pione:traceType", "agent_activity")
51
+ trace.identity_id = agent_uuid
52
+ trace.events = records.sort{|a, b| a.timestamp <=> b.timestamp}.map do |record|
53
+ XES::Event.new.tap do |event|
54
+ event.concept_name = record.state
55
+ event.org_resource = record.agent_type
56
+ event.time_timestamp = record.timestamp
57
+ event.lifecycle_transition = record.transition
48
58
  end
49
59
  end
50
- end.flatten
51
- end
60
+ end
61
+ end.flatten
52
62
  end
53
63
 
54
64
  # Format rule process records.
55
65
  #
56
- # @return [Array<XES::Trace>]
66
+ # @return [XES::Trace]
57
67
  def format_rule_process
58
- @bundles.map do |bundle|
59
- XES::Trace.new.tap do |trace|
60
- trace.concept_name = "rule_process %s" % Util.generate_uuid
61
- trace.attributes << XES.string("pione:traceType", "rule_process")
62
- trace.events = bundle.rule_process_log.records.map do |record|
63
- XES::Event.new.tap do |event|
64
- # standard attributes
65
- event.concept_name = record.name
66
- event.org_resource = record.caller
67
- event.time_timestamp = record.timestamp
68
- event.lifecycle_transition = record.transition
68
+ XES::Trace.new.tap do |trace|
69
+ trace.concept_name = "rule_process %s" % Util::UUID.generate
70
+ trace.attributes << XES.string("pione:traceType", "rule_process")
71
+ trace.events = @rule_process_log.records.map do |record|
72
+ XES::Event.new.tap do |event|
73
+ # standard attributes
74
+ event.concept_name = record.name
75
+ event.org_resource = record.caller
76
+ event.time_timestamp = record.timestamp
77
+ event.lifecycle_transition = record.transition
69
78
 
70
- # pione extension attributes
71
- event.attributes << XES.string("pione:ruleType", record.rule_type)
72
- end
79
+ # pione extension attributes
80
+ event.attributes << XES.string("pione:ruleType", record.rule_type)
73
81
  end
74
82
  end
75
83
  end
@@ -77,25 +85,23 @@ module Pione
77
85
 
78
86
  # Format task process records.
79
87
  #
80
- # @return [Array<XES::Trace>]
88
+ # @return [XES::Trace]
81
89
  def format_task_process
82
- @bundles.map do |bundle|
83
- XES::Trace.new.tap do |trace|
84
- trace.concept_name = "task process %s" % Util.generate_uuid
85
- trace.attributes << XES.string("pione:traceType", "task_process")
86
- trace.events = bundle.task_process_log.records.map do |record|
87
- XES::Event.new.tap do |event|
88
- # standard attributes
89
- event.concept_name = record.name
90
- # event.org_resource = record.caller
91
- event.time_timestamp = record.timestamp
92
- event.lifecycle_transition = record.transition
90
+ XES::Trace.new.tap do |trace|
91
+ trace.concept_name = "task process %s" % Util::UUID.generate
92
+ trace.attributes << XES.string("pione:traceType", "task_process")
93
+ trace.events = @task_process_log.records.map do |record|
94
+ XES::Event.new.tap do |event|
95
+ # standard attributes
96
+ event.concept_name = record.name
97
+ # event.org_resource = record.caller
98
+ event.time_timestamp = record.timestamp
99
+ event.lifecycle_transition = record.transition
93
100
 
94
- # pione extension attributes
95
- event.attributes << XES.string("pione:ruleType", record.rule_type)
96
- event.attributes << XES.string("pione:inputs", record.inputs)
97
- event.attributes << XES.string("pione:parameters", record.parameters)
98
- end
101
+ # pione extension attributes
102
+ event.attributes << XES.string("pione:ruleType", record.rule_type)
103
+ event.attributes << XES.string("pione:inputs", record.inputs)
104
+ event.attributes << XES.string("pione:parameters", record.parameters)
99
105
  end
100
106
  end
101
107
  end
data/lib/pione/model.rb CHANGED
@@ -14,16 +14,14 @@ require 'pione/model/variable'
14
14
  require 'pione/model/variable-table'
15
15
  require 'pione/model/data-expr'
16
16
  require 'pione/model/parameters'
17
- require 'pione/model/package'
17
+ require 'pione/model/package-expr'
18
18
  require 'pione/model/ticket-expr'
19
19
  require 'pione/model/rule-expr'
20
- require 'pione/model/binary-operator'
21
20
  require 'pione/model/message'
22
21
  require 'pione/model/call-rule'
23
22
  require 'pione/model/assignment'
24
23
  require 'pione/model/block'
25
24
  require 'pione/model/constraints'
26
- require 'pione/model/rule'
27
25
 
28
26
  module Pione
29
27
  # Model is a name space for all PIONE models.
@@ -43,6 +43,7 @@ module Pione
43
43
  # self
44
44
  def eval(vtable)
45
45
  vtable.set(@variable, @expr)
46
+ return @expr
46
47
  end
47
48
 
48
49
  # Set truth of toplevel assignment.
@@ -25,21 +25,26 @@ module Pione
25
25
  # MethodNotFound is an exception class for the case of method missing.
26
26
  class MethodNotFound < StandardError
27
27
  attr_reader :name
28
- attr_reader :obj
28
+ attr_reader :receiver
29
+ attr_reader :arguments
29
30
 
30
31
  # Creates an exception.
31
- # @param [String, Symbol] name
32
+ # @param name [String]
32
33
  # method name
33
- # @param [BasicModel] obj
34
+ # @param receiver [Callable]
34
35
  # method reciever
35
- def initialize(name, obj)
36
+ # @param arguments [Array<Callable>]
37
+ # method arguments
38
+ def initialize(name, receiver, *arguments)
36
39
  @name = name
37
- @obj = obj
40
+ @receiver = receiver
41
+ @arguments = arguments
38
42
  end
39
43
 
40
- # @api private
41
44
  def message
42
- "PIONE method \"%s\" is not found in %s" % [@name, @obj.inspect]
45
+ rec_type = @receiver.pione_model_type
46
+ arg_types = @arguments.map{|arg| arg.pione_model_type}.join(" -> ")
47
+ "PIONE method \"%s\" is not found: %s. %s" % [@name, rec_type, arg_types]
43
48
  end
44
49
  end
45
50
 
@@ -162,17 +167,19 @@ module Pione
162
167
 
163
168
  # Call pione model object method.
164
169
  #
165
- # @param [String] name
166
- # method name
167
- # @param [Array] args
170
+ # @param vtable [VariableTable]
171
+ # variable table
172
+ # @param name [String]
173
+ # method's name
174
+ # @param args [Array]
168
175
  # method's arguments
169
176
  # @return [Object]
170
- # method's result
171
- def call_pione_method(name, *args)
177
+ # the result
178
+ def call_pione_method(vtable, name, *args)
172
179
  if pione_method = pione_model_type.find_method(name, self, *args)
173
- pione_method.call(self, *args)
180
+ pione_method.call(vtable, self, *args)
174
181
  else
175
- raise MethodNotFound.new(name, self)
182
+ raise MethodNotFound.new(name, self, *args)
176
183
  end
177
184
  end
178
185
 
@@ -184,6 +191,8 @@ module Pione
184
191
  end
185
192
 
186
193
  class Element < BasicModel
194
+ include SimpleIdentity
195
+
187
196
  class << self
188
197
  attr_reader :sequence_class
189
198
 
@@ -200,13 +209,20 @@ module Pione
200
209
  end
201
210
 
202
211
  class Value < Element
212
+ include SimpleIdentity
213
+
203
214
  attr_reader :value
204
215
 
205
- # @param value [Integer]
216
+ # @param value [Object]
206
217
  # value in ruby
207
218
  def initialize(value)
208
219
  @value = value
209
220
  end
221
+
222
+ def inspect
223
+ '#<%s "%s">' % [self.class.name, @value]
224
+ end
225
+ alias :to_s :inspect
210
226
  end
211
227
  end
212
228
  end