Skip to content

Commit

Permalink
Use ._syntax_error in place of HyTypeError.
Browse files Browse the repository at this point in the history
And standardize the indentation of these calls.
  • Loading branch information
Kodiologist committed Jan 26, 2019
1 parent a42e17a commit 8b8096f
Showing 1 changed file with 46 additions and 50 deletions.
96 changes: 46 additions & 50 deletions hy/compiler.py
Original file line number Diff line number Diff line change
Expand Up @@ -436,6 +436,9 @@ def compile(self, tree):
except Exception as e:
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,
oldpy_unpack=False):
"""Collect the expression contexts from a list of compiled expression.
Expand All @@ -455,8 +458,8 @@ def _compile_collect(self, exprs, with_kwargs=False, dict_display=False,

if not PY35 and oldpy_unpack and is_unpack("iterable", expr):
if oldpy_starargs:
raise HyTypeError(expr, "Pythons < 3.5 allow only one "
"`unpack-iterable` per call")
raise self._syntax_error(expr,
"Pythons < 3.5 allow only one `unpack-iterable` per call")
oldpy_starargs = self.compile(expr[1])
ret += oldpy_starargs
oldpy_starargs = oldpy_starargs.force_expr
Expand All @@ -472,21 +475,20 @@ def _compile_collect(self, exprs, with_kwargs=False, dict_display=False,
expr, arg=None, value=ret.force_expr))
elif oldpy_unpack:
if oldpy_kwargs:
raise HyTypeError(expr, "Pythons < 3.5 allow only one "
"`unpack-mapping` per call")
raise self._syntax_error(expr,
"Pythons < 3.5 allow only one `unpack-mapping` per call")
oldpy_kwargs = ret.force_expr

elif with_kwargs and isinstance(expr, HyKeyword):
try:
value = next(exprs_iter)
except StopIteration:
raise HyTypeError(expr,
"Keyword argument {kw} needs "
"a value.".format(kw=expr))
raise self._syntax_error(expr,
"Keyword argument {kw} needs a value.".format(kw=expr))

if not expr:
raise HyTypeError(expr, "Can't call a function with the "
"empty keyword")
raise self._syntax_error(expr,
"Can't call a function with the empty keyword")

compiled_value = self.compile(value)
ret += compiled_value
Expand Down Expand Up @@ -527,8 +529,8 @@ def _storeize(self, expr, name, func=None):

if isinstance(name, Result):
if not name.is_expr():
raise HyTypeError(expr,
"Can't assign or delete a non-expression")
raise self._syntax_error(expr,
"Can't assign or delete a non-expression")
name = name.expr

if isinstance(name, (ast.Tuple, ast.List)):
Expand All @@ -547,9 +549,8 @@ def _storeize(self, expr, name, func=None):
new_name = ast.Starred(
value=self._storeize(expr, name.value, func))
else:
raise HyTypeError(expr,
"Can't assign or delete a %s" %
type(expr).__name__)
raise self._syntax_error(expr,
"Can't assign or delete a %s" % type(expr).__name__)

new_name.ctx = func()
ast.copy_location(new_name, name)
Expand All @@ -575,9 +576,8 @@ def _render_quoted_form(self, form, level):
op = unmangle(ast_str(form[0]))
if level == 0 and op in ("unquote", "unquote-splice"):
if len(form) != 2:
raise HyTypeError(form,
("`%s' needs 1 argument, got %s" %
op, len(form) - 1))
raise HyTypeError("`%s' needs 1 argument, got %s" % op, len(form) - 1,
self.filename, form, self.source)
return set(), form[1], op == "unquote-splice"
elif op == "quasiquote":
level += 1
Expand Down Expand Up @@ -629,7 +629,8 @@ def compile_quote(self, expr, root, arg):
@special("unpack-iterable", [FORM])
def compile_unpack_iterable(self, expr, root, arg):
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 += asty.Starred(expr, value=ret.force_expr, ctx=ast.Load())
return ret
Expand Down Expand Up @@ -659,7 +660,8 @@ def compile_raise_expression(self, expr, root, exc, cause):

if cause is not None:
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)
ret += cause
cause = cause.force_expr
Expand Down Expand Up @@ -706,13 +708,11 @@ def compile_try_expression(self, expr, root, body, catchers, orelse, finalbody):

# Using (else) without (except) is verboten!
if orelse and not handlers:
raise HyTypeError(
expr,
raise self._syntax_error(expr,
"`try' cannot have `else' without `except'")
# Likewise a bare (try) or (try BODY).
if not (handlers or finalbody):
raise HyTypeError(
expr,
raise self._syntax_error(expr,
"`try' must have an `except' or `finally' clause")

returnable = Result(
Expand Down Expand Up @@ -963,7 +963,8 @@ def c(e):
def compile_decorate_expression(self, expr, name, args):
decs, fn = args[:-1], self.compile(args[-1])
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)
fn.stmts[-1].decorator_list = decs + fn.stmts[-1].decorator_list
return ret + fn
Expand Down Expand Up @@ -1194,8 +1195,8 @@ def compile_import_or_require(self, expr, root, entries):
if (HySymbol('*'), None) in kids:
if len(kids) != 1:
star = kids[kids.index((HySymbol('*'), None))][0]
raise HyTypeError(star, "* in an import name list "
"must be on its own")
raise self._syntax_error(star,
"* in an import name list must be on its own")
else:
assignments = [(k, v or k) for k, v in kids]

Expand Down Expand Up @@ -1390,15 +1391,15 @@ def _compile_assign(self, name, result):
if str_name in (["None"] + (["True", "False"] if PY3 else [])):
# Python 2 allows assigning to True and False, although
# this is rarely wise.
raise HyTypeError(name,
"Can't assign to `%s'" % str_name)
raise self._syntax_error(name,
"Can't assign to `%s'" % str_name)

result = self.compile(result)
ld_name = self.compile(name)

if isinstance(ld_name.expr, ast.Call):
raise HyTypeError(name,
"Can't assign to a callable: `%s'" % str_name)
raise self._syntax_error(name,
"Can't assign to a callable: `%s'" % str_name)

if (result.temp_variables
and isinstance(name, HySymbol)
Expand Down Expand Up @@ -1474,7 +1475,8 @@ def compile_function_def(self, expr, root, params, body):
mandatory, optional, rest, kwonly, kwargs = params
optional, defaults, ret = self._parse_optional_args(optional)
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)
ret += ret2
main_args = mandatory + optional
Expand Down Expand Up @@ -1627,8 +1629,8 @@ def compile_expression(self, expr):
return self.compile(expr)

if not expr:
raise HyTypeError(
expr, "empty expressions are not allowed at top level")
raise self._syntax_error(expr,
"empty expressions are not allowed at top level")

args = list(expr)
root = args.pop(0)
Expand All @@ -1646,20 +1648,18 @@ def compile_expression(self, expr):
sroot in (mangle(","), mangle(".")) or
not any(is_unpack("iterable", x) for x in args)):
if sroot in _bad_roots:
raise HyTypeError(
expr,
raise self._syntax_error(expr,
"The special form '{}' is not allowed here".format(root))
# `sroot` is a special operator. Get the build method and
# pattern-match the arguments.
build_method, pattern = _special_form_compilers[sroot]
try:
parse_tree = pattern.parse(args)
except NoParseError as e:
raise HyTypeError(
raise self._syntax_error(
expr[min(e.state.pos + 1, len(expr) - 1)],
"parse error for special form '{}': {}".format(
root,
e.msg.replace("<EOF>", "end of form")))
root, e.msg.replace("<EOF>", "end of form")))
return Result() + build_method(
self, expr, unmangle(sroot), *parse_tree)

Expand All @@ -1681,13 +1681,13 @@ def compile_expression(self, expr):
FORM +
many(FORM)).parse(args)
except NoParseError:
raise HyTypeError(
expr, "attribute access requires object")
raise self._syntax_error(expr,
"attribute access requires object")
# Reconstruct `args` to exclude `obj`.
args = [x for p in kws for x in p] + list(rest)
if is_unpack("iterable", obj):
raise HyTypeError(
obj, "can't call a method on an unpacking form")
raise self._syntax_error(obj,
"can't call a method on an unpacking form")
func = self.compile(HyExpression(
[HySymbol(".").replace(root), obj] +
attrs))
Expand Down Expand Up @@ -1725,16 +1725,12 @@ def compile_symbol(self, symbol):
glob, local = symbol.rsplit(".", 1)

if not glob:
raise HyTypeError(symbol, '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))
raise self._syntax_error(symbol,
'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))

if not local:
raise HyTypeError(symbol, 'cannot access empty attribute')
raise self._syntax_error(symbol,
'cannot access empty attribute')

glob = HySymbol(glob).replace(symbol)
ret = self.compile_symbol(glob)
Expand Down

0 comments on commit 8b8096f

Please sign in to comment.