|
@@ -17,7 +17,7 @@ Boolean function is_nominal_instance(model : Element, instance : String, type :
|
|
|
// Doesn't even have a type
|
|
|
return False
|
|
|
|
|
|
- return is_nominal_subtype(model["metamodel"], getName(model["metamodel"], dict_read_node(model["type_mapping"], model["model"][instance])), type)
|
|
|
+ return is_nominal_subtype(model["metamodel"], reverseKeyLookup(model["metamodel"]["model"], dict_read_node(model["type_mapping"], model["model"][instance])), type)
|
|
|
|
|
|
Boolean function is_nominal_subtype(metamodel : Element, subclass : String, superclass : String):
|
|
|
if (element_eq(metamodel["model"][subclass], metamodel["model"][superclass])):
|
|
@@ -76,7 +76,6 @@ String function conformance_scd(model : Element):
|
|
|
|
|
|
while (0 < list_len(keys)):
|
|
|
key = set_pop(keys)
|
|
|
- log("Read cardinalities for " + key)
|
|
|
if (is_nominal_instance(metamodel, key, "Association")):
|
|
|
tmp_dict = create_node()
|
|
|
slc = read_attribute(metamodel, key, "source_lower_cardinality")
|
|
@@ -100,7 +99,6 @@ String function conformance_scd(model : Element):
|
|
|
keys = dict_keys(model["model"])
|
|
|
while (0 < list_len(keys)):
|
|
|
model_name = set_pop(keys)
|
|
|
- log("Check element " + model_name)
|
|
|
element = model["model"][model_name]
|
|
|
|
|
|
if (bool_not(dict_in_node(typing, element))):
|
|
@@ -109,14 +107,14 @@ String function conformance_scd(model : Element):
|
|
|
if (bool_not(set_in_node(metamodel["model"], dict_read_node(typing, element)))):
|
|
|
return "Type of element not in specified metamodel: " + model_name
|
|
|
|
|
|
- if (bool_not(is_nominal_instance(model, model_name, getName(metamodel, dict_read_node(typing, element))))):
|
|
|
+ if (bool_not(is_nominal_instance(model, model_name, reverseKeyLookup(metamodel["model"], dict_read_node(typing, element))))):
|
|
|
return "Element is not an instance of its specified type: " + model_name
|
|
|
|
|
|
if (is_edge(element)):
|
|
|
- src_model = getName(model, read_edge_src(element))
|
|
|
- dst_model = getName(model, read_edge_dst(element))
|
|
|
- src_metamodel = getName(metamodel, read_edge_src(dict_read_node(typing, element)))
|
|
|
- dst_metamodel = getName(metamodel, read_edge_dst(dict_read_node(typing, element)))
|
|
|
+ src_model = reverseKeyLookup(model["model"], read_edge_src(element))
|
|
|
+ dst_model = reverseKeyLookup(model["model"], read_edge_dst(element))
|
|
|
+ src_metamodel = reverseKeyLookup(metamodel["model"], read_edge_src(dict_read_node(typing, element)))
|
|
|
+ dst_metamodel = reverseKeyLookup(metamodel["model"], read_edge_dst(dict_read_node(typing, element)))
|
|
|
|
|
|
if (bool_not(is_nominal_instance(model, src_model, src_metamodel))):
|
|
|
return "Source of model edge not typed by source of type: " + model_name
|
|
@@ -124,52 +122,52 @@ String function conformance_scd(model : Element):
|
|
|
if (bool_not(is_nominal_instance(model, dst_model, dst_metamodel))):
|
|
|
return "Destination of model edge not typed by source of type: " + model_name
|
|
|
|
|
|
- // Check cardinality for all of our edges
|
|
|
- //
|
|
|
- // SLC..SUC TLC..TUC
|
|
|
- // A ---------------------> B
|
|
|
- //
|
|
|
- // First the incoming, so we are at B in the above figure
|
|
|
- Integer lower_val
|
|
|
- Integer upper_val
|
|
|
- Integer instances
|
|
|
-
|
|
|
- check_list = selectPossibleOutgoing(model, model_name, dict_keys(cardinalities))
|
|
|
- while (0 < list_len(check_list)):
|
|
|
- check_type = set_pop(check_list)
|
|
|
- if (dict_in(cardinalities, check_type)):
|
|
|
- // Cardinalities defined for this association, so check them
|
|
|
- lower_val = cardinalities[check_type]["tlc"]
|
|
|
- upper_val = cardinalities[check_type]["tuc"]
|
|
|
- instances = list_len(allOutgoingAssociationInstances(model, model_name, check_type))
|
|
|
- if (dict_in(cardinalities[check_type], "tlc")):
|
|
|
- // A lower cardinality was defined at the target
|
|
|
- if (integer_gt(cardinalities[check_type]["tlc"], instances)):
|
|
|
- return "Lower cardinality violation for outgoing edge at " + model_name
|
|
|
- if (dict_in(cardinalities[check_type], "tuc")):
|
|
|
- // An upper cardinality was defined at the target
|
|
|
- if (integer_lt(cardinalities[check_type]["tuc"], instances)):
|
|
|
- return "Upper cardinality violation for outgoing edge at " + model_name
|
|
|
-
|
|
|
- // Identical, but for outgoing, and thus for A in the figure
|
|
|
- check_list = selectPossibleIncoming(model, model_name, dict_keys(cardinalities))
|
|
|
- while (0 < list_len(check_list)):
|
|
|
- check_type = set_pop(check_list)
|
|
|
- if (dict_in(cardinalities, check_type)):
|
|
|
- // Cardinalities defined for this association, so check them
|
|
|
- lower_val = cardinalities[check_type]["slc"]
|
|
|
- upper_val = cardinalities[check_type]["suc"]
|
|
|
- instances = list_len(allIncomingAssociationInstances(model, model_name, check_type))
|
|
|
- if (dict_in(cardinalities[check_type], "slc")):
|
|
|
- // A lower cardinality was defined at the source
|
|
|
- if (integer_gt(cardinalities[check_type]["slc"], instances)):
|
|
|
- return "Lower cardinality violation for incoming edge at " + model_name
|
|
|
- if (dict_in(cardinalities[check_type], "suc")):
|
|
|
- // An upper cardinality was defined at the source
|
|
|
- if (integer_lt(cardinalities[check_type]["suc"], instances)):
|
|
|
- return "Upper cardinality violation for incoming edge at " + model_name
|
|
|
-
|
|
|
- log("Finished, checking multiplicities at the end")
|
|
|
+ if (dict_in(cardinalities, model_name)):
|
|
|
+ // Check cardinality for all of our edges
|
|
|
+ //
|
|
|
+ // SLC..SUC TLC..TUC
|
|
|
+ // A ---------------------> B
|
|
|
+ //
|
|
|
+ // First the incoming, so we are at B in the above figure
|
|
|
+ Integer lower_val
|
|
|
+ Integer upper_val
|
|
|
+ Integer instances
|
|
|
+
|
|
|
+ check_list = selectPossibleOutgoing(model, model_name, dict_keys(cardinalities))
|
|
|
+ while (0 < list_len(check_list)):
|
|
|
+ check_type = set_pop(check_list)
|
|
|
+ if (dict_in(cardinalities, check_type)):
|
|
|
+ // Cardinalities defined for this association, so check them
|
|
|
+ lower_val = cardinalities[check_type]["tlc"]
|
|
|
+ upper_val = cardinalities[check_type]["tuc"]
|
|
|
+ instances = list_len(allOutgoingAssociationInstances(model, model_name, check_type))
|
|
|
+ if (dict_in(cardinalities[check_type], "tlc")):
|
|
|
+ // A lower cardinality was defined at the target
|
|
|
+ if (integer_gt(cardinalities[check_type]["tlc"], instances)):
|
|
|
+ return "Lower cardinality violation for outgoing edge at " + model_name
|
|
|
+ if (dict_in(cardinalities[check_type], "tuc")):
|
|
|
+ // An upper cardinality was defined at the target
|
|
|
+ if (integer_lt(cardinalities[check_type]["tuc"], instances)):
|
|
|
+ return "Upper cardinality violation for outgoing edge at " + model_name
|
|
|
+
|
|
|
+ // Identical, but for outgoing, and thus for A in the figure
|
|
|
+ check_list = selectPossibleIncoming(model, model_name, dict_keys(cardinalities))
|
|
|
+ while (0 < list_len(check_list)):
|
|
|
+ check_type = set_pop(check_list)
|
|
|
+ if (dict_in(cardinalities, check_type)):
|
|
|
+ // Cardinalities defined for this association, so check them
|
|
|
+ lower_val = cardinalities[check_type]["slc"]
|
|
|
+ upper_val = cardinalities[check_type]["suc"]
|
|
|
+ instances = list_len(allIncomingAssociationInstances(model, model_name, check_type))
|
|
|
+ if (dict_in(cardinalities[check_type], "slc")):
|
|
|
+ // A lower cardinality was defined at the source
|
|
|
+ if (integer_gt(cardinalities[check_type]["slc"], instances)):
|
|
|
+ return "Lower cardinality violation for incoming edge at " + model_name
|
|
|
+ if (dict_in(cardinalities[check_type], "suc")):
|
|
|
+ // An upper cardinality was defined at the source
|
|
|
+ if (integer_lt(cardinalities[check_type]["suc"], instances)):
|
|
|
+ return "Upper cardinality violation for incoming edge at " + model_name
|
|
|
+
|
|
|
// Check multiplicities, if they are defined (optional)
|
|
|
Element metamodel_keys
|
|
|
String metamodel_element
|
|
@@ -178,7 +176,6 @@ String function conformance_scd(model : Element):
|
|
|
metamodel_keys = dict_keys(metamodel["model"])
|
|
|
while (0 < list_len(metamodel_keys)):
|
|
|
metamodel_element = set_pop(metamodel_keys)
|
|
|
- log("Check " + metamodel_element)
|
|
|
|
|
|
// Lower multiplicities
|
|
|
attr_value = read_attribute(metamodel, metamodel_element, "lower_cardinality")
|