From 275c1e44383bbacd8d81a9f80df9ad4da99f0168 Mon Sep 17 00:00:00 2001 From: Michael Sullivan Date: Fri, 22 Jun 2012 11:58:07 -0700 Subject: [PATCH] Serialize out uniq vecs types --- src/libsyntax/ext/auto_serialize.rs | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/src/libsyntax/ext/auto_serialize.rs b/src/libsyntax/ext/auto_serialize.rs index 75a88fb221b..fe9f59d5538 100644 --- a/src/libsyntax/ext/auto_serialize.rs +++ b/src/libsyntax/ext/auto_serialize.rs @@ -452,10 +452,7 @@ fn ser_ty(cx: ext_ctxt, tps: ser_tps_map, [] } - ast::ty_vstore(_, _) { - cx.span_unimpl(ty.span, "serialization for vstore types"); - } - + ast::ty_vstore(@{node: ast::ty_vec(mt),_}, ast::vstore_uniq) | ast::ty_vec(mt) { let ser_e = cx.expr( @@ -472,6 +469,11 @@ fn ser_ty(cx: ext_ctxt, tps: ser_tps_map, std::serialization::emit_from_vec($(s), $(v), {|__e| $(ser_e) }) }] } + + ast::ty_vstore(_, _) { + cx.span_unimpl(ty.span, "serialization for vstore types"); + } + } } @@ -673,14 +675,15 @@ fn deser_ty(cx: ext_ctxt, tps: deser_tps_map, #ast{ fail } } - ast::ty_vstore(_, _) { - cx.span_unimpl(ty.span, "deserialization for vstore types"); - } - + ast::ty_vstore(@{node: ast::ty_vec(mt),_}, ast::vstore_uniq) | ast::ty_vec(mt) { let l = deser_lambda(cx, tps, mt.ty, cx.clone(d)); #ast{ std::serialization::read_to_vec($(d), $(l)) } } + + ast::ty_vstore(_, _) { + cx.span_unimpl(ty.span, "deserialization for vstore types"); + } } }