ramify.alc 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. include "primitives.alh"
  2. include "object_operations.alh"
  3. include "modelling.alh"
  4. include "metamodels.alh"
  5. Element function ramify_func(model : Element, prepost : String):
  6. // Create new model structure
  7. Element new_model
  8. new_model = create_node()
  9. dict_add(new_model, "model", create_node())
  10. dict_add(new_model, "type_mapping", create_node())
  11. dict_add(new_model, "metamodel", model["metamodel"])
  12. dict_add(new_model, "inheritance", model["inheritance"])
  13. log("Copied basic data")
  14. // Get local variables for parts
  15. Element old_m
  16. Element new_m
  17. Element mm
  18. String inheritor
  19. new_m = new_model["model"]
  20. old_m = model["model"]
  21. mm = new_model["metamodel"]["model"]
  22. Boolean is_pre
  23. is_pre = (prepost == "pre")
  24. // Add in Natural and String
  25. log("Adding Natural and String")
  26. instantiate_node(new_model, "Class", "Natural")
  27. instantiate_node(new_model, "Class", "String")
  28. // Add in the complete AL metamodel
  29. //TODO this is broken right now because of the use of Any in the AL MM
  30. //add_AL_to_MM(new_model)
  31. //TODO temporarily add them like this
  32. instantiate_node(new_model, "Class", "Expression")
  33. instantiate_node(new_model, "Class", "FuncDef")
  34. log("Adding default elements")
  35. // Add some default elements
  36. if (is_pre):
  37. // Class LHS {
  38. // constraint : Expression {
  39. // target_upper_cardinality = 1
  40. // }
  41. // upper_cardinality = 1
  42. // lower_cardinality = 1
  43. // }
  44. log("LHS")
  45. instantiate_node(new_model, "Class", "LHS")
  46. instantiate_attribute(new_model, "LHS", "lower_cardinality", 1)
  47. instantiate_attribute(new_model, "LHS", "upper_cardinality", 1)
  48. instantiate_link(new_model, "Association", "LHS_constraint", "LHS", "Expression")
  49. instantiate_attribute(new_model, "LHS_constraint", "name", "constraint")
  50. instantiate_attribute(new_model, "LHS_constraint", "target_upper_cardinality", 1)
  51. log("LHS OK")
  52. // Class NAC {}
  53. instantiate_node(new_model, "Class", "NAC")
  54. log("NAC OK")
  55. // Class Pre_Element {
  56. // label : String {
  57. // target_lower_cardinality = 1
  58. // target_upper_cardinality = 1
  59. // }
  60. // constraint : Expression {
  61. // target_upper_cardinality = 1
  62. // }
  63. // }
  64. instantiate_node(new_model, "Class", "Pre_Element")
  65. instantiate_link(new_model, "Association", "Pre_Element_label", "Pre_Element", "String")
  66. instantiate_attribute(new_model, "Pre_Element_label", "name", "label")
  67. instantiate_attribute(new_model, "Pre_Element_label", "target_lower_cardinality", 1)
  68. instantiate_attribute(new_model, "Pre_Element_label", "target_upper_cardinality", 1)
  69. instantiate_link(new_model, "Association", "Pre_Element_constraint", "Pre_Element", "Expression")
  70. instantiate_attribute(new_model, "Pre_Element_constraint", "name", "constraint")
  71. instantiate_attribute(new_model, "Pre_Element_constraint", "target_upper_cardinality", 1)
  72. log("Pre_Element OK")
  73. // Association LHS_contains (LHS, Pre_Element) {}
  74. instantiate_link(new_model, "Association", "LHS_contains", "LHS", "Pre_Element")
  75. instantiate_attribute(new_model, "LHS_contains", "name", "contains")
  76. log("LHS_contains OK")
  77. // Association NAC_contains (NAC, Pre_Element) {}
  78. instantiate_link(new_model, "Association", "NAC_contains", "NAC", "Pre_Element")
  79. instantiate_attribute(new_model, "NAC_contains", "name", "contains")
  80. log("NAC_contains OK")
  81. inheritor = "Pre_Element"
  82. else:
  83. // Class RHS {
  84. // action : FuncDef {
  85. // target_upper_cardinality = 1
  86. // }
  87. // upper_cardinality = 1
  88. // lower_cardinality = 1
  89. // }
  90. log("RHS")
  91. instantiate_node(new_model, "Class", "RHS")
  92. instantiate_attribute(new_model, "RHS", "lower_cardinality", 1)
  93. instantiate_attribute(new_model, "RHS", "upper_cardinality", 1)
  94. instantiate_link(new_model, "Association", "RHS_action", "RHS", "FuncDef")
  95. instantiate_attribute(new_model, "RHS_action", "name", "action")
  96. instantiate_attribute(new_model, "RHS_action", "target_upper_cardinality", 1)
  97. log("RHS OK")
  98. // Class Post_Element {
  99. // label : String {
  100. // target_lower_cardinality = 1
  101. // target_upper_cardinality = 1
  102. // }
  103. // value : Expression {
  104. // target_upper_cardinality = 1
  105. // }
  106. // }
  107. instantiate_node(new_model, "Class", "Post_Element")
  108. instantiate_link(new_model, "Association", "Post_Element_label", "Post_Element", "String")
  109. instantiate_attribute(new_model, "Post_Element_label", "name", "label")
  110. instantiate_attribute(new_model, "Post_Element_label", "target_lower_cardinality", 1)
  111. instantiate_attribute(new_model, "Post_Element_label", "target_upper_cardinality", 1)
  112. instantiate_link(new_model, "Association", "Post_Element_value", "Post_Element", "Expression")
  113. instantiate_attribute(new_model, "Post_Element_value", "name", "value")
  114. instantiate_attribute(new_model, "Post_Element_value", "target_upper_cardinality", 1)
  115. log("Post_Element OK")
  116. // Association RHS_contains (RHS, Post_Element) {}
  117. instantiate_link(new_model, "Association", "RHS_contains", "RHS", "Post_Element")
  118. instantiate_attribute(new_model, "RHS_contains", "name", "contains")
  119. log("RHS_contains OK")
  120. inheritor = "Post_Element"
  121. // Basics are added, now we need to add each node and transition, but slightly modified
  122. Element keys
  123. String key
  124. Element new_entry
  125. Element entry
  126. String append
  127. if (is_pre):
  128. append = "Pre_"
  129. else:
  130. append = "Post_"
  131. keys = dict_keys(old_m)
  132. String type_name
  133. String old_source
  134. String old_target
  135. log("Iterate!")
  136. Element to_link
  137. to_link = create_node()
  138. while (read_nr_out(keys) > 0):
  139. key = set_pop(keys)
  140. entry = old_m[key]
  141. log("Try " + key)
  142. type_name = reverseKeyLookup(model["metamodel"]["model"], dict_read_node(model["type_mapping"], entry))
  143. log("Type Name: " + cast_e2s(type_name))
  144. if (type_name == "Class"):
  145. log("Class")
  146. instantiate_node(new_model, type_name, append + key)
  147. // Also make it inherit from the "root element"
  148. instantiate_link(new_model, "Inheritance", "", append + key, inheritor)
  149. elif (type_name == "Association"):
  150. log("Association")
  151. old_source = reverseKeyLookup(model["model"], read_edge_src(entry))
  152. old_target = reverseKeyLookup(model["model"], read_edge_dst(entry))
  153. instantiate_link(new_model, type_name, append + key, append + old_source, append + old_target)
  154. // 1) Make it inherit from the Root Element (Pre_Element or Post_Element)
  155. instantiate_link(new_model, "Inheritance", "", append + key, inheritor)
  156. elif (type_name == "Inheritance"):
  157. log("Inheritance")
  158. old_source = reverseKeyLookup(model["model"], read_edge_src(entry))
  159. old_target = reverseKeyLookup(model["model"], read_edge_dst(entry))
  160. instantiate_link(new_model, type_name, append + key, append + old_source, append + old_target)
  161. elif (bool_not(has_value(entry))):
  162. log("Attribute")
  163. create_edge(to_link, entry)
  164. while (read_nr_out(to_link) > 0):
  165. entry = set_pop(to_link)
  166. type_name = reverseKeyLookup(model["metamodel"]["model"], dict_read_node(model["type_mapping"], entry))
  167. // Primitive values themselves are not copied, so skip that here
  168. // An instance link, so just copy over (don't make element of Root Element), and don't even copy if it is lower cardinality
  169. // It is probably an attribute at the meta-language level, so check which one it is
  170. String name
  171. name = read_attribute(model["metamodel"], type_name, "name")
  172. if (bool_not(bool_or(bool_or(name == "lower_cardinality", name == "source_lower_cardinality"), bool_or(name == "constraint", name == "target_lower_cardinality")))):
  173. // Not a lower cardinality or constraint, so copy
  174. old_source = reverseKeyLookup(model["model"], read_edge_src(entry))
  175. if (bool_or(bool_or(name == "name", name == "upper_cardinality"), bool_or(name == "source_upper_cardinality", name == "target_upper_cardinality"))):
  176. // Keep the old name for the physical attributes!
  177. instantiate_attribute(new_model, append + old_source, name, read_edge_dst(entry))
  178. else:
  179. // Rename the attributes as well
  180. instantiate_attribute(new_model, append + old_source, append + name, read_edge_dst(entry))
  181. log("Finished")
  182. return new_model!
  183. Element function ramify(model : Element):
  184. Element rv
  185. rv = create_node()
  186. // Create Pre part
  187. log("PRE")
  188. dict_add(rv, "pre", ramify_func(model, "pre"))
  189. // Create Post part
  190. log("POST")
  191. dict_add(rv, "post", ramify_func(model, "post"))
  192. log("FINISHED")
  193. return rv!