Use ._syntax_error in place of HyTypeError.

And standardize the indentation of these calls.
This commit is contained in:
Kodi Arfer 2018-12-08 15:36:13 -05:00
parent 62638b44a3
commit 902926c543

View File

@ -436,6 +436,9 @@ class HyASTCompiler(object):
except Exception as e: except Exception as e:
raise_empty(HyCompileError, e, sys.exc_info()[2]) raise_empty(HyCompileError, e, sys.exc_info()[2])
def _syntax_error(self, expr, message):
return HyTypeError(expr, message)
def _compile_collect(self, exprs, with_kwargs=False, dict_display=False, def _compile_collect(self, exprs, with_kwargs=False, dict_display=False,
oldpy_unpack=False): oldpy_unpack=False):
"""Collect the expression contexts from a list of compiled expression. """Collect the expression contexts from a list of compiled expression.
@ -455,8 +458,8 @@ class HyASTCompiler(object):
if not PY35 and oldpy_unpack and is_unpack("iterable", expr): if not PY35 and oldpy_unpack and is_unpack("iterable", expr):
if oldpy_starargs: if oldpy_starargs:
raise HyTypeError(expr, "Pythons < 3.5 allow only one " raise self._syntax_error(expr,
"`unpack-iterable` per call") "Pythons < 3.5 allow only one `unpack-iterable` per call")
oldpy_starargs = self.compile(expr[1]) oldpy_starargs = self.compile(expr[1])
ret += oldpy_starargs ret += oldpy_starargs
oldpy_starargs = oldpy_starargs.force_expr oldpy_starargs = oldpy_starargs.force_expr
@ -472,21 +475,20 @@ class HyASTCompiler(object):
expr, arg=None, value=ret.force_expr)) expr, arg=None, value=ret.force_expr))
elif oldpy_unpack: elif oldpy_unpack:
if oldpy_kwargs: if oldpy_kwargs:
raise HyTypeError(expr, "Pythons < 3.5 allow only one " raise self._syntax_error(expr,
"`unpack-mapping` per call") "Pythons < 3.5 allow only one `unpack-mapping` per call")
oldpy_kwargs = ret.force_expr oldpy_kwargs = ret.force_expr
elif with_kwargs and isinstance(expr, HyKeyword): elif with_kwargs and isinstance(expr, HyKeyword):
try: try:
value = next(exprs_iter) value = next(exprs_iter)
except StopIteration: except StopIteration:
raise HyTypeError(expr, raise self._syntax_error(expr,
"Keyword argument {kw} needs " "Keyword argument {kw} needs a value.".format(kw=expr))
"a value.".format(kw=expr))
if not expr: if not expr:
raise HyTypeError(expr, "Can't call a function with the " raise self._syntax_error(expr,
"empty keyword") "Can't call a function with the empty keyword")
compiled_value = self.compile(value) compiled_value = self.compile(value)
ret += compiled_value ret += compiled_value
@ -527,7 +529,7 @@ class HyASTCompiler(object):
if isinstance(name, Result): if isinstance(name, Result):
if not name.is_expr(): if not name.is_expr():
raise HyTypeError(expr, raise self._syntax_error(expr,
"Can't assign or delete a non-expression") "Can't assign or delete a non-expression")
name = name.expr name = name.expr
@ -547,9 +549,8 @@ class HyASTCompiler(object):
new_name = ast.Starred( new_name = ast.Starred(
value=self._storeize(expr, name.value, func)) value=self._storeize(expr, name.value, func))
else: else:
raise HyTypeError(expr, raise self._syntax_error(expr,
"Can't assign or delete a %s" % "Can't assign or delete a %s" % type(expr).__name__)
type(expr).__name__)
new_name.ctx = func() new_name.ctx = func()
ast.copy_location(new_name, name) ast.copy_location(new_name, name)
@ -575,9 +576,8 @@ class HyASTCompiler(object):
op = unmangle(ast_str(form[0])) op = unmangle(ast_str(form[0]))
if level == 0 and op in ("unquote", "unquote-splice"): if level == 0 and op in ("unquote", "unquote-splice"):
if len(form) != 2: if len(form) != 2:
raise HyTypeError(form, raise HyTypeError("`%s' needs 1 argument, got %s" % op, len(form) - 1,
("`%s' needs 1 argument, got %s" % self.filename, form, self.source)
op, len(form) - 1))
return set(), form[1], op == "unquote-splice" return set(), form[1], op == "unquote-splice"
elif op == "quasiquote": elif op == "quasiquote":
level += 1 level += 1
@ -629,7 +629,8 @@ class HyASTCompiler(object):
@special("unpack-iterable", [FORM]) @special("unpack-iterable", [FORM])
def compile_unpack_iterable(self, expr, root, arg): def compile_unpack_iterable(self, expr, root, arg):
if not PY3: if not PY3:
raise HyTypeError(expr, "`unpack-iterable` isn't allowed here") raise self._syntax_error(expr,
"`unpack-iterable` isn't allowed here")
ret = self.compile(arg) ret = self.compile(arg)
ret += asty.Starred(expr, value=ret.force_expr, ctx=ast.Load()) ret += asty.Starred(expr, value=ret.force_expr, ctx=ast.Load())
return ret return ret
@ -659,7 +660,8 @@ class HyASTCompiler(object):
if cause is not None: if cause is not None:
if not PY3: if not PY3:
raise HyTypeError(expr, "raise from only supported in python 3") raise self._syntax_error(expr,
"raise from only supported in python 3")
cause = self.compile(cause) cause = self.compile(cause)
ret += cause ret += cause
cause = cause.force_expr cause = cause.force_expr
@ -706,13 +708,11 @@ class HyASTCompiler(object):
# Using (else) without (except) is verboten! # Using (else) without (except) is verboten!
if orelse and not handlers: if orelse and not handlers:
raise HyTypeError( raise self._syntax_error(expr,
expr,
"`try' cannot have `else' without `except'") "`try' cannot have `else' without `except'")
# Likewise a bare (try) or (try BODY). # Likewise a bare (try) or (try BODY).
if not (handlers or finalbody): if not (handlers or finalbody):
raise HyTypeError( raise self._syntax_error(expr,
expr,
"`try' must have an `except' or `finally' clause") "`try' must have an `except' or `finally' clause")
returnable = Result( returnable = Result(
@ -963,7 +963,8 @@ class HyASTCompiler(object):
def compile_decorate_expression(self, expr, name, args): def compile_decorate_expression(self, expr, name, args):
decs, fn = args[:-1], self.compile(args[-1]) decs, fn = args[:-1], self.compile(args[-1])
if not fn.stmts or not isinstance(fn.stmts[-1], _decoratables): if not fn.stmts or not isinstance(fn.stmts[-1], _decoratables):
raise HyTypeError(args[-1], "Decorated a non-function") raise self._syntax_error(args[-1],
"Decorated a non-function")
decs, ret, _ = self._compile_collect(decs) decs, ret, _ = self._compile_collect(decs)
fn.stmts[-1].decorator_list = decs + fn.stmts[-1].decorator_list fn.stmts[-1].decorator_list = decs + fn.stmts[-1].decorator_list
return ret + fn return ret + fn
@ -1194,8 +1195,8 @@ class HyASTCompiler(object):
if (HySymbol('*'), None) in kids: if (HySymbol('*'), None) in kids:
if len(kids) != 1: if len(kids) != 1:
star = kids[kids.index((HySymbol('*'), None))][0] star = kids[kids.index((HySymbol('*'), None))][0]
raise HyTypeError(star, "* in an import name list " raise self._syntax_error(star,
"must be on its own") "* in an import name list must be on its own")
else: else:
assignments = [(k, v or k) for k, v in kids] assignments = [(k, v or k) for k, v in kids]
@ -1390,14 +1391,14 @@ class HyASTCompiler(object):
if str_name in (["None"] + (["True", "False"] if PY3 else [])): if str_name in (["None"] + (["True", "False"] if PY3 else [])):
# Python 2 allows assigning to True and False, although # Python 2 allows assigning to True and False, although
# this is rarely wise. # this is rarely wise.
raise HyTypeError(name, raise self._syntax_error(name,
"Can't assign to `%s'" % str_name) "Can't assign to `%s'" % str_name)
result = self.compile(result) result = self.compile(result)
ld_name = self.compile(name) ld_name = self.compile(name)
if isinstance(ld_name.expr, ast.Call): if isinstance(ld_name.expr, ast.Call):
raise HyTypeError(name, raise self._syntax_error(name,
"Can't assign to a callable: `%s'" % str_name) "Can't assign to a callable: `%s'" % str_name)
if (result.temp_variables if (result.temp_variables
@ -1474,7 +1475,8 @@ class HyASTCompiler(object):
mandatory, optional, rest, kwonly, kwargs = params mandatory, optional, rest, kwonly, kwargs = params
optional, defaults, ret = self._parse_optional_args(optional) optional, defaults, ret = self._parse_optional_args(optional)
if kwonly is not None and not PY3: if kwonly is not None and not PY3:
raise HyTypeError(params, "&kwonly parameters require Python 3") raise self._syntax_error(params,
"&kwonly parameters require Python 3")
kwonly, kw_defaults, ret2 = self._parse_optional_args(kwonly, True) kwonly, kw_defaults, ret2 = self._parse_optional_args(kwonly, True)
ret += ret2 ret += ret2
main_args = mandatory + optional main_args = mandatory + optional
@ -1627,8 +1629,8 @@ class HyASTCompiler(object):
return self.compile(expr) return self.compile(expr)
if not expr: if not expr:
raise HyTypeError( raise self._syntax_error(expr,
expr, "empty expressions are not allowed at top level") "empty expressions are not allowed at top level")
args = list(expr) args = list(expr)
root = args.pop(0) root = args.pop(0)
@ -1646,8 +1648,7 @@ class HyASTCompiler(object):
sroot in (mangle(","), mangle(".")) or sroot in (mangle(","), mangle(".")) or
not any(is_unpack("iterable", x) for x in args)): not any(is_unpack("iterable", x) for x in args)):
if sroot in _bad_roots: if sroot in _bad_roots:
raise HyTypeError( raise self._syntax_error(expr,
expr,
"The special form '{}' is not allowed here".format(root)) "The special form '{}' is not allowed here".format(root))
# `sroot` is a special operator. Get the build method and # `sroot` is a special operator. Get the build method and
# pattern-match the arguments. # pattern-match the arguments.
@ -1655,11 +1656,10 @@ class HyASTCompiler(object):
try: try:
parse_tree = pattern.parse(args) parse_tree = pattern.parse(args)
except NoParseError as e: except NoParseError as e:
raise HyTypeError( raise self._syntax_error(
expr[min(e.state.pos + 1, len(expr) - 1)], expr[min(e.state.pos + 1, len(expr) - 1)],
"parse error for special form '{}': {}".format( "parse error for special form '{}': {}".format(
root, root, e.msg.replace("<EOF>", "end of form")))
e.msg.replace("<EOF>", "end of form")))
return Result() + build_method( return Result() + build_method(
self, expr, unmangle(sroot), *parse_tree) self, expr, unmangle(sroot), *parse_tree)
@ -1681,13 +1681,13 @@ class HyASTCompiler(object):
FORM + FORM +
many(FORM)).parse(args) many(FORM)).parse(args)
except NoParseError: except NoParseError:
raise HyTypeError( raise self._syntax_error(expr,
expr, "attribute access requires object") "attribute access requires object")
# Reconstruct `args` to exclude `obj`. # Reconstruct `args` to exclude `obj`.
args = [x for p in kws for x in p] + list(rest) args = [x for p in kws for x in p] + list(rest)
if is_unpack("iterable", obj): if is_unpack("iterable", obj):
raise HyTypeError( raise self._syntax_error(obj,
obj, "can't call a method on an unpacking form") "can't call a method on an unpacking form")
func = self.compile(HyExpression( func = self.compile(HyExpression(
[HySymbol(".").replace(root), obj] + [HySymbol(".").replace(root), obj] +
attrs)) attrs))
@ -1725,16 +1725,12 @@ class HyASTCompiler(object):
glob, local = symbol.rsplit(".", 1) glob, local = symbol.rsplit(".", 1)
if not glob: if not glob:
raise HyTypeError(symbol, 'cannot access attribute on ' raise self._syntax_error(symbol,
'anything other than a name ' 'cannot access attribute on anything other than a name (in order to get attributes of expressions, use `(. <expression> {attr})` or `(.{attr} <expression>)`)'.format(attr=local))
'(in order to get attributes of '
'expressions, use '
'`(. <expression> {attr})` or '
'`(.{attr} <expression>)`)'.format(
attr=local))
if not local: if not local:
raise HyTypeError(symbol, 'cannot access empty attribute') raise self._syntax_error(symbol,
'cannot access empty attribute')
glob = HySymbol(glob).replace(symbol) glob = HySymbol(glob).replace(symbol)
ret = self.compile_symbol(glob) ret = self.compile_symbol(glob)