Extract function
This commit is contained in:
parent
80beadfe08
commit
264e96c11d
2 changed files with 26 additions and 23 deletions
|
|
@ -261,3 +261,18 @@ def get_attributes(bottom, class_node: UUID):
|
||||||
# typ = navigate_modelref(bottom, ref_type)
|
# typ = navigate_modelref(bottom, ref_type)
|
||||||
result.append((attr_name, attr_edge))
|
result.append((attr_name, attr_edge))
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
# We need the meta-model (`mm`) to find out how to read the `modelref`
|
||||||
|
def read_primitive_value(bottom, modelref: UUID, mm: UUID):
|
||||||
|
typ = get_type(bottom, modelref)
|
||||||
|
if not is_typed_by(bottom, typ, get_scd_mm_modelref_node(bottom)):
|
||||||
|
raise Exception("Assertion failed: argument must be typed by ModelRef")
|
||||||
|
referred_model = UUID(bottom.read_value(modelref))
|
||||||
|
typ_name = get_object_name(bottom, mm, typ)
|
||||||
|
if typ_name == "Integer":
|
||||||
|
return Integer(referred_model, bottom.state).read()
|
||||||
|
elif typ_name == "String":
|
||||||
|
return String(referred_model, bottom.state).read()
|
||||||
|
else:
|
||||||
|
raise Exception("Unimplemented type:", host_type_name)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -136,8 +136,8 @@ def rewrite(state, lhs: UUID, rhs: UUID, rhs_mm: UUID, match_mapping: dict, m_to
|
||||||
model_element_name = match_mapping[pattern_element_name]
|
model_element_name = match_mapping[pattern_element_name]
|
||||||
print('updating', model_element_name)
|
print('updating', model_element_name)
|
||||||
model_element, = bottom.read_outgoing_elements(m_to_transform, model_element_name)
|
model_element, = bottom.read_outgoing_elements(m_to_transform, model_element_name)
|
||||||
old_value = bottom.read_value(model_element)
|
# old_value = bottom.read_value(model_element)
|
||||||
print('old value:', old_value)
|
# print('old value:', old_value)
|
||||||
host_type = od.get_type(bottom, model_element)
|
host_type = od.get_type(bottom, model_element)
|
||||||
if od.is_typed_by(bottom, host_type, class_type):
|
if od.is_typed_by(bottom, host_type, class_type):
|
||||||
print(' -> is classs')
|
print(' -> is classs')
|
||||||
|
|
@ -149,29 +149,17 @@ def rewrite(state, lhs: UUID, rhs: UUID, rhs_mm: UUID, match_mapping: dict, m_to
|
||||||
# referred_model_type = od.get_type(bottom, referred_model_id) # None
|
# referred_model_type = od.get_type(bottom, referred_model_id) # None
|
||||||
# print('referred_model_type:', referred_model_type)
|
# print('referred_model_type:', referred_model_type)
|
||||||
|
|
||||||
host_type_name = od.get_object_name(bottom, mm, host_type)
|
v = od.read_primitive_value(bottom, model_element, mm)
|
||||||
print('host_type_name:', host_type_name)
|
|
||||||
if host_type_name == "Integer":
|
|
||||||
v = Integer(UUID(old_value), state).read()
|
|
||||||
elif host_type_name == "String":
|
|
||||||
v = String(UUID(old_value), state).read()
|
|
||||||
else:
|
|
||||||
raise Exception("Unimplemented type:", host_type_name)
|
|
||||||
|
|
||||||
# the referred model itself doesn't have a type, so we have to look at the type of the ModelRef element in the RHS-MM:
|
# the referred model itself doesn't have a type, so we have to look at the type of the ModelRef element in the RHS-MM:
|
||||||
rhs_element, = bottom.read_outgoing_elements(rhs, pattern_element_name)
|
rhs_element, = bottom.read_outgoing_elements(rhs, pattern_element_name)
|
||||||
rhs_type = od.get_type(bottom, rhs_element)
|
|
||||||
rhs_type_name = od.get_object_name(bottom, rhs_mm, rhs_type)
|
|
||||||
print("rhs_type_name:", rhs_type_name)
|
|
||||||
|
|
||||||
print(od.get_object_name(bottom, mm, model_element))
|
expr = od.read_primitive_value(bottom, rhs_element, rhs_mm)
|
||||||
|
|
||||||
if rhs_type_name == "String":
|
result = eval(expr, {}, {'v': v})
|
||||||
python_expr = String(UUID(bottom.read_value(rhs_element)), state).read()
|
# print('eval result=', result)
|
||||||
result = eval(python_expr, {}, {'v': v})
|
|
||||||
print('eval result=', result)
|
|
||||||
if isinstance(result, int):
|
if isinstance(result, int):
|
||||||
# overwrite the old value
|
# overwrite the old value
|
||||||
Integer(UUID(old_value), state).create(result)
|
Integer(referred_model_id, state).create(result)
|
||||||
else:
|
else:
|
||||||
raise Exception("Unimplemented type. Value:", result)
|
raise Exception("Unimplemented type. Value:", result)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue