render_SCD.alc 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. include "primitives.alh"
  2. include "modelling.alh"
  3. include "object_operations.alh"
  4. include "utils.alh"
  5. Boolean function main(model : Element):
  6. Element elements
  7. String class
  8. Element attrs
  9. Element attr_keys
  10. String attr_key
  11. String group
  12. String elem
  13. Integer loc
  14. Integer text_loc
  15. Element related_groups
  16. loc = 10
  17. Element groups
  18. groups = dict_create()
  19. elements = allInstances(model, "rendered/Group")
  20. while (set_len(elements) > 0):
  21. group = set_pop(elements)
  22. if (set_len(allIncomingAssociationInstances(model, group, "TracabilityClass")) == 0):
  23. Element to_remove
  24. String elem_to_remove
  25. to_remove = allAssociationDestinations(model, group, "rendered/contains")
  26. while (set_len(to_remove) > 0):
  27. elem_to_remove = set_pop(to_remove)
  28. if (read_type(model, elem_to_remove) == "rendered/Group"):
  29. set_add(to_remove, elem_to_remove)
  30. else:
  31. model_delete_element(model, elem_to_remove)
  32. model_delete_element(model, group)
  33. elements = allInstances(model, "abstract/Class")
  34. while (set_len(elements) > 0):
  35. class = set_pop(elements)
  36. Integer x
  37. Integer y
  38. x = loc
  39. y = 10
  40. // Check if there is already an associated element
  41. if (set_len(allOutgoingAssociationInstances(model, class, "TracabilityClass")) > 0):
  42. // Yes, but is it still clean?
  43. related_groups = allAssociationDestinations(model, class, "TracabilityClass")
  44. Element to_remove
  45. String elem_to_remove
  46. while (set_len(related_groups) > 0):
  47. group = set_pop(related_groups)
  48. to_remove = allAssociationDestinations(model, group, "rendered/contains")
  49. x = create_value(read_attribute(model, group, "x"))
  50. y = create_value(read_attribute(model, group, "y"))
  51. while (set_len(to_remove) > 0):
  52. elem_to_remove = set_pop(to_remove)
  53. if (read_type(model, elem_to_remove) == "rendered/Group"):
  54. set_add(to_remove, elem_to_remove)
  55. else:
  56. model_delete_element(model, elem_to_remove)
  57. model_delete_element(model, group)
  58. attr_keys = dict_keys(getAttributeList(model, class))
  59. text_loc = 5
  60. group = instantiate_node(model, "rendered/Group", "")
  61. instantiate_attribute(model, group, "x", x)
  62. instantiate_attribute(model, group, "y", y)
  63. instantiate_attribute(model, group, "__asid", list_read(string_split_nr(class, "/", 1), 1))
  64. instantiate_attribute(model, group, "layer", 0)
  65. dict_add(groups, class, group)
  66. loc = loc + 200
  67. elem = instantiate_node(model, "rendered/Rectangle", "")
  68. instantiate_attribute(model, elem, "x", 0)
  69. instantiate_attribute(model, elem, "y", 0)
  70. instantiate_attribute(model, elem, "height", 40 + set_len(getInstantiatableAttributes(model, class, "abstract/AttributeLink")) * 20)
  71. instantiate_attribute(model, elem, "width", 150)
  72. instantiate_attribute(model, elem, "lineWidth", 2)
  73. instantiate_attribute(model, elem, "lineColour", "black")
  74. instantiate_attribute(model, elem, "fillColour", "white")
  75. instantiate_attribute(model, elem, "layer", 1)
  76. instantiate_link(model, "rendered/contains", "", group, elem)
  77. String multiplicities
  78. String lower_card
  79. String upper_card
  80. if (element_eq(read_attribute(model, class, "lower_cardinality"), read_root())):
  81. lower_card = "*"
  82. else:
  83. lower_card = cast_value(read_attribute(model, class, "lower_cardinality"))
  84. if (element_eq(read_attribute(model, class, "upper_cardinality"), read_root())):
  85. upper_card = "*"
  86. else:
  87. upper_card = cast_value(read_attribute(model, class, "upper_cardinality"))
  88. multiplicities = ((("[" + lower_card) + "..") + upper_card) + "]"
  89. elem = instantiate_node(model, "rendered/Text", "")
  90. instantiate_attribute(model, elem, "x", 5)
  91. instantiate_attribute(model, elem, "y", 3)
  92. instantiate_attribute(model, elem, "lineWidth", 1)
  93. instantiate_attribute(model, elem, "lineColour", "black")
  94. if (element_neq(read_attribute(model, class, "name"), read_root())):
  95. instantiate_attribute(model, elem, "text", string_join(read_attribute(model, class, "name"), " " + multiplicities))
  96. else:
  97. instantiate_attribute(model, elem, "text", "(unnamed) " + multiplicities)
  98. instantiate_attribute(model, elem, "layer", 2)
  99. instantiate_link(model, "rendered/contains", "", group, elem)
  100. elem = instantiate_node(model, "rendered/Line", "")
  101. instantiate_attribute(model, elem, "x", 0)
  102. instantiate_attribute(model, elem, "y", 20)
  103. instantiate_attribute(model, elem, "targetX", 150)
  104. instantiate_attribute(model, elem, "targetY", 20)
  105. instantiate_attribute(model, elem, "lineWidth", 1)
  106. instantiate_attribute(model, elem, "lineColour", "black")
  107. instantiate_attribute(model, elem, "arrow", False)
  108. instantiate_attribute(model, elem, "layer", 2)
  109. instantiate_link(model, "rendered/contains", "", group, elem)
  110. attrs = getInstantiatableAttributes(model, class, "abstract/AttributeLink")
  111. attr_keys = dict_keys(attrs)
  112. while (dict_len(attr_keys) > 0):
  113. attr_key = set_pop(attr_keys)
  114. elem = instantiate_node(model, "rendered/Text", "")
  115. instantiate_attribute(model, elem, "x", 5)
  116. instantiate_attribute(model, elem, "y", text_loc + 20)
  117. instantiate_attribute(model, elem, "lineWidth", 1)
  118. instantiate_attribute(model, elem, "lineColour", "black")
  119. instantiate_attribute(model, elem, "text", (attr_key + " : ") + cast_string(list_read(string_split_nr(attrs[attr_key], "/", 1), 1)))
  120. instantiate_attribute(model, elem, "layer", 2)
  121. instantiate_link(model, "rendered/contains", "", group, elem)
  122. text_loc = text_loc + 15
  123. instantiate_link(model, "TracabilityClass", "", class, group)
  124. // Flush all associations
  125. elements = allInstances(model, "rendered/ConnectingLine")
  126. while (set_len(elements) > 0):
  127. class = set_pop(elements)
  128. model_delete_element(model, class)
  129. // Rerender associations
  130. elements = allInstances(model, "abstract/Association")
  131. while (set_len(elements) > 0):
  132. class = set_pop(elements)
  133. attr_keys = dict_keys(getAttributeList(model, class))
  134. elem = instantiate_link(model, "rendered/ConnectingLine", "", groups[readAssociationSource(model, class)], groups[readAssociationDestination(model, class)])
  135. instantiate_attribute(model, elem, "offsetSourceX", 75)
  136. instantiate_attribute(model, elem, "offsetSourceY", 30)
  137. instantiate_attribute(model, elem, "offsetTargetX", 75)
  138. instantiate_attribute(model, elem, "offsetTargetY", 30)
  139. instantiate_attribute(model, elem, "lineWidth", 1)
  140. instantiate_attribute(model, elem, "lineColour", "black")
  141. instantiate_attribute(model, elem, "arrow", True)
  142. instantiate_attribute(model, elem, "__asid", list_read(string_split_nr(class, "/", 1), 1))
  143. instantiate_attribute(model, elem, "layer", 0)
  144. log("Real ASID: " + cast_value(class))
  145. log("Found ASID " + cast_value(list_read(string_split_nr(class, "/", 1), 1)))
  146. instantiate_link(model, "rendered/contains", "", group, elem)
  147. return True!