From: Nathan Binkert Date: Tue, 4 Aug 2009 16:37:27 +0000 (-0700) Subject: slicc: better error messages when the python parser fails X-Git-Tag: Calvin_Submission~160^2 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=bd7af84d5ecd037fe4ab1a66948c51d23eb0eb0d;p=gem5.git slicc: better error messages when the python parser fails --- diff --git a/src/mem/slicc/parser/parser.py b/src/mem/slicc/parser/parser.py index 1c7d582ec..c042ba2c1 100644 --- a/src/mem/slicc/parser/parser.py +++ b/src/mem/slicc/parser/parser.py @@ -100,8 +100,15 @@ t_SEMICOLON = r';' t_ASSIGN = r':=' t_DOT = r'\.' -class TokenError(Exception): pass -class ParseError(Exception): pass +class TokenError(Exception): + def __init__(self, msg, t): + super(TokenError, self).__init__(msg) + self.token = t + +class ParseError(Exception): + def __init__(self, msg, t): + super(ParseError, self).__init__(msg) + self.token = t def t_error(t): raise TokenError("Illegal character", t) @@ -157,7 +164,7 @@ def p_file(p): p[0] = [ x for x in p[1] if x is not None ] def p_error(t): - raise ParseError(t) + raise ParseError("Syntax error", t) def p_empty(p): "empty :" @@ -544,7 +551,7 @@ def scan(filenames): try: results = yacc.parse(file(filename, 'r').read()) except (TokenError, ParseError), e: - raise type(e), tuple([filename] + [ i for i in e ]) + sys.exit("%s: %s:%d" % (e, filename, e.token.lineno)) for result in results: result.add(hh, cc)