executor.xml 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <class name="Executor">
  2. <relationships>
  3. <association name="parent" class="MvKController" min="1" max="1"/>
  4. </relationships>
  5. <constructor>
  6. <body>
  7. <![CDATA[
  8. self.mvs = ModelverseState("../../bootstrap/bootstrap.m.gz")
  9. self.request_queue = [("", "", "load_primitives", [], None, False)]
  10. self.mvs.GC = True
  11. self.mvk = ModelverseKernel(self.mvs.read_root()[0])
  12. self.first = True
  13. self.mvs_response = None
  14. self.mvs_operations = {
  15. "CN": self.mvs.create_node,
  16. "CE": self.mvs.create_edge,
  17. "CNV": self.mvs.create_nodevalue,
  18. "CD": self.mvs.create_dict,
  19. "RV": self.mvs.read_value,
  20. "RO": self.mvs.read_outgoing,
  21. "RI": self.mvs.read_incoming,
  22. "RE": self.mvs.read_edge,
  23. "RD": self.mvs.read_dict,
  24. "RDN": self.mvs.read_dict_node,
  25. "RDNE": self.mvs.read_dict_node_edge,
  26. "RDE": self.mvs.read_dict_edge,
  27. "RRD": self.mvs.read_reverse_dict,
  28. "RR": self.mvs.read_root,
  29. "RDK": self.mvs.read_dict_keys,
  30. "DE": self.mvs.delete_edge,
  31. "DN": self.mvs.delete_node,
  32. }
  33. ]]>
  34. </body>
  35. </constructor>
  36. <scxml initial="init">
  37. <parallel id="init">
  38. <state id="raw_exec">
  39. <state id="raw_exec">
  40. <transition event="raw_exec" target=".">
  41. <parameter name="operations"/>
  42. <parameter name="source"/>
  43. <script>
  44. reply = [self.mvs_operations[command[0]](*command[1]) for command in operations]
  45. </script>
  46. <raise event="raw_exec_reply" scope="narrow" target="source">
  47. <parameter expr="reply"/>
  48. </raise>
  49. </transition>
  50. <transition event="get_mvk" target=".">
  51. <parameter name="source"/>
  52. <raise event="get_mvk_reply" scope="narrow" target="source">
  53. <parameter expr="self.mvk"/>
  54. </raise>
  55. </transition>
  56. </state>
  57. </state>
  58. <state id="queue">
  59. <state id="queue">
  60. <transition event="execute" target=".">
  61. <parameter name="returnpath"/>
  62. <parameter name="taskname"/>
  63. <parameter name="operation"/>
  64. <parameter name="params"/>
  65. <parameter name="request_id"/>
  66. <script>
  67. self.request_queue.append((("/" + returnpath) if returnpath is not None else None, taskname, operation, params, request_id, True))
  68. </script>
  69. </transition>
  70. <transition event="execute_debug" target=".">
  71. <parameter name="returnpath"/>
  72. <parameter name="taskname"/>
  73. <parameter name="operation"/>
  74. <parameter name="params"/>
  75. <parameter name="request_id"/>
  76. <script>
  77. self.request_queue.append((("/" + returnpath) if returnpath is not None else None, taskname, operation, params, request_id, False))
  78. </script>
  79. </transition>
  80. </state>
  81. </state>
  82. <state id="execute" initial="idle">
  83. <state id="idle">
  84. <transition cond="self.request_queue" target="../execution"/>
  85. </state>
  86. <state id="execution">
  87. <onentry>
  88. <script>
  89. self.mvk.returnvalue = None
  90. self.mvk.success = True
  91. self.first = True
  92. self.returnpath, taskname, operation, params, self.request_id, self.mvk.allow_compiled = self.request_queue.pop(0)
  93. reply = None
  94. commands = []
  95. while 1:
  96. commands = self.mvk.execute_yields(taskname, operation, params, reply)
  97. if commands is None:
  98. break
  99. reply = [self.mvs_operations[command[0]](*(command[1]))[0] for command in commands]
  100. </script>
  101. </onentry>
  102. <transition cond="self.returnpath is not None" target="../idle">
  103. <raise event="executed" scope="narrow" target="'parent' + self.returnpath">
  104. <parameter expr="self.mvk.returnvalue"/>
  105. <parameter expr="self.mvk.success"/>
  106. <parameter expr="self.request_id"/>
  107. </raise>
  108. </transition>
  109. <transition cond="self.returnpath is None" target="../idle"/>
  110. </state>
  111. </state>
  112. </parallel>
  113. </scxml>
  114. </class>