ramify.alc 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. include "primitives.alh"
  2. include "object_operations.alh"
  3. include "modelling.alh"
  4. include "metamodels.alh"
  5. include "model_management.alh"
  6. Element function ramify(model : Element):
  7. // Create new model structure
  8. Element new_model
  9. new_model = create_node()
  10. dict_add(new_model, "model", create_node())
  11. dict_add(new_model, "type_mapping", create_node())
  12. dict_add(new_model, "metamodel", model["metamodel"])
  13. dict_add(new_model, "source", model)
  14. dict_add(new_model, "target", model)
  15. // Get local variables for parts
  16. Element old_m
  17. Element new_m
  18. Element mm
  19. new_m = new_model["model"]
  20. old_m = model["model"]
  21. mm = new_model["metamodel"]["model"]
  22. // Add in some primitives
  23. instantiate_node(new_model, "Class", "Natural")
  24. instantiate_node(new_model, "Class", "String")
  25. instantiate_node(new_model, "Class", "Any")
  26. // Add in the complete AL metamodel
  27. add_AL_to_MM(new_model)
  28. // Add some default elements
  29. // Class LHS {
  30. // constraint : funcdef {
  31. // target_upper_cardinality = 1
  32. // }
  33. // upper_cardinality = 1
  34. // lower_cardinality = 1
  35. // }
  36. instantiate_node(new_model, "Class", "LHS")
  37. instantiate_attribute(new_model, "LHS", "lower_cardinality", 1)
  38. instantiate_attribute(new_model, "LHS", "upper_cardinality", 1)
  39. instantiate_link(new_model, "Association", "LHS_constraint", "LHS", "funcdef")
  40. instantiate_attribute(new_model, "LHS_constraint", "name", "constraint")
  41. instantiate_attribute(new_model, "LHS_constraint", "target_upper_cardinality", 1)
  42. // Class Pre_Element {
  43. // label : String {
  44. // target_lower_cardinality = 1
  45. // target_upper_cardinality = 1
  46. // }
  47. // constraint : funcdef {
  48. // target_upper_cardinality = 1
  49. // }
  50. // }
  51. instantiate_node(new_model, "Class", "Pre_Element")
  52. instantiate_link(new_model, "Association", "Pre_Element_label", "Pre_Element", "String")
  53. instantiate_attribute(new_model, "Pre_Element_label", "name", "label")
  54. instantiate_attribute(new_model, "Pre_Element_label", "target_lower_cardinality", 1)
  55. instantiate_attribute(new_model, "Pre_Element_label", "target_upper_cardinality", 1)
  56. instantiate_link(new_model, "Association", "Pre_Element_constraint", "Pre_Element", "funcdef")
  57. instantiate_attribute(new_model, "Pre_Element_constraint", "name", "constraint")
  58. instantiate_attribute(new_model, "Pre_Element_constraint", "target_upper_cardinality", 1)
  59. // Association LHS_contains (LHS, Pre_Element) {}
  60. instantiate_link(new_model, "Association", "LHS_contains", "LHS", "Pre_Element")
  61. instantiate_attribute(new_model, "LHS_contains", "name", "contains")
  62. // Class RHS {
  63. // action : FuncDef {
  64. // target_upper_cardinality = 1
  65. // }
  66. // upper_cardinality = 1
  67. // lower_cardinality = 1
  68. // }
  69. instantiate_node(new_model, "Class", "RHS")
  70. instantiate_attribute(new_model, "RHS", "lower_cardinality", 1)
  71. instantiate_attribute(new_model, "RHS", "upper_cardinality", 1)
  72. instantiate_link(new_model, "Association", "RHS_action", "RHS", "funcdef")
  73. instantiate_attribute(new_model, "RHS_action", "name", "action")
  74. instantiate_attribute(new_model, "RHS_action", "target_upper_cardinality", 1)
  75. // Class Post_Element {
  76. // label : String {
  77. // target_lower_cardinality = 1
  78. // target_upper_cardinality = 1
  79. // }
  80. // value : funcdef {
  81. // target_upper_cardinality = 1
  82. // }
  83. // action : funcdef {
  84. // target_upper_cardinality = 1
  85. // }
  86. // }
  87. instantiate_node(new_model, "Class", "Post_Element")
  88. instantiate_link(new_model, "Association", "Post_Element_label", "Post_Element", "String")
  89. instantiate_attribute(new_model, "Post_Element_label", "name", "label")
  90. instantiate_attribute(new_model, "Post_Element_label", "target_lower_cardinality", 1)
  91. instantiate_attribute(new_model, "Post_Element_label", "target_upper_cardinality", 1)
  92. instantiate_link(new_model, "Association", "Post_Element_value", "Post_Element", "funcdef")
  93. instantiate_attribute(new_model, "Post_Element_value", "name", "value")
  94. instantiate_attribute(new_model, "Post_Element_value", "target_upper_cardinality", 1)
  95. instantiate_link(new_model, "Association", "Post_Element_action", "Post_Element", "funcdef")
  96. instantiate_attribute(new_model, "Post_Element_action", "name", "action")
  97. instantiate_attribute(new_model, "Post_Element_action", "target_upper_cardinality", 1)
  98. // Association RHS_contains (RHS, Post_Element) {}
  99. instantiate_link(new_model, "Association", "RHS_contains", "RHS", "Post_Element")
  100. instantiate_attribute(new_model, "RHS_contains", "name", "contains")
  101. // Basics are added, now we need to add each node and transition, but slightly modified
  102. Element keys
  103. String key
  104. Element new_entry
  105. Element entry
  106. keys = dict_keys(old_m)
  107. String type_name
  108. String old_source
  109. String old_target
  110. Element to_link
  111. to_link = create_node()
  112. while (read_nr_out(keys) > 0):
  113. key = set_pop(keys)
  114. entry = old_m[key]
  115. type_name = reverseKeyLookup(model["metamodel"]["model"], dict_read_node(model["type_mapping"], entry))
  116. if (type_name == "Class"):
  117. instantiate_node(new_model, type_name, "Pre_" + key)
  118. instantiate_node(new_model, type_name, "Post_" + key)
  119. // Also make it inherit from the "root element"
  120. instantiate_link(new_model, "Inheritance", "", "Pre_" + key, "Pre_Element")
  121. instantiate_link(new_model, "Inheritance", "", "Post_" + key, "Post_Element")
  122. elif (type_name == "Association"):
  123. old_source = reverseKeyLookup(model["model"], read_edge_src(entry))
  124. old_target = reverseKeyLookup(model["model"], read_edge_dst(entry))
  125. instantiate_link(new_model, type_name, "Pre_" + key, "Pre_" + old_source, "Pre_" + old_target)
  126. instantiate_link(new_model, type_name, "Post_" + key, "Post_" + old_source, "Post_" + old_target)
  127. // 1) Make it inherit from the Root Element (Pre_Element or Post_Element)
  128. instantiate_link(new_model, "Inheritance", "", "Pre_" + key, "Pre_Element")
  129. instantiate_link(new_model, "Inheritance", "", "Post_" + key, "Post_Element")
  130. elif (type_name == "Inheritance"):
  131. old_source = reverseKeyLookup(model["model"], read_edge_src(entry))
  132. old_target = reverseKeyLookup(model["model"], read_edge_dst(entry))
  133. instantiate_link(new_model, type_name, "Pre_" + key, "Pre_" + old_source, "Pre_" + old_target)
  134. instantiate_link(new_model, type_name, "Post_" + key, "Post_" + old_source, "Post_" + old_target)
  135. elif (bool_not(has_value(entry))):
  136. create_edge(to_link, entry)
  137. while (read_nr_out(to_link) > 0):
  138. entry = set_pop(to_link)
  139. type_name = reverseKeyLookup(model["metamodel"]["model"], dict_read_node(model["type_mapping"], entry))
  140. // Primitive values themselves are not copied, so skip that here
  141. // An instance link, so just copy over (don't make element of Root Element), and don't even copy if it is lower cardinality
  142. // It is probably an attribute at the meta-language level, so check which one it is
  143. String name
  144. name = read_attribute(model["metamodel"], type_name, "name")
  145. if (bool_not(bool_or(bool_or(name == "lower_cardinality", name == "source_lower_cardinality"), bool_or(name == "constraint", name == "target_lower_cardinality")))):
  146. // Not a lower cardinality or constraint, so copy
  147. old_source = reverseKeyLookup(model["model"], read_edge_src(entry))
  148. if (bool_or(bool_or(name == "name", name == "upper_cardinality"), bool_or(name == "source_upper_cardinality", name == "target_upper_cardinality"))):
  149. // Keep the old name for the physical attributes!
  150. instantiate_attribute(new_model, "Pre_" + old_source, name, read_edge_dst(entry))
  151. instantiate_attribute(new_model, "Post_" + old_source, name, read_edge_dst(entry))
  152. else:
  153. // Rename the attributes as well
  154. instantiate_attribute(new_model, "Pre_" + old_source, "Pre_" + name, read_edge_dst(entry))
  155. instantiate_attribute(new_model, "Post_" + old_source, "Post_" + name, read_edge_dst(entry))
  156. // Define schedule over these elements
  157. // Class Entry {}
  158. instantiate_node(new_model, "Class", "Entry")
  159. // Class Success : Entry {}
  160. instantiate_node(new_model, "Class", "Success")
  161. instantiate_link(new_model, "Inheritance", "", "Success", "Entry")
  162. // Class Failure : Entry {}
  163. instantiate_node(new_model, "Class", "Failure")
  164. instantiate_link(new_model, "Inheritance", "", "Failure", "Entry")
  165. // Class Rule : Entry {}
  166. instantiate_node(new_model, "Class", "Rule")
  167. instantiate_link(new_model, "Inheritance", "", "Rule", "Entry")
  168. // Association OnSuccess(Rule, Entry){
  169. // target_lower_cardinality = 1
  170. // target_upper_cardinality = 1
  171. // }
  172. instantiate_link(new_model, "Association", "OnSuccess", "Rule", "Entry")
  173. instantiate_attribute(new_model, "OnSuccess", "target_lower_cardinality", 1)
  174. instantiate_attribute(new_model, "OnSuccess", "target_upper_cardinality", 1)
  175. // Association OnFailure(Rule, Entry){
  176. // target_lower_cardinality = 1
  177. // target_upper_cardinality = 1
  178. // }
  179. instantiate_link(new_model, "Association", "OnFailure", "Rule", "Entry")
  180. instantiate_attribute(new_model, "OnFailure", "target_lower_cardinality", 1)
  181. instantiate_attribute(new_model, "OnFailure", "target_upper_cardinality", 1)
  182. // Class Query : Rule {}
  183. instantiate_node(new_model, "Class", "Query")
  184. instantiate_link(new_model, "Inheritance", "", "Query", "Rule")
  185. // Association QueryLHS (Query, LHS) {
  186. // target_lower_cardinality = 1
  187. // target_upper_cardinality = 1
  188. // }
  189. instantiate_link(new_model, "Association", "QueryLHS", "Query", "LHS")
  190. instantiate_attribute(new_model, "QueryLHS", "target_lower_cardinality", 1)
  191. instantiate_attribute(new_model, "QueryLHS", "target_upper_cardinality", 1)
  192. // Class Atomic : Rule {}
  193. instantiate_node(new_model, "Class", "Atomic")
  194. instantiate_link(new_model, "Inheritance", "", "Atomic", "Rule")
  195. // Association AtomicLHS (Atomic, LHS) {
  196. // target_lower_cardinality = 1
  197. // target_upper_cardinality = 1
  198. // }
  199. instantiate_link(new_model, "Association", "AtomicLHS", "Atomic", "LHS")
  200. instantiate_attribute(new_model, "AtomicLHS", "target_lower_cardinality", 1)
  201. instantiate_attribute(new_model, "AtomicLHS", "target_upper_cardinality", 1)
  202. // Association AtomicRHS (Atomic, RHS) {
  203. // target_lower_cardinality = 1
  204. // target_upper_cardinality = 1
  205. // }
  206. instantiate_link(new_model, "Association", "AtomicRHS", "Atomic", "RHS")
  207. instantiate_attribute(new_model, "AtomicRHS", "target_lower_cardinality", 1)
  208. instantiate_attribute(new_model, "AtomicRHS", "target_upper_cardinality", 1)
  209. // Class ForAll : Atomic {}
  210. instantiate_node(new_model, "Class", "ForAll")
  211. instantiate_link(new_model, "Inheritance", "", "ForAll", "Atomic")
  212. // Class Composite : Rule {}
  213. instantiate_node(new_model, "Class", "Composite")
  214. instantiate_link(new_model, "Inheritance", "", "Composite", "Rule")
  215. // Association Initial(Composite, Entry){
  216. // target_lower_cardinality = 1
  217. // target_upper_cardinality = 1
  218. // }
  219. instantiate_link(new_model, "Association", "Initial", "Composite", "Entry")
  220. instantiate_attribute(new_model, "Initial", "target_lower_cardinality", 1)
  221. instantiate_attribute(new_model, "Initial", "target_upper_cardinality", 1)
  222. // Association Contains(Composite, Entry){
  223. // source_upper_cardinality = 1
  224. // target_lower_cardinality = 1
  225. // }
  226. instantiate_link(new_model, "Association", "Contains", "Composite", "Entry")
  227. instantiate_attribute(new_model, "Contains", "source_upper_cardinality", 1)
  228. instantiate_attribute(new_model, "Contains", "target_lower_cardinality", 1)
  229. return new_model!