Fix the signature of expr_ext
The extension body is just a string, not an expression.
This commit is contained in:
@@ -275,7 +275,7 @@ tag expr_ {
|
||||
expr_field(@expr, ident, ann);
|
||||
expr_index(@expr, @expr, ann);
|
||||
expr_path(path, option.t[def], ann);
|
||||
expr_ext(path, vec[@expr], option.t[@expr], @expr, ann);
|
||||
expr_ext(path, vec[@expr], option.t[str], @expr, ann);
|
||||
expr_fail(ann);
|
||||
expr_break(ann);
|
||||
expr_cont(ann);
|
||||
|
||||
@@ -46,7 +46,7 @@ export expand_syntax_ext;
|
||||
|
||||
// FIXME: Need to thread parser through here to handle errors correctly
|
||||
fn expand_syntax_ext(vec[@ast.expr] args,
|
||||
option.t[@ast.expr] body) -> @ast.expr {
|
||||
option.t[str] body) -> @ast.expr {
|
||||
|
||||
if (_vec.len[@ast.expr](args) == 0u) {
|
||||
log_err "malformed #fmt call";
|
||||
|
||||
@@ -794,7 +794,7 @@ fn parse_bottom_expr(parser p) -> @ast.expr {
|
||||
pf, p);
|
||||
hi = es.span.hi;
|
||||
ex = expand_syntax_ext(p, es.span, pth, es.node,
|
||||
none[@ast.expr]);
|
||||
none[str]);
|
||||
}
|
||||
|
||||
case (token.FAIL) {
|
||||
@@ -935,7 +935,7 @@ fn parse_bottom_expr(parser p) -> @ast.expr {
|
||||
|
||||
fn expand_syntax_ext(parser p, ast.span sp,
|
||||
&ast.path path, vec[@ast.expr] args,
|
||||
option.t[@ast.expr] body) -> ast.expr_ {
|
||||
option.t[str] body) -> ast.expr_ {
|
||||
|
||||
check (_vec.len[ast.ident](path.node.idents) > 0u);
|
||||
auto extname = path.node.idents.(0);
|
||||
|
||||
@@ -173,7 +173,7 @@ type ast_fold[ENV] =
|
||||
|
||||
(fn(&ENV e, &span sp,
|
||||
&path p, vec[@expr] args,
|
||||
option.t[@expr] body,
|
||||
option.t[str] body,
|
||||
@expr expanded,
|
||||
ann a) -> @expr) fold_expr_ext,
|
||||
|
||||
@@ -1343,7 +1343,7 @@ fn identity_fold_expr_path[ENV](&ENV env, &span sp,
|
||||
|
||||
fn identity_fold_expr_ext[ENV](&ENV env, &span sp,
|
||||
&path p, vec[@expr] args,
|
||||
option.t[@expr] body,
|
||||
option.t[str] body,
|
||||
@expr expanded,
|
||||
ann a) -> @expr {
|
||||
ret @respan(sp, ast.expr_ext(p, args, body, expanded, a));
|
||||
|
||||
@@ -1922,9 +1922,9 @@ fn annotate_expr(&fn_info_map fm, &@expr e) -> @expr {
|
||||
case (expr_path(_,_,_)) {
|
||||
/* no change */
|
||||
}
|
||||
case (expr_ext(?p, ?es, ?e_opt, ?e, ?a)) {
|
||||
case (expr_ext(?p, ?es, ?s_opt, ?e, ?a)) {
|
||||
e1 = expr_ext(p, annotate_exprs(fm, es),
|
||||
annotate_option_exp(fm, e_opt),
|
||||
s_opt,
|
||||
annotate_expr(fm, e), a);
|
||||
}
|
||||
/* no change, next 3 cases */
|
||||
|
||||
Reference in New Issue
Block a user