X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=test%2FScripts%2Fcoff-dump.py;h=36ec53932c638be69bb556ee214c8fbb3ca9f3d9;hb=ab3d00e5350fd4c097e2a5b077da7584692029a7;hp=055fec5bde80177bf1fd8c62a1658fa839b63c5f;hpb=a25c0a4283e627a34a3fb3cf0ed2ddde0d886a36;p=oota-llvm.git diff --git a/test/Scripts/coff-dump.py b/test/Scripts/coff-dump.py index 055fec5bde8..36ec53932c6 100755 --- a/test/Scripts/coff-dump.py +++ b/test/Scripts/coff-dump.py @@ -167,7 +167,8 @@ file = ('struct', [ ('Name', ('scalar', '<8s', symname)), ('Value', ('scalar', '> 4 + ('ComplexType', ('enum', '>> & _Type 240 4', '%d', { 0: 'IMAGE_SYM_DTYPE_NULL', 1: 'IMAGE_SYM_DTYPE_POINTER', 2: 'IMAGE_SYM_DTYPE_FUNCTION', @@ -317,7 +318,7 @@ def print_binary_data(size): write("%s|%s|\n" % (bytes, text)) return value -idlit = re.compile("[a-zA-Z][a-zA-Z0-9_-]*") +idlit = re.compile("[a-zA-Z_][a-zA-Z0-9_-]*") numlit = re.compile("[0-9]+") def read_value(expr): @@ -335,11 +336,6 @@ def read_value(expr): if expr == 'false': return False - if len(token) > 1 and token[0] in ('=', '@', '<', '!', '>'): - val = read(expr) - assert(len(val) == 1) - return val[0] - if token == '+': return eval() + eval() if token == '-': @@ -348,6 +344,19 @@ def read_value(expr): return eval() * eval() if token == '/': return eval() / eval() + if token == '&': + return eval() & eval() + if token == '|': + return eval() | eval() + if token == '>>': + return eval() >> eval() + if token == '<<': + return eval() << eval() + + if len(token) > 1 and token[0] in ('=', '@', '<', '!', '>'): + val = read(expr) + assert(len(val) == 1) + return val[0] if idlit.match(token): return Fields[token] @@ -356,10 +365,10 @@ def read_value(expr): raise RuntimeError("unexpected token %s" % repr(token)) - value = eval () + value = eval() try: - input.next () + input.next() except StopIteration: return value raise RuntimeError("unexpected input at end of expression") @@ -373,6 +382,8 @@ def write_value(format,value): elif format_type is types.TupleType: Fields['this'] = value handle_element(format) + elif format_type is types.NoneType: + pass else: raise RuntimeError("unexpected type: %s" % repr(format_type)) @@ -448,11 +459,13 @@ def handle_struct(entry): name = member[0] type = member[1] - write("%s = "%name.ljust(24)) + if name[0] != "_": + write("%s = " % name.ljust(24)) value = handle_element(type) - write("\n") + if name[0] != "_": + write("\n") Fields[name] = value newFields[name] = value