bootstrap_visitor.py 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import string
  2. from primitives_visitor import PrimitivesVisitor, Action
  3. class BootstrapVisitor(PrimitivesVisitor):
  4. def __init__(self, args):
  5. PrimitivesVisitor.__init__(self, args)
  6. self.main = "--main" in args
  7. for f in args:
  8. if "--prepend:" in f:
  9. self.prepend_name = f.split(":", 1)[1]
  10. break
  11. else:
  12. self.prepend_name = "auto"
  13. self.object_symbols = {}
  14. def rename(self, name):
  15. if name == "initial_IP":
  16. return "%s_%s" % (self.prepend_name, name)
  17. else:
  18. return "%s_%s" % (self.prepend_name, name) if isinstance(name, int) else name
  19. def dump(self):
  20. link_id = 0
  21. if self.main:
  22. call = self.value(Action("call"))
  23. access = self.value(Action("access"))
  24. resolve = self.value(Action("resolve"))
  25. main = self.value("__main")
  26. self.dict(resolve, "var", main)
  27. self.dict(access, "var", resolve)
  28. self.dict(call, "func", access)
  29. self.dict(self.last_instruction, "next", call)
  30. output = []
  31. for t, data in self.output:
  32. if t == "N":
  33. output.append("Node %s_%s()\n" % (self.prepend_name, data))
  34. elif t == "V":
  35. name, value = data
  36. name = name if self.first != name else "initial_IP"
  37. output.append("Node %s_%s(%s)\n" % (self.prepend_name, name, value))
  38. elif t == "D":
  39. source, value, target = data
  40. source = source if self.first != source else "initial_IP"
  41. target = target if self.first != target else "initial_IP"
  42. source = self.rename(source)
  43. target = self.rename(target)
  44. linkname = "%s_%s_%s" % (source, link_id, target)
  45. link_id += 1
  46. output.append("Edge _%s_0(%s, %s)\n" % (linkname, source, target))
  47. output.append("Node _%s_2(%s)\n" % (linkname, value))
  48. output.append("Edge _%s_1(_%s_0, _%s_2)\n" % (linkname, linkname, linkname))
  49. elif t == "E":
  50. name, source, target = data
  51. source = source if self.first != source else "initial_IP"
  52. target = target if self.first != target else "initial_IP"
  53. name = self.rename(name)
  54. source = self.rename(source)
  55. target = self.rename(target)
  56. output.append("Edge _%s(_%s, _%s)\n" % (name, source, target))
  57. return ''.join(output)
  58. def visit_definition(self, tree):
  59. for a in tree.get_children("ID"):
  60. name = a.get_tail()[0]
  61. self.object_symbols[name] = True
  62. return PrimitivesVisitor.visit_definition(self, tree)
  63. def visit_vardecl(self, tree):
  64. if len(tree.get_tail()) > 2:
  65. for a in tree.get_children("ID"):
  66. name = a.get_tail()[0]
  67. self.object_symbols.setdefault(name, False)
  68. return PrimitivesVisitor.visit_vardecl(self, tree)
  69. else:
  70. return PrimitivesVisitor.visit_vardecl(self, tree)
  71. def visit_funcdecl(self, tree):
  72. for a in tree.get_children("func_name"):
  73. for b in a.get_children("ID"):
  74. name = b.get_tail()[0]
  75. if tree.get_children("func_body") or tree.get_children("ASSIGN"):
  76. self.object_symbols[name] = True
  77. else:
  78. self.object_symbols.setdefault(name, False)
  79. return PrimitivesVisitor.visit_funcdecl(self, tree)