Fix fallout from coercion removal
This commit is contained in:
parent
803aacd5ae
commit
ca08540a00
142 changed files with 1269 additions and 1283 deletions
|
|
@ -136,6 +136,7 @@ fn decodable_substructure(cx: &mut ExtCtxt, trait_span: Span,
|
|||
cx.expr_ident(trait_span, variant), arms));
|
||||
let lambda = cx.lambda_expr(trait_span, vec!(blkarg, variant), result);
|
||||
let variant_vec = cx.expr_vec(trait_span, variants);
|
||||
let variant_vec = cx.expr_addr_of(trait_span, variant_vec);
|
||||
let result = cx.expr_method_call(trait_span, blkdecoder,
|
||||
cx.ident_of("read_enum_variant"),
|
||||
vec!(variant_vec, lambda));
|
||||
|
|
|
|||
|
|
@ -14,7 +14,7 @@ use ext::base::*;
|
|||
use ext::base;
|
||||
use ext::build::AstBuilder;
|
||||
use fmt_macros as parse;
|
||||
use parse::token::InternedString;
|
||||
use parse::token::{InternedString, special_idents};
|
||||
use parse::token;
|
||||
use ptr::P;
|
||||
|
||||
|
|
@ -476,12 +476,11 @@ impl<'a, 'b> Context<'a, 'b> {
|
|||
pieces: Vec<P<ast::Expr>>)
|
||||
-> P<ast::Stmt> {
|
||||
let fmtsp = piece_ty.span;
|
||||
let pieces_len = ecx.expr_uint(fmtsp, pieces.len());
|
||||
let fmt = ecx.expr_vec(fmtsp, pieces);
|
||||
let ty = ast::TyFixedLengthVec(
|
||||
piece_ty,
|
||||
pieces_len
|
||||
);
|
||||
let fmt = ecx.expr_addr_of(fmtsp, fmt);
|
||||
let ty = ast::TyVec(piece_ty);
|
||||
let ty = ast::TyRptr(Some(ecx.lifetime(fmtsp, special_idents::static_lifetime.name)),
|
||||
ast::MutTy{ mutbl: ast::MutImmutable, ty: ecx.ty(fmtsp, ty) });
|
||||
let ty = ecx.ty(fmtsp, ty);
|
||||
let st = ast::ItemStatic(ty, ast::MutImmutable, fmt);
|
||||
let item = ecx.item(fmtsp, name, Context::static_attrs(ecx, fmtsp), st);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue