metamodels.alt 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341
  1. include "primitives.alh"
  2. include "object_operations.alh"
  3. include "library.alh"
  4. include "conformance_scd.alh"
  5. include "modelling.alh"
  6. include "typing.alh"
  7. String function constraint_Natural(model : Element, name : String):
  8. Element self
  9. self = model["model"][name]
  10. if (is_physical_int(self)):
  11. if (integer_gte(self, 0)):
  12. return "OK"!
  13. else:
  14. return "Natural number not larger than or equal to zero"!
  15. else:
  16. return "Natural number not larger than or equal to zero"!
  17. Element function constraint_String(model : Element, name : String):
  18. Element self
  19. self = model["model"][name]
  20. if (is_physical_string(self)):
  21. return "OK"!
  22. else:
  23. return "String has non-string instance"!
  24. Element function constraint_Boolean(model : Element, name : String):
  25. Element self
  26. self = model["model"][name]
  27. if (is_physical_boolean(self)):
  28. return "OK"!
  29. else:
  30. return "Boolean has non-boolean instance"!
  31. Element function constraint_Location(model : Element, name : String):
  32. Element self
  33. self = model["model"][name]
  34. if (is_physical_string(self)):
  35. if (element_neq(import_node(self), read_root())):
  36. return "OK"!
  37. else:
  38. return "Location references non-existing element!"!
  39. else:
  40. return "Location has non-string instance"!
  41. Element function constraint_ActionLanguage(model : Element, name : String):
  42. Element self
  43. self = model["model"][name]
  44. if (is_physical_string(self)):
  45. if (element_neq(import_node(self), read_root())):
  46. return "OK"!
  47. else:
  48. return "ActionLanguage references non-existing element!"!
  49. else:
  50. return "ActionLanguage has non-string value!"!
  51. Element function initialize_SCD(location : String):
  52. if (element_neq(import_node(location), read_root())):
  53. return import_node(location)!
  54. Element scd
  55. String al_location
  56. al_location = "models/ActionLanguage"
  57. scd = instantiate_bottom()
  58. model_add_node(scd, "Element")
  59. model_add_node(scd, "Class")
  60. model_add_node(scd, "Attribute")
  61. model_add_node(scd, "SimpleAttribute")
  62. model_add_node(scd, "String")
  63. model_add_value(scd, "name_value", "name")
  64. model_add_edge(scd, "Association", "Class", "Class")
  65. model_add_edge(scd, "Inheritance", "Class", "Class")
  66. model_add_edge(scd, "AttributeLink", "Class", "Attribute")
  67. model_add_edge(scd, "attr_name", "AttributeLink", "String")
  68. model_add_edge(scd, "attr_name_name", "attr_name", "name_value")
  69. model_add_edge(scd, "class_inh_element", "Class", "Element")
  70. model_add_edge(scd, "attribute_inh_element", "Attribute", "Element")
  71. model_add_edge(scd, "simple_inh_attribute", "SimpleAttribute", "Attribute")
  72. model_add_edge(scd, "association_inh_element", "Association", "Class")
  73. model_add_edge(scd, "attributelink_inh_element", "AttributeLink", "Element")
  74. // Retype to self
  75. retype_model(scd, scd)
  76. retype(scd, "Element", "Class")
  77. retype(scd, "Class", "Class")
  78. retype(scd, "Attribute", "Class")
  79. retype(scd, "SimpleAttribute", "Class")
  80. retype(scd, "String", "SimpleAttribute")
  81. retype(scd, "name_value", "String")
  82. retype(scd, "Association", "Association")
  83. retype(scd, "Inheritance", "Association")
  84. retype(scd, "AttributeLink", "Association")
  85. retype(scd, "attr_name", "AttributeLink")
  86. retype(scd, "attr_name_name", "attr_name")
  87. retype(scd, "class_inh_element", "Inheritance")
  88. retype(scd, "attribute_inh_element", "Inheritance")
  89. retype(scd, "simple_inh_attribute", "Inheritance")
  90. retype(scd, "association_inh_element", "Inheritance")
  91. retype(scd, "attributelink_inh_element", "Inheritance")
  92. // Add some attributes, now that it is an ordinary model
  93. instantiate_node(scd, "SimpleAttribute", "Location")
  94. instantiate_attribute(scd, "Location", "name", "Location")
  95. instantiate_node(scd, "SimpleAttribute", "Natural")
  96. instantiate_attribute(scd, "Natural", "name", "Natural")
  97. instantiate_node(scd, "SimpleAttribute", "Boolean")
  98. instantiate_attribute(scd, "Boolean", "name", "Boolean")
  99. instantiate_link(scd, "AttributeLink", "attr_optional", "AttributeLink", "Boolean")
  100. instantiate_attribute(scd, "attr_optional", "name", "optional")
  101. instantiate_attribute(scd, "attr_optional", "optional", False)
  102. instantiate_attribute(scd, "attr_name", "optional", False)
  103. instantiate_node(scd, "Class", "ActionLanguage")
  104. instantiate_link(scd, "Inheritance", "", "ActionLanguage", "Attribute")
  105. model_define_attribute(scd, "Class", "lower_cardinality", True, "Natural")
  106. model_define_attribute(scd, "Class", "upper_cardinality", True, "Natural")
  107. model_define_attribute(scd, "Association", "source_lower_cardinality", True, "Natural")
  108. model_define_attribute(scd, "Association", "target_lower_cardinality", True, "Natural")
  109. model_define_attribute(scd, "Association", "source_upper_cardinality", True, "Natural")
  110. model_define_attribute(scd, "Association", "target_upper_cardinality", True, "Natural")
  111. model_define_attribute(scd, "Class", "name", False, "String")
  112. model_define_attribute(scd, "Class", "abstract", True, "Boolean")
  113. model_define_attribute(scd, "SimpleAttribute", "name", False, "String")
  114. instantiate_attribute(scd, "String", "name", "String")
  115. instantiate_attribute(scd, "Element", "name", "Element")
  116. instantiate_attribute(scd, "Element", "abstract", True)
  117. instantiate_attribute(scd, "Attribute", "name", "Attribute")
  118. instantiate_attribute(scd, "Attribute", "abstract", True)
  119. instantiate_attribute(scd, "Class", "name", "Class")
  120. instantiate_attribute(scd, "Association", "name", "Association")
  121. instantiate_attribute(scd, "SimpleAttribute", "name", "SimpleAttribute")
  122. instantiate_attribute(scd, "Location", "name", "Location")
  123. instantiate_attribute(scd, "Natural", "name", "Natural")
  124. instantiate_attribute(scd, "Boolean", "name", "Boolean")
  125. instantiate_attribute(scd, "Inheritance", "name", "Inheritance")
  126. instantiate_attribute(scd, "AttributeLink", "name", "AttributeLink")
  127. // Export already, to allow AL to pick it up
  128. export_node(location, scd)
  129. // Add in the Action Language metamodel
  130. initialize_AL(location, al_location)
  131. // Define additional attributes that define functions
  132. instantiate_node(scd, "ActionLanguage", "ActionCode")
  133. instantiate_attribute(scd, "ActionLanguage", "name", "ActionLanguage")
  134. model_define_attribute(scd, "Element", "constraint", True, "ActionCode")
  135. // Define some constraints
  136. //instantiate_attribute_code(scd, "Natural", "constraint", constraint_Natural)
  137. //instantiate_attribute_code(scd, "String", "constraint", constraint_String)
  138. //instantiate_attribute_code(scd, "Boolean", "constraint", constraint_Boolean)
  139. //instantiate_attribute_code(scd, "Location", "constraint", constraint_Location)
  140. //instantiate_attribute_code(scd, "ActionLanguage", "constraint", constraint_ActionLanguage)
  141. instantiate_node(scd, "Class", "GlobalConstraint")
  142. model_define_attribute(scd, "GlobalConstraint", "global_constraint", False, "ActionCode")
  143. instantiate_attribute(scd, "GlobalConstraint", "name", "GlobalConstraint")
  144. dict_overwrite(scd, "types", get_type_mapping(scd))
  145. return scd!
  146. Void function initialize_AL(scd_location : String, export_location : String):
  147. // TODO this should be written in a file-based model and not created like this in the bootstrap
  148. Element model
  149. Element scd_model
  150. if (element_neq(import_node(export_location), read_root())):
  151. return!
  152. scd_model = import_node(scd_location)
  153. model = instantiate_model(scd_model)
  154. instantiate_node(model, "Class", "Element")
  155. instantiate_node(model, "Class", "Action")
  156. instantiate_node(model, "Class", "Statement")
  157. instantiate_node(model, "Class", "Expression")
  158. instantiate_node(model, "Class", "funcdef")
  159. instantiate_node(model, "Class", "param")
  160. instantiate_node(model, "Class", "param_dict")
  161. instantiate_node(model, "Class", "if")
  162. instantiate_node(model, "Class", "break")
  163. instantiate_node(model, "Class", "while")
  164. instantiate_node(model, "Class", "continue")
  165. instantiate_node(model, "Class", "assign")
  166. instantiate_node(model, "Class", "return")
  167. instantiate_node(model, "Class", "output")
  168. instantiate_node(model, "Class", "declare")
  169. instantiate_node(model, "Class", "global")
  170. instantiate_node(model, "Class", "access")
  171. instantiate_node(model, "Class", "constant")
  172. instantiate_node(model, "Class", "input")
  173. instantiate_node(model, "Class", "resolve")
  174. instantiate_node(model, "Class", "call")
  175. instantiate_node(model, "Class", "String")
  176. instantiate_node(model, "SimpleAttribute", "StringAttr")
  177. instantiate_node(model, "Class", "Initial")
  178. instantiate_attribute(model, "Initial", "lower_cardinality", 1)
  179. instantiate_attribute(model, "Initial", "upper_cardinality", 1)
  180. instantiate_link(model, "Association", "initial_funcdef", "Initial", "Action")
  181. instantiate_attribute(model, "initial_funcdef", "target_lower_cardinality", 1)
  182. instantiate_attribute(model, "initial_funcdef", "target_upper_cardinality", 1)
  183. instantiate_link(model, "Inheritance", "", "Action", "Element")
  184. instantiate_link(model, "Inheritance", "", "funcdef", "Action")
  185. instantiate_link(model, "Inheritance", "", "param", "Action")
  186. instantiate_link(model, "Inheritance", "", "param_dict", "Element")
  187. instantiate_link(model, "Inheritance", "", "Statement", "Action")
  188. instantiate_link(model, "Inheritance", "", "Expression", "Action")
  189. instantiate_link(model, "Inheritance", "", "resolve", "Statement")
  190. instantiate_link(model, "Inheritance", "", "if", "Statement")
  191. instantiate_link(model, "Inheritance", "", "break", "Statement")
  192. instantiate_link(model, "Inheritance", "", "continue", "Statement")
  193. instantiate_link(model, "Inheritance", "", "global", "Statement")
  194. instantiate_link(model, "Inheritance", "", "while", "Statement")
  195. instantiate_link(model, "Inheritance", "", "assign", "Statement")
  196. instantiate_link(model, "Inheritance", "", "return", "Statement")
  197. instantiate_link(model, "Inheritance", "", "call", "Statement")
  198. instantiate_link(model, "Inheritance", "", "declare", "Statement")
  199. instantiate_link(model, "Inheritance", "", "output", "Statement")
  200. instantiate_link(model, "Inheritance", "", "call", "Expression")
  201. instantiate_link(model, "Inheritance", "", "access", "Expression")
  202. instantiate_link(model, "Inheritance", "", "constant", "Expression")
  203. instantiate_link(model, "Inheritance", "", "input", "Expression")
  204. instantiate_link(model, "Inheritance", "", "String", "Element")
  205. instantiate_link(model, "Association", "dict_link", "Action", "Element")
  206. model_define_attribute(model, "dict_link", "name", False, "StringAttr")
  207. instantiate_link(model, "Association", "Statement_next", "Statement", "Statement")
  208. instantiate_link(model, "Association", "if_cond", "if", "Expression")
  209. instantiate_link(model, "Association", "if_then", "if", "Statement")
  210. instantiate_link(model, "Association", "if_else", "if", "Statement")
  211. instantiate_link(model, "Association", "while_cond", "while", "Expression")
  212. instantiate_link(model, "Association", "while_body", "while", "Statement")
  213. instantiate_link(model, "Association", "assign_var", "assign", "resolve")
  214. instantiate_link(model, "Association", "assign_value", "assign", "Expression")
  215. instantiate_link(model, "Association", "break_while", "break", "while")
  216. instantiate_link(model, "Association", "continue_while", "continue", "while")
  217. instantiate_link(model, "Association", "return_value", "return", "Expression")
  218. instantiate_link(model, "Association", "resolve_var", "resolve", "Element")
  219. instantiate_link(model, "Association", "access_var", "access", "resolve")
  220. instantiate_link(model, "Association", "constant_node", "constant", "Element")
  221. instantiate_link(model, "Association", "output_node", "output", "Expression")
  222. instantiate_link(model, "Association", "global_var", "global", "String")
  223. instantiate_link(model, "Association", "declare_var", "declare", "Element")
  224. instantiate_link(model, "Association", "param_name", "param", "String")
  225. instantiate_link(model, "Association", "param_value", "param", "Expression")
  226. instantiate_link(model, "Association", "param_next_param", "param", "param")
  227. instantiate_link(model, "Association", "funcdef_body", "funcdef", "Statement")
  228. instantiate_link(model, "Association", "funcdef_params", "funcdef", "param_dict")
  229. instantiate_link(model, "Association", "funcdef_mutable", "funcdef", "Element")
  230. instantiate_link(model, "Association", "call_func", "call", "Expression")
  231. instantiate_link(model, "Association", "call_params", "call", "param")
  232. instantiate_link(model, "Association", "call_last_param", "call", "param")
  233. instantiate_link(model, "Association", "param_dict_link", "param_dict", "Element")
  234. instantiate_link(model, "Inheritance", "", "Statement_next", "dict_link")
  235. instantiate_link(model, "Inheritance", "", "if_cond", "dict_link")
  236. instantiate_link(model, "Inheritance", "", "if_then", "dict_link")
  237. instantiate_link(model, "Inheritance", "", "if_else", "dict_link")
  238. instantiate_link(model, "Inheritance", "", "while_cond", "dict_link")
  239. instantiate_link(model, "Inheritance", "", "while_body", "dict_link")
  240. instantiate_link(model, "Inheritance", "", "assign_var", "dict_link")
  241. instantiate_link(model, "Inheritance", "", "assign_value", "dict_link")
  242. instantiate_link(model, "Inheritance", "", "break_while", "dict_link")
  243. instantiate_link(model, "Inheritance", "", "continue_while", "dict_link")
  244. instantiate_link(model, "Inheritance", "", "return_value", "dict_link")
  245. instantiate_link(model, "Inheritance", "", "resolve_var", "dict_link")
  246. instantiate_link(model, "Inheritance", "", "access_var", "dict_link")
  247. instantiate_link(model, "Inheritance", "", "constant_node", "dict_link")
  248. instantiate_link(model, "Inheritance", "", "output_node", "dict_link")
  249. instantiate_link(model, "Inheritance", "", "global_var", "dict_link")
  250. instantiate_link(model, "Inheritance", "", "declare_var", "dict_link")
  251. instantiate_link(model, "Inheritance", "", "param_name", "dict_link")
  252. instantiate_link(model, "Inheritance", "", "param_value", "dict_link")
  253. instantiate_link(model, "Inheritance", "", "param_next_param", "dict_link")
  254. instantiate_link(model, "Inheritance", "", "funcdef_body", "dict_link")
  255. instantiate_link(model, "Inheritance", "", "funcdef_params", "dict_link")
  256. instantiate_link(model, "Inheritance", "", "funcdef_mutable", "dict_link")
  257. instantiate_link(model, "Inheritance", "", "call_func", "dict_link")
  258. instantiate_link(model, "Inheritance", "", "call_params", "dict_link")
  259. instantiate_link(model, "Inheritance", "", "call_last_param", "dict_link")
  260. instantiate_link(model, "Inheritance", "", "param_dict_link", "dict_link")
  261. instantiate_attribute(model, "if_cond", "target_lower_cardinality", 1)
  262. instantiate_attribute(model, "if_then", "target_lower_cardinality", 1)
  263. instantiate_attribute(model, "while_cond", "target_lower_cardinality", 1)
  264. instantiate_attribute(model, "while_body", "target_lower_cardinality", 1)
  265. instantiate_attribute(model, "assign_var", "target_lower_cardinality", 1)
  266. instantiate_attribute(model, "assign_value", "target_lower_cardinality", 1)
  267. instantiate_attribute(model, "break_while", "target_lower_cardinality", 1)
  268. instantiate_attribute(model, "continue_while", "target_lower_cardinality", 1)
  269. instantiate_attribute(model, "resolve_var", "target_lower_cardinality", 1)
  270. instantiate_attribute(model, "access_var", "target_lower_cardinality", 1)
  271. instantiate_attribute(model, "constant_node", "target_lower_cardinality", 1)
  272. instantiate_attribute(model, "output_node", "target_lower_cardinality", 1)
  273. instantiate_attribute(model, "global_var", "target_lower_cardinality", 1)
  274. instantiate_attribute(model, "declare_var", "target_lower_cardinality", 1)
  275. instantiate_attribute(model, "param_name", "target_lower_cardinality", 1)
  276. instantiate_attribute(model, "param_value", "target_lower_cardinality", 1)
  277. instantiate_attribute(model, "funcdef_body", "target_lower_cardinality", 1)
  278. instantiate_attribute(model, "funcdef_params", "target_lower_cardinality", 1)
  279. instantiate_attribute(model, "call_func", "target_lower_cardinality", 1)
  280. instantiate_attribute(model, "Statement_next", "target_upper_cardinality", 1)
  281. instantiate_attribute(model, "if_cond", "target_upper_cardinality", 1)
  282. instantiate_attribute(model, "if_then", "target_upper_cardinality", 1)
  283. instantiate_attribute(model, "if_else", "target_upper_cardinality", 1)
  284. instantiate_attribute(model, "while_cond", "target_upper_cardinality", 1)
  285. instantiate_attribute(model, "while_body", "target_upper_cardinality", 1)
  286. instantiate_attribute(model, "assign_var", "target_upper_cardinality", 1)
  287. instantiate_attribute(model, "assign_value", "target_upper_cardinality", 1)
  288. instantiate_attribute(model, "break_while", "target_upper_cardinality", 1)
  289. instantiate_attribute(model, "continue_while", "target_upper_cardinality", 1)
  290. instantiate_attribute(model, "return_value", "target_upper_cardinality", 1)
  291. instantiate_attribute(model, "resolve_var", "target_upper_cardinality", 1)
  292. instantiate_attribute(model, "access_var", "target_upper_cardinality", 1)
  293. instantiate_attribute(model, "constant_node", "target_upper_cardinality", 1)
  294. instantiate_attribute(model, "output_node", "target_upper_cardinality", 1)
  295. instantiate_attribute(model, "global_var", "target_upper_cardinality", 1)
  296. instantiate_attribute(model, "declare_var", "target_upper_cardinality", 1)
  297. instantiate_attribute(model, "param_name", "target_upper_cardinality", 1)
  298. instantiate_attribute(model, "param_value", "target_upper_cardinality", 1)
  299. instantiate_attribute(model, "param_next_param", "target_upper_cardinality", 1)
  300. instantiate_attribute(model, "funcdef_body", "target_upper_cardinality", 1)
  301. instantiate_attribute(model, "funcdef_params", "target_upper_cardinality", 1)
  302. instantiate_attribute(model, "funcdef_mutable", "target_upper_cardinality", 1)
  303. instantiate_attribute(model, "call_func", "target_upper_cardinality", 1)
  304. instantiate_attribute(model, "call_params", "target_upper_cardinality", 1)
  305. instantiate_attribute(model, "call_last_param", "target_upper_cardinality", 1)
  306. dict_overwrite(model, "types", get_type_mapping(model))
  307. export_node(export_location, model)
  308. return !