X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=scripts%2Fspec_util.py;h=f8aa0b9869e96ea0fec80a3cb22a84ca70bb106b;hb=0f234e2d94155d13c0e4727871125beda0eaa66d;hp=b70e82391122836571fa510d3694987f88e6be52;hpb=d556fd12cea28fd3e32f7c5e317e6e4d50f4ee17;p=libfirm diff --git a/scripts/spec_util.py b/scripts/spec_util.py index b70e82391..f8aa0b986 100644 --- a/scripts/spec_util.py +++ b/scripts/spec_util.py @@ -1,6 +1,43 @@ +abstracts = set() +def abstract(cls): + abstracts.add(cls) + return cls +def isAbstract(nodetype): + return nodetype in abstracts + def is_dynamic_pinned(node): - return node["pinned"] in ["memory", "exception"] + return node.pinned in ["memory", "exception"] def verify_node(node): - if node["pinned"] not in ["yes", "no", "memory", "exception"]: - print "UNKNOWN PINNED MODE: %s" % node["pinned"] + if not hasattr(node, "pinned"): + print "%s: NO PINNED SET" % node.__name__ + elif node.pinned not in ["yes", "no", "memory", "exception"]: + print "%s: UNKNOWN PINNED MODE: %s" % (node.__name__, node.pinned) + + if not hasattr(node, "flags") and not isAbstract(node): + print "WARNING: no flags specified for %s\n" % node.__name__ + elif type(node.flags) != list: + print "ERROR: flags of %s not a list" % node.__name__ + +def setldefault(node, attr, val): + # Don't use hasattr, as these things should not be inherited + if attr not in node.__dict__: + setattr(node, attr, val) + +def setdefault(node, attr, val): + # Don't use hasattr, as these things should not be inherited + if not hasattr(node, attr): + setattr(node, attr, val) + +def setnodedefaults(node): + setldefault(node, "name", node.__name__) + if isAbstract(node): + return + + setdefault(node, "ins", []) + setdefault(node, "arity", len(node.ins)) + setdefault(node, "attrs", []) + setdefault(node, "constructor_args", []) + setldefault(node, "constrname", node.name) + if hasattr(node, "outs"): + node.mode = "mode_T"