runner.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. from state.devstate import DevState
  2. from bootstrap.scd import bootstrap_scd
  3. from concrete_syntax.common import indent
  4. from concrete_syntax.textual_od import renderer as od_renderer
  5. from concrete_syntax.plantuml import renderer as plantuml
  6. from concrete_syntax.plantuml.make_url import make_url as make_plantuml_url
  7. from concrete_syntax.graphviz.make_url import make_url as make_graphviz_url
  8. from concrete_syntax.graphviz import renderer as graphviz
  9. from transformation.matcher.mvs_adapter import match_od
  10. from transformation.rewriter import rewrite
  11. from transformation.cloner import clone_od
  12. import models
  13. state = DevState()
  14. scd_mmm = bootstrap_scd(state)
  15. mm, mm_rt, m, m_rt_initial = models.get_fibonacci(state, scd_mmm)
  16. mm_rt_ram, rules = models.get_rules(state, mm_rt)
  17. # print("RT-MM")
  18. # print(make_plantuml_url(plantuml.render_class_diagram(state, mm_rt)))
  19. # print("RAMIFIED RT-MM")
  20. # print(make_plantuml_url(plantuml.render_class_diagram(state, mm_rt_ram)))
  21. m_rt = m_rt_initial
  22. def get_matches():
  23. for rule_name, rule in rules.items():
  24. lhs = rule["lhs"]
  25. lhs_matcher = match_od(state,
  26. host_m=m_rt,
  27. host_mm=mm_rt,
  28. pattern_m=lhs,
  29. pattern_mm=mm_rt_ram)
  30. for i, lhs_match in enumerate(lhs_matcher):
  31. nac_matcher = match_od(state,
  32. host_m=m_rt,
  33. host_mm=mm_rt,
  34. pattern_m=rule["nac"],
  35. pattern_mm=mm_rt_ram,
  36. pivot=lhs_match)
  37. for j, nac_match in enumerate(nac_matcher):
  38. break # there may be more NAC-matches, but we already now enough
  39. else:
  40. # We got a match!
  41. yield (rule_name, lhs, rule["rhs"], lhs_match)
  42. while True:
  43. # print(make_graphviz_url(graphviz.render_object_diagram(state, m_rt, mm_rt)))
  44. cs = od_renderer.render_od(state, m_rt, mm_rt, hide_names=False)
  45. print(indent(cs, 6))
  46. matches = list(get_matches())
  47. print(f"There are {len(matches)} matches.")
  48. if len(matches) == 0:
  49. break
  50. rule_name, lhs, rhs, lhs_match = matches[0]
  51. # txt = graphviz.render_package("Host", graphviz.render_object_diagram(state, m_rt, mm_rt))
  52. # txt += graphviz.render_package("LHS", graphviz.render_object_diagram(state, lhs, mm_rt_ram))
  53. # txt += graphviz.render_trace_match(state, lhs_match, lhs, m_rt, color="orange")
  54. # match_urls.append(make_graphviz_url(txt))
  55. print('picking', lhs_match)
  56. print('rewriting')
  57. # copy or will be overwritten in-place
  58. m_rt = clone_od(state, m_rt, mm_rt)
  59. rhs_match = dict(lhs_match)
  60. rewrite(state,
  61. lhs_m=lhs,
  62. rhs_m=rhs,
  63. pattern_mm=mm_rt_ram,
  64. name_mapping=rhs_match,
  65. host_m=m_rt,
  66. mm=mm_rt)
  67. # import subprocess
  68. # subprocess.run(["firefox", "--new-window", *match_urls])
  69. # get_actions(state, rules, m_rt_initial, mm_rt)