metamodels.alc 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459
  1. include "primitives.alh"
  2. include "object_operations.alh"
  3. include "library.alh"
  4. include "conformance_scd.alh"
  5. include "modelling.alh"
  6. Element function constraint_natural(model : Element, name : String):
  7. if (is_physical_int(model["model"][name])):
  8. if (integer_gte(model["model"][name], 0)):
  9. return "OK"!
  10. else:
  11. return "Natural number not larger than or equal to zero"!
  12. else:
  13. return "Natural has non-integer instance"!
  14. Element function constraint_string(model : Element, name : String):
  15. if (is_physical_string(model["model"][name])):
  16. return "OK"!
  17. else:
  18. return "String has non-string instance"!
  19. Element function constraint_if(model : Element, name : String):
  20. if (is_physical_action(model["model"][name])):
  21. if (cast_a2s(model["model"][name]) == "if"):
  22. return "OK"!
  23. else:
  24. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  25. else:
  26. return "Expected physical action value"!
  27. Element function constraint_while(model : Element, name : String):
  28. if (is_physical_action(model["model"][name])):
  29. if (cast_a2s(model["model"][name]) == "while"):
  30. return "OK"!
  31. else:
  32. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  33. else:
  34. return "Expected physical action value"!
  35. Element function constraint_break(model : Element, name : String):
  36. if (is_physical_action(model["model"][name])):
  37. if (cast_a2s(model["model"][name]) == "break"):
  38. return "OK"!
  39. else:
  40. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  41. else:
  42. return "Expected physical action value"!
  43. Element function constraint_continue(model : Element, name : String):
  44. if (is_physical_action(model["model"][name])):
  45. if (cast_a2s(model["model"][name]) == "continue"):
  46. return "OK"!
  47. else:
  48. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  49. else:
  50. return "Expected physical action value"!
  51. Element function constraint_assign(model : Element, name : String):
  52. if (is_physical_action(model["model"][name])):
  53. if (cast_a2s(model["model"][name]) == "assign"):
  54. return "OK"!
  55. else:
  56. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  57. else:
  58. return "Expected physical action value"!
  59. Element function constraint_return(model : Element, name : String):
  60. if (is_physical_action(model["model"][name])):
  61. if (cast_a2s(model["model"][name]) == "return"):
  62. return "OK"!
  63. else:
  64. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  65. else:
  66. return "Expected physical action value"!
  67. Element function constraint_output(model : Element, name : String):
  68. if (is_physical_action(model["model"][name])):
  69. if (cast_a2s(model["model"][name]) == "output"):
  70. return "OK"!
  71. else:
  72. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  73. else:
  74. return "Expected physical action value"!
  75. Element function constraint_input(model : Element, name : String):
  76. if (is_physical_action(model["model"][name])):
  77. if (cast_a2s(model["model"][name]) == "input"):
  78. return "OK"!
  79. else:
  80. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  81. else:
  82. return "Expected physical action value"!
  83. Element function constraint_declare(model : Element, name : String):
  84. if (is_physical_action(model["model"][name])):
  85. if (cast_a2s(model["model"][name]) == "declare"):
  86. return "OK"!
  87. else:
  88. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  89. else:
  90. return "Expected physical action value"!
  91. Element function constraint_global(model : Element, name : String):
  92. if (is_physical_action(model["model"][name])):
  93. if (cast_a2s(model["model"][name]) == "global"):
  94. return "OK"!
  95. else:
  96. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  97. else:
  98. return "Expected physical action value"!
  99. Element function constraint_access(model : Element, name : String):
  100. if (is_physical_action(model["model"][name])):
  101. if (cast_a2s(model["model"][name]) == "access"):
  102. return "OK"!
  103. else:
  104. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  105. else:
  106. return "Expected physical action value"!
  107. Element function constraint_constant(model : Element, name : String):
  108. if (is_physical_action(model["model"][name])):
  109. if (cast_a2s(model["model"][name]) == "constant"):
  110. return "OK"!
  111. else:
  112. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  113. else:
  114. return "Expected physical action value"!
  115. Element function constraint_resolve(model : Element, name : String):
  116. if (is_physical_action(model["model"][name])):
  117. if (cast_a2s(model["model"][name]) == "resolve"):
  118. return "OK"!
  119. else:
  120. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  121. else:
  122. return "Expected physical action value"!
  123. Element function constraint_call(model : Element, name : String):
  124. if (is_physical_action(model["model"][name])):
  125. if (cast_a2s(model["model"][name]) == "call"):
  126. return "OK"!
  127. else:
  128. return "Got wrong action primitive: " + cast_a2s(model["model"][name])!
  129. else:
  130. return "Expected physical action value"!
  131. Element function initialize_SCD(location : String):
  132. if (import_node(location) != read_root()):
  133. return import_node(location)!
  134. Element scd
  135. scd = instantiate_bottom()
  136. // Initial model, typed using LTM_bottom
  137. model_add_node(scd, "Class")
  138. model_add_node(scd, "Any")
  139. model_add_node(scd, "String")
  140. model_add_value(scd, "name", "name")
  141. model_add_edge(scd, "Association", "Class", "Any")
  142. model_add_edge(scd, "Inheritance", "Class", "Class")
  143. model_add_edge(scd, "Association_attribute", "Association", "String")
  144. model_add_edge(scd, "Association_name", "Association_attribute", "name")
  145. model_add_edge(scd, "assoc_inh_class", "Association", "Class")
  146. model_add_edge(scd, "class_inh_any", "Class", "Any")
  147. model_add_edge(scd, "string_inh_any", "String", "Any")
  148. // Retype to a "real" LTM, which happens to be itself
  149. retype_model(scd, scd)
  150. retype(scd, "Class", "Class")
  151. retype(scd, "Any", "Class")
  152. retype(scd, "String", "Class")
  153. retype(scd, "name", "String")
  154. retype(scd, "Association", "Association")
  155. retype(scd, "Inheritance", "Association")
  156. retype(scd, "Association_attribute", "Association")
  157. retype(scd, "Association_name", "Association_attribute")
  158. retype(scd, "assoc_inh_class", "Inheritance")
  159. retype(scd, "class_inh_any", "Inheritance")
  160. retype(scd, "string_inh_any", "Inheritance")
  161. // Add some attributes, now that it is an ordinary model
  162. instantiate_node(scd, "Class", "Natural")
  163. instantiate_link(scd, "Association", "lc", "Class", "Natural")
  164. instantiate_attribute(scd, "lc", "name", "lower_cardinality")
  165. instantiate_link(scd, "Association", "uc", "Class", "Natural")
  166. instantiate_attribute(scd, "uc", "name", "upper_cardinality")
  167. instantiate_link(scd, "Association", "slc", "Association", "Natural")
  168. instantiate_attribute(scd, "slc", "name", "source_lower_cardinality")
  169. instantiate_link(scd, "Association", "suc", "Association", "Natural")
  170. instantiate_attribute(scd, "suc", "name", "source_upper_cardinality")
  171. instantiate_link(scd, "Association", "tlc", "Association", "Natural")
  172. instantiate_attribute(scd, "tlc", "name", "target_lower_cardinality")
  173. instantiate_link(scd, "Association", "tuc", "Association", "Natural")
  174. instantiate_attribute(scd, "tuc", "name", "target_upper_cardinality")
  175. // Add in the Action Language metamodel
  176. add_AL_to_MM(scd)
  177. // Now still allow for constraints on classes
  178. instantiate_link(scd, "Association", "constraint", "Class", "funcdef")
  179. instantiate_attribute(scd, "constraint", "name", "constraint")
  180. // Add constraints to all primitive classes
  181. //add_constraint(scd, "if", constraint_if)
  182. //add_constraint(scd, "while", constraint_while)
  183. //add_constraint(scd, "break", constraint_break)
  184. //add_constraint(scd, "continue", constraint_continue)
  185. //add_constraint(scd, "assign", constraint_assign)
  186. //add_constraint(scd, "return", constraint_return)
  187. //add_constraint(scd, "output", constraint_output)
  188. //add_constraint(scd, "input", constraint_input)
  189. //add_constraint(scd, "declare", constraint_declare)
  190. //add_constraint(scd, "global", constraint_global)
  191. //add_constraint(scd, "access", constraint_access)
  192. //add_constraint(scd, "constant", constraint_constant)
  193. //add_constraint(scd, "resolve", constraint_resolve)
  194. //add_constraint(scd, "call", constraint_call)
  195. // And add some, to enforce correct physical types
  196. add_constraint(scd, "Natural", constraint_natural)
  197. add_constraint(scd, "String", constraint_string)
  198. // Finally done, so export!
  199. export_node(location, scd)
  200. return scd!
  201. Element function initialize_PN(location_SCD : String, location_PN : String):
  202. Element pn
  203. Element scd
  204. scd = import_node(location_SCD)
  205. pn = instantiate_model(scd)
  206. instantiate_node(pn, "Class", "Place")
  207. instantiate_node(pn, "Class", "Transition")
  208. instantiate_node(pn, "Class", "Natural")
  209. instantiate_link(pn, "Association", "P2T", "Place", "Transition")
  210. instantiate_link(pn, "Association", "T2P", "Transition", "Place")
  211. instantiate_link(pn, "Association", "Place_tokens", "Place", "Natural")
  212. instantiate_attribute(pn, "Place_tokens", "name", "tokens")
  213. instantiate_attribute(pn, "Place_tokens", "target_lower_cardinality", 1)
  214. instantiate_attribute(pn, "Place_tokens", "target_upper_cardinality", 1)
  215. instantiate_link(pn, "Association", "P2T_weight", "P2T", "Natural")
  216. instantiate_attribute(pn, "P2T_weight", "name", "weight")
  217. instantiate_attribute(pn, "P2T_weight", "target_lower_cardinality", 1)
  218. instantiate_attribute(pn, "P2T_weight", "target_upper_cardinality", 1)
  219. instantiate_link(pn, "Association", "T2P_weight", "T2P", "Natural")
  220. instantiate_attribute(pn, "T2P_weight", "name", "weight")
  221. instantiate_attribute(pn, "T2P_weight", "target_lower_cardinality", 1)
  222. instantiate_attribute(pn, "T2P_weight", "target_upper_cardinality", 1)
  223. // Add constraint on the Natural
  224. add_constraint(pn, "Natural", constraint_natural)
  225. export_node(location_PN, pn)
  226. return pn!
  227. Element function initialize_FTG(location_SCD : String, location_FTG : String):
  228. Element ftg
  229. Element scd
  230. String attr
  231. scd = import_node(location_SCD)
  232. ftg = instantiate_model(scd)
  233. instantiate_node(ftg, "Class", "String")
  234. instantiate_node(ftg, "Class", "Formalism")
  235. attr = model_define_attribute(ftg, "Formalism", "location", "String")
  236. instantiate_attribute(ftg, attr, "target_lower_cardinality", 1)
  237. instantiate_attribute(ftg, attr, "target_upper_cardinality", 1)
  238. instantiate_link(ftg, "Association", "Transformation", "Formalism", "Formalism")
  239. attr = model_define_attribute(ftg, "Transformation", "location", "String")
  240. instantiate_attribute(ftg, attr, "target_lower_cardinality", 1)
  241. instantiate_attribute(ftg, attr, "target_upper_cardinality", 1)
  242. // Add constraint on the String
  243. add_constraint(ftg, "String", constraint_string)
  244. export_node(location_FTG, ftg)
  245. return ftg!
  246. Element function initialize_bottom(location_bottom : String):
  247. Element ltm_bottom
  248. ltm_bottom = instantiate_bottom()
  249. model_add_node(ltm_bottom, "Node")
  250. model_add_edge(ltm_bottom, "Edge", "Node", "Node")
  251. model_add_edge(ltm_bottom, "inheritance", "Node", "Node")
  252. model_add_edge(ltm_bottom, "__inh", "Edge", "Node")
  253. retype_model(ltm_bottom, ltm_bottom)
  254. retype(ltm_bottom, "Node", "Node")
  255. retype(ltm_bottom, "Edge", "Edge")
  256. retype(ltm_bottom, "inheritance", "Edge")
  257. retype(ltm_bottom, "__inh", "inheritance")
  258. export_node(location_bottom, ltm_bottom)
  259. return ltm_bottom!
  260. Element function create_metamodels():
  261. String location_SCD
  262. String location_PN
  263. String location_bottom
  264. String location_FTG
  265. location_SCD = "models/SimpleClassDiagrams"
  266. location_PN = "models/PetriNets"
  267. location_bottom = "models/LTM_bottom"
  268. location_FTG = "models/FTG"
  269. if (bool_not(dict_in(dict_read(dict_read(read_root(), "__hierarchy"), "models"), "SimpleClassDiagrams"))):
  270. initialize_SCD(location_SCD)
  271. if (bool_not(dict_in(dict_read(dict_read(read_root(), "__hierarchy"), "models"), "PetriNets"))):
  272. initialize_PN(location_SCD, location_PN)
  273. if (bool_not(dict_in(dict_read(dict_read(read_root(), "__hierarchy"), "models"), "FTG"))):
  274. initialize_FTG(location_SCD, location_FTG)
  275. if (bool_not(dict_in(dict_read(dict_read(read_root(), "__hierarchy"), "models"), "LTM_bottom"))):
  276. initialize_bottom(location_bottom)
  277. return dict_read(dict_read(read_root(), "__hierarchy"), "models")!
  278. Void function add_AL_to_MM(model : Element):
  279. instantiate_node(model, "Class", "Action")
  280. instantiate_node(model, "Class", "Statement")
  281. instantiate_node(model, "Class", "Expression")
  282. instantiate_node(model, "Class", "funcdef")
  283. instantiate_node(model, "Class", "param")
  284. instantiate_node(model, "Class", "if")
  285. instantiate_node(model, "Class", "break")
  286. instantiate_node(model, "Class", "while")
  287. instantiate_node(model, "Class", "continue")
  288. instantiate_node(model, "Class", "assign")
  289. instantiate_node(model, "Class", "return")
  290. instantiate_node(model, "Class", "output")
  291. instantiate_node(model, "Class", "declare")
  292. instantiate_node(model, "Class", "global")
  293. instantiate_node(model, "Class", "access")
  294. instantiate_node(model, "Class", "constant")
  295. instantiate_node(model, "Class", "input")
  296. instantiate_node(model, "Class", "resolve")
  297. instantiate_node(model, "Class", "call")
  298. instantiate_link(model, "Association", "dict_link", "Action", "Any")
  299. instantiate_link(model, "Association", "to_str", "dict_link", "String")
  300. instantiate_attribute(model, "to_str", "name", "name")
  301. instantiate_link(model, "Inheritance", "", "Action", "Any")
  302. instantiate_link(model, "Inheritance", "", "funcdef", "Action")
  303. instantiate_link(model, "Inheritance", "", "param", "Action")
  304. instantiate_link(model, "Inheritance", "", "Statement", "Action")
  305. instantiate_link(model, "Inheritance", "", "Expression", "Action")
  306. instantiate_link(model, "Inheritance", "", "resolve", "Statement")
  307. instantiate_link(model, "Inheritance", "", "if", "Statement")
  308. instantiate_link(model, "Inheritance", "", "break", "Statement")
  309. instantiate_link(model, "Inheritance", "", "continue", "Statement")
  310. instantiate_link(model, "Inheritance", "", "global", "Statement")
  311. instantiate_link(model, "Inheritance", "", "while", "Statement")
  312. instantiate_link(model, "Inheritance", "", "assign", "Statement")
  313. instantiate_link(model, "Inheritance", "", "return", "Statement")
  314. instantiate_link(model, "Inheritance", "", "call", "Statement")
  315. instantiate_link(model, "Inheritance", "", "declare", "Statement")
  316. instantiate_link(model, "Inheritance", "", "call", "Expression")
  317. instantiate_link(model, "Inheritance", "", "access", "Expression")
  318. instantiate_link(model, "Inheritance", "", "constant", "Expression")
  319. instantiate_link(model, "Inheritance", "", "input", "Expression")
  320. instantiate_link(model, "Association", "statement_next", "Statement", "Statement")
  321. instantiate_link(model, "Association", "if_cond", "if", "Expression")
  322. instantiate_link(model, "Association", "if_then", "if", "Statement")
  323. instantiate_link(model, "Association", "if_else", "if", "Statement")
  324. instantiate_link(model, "Association", "while_cond", "while", "Expression")
  325. instantiate_link(model, "Association", "while_body", "while", "Statement")
  326. instantiate_link(model, "Association", "assign_var", "assign", "Any")
  327. instantiate_link(model, "Association", "assign_value", "assign", "Expression")
  328. instantiate_link(model, "Association", "break_while", "break", "while")
  329. instantiate_link(model, "Association", "continue_while", "continue", "while")
  330. instantiate_link(model, "Association", "return_value", "return", "Expression")
  331. instantiate_link(model, "Association", "resolve_var", "resolve", "Any")
  332. instantiate_link(model, "Association", "access_var", "access", "Any")
  333. instantiate_link(model, "Association", "constant_node", "constant", "Any")
  334. instantiate_link(model, "Association", "output_node", "output", "Expression")
  335. instantiate_link(model, "Association", "global_var", "global", "String")
  336. instantiate_link(model, "Association", "param_name", "param", "String")
  337. instantiate_link(model, "Association", "param_value", "param", "Expression")
  338. instantiate_link(model, "Association", "param_next_param", "param", "param")
  339. instantiate_link(model, "Association", "funcdef_body", "funcdef", "Statement")
  340. instantiate_link(model, "Association", "call_func", "call", "Expression")
  341. instantiate_link(model, "Association", "call_params", "call", "param")
  342. instantiate_link(model, "Association", "call_last_param", "call", "param")
  343. instantiate_link(model, "Inheritance", "", "statement_next", "dict_link")
  344. instantiate_link(model, "Inheritance", "", "if_cond", "dict_link")
  345. instantiate_link(model, "Inheritance", "", "if_then", "dict_link")
  346. instantiate_link(model, "Inheritance", "", "if_else", "dict_link")
  347. instantiate_link(model, "Inheritance", "", "while_cond", "dict_link")
  348. instantiate_link(model, "Inheritance", "", "while_body", "dict_link")
  349. instantiate_link(model, "Inheritance", "", "assign_var", "dict_link")
  350. instantiate_link(model, "Inheritance", "", "assign_value", "dict_link")
  351. instantiate_link(model, "Inheritance", "", "break_while", "dict_link")
  352. instantiate_link(model, "Inheritance", "", "continue_while", "dict_link")
  353. instantiate_link(model, "Inheritance", "", "return_value", "dict_link")
  354. instantiate_link(model, "Inheritance", "", "resolve_var", "dict_link")
  355. instantiate_link(model, "Inheritance", "", "access_var", "dict_link")
  356. instantiate_link(model, "Inheritance", "", "constant_node", "dict_link")
  357. instantiate_link(model, "Inheritance", "", "output_node", "dict_link")
  358. instantiate_link(model, "Inheritance", "", "global_var", "dict_link")
  359. instantiate_link(model, "Inheritance", "", "param_name", "dict_link")
  360. instantiate_link(model, "Inheritance", "", "param_value", "dict_link")
  361. instantiate_link(model, "Inheritance", "", "param_next_param", "dict_link")
  362. instantiate_link(model, "Inheritance", "", "funcdef_body", "dict_link")
  363. instantiate_link(model, "Inheritance", "", "call_func", "dict_link")
  364. instantiate_link(model, "Inheritance", "", "call_params", "dict_link")
  365. instantiate_link(model, "Inheritance", "", "call_last_param", "dict_link")
  366. // Add cardinalities on how many connections are allowed: one of each
  367. instantiate_attribute(model, "statement_next", "target_upper_cardinality", 1)
  368. instantiate_attribute(model, "if_cond", "target_lower_cardinality", 1)
  369. instantiate_attribute(model, "if_cond", "target_upper_cardinality", 1)
  370. instantiate_attribute(model, "if_then", "target_lower_cardinality", 1)
  371. instantiate_attribute(model, "if_then", "target_upper_cardinality", 1)
  372. instantiate_attribute(model, "if_else", "target_upper_cardinality", 1)
  373. instantiate_attribute(model, "while_cond", "target_lower_cardinality", 1)
  374. instantiate_attribute(model, "while_cond", "target_upper_cardinality", 1)
  375. instantiate_attribute(model, "while_body", "target_lower_cardinality", 1)
  376. instantiate_attribute(model, "while_body", "target_upper_cardinality", 1)
  377. instantiate_attribute(model, "assign_var", "target_lower_cardinality", 1)
  378. instantiate_attribute(model, "assign_var", "target_upper_cardinality", 1)
  379. instantiate_attribute(model, "assign_value", "target_lower_cardinality", 1)
  380. instantiate_attribute(model, "assign_value", "target_upper_cardinality", 1)
  381. instantiate_attribute(model, "break_while", "target_lower_cardinality", 1)
  382. instantiate_attribute(model, "break_while", "target_upper_cardinality", 1)
  383. instantiate_attribute(model, "continue_while", "target_lower_cardinality", 1)
  384. instantiate_attribute(model, "continue_while", "target_upper_cardinality", 1)
  385. instantiate_attribute(model, "return_value", "target_upper_cardinality", 1)
  386. instantiate_attribute(model, "resolve_var", "target_lower_cardinality", 1)
  387. instantiate_attribute(model, "resolve_var", "target_upper_cardinality", 1)
  388. instantiate_attribute(model, "access_var", "target_lower_cardinality", 1)
  389. instantiate_attribute(model, "access_var", "target_upper_cardinality", 1)
  390. instantiate_attribute(model, "constant_node", "target_lower_cardinality", 1)
  391. instantiate_attribute(model, "constant_node", "target_upper_cardinality", 1)
  392. instantiate_attribute(model, "output_node", "target_lower_cardinality", 1)
  393. instantiate_attribute(model, "output_node", "target_upper_cardinality", 1)
  394. instantiate_attribute(model, "global_var", "target_lower_cardinality", 1)
  395. instantiate_attribute(model, "global_var", "target_upper_cardinality", 1)
  396. instantiate_attribute(model, "param_name", "target_lower_cardinality", 1)
  397. instantiate_attribute(model, "param_name", "target_upper_cardinality", 1)
  398. instantiate_attribute(model, "param_value", "target_lower_cardinality", 1)
  399. instantiate_attribute(model, "param_value", "target_upper_cardinality", 1)
  400. instantiate_attribute(model, "param_next_param", "target_upper_cardinality", 1)
  401. instantiate_attribute(model, "funcdef_body", "target_lower_cardinality", 1)
  402. instantiate_attribute(model, "funcdef_body", "target_upper_cardinality", 1)
  403. instantiate_attribute(model, "call_func", "target_lower_cardinality", 1)
  404. instantiate_attribute(model, "call_func", "target_upper_cardinality", 1)
  405. instantiate_attribute(model, "call_params", "target_upper_cardinality", 1)
  406. instantiate_attribute(model, "call_last_param", "target_upper_cardinality", 1)
  407. return !