From a0617eae68135b48a36e3fdf978cc6f951f92b6e Mon Sep 17 00:00:00 2001 From: Patrick Walton Date: Thu, 29 Nov 2012 17:51:16 -0800 Subject: [PATCH] librustc: Eliminate most expressions of the form `a.b()` that are not method calls. rs=refactoring --- src/libcore/task/mod.rs | 2 +- src/librustc/back/link.rs | 4 +- src/librustc/front/config.rs | 12 +- src/librustc/metadata/encoder.rs | 12 +- src/librustc/metadata/tyencode.rs | 12 +- src/librustc/middle/borrowck/gather_loans.rs | 4 +- src/librustc/middle/check_const.rs | 14 +- src/librustc/middle/check_loop.rs | 14 +- src/librustc/middle/freevars.rs | 2 +- src/librustc/middle/liveness.rs | 4 +- src/librustc/middle/region.rs | 20 +- src/librustc/middle/trans/base.rs | 8 +- src/librustc/middle/trans/common.rs | 4 +- src/librustc/middle/trans/debuginfo.rs | 6 +- src/librustc/middle/trans/glue.rs | 2 +- src/librustc/middle/trans/meth.rs | 3 +- src/librustc/middle/trans/monomorphize.rs | 2 +- src/librustc/middle/trans/reachable.rs | 2 +- src/librustc/middle/trans/type_use.rs | 2 +- src/librustc/middle/typeck/check/mod.rs | 2 +- src/librustc/middle/typeck/check/regionck.rs | 10 +- src/librustc/middle/typeck/check/writeback.rs | 4 +- src/librustdoc/attr_pass.rs | 2 +- src/librustdoc/desc_to_brief_pass.rs | 2 +- src/librustdoc/fold.rs | 62 ++--- src/librustdoc/markdown_index_pass.rs | 2 +- src/librustdoc/markdown_pass.rs | 4 +- src/librustdoc/page_pass.rs | 2 +- src/librustdoc/pass.rs | 2 +- src/librustdoc/path_pass.rs | 6 +- src/librustdoc/prune_hidden_pass.rs | 2 +- src/librustdoc/prune_private_pass.rs | 2 +- src/librustdoc/sectionalize_pass.rs | 2 +- src/librustdoc/sort_pass.rs | 2 +- src/librustdoc/text_pass.rs | 8 +- src/librustdoc/tystr_pass.rs | 2 +- src/libstd/net_tcp.rs | 2 +- src/libsyntax/ast_util.rs | 4 +- src/libsyntax/diagnostic.rs | 10 +- src/libsyntax/ext/expand.rs | 4 +- src/libsyntax/fold.rs | 72 +++--- src/libsyntax/print/pprust.rs | 16 +- src/libsyntax/visit.rs | 217 ++++++++++-------- 43 files changed, 295 insertions(+), 275 deletions(-) diff --git a/src/libcore/task/mod.rs b/src/libcore/task/mod.rs index 90781044277..8497ac7e565 100644 --- a/src/libcore/task/mod.rs +++ b/src/libcore/task/mod.rs @@ -414,7 +414,7 @@ impl TaskBuilder { mut notify_chan: move notify_chan, sched: x.opts.sched }; - spawn::spawn_raw(move opts, x.gen_body(move f)); + spawn::spawn_raw(move opts, (x.gen_body)(move f)); } /// Runs a task, while transfering ownership of one argument to the child. fn spawn_with(arg: A, f: fn~(v: A)) { diff --git a/src/librustc/back/link.rs b/src/librustc/back/link.rs index 36cbdf8c664..2914eec6165 100644 --- a/src/librustc/back/link.rs +++ b/src/librustc/back/link.rs @@ -610,7 +610,7 @@ fn mangle_internal_name_by_type_only(ccx: @crate_ctxt, fn mangle_internal_name_by_path_and_seq(ccx: @crate_ctxt, path: path, flav: ~str) -> ~str { return mangle(ccx.sess, - vec::append_one(path, path_name(ccx.names(flav)))); + vec::append_one(path, path_name((ccx.names)(flav)))); } fn mangle_internal_name_by_path(ccx: @crate_ctxt, path: path) -> ~str { @@ -618,7 +618,7 @@ fn mangle_internal_name_by_path(ccx: @crate_ctxt, path: path) -> ~str { } fn mangle_internal_name_by_seq(ccx: @crate_ctxt, flav: ~str) -> ~str { - return fmt!("%s_%u", flav, ccx.names(flav).repr); + return fmt!("%s_%u", flav, (ccx.names)(flav).repr); } // If the user wants an exe generated we need to invoke diff --git a/src/librustc/front/config.rs b/src/librustc/front/config.rs index 3e0016ee401..df44083361e 100644 --- a/src/librustc/front/config.rs +++ b/src/librustc/front/config.rs @@ -126,25 +126,25 @@ fn fold_block(cx: ctxt, b: ast::blk_, fld: fold::ast_fold) -> } fn item_in_cfg(cx: ctxt, item: @ast::item) -> bool { - return cx.in_cfg(item.attrs); + return (cx.in_cfg)(item.attrs); } fn foreign_item_in_cfg(cx: ctxt, item: @ast::foreign_item) -> bool { - return cx.in_cfg(item.attrs); + return (cx.in_cfg)(item.attrs); } fn view_item_in_cfg(cx: ctxt, item: @ast::view_item) -> bool { - return cx.in_cfg(item.attrs); + return (cx.in_cfg)(item.attrs); } fn method_in_cfg(cx: ctxt, meth: @ast::method) -> bool { - return cx.in_cfg(meth.attrs); + return (cx.in_cfg)(meth.attrs); } fn trait_method_in_cfg(cx: ctxt, meth: &ast::trait_method) -> bool { match *meth { - ast::required(ref meth) => cx.in_cfg(meth.attrs), - ast::provided(@ref meth) => cx.in_cfg(meth.attrs) + ast::required(ref meth) => (cx.in_cfg)(meth.attrs), + ast::provided(@ref meth) => (cx.in_cfg)(meth.attrs) } } diff --git a/src/librustc/metadata/encoder.rs b/src/librustc/metadata/encoder.rs index e1d5fd77f99..61a1615185e 100644 --- a/src/librustc/metadata/encoder.rs +++ b/src/librustc/metadata/encoder.rs @@ -474,7 +474,7 @@ fn encode_info_for_ctor(ecx: @encode_ctxt, ebml_w: Writer::Serializer, encode_path(ecx, ebml_w, path, ast_map::path_name(ident)); match item { Some(it) => { - ecx.encode_inlined_item(ecx, ebml_w, path, it); + (ecx.encode_inlined_item)(ecx, ebml_w, path, it); } None => { encode_symbol(ecx, ebml_w, id); @@ -503,7 +503,7 @@ fn encode_info_for_method(ecx: @encode_ctxt, ebml_w: Writer::Serializer, encode_path(ecx, ebml_w, impl_path, ast_map::path_name(m.ident)); encode_self_type(ebml_w, m.self_ty.node); if all_tps.len() > 0u || should_inline { - ecx.encode_inlined_item( + (ecx.encode_inlined_item)( ecx, ebml_w, impl_path, ii_method(local_def(parent_id), m)); } else { @@ -581,7 +581,7 @@ fn encode_info_for_item(ecx: @encode_ctxt, ebml_w: Writer::Serializer, encode_path(ecx, ebml_w, path, ast_map::path_name(item.ident)); encode_attributes(ebml_w, item.attrs); if tps.len() > 0u || should_inline(item.attrs) { - ecx.encode_inlined_item(ecx, ebml_w, path, ii_item(item)); + (ecx.encode_inlined_item)(ecx, ebml_w, path, ii_item(item)); } else { encode_symbol(ecx, ebml_w, item.id); } @@ -623,7 +623,7 @@ fn encode_info_for_item(ecx: @encode_ctxt, ebml_w: Writer::Serializer, for enum_definition.variants.each |v| { encode_variant_id(ebml_w, local_def(v.node.id)); } - ecx.encode_inlined_item(ecx, ebml_w, path, ii_item(item)); + (ecx.encode_inlined_item)(ecx, ebml_w, path, ii_item(item)); encode_path(ecx, ebml_w, path, ast_map::path_name(item.ident)); encode_region_param(ecx, ebml_w, item); } @@ -851,8 +851,8 @@ fn encode_info_for_foreign_item(ecx: @encode_ctxt, ebml_w: Writer::Serializer, encode_type_param_bounds(ebml_w, ecx, tps); encode_type(ecx, ebml_w, node_id_to_type(ecx.tcx, nitem.id)); if abi == foreign_abi_rust_intrinsic { - ecx.encode_inlined_item(ecx, ebml_w, path, - ii_foreign(nitem)); + (ecx.encode_inlined_item)(ecx, ebml_w, path, + ii_foreign(nitem)); } else { encode_symbol(ecx, ebml_w, nitem.id); } diff --git a/src/librustc/metadata/tyencode.rs b/src/librustc/metadata/tyencode.rs index 232fb7c3b3d..7b5571851a5 100644 --- a/src/librustc/metadata/tyencode.rs +++ b/src/librustc/metadata/tyencode.rs @@ -67,9 +67,9 @@ fn enc_ty(w: io::Writer, cx: @ctxt, t: ty::t) { // Do not emit node ids that map to unexported names. Those // are not helpful. if def_id.crate != local_crate || - cx.reachable(def_id.node) { + (cx.reachable)(def_id.node) { w.write_char('"'); - w.write_str(cx.ds(def_id)); + w.write_str((cx.ds)(def_id)); w.write_char('|'); } } @@ -229,14 +229,14 @@ fn enc_sty(w: io::Writer, cx: @ctxt, st: ty::sty) { } ty::ty_enum(def, substs) => { w.write_str(&"t["); - w.write_str(cx.ds(def)); + w.write_str((cx.ds)(def)); w.write_char('|'); enc_substs(w, cx, substs); w.write_char(']'); } ty::ty_trait(def, substs, vstore) => { w.write_str(&"x["); - w.write_str(cx.ds(def)); + w.write_str((cx.ds)(def)); w.write_char('|'); enc_substs(w, cx, substs); enc_vstore(w, cx, vstore); @@ -293,7 +293,7 @@ fn enc_sty(w: io::Writer, cx: @ctxt, st: ty::sty) { } ty::ty_param({idx: id, def_id: did}) => { w.write_char('p'); - w.write_str(cx.ds(did)); + w.write_str((cx.ds)(did)); w.write_char('|'); w.write_str(uint::str(id)); } @@ -309,7 +309,7 @@ fn enc_sty(w: io::Writer, cx: @ctxt, st: ty::sty) { ty::ty_class(def, substs) => { debug!("~~~~ %s", ~"a["); w.write_str(&"a["); - let s = cx.ds(def); + let s = (cx.ds)(def); debug!("~~~~ %s", s); w.write_str(s); debug!("~~~~ %s", ~"|"); diff --git a/src/librustc/middle/borrowck/gather_loans.rs b/src/librustc/middle/borrowck/gather_loans.rs index 12e8c2b133d..25c43019e47 100644 --- a/src/librustc/middle/borrowck/gather_loans.rs +++ b/src/librustc/middle/borrowck/gather_loans.rs @@ -189,11 +189,11 @@ fn req_loans_in_expr(ex: @ast::expr, ast::expr_while(cond, body) => { // during the condition, can only root for the condition self.root_ub = cond.id; - vt.visit_expr(cond, self, vt); + (vt.visit_expr)(cond, self, vt); // during body, can only root for the body self.root_ub = body.node.id; - vt.visit_block(body, self, vt); + (vt.visit_block)(body, self, vt); } // see explanation attached to the `root_ub` field: diff --git a/src/librustc/middle/check_const.rs b/src/librustc/middle/check_const.rs index 6eb592942e1..e900b13b7c5 100644 --- a/src/librustc/middle/check_const.rs +++ b/src/librustc/middle/check_const.rs @@ -22,13 +22,13 @@ fn check_item(sess: Session, ast_map: ast_map::map, it: @item, &&_is_const: bool, v: visit::vt) { match it.node { item_const(_, ex) => { - v.visit_expr(ex, true, v); + (v.visit_expr)(ex, true, v); check_item_recursion(sess, ast_map, def_map, it); } item_enum(enum_definition, _) => { for enum_definition.variants.each |var| { do option::iter(&var.node.disr_expr) |ex| { - v.visit_expr(*ex, true, v); + (v.visit_expr)(*ex, true, v); } } } @@ -46,10 +46,10 @@ fn check_pat(p: @pat, &&_is_const: bool, v: visit::vt) { } match p.node { // Let through plain ~-string literals here - pat_lit(a) => if !is_str(a) { v.visit_expr(a, true, v); }, + pat_lit(a) => if !is_str(a) { (v.visit_expr)(a, true, v); }, pat_range(a, b) => { - if !is_str(a) { v.visit_expr(a, true, v); } - if !is_str(b) { v.visit_expr(b, true, v); } + if !is_str(a) { (v.visit_expr)(a, true, v); } + if !is_str(b) { (v.visit_expr)(b, true, v); } } _ => visit::visit_pat(p, false, v) } @@ -179,7 +179,7 @@ fn check_item_recursion(sess: Session, ast_map: ast_map::map, visit_expr: visit_expr, .. *visit::default_visitor() }); - visitor.visit_item(it, env, visitor); + (visitor.visit_item)(it, env, visitor); fn visit_item(it: @item, &&env: env, v: visit::vt) { if (*env.idstack).contains(&(it.id)) { @@ -197,7 +197,7 @@ fn check_item_recursion(sess: Session, ast_map: ast_map::map, Some(def_const(def_id)) => { match env.ast_map.get(def_id.node) { ast_map::node_item(it, _) => { - v.visit_item(it, env, v); + (v.visit_item)(it, env, v); } _ => fail ~"const not bound to an item" } diff --git a/src/librustc/middle/check_loop.rs b/src/librustc/middle/check_loop.rs index de275fdcfc4..6372c2c53af 100644 --- a/src/librustc/middle/check_loop.rs +++ b/src/librustc/middle/check_loop.rs @@ -4,29 +4,31 @@ use syntax::visit; type ctx = {in_loop: bool, can_ret: bool}; fn check_crate(tcx: ty::ctxt, crate: @crate) { - visit::visit_crate(*crate, {in_loop: false,can_ret: true}, visit::mk_vt(@{ + visit::visit_crate(*crate, + {in_loop: false, can_ret: true}, + visit::mk_vt(@{ visit_item: |i, _cx, v| { visit::visit_item(i, {in_loop: false, can_ret: true}, v); }, visit_expr: |e: @expr, cx: ctx, v: visit::vt| { match e.node { expr_while(e, b) => { - v.visit_expr(e, cx, v); - v.visit_block(b, {in_loop: true,.. cx}, v); + (v.visit_expr)(e, cx, v); + (v.visit_block)(b, {in_loop: true,.. cx}, v); } expr_loop(b, _) => { - v.visit_block(b, {in_loop: true,.. cx}, v); + (v.visit_block)(b, {in_loop: true,.. cx}, v); } expr_fn(_, _, _, _) => { visit::visit_expr(e, {in_loop: false, can_ret: true}, v); } expr_fn_block(_, b, _) => { - v.visit_block(b, {in_loop: false, can_ret: false}, v); + (v.visit_block)(b, {in_loop: false, can_ret: false}, v); } expr_loop_body(@{node: expr_fn_block(_, b, _), _}) => { let proto = ty::ty_fn_proto(ty::expr_ty(tcx, e)); let blk = (proto == ProtoBorrowed); - v.visit_block(b, {in_loop: true, can_ret: blk}, v); + (v.visit_block)(b, {in_loop: true, can_ret: blk}, v); } expr_break(_) => { if !cx.in_loop { diff --git a/src/librustc/middle/freevars.rs b/src/librustc/middle/freevars.rs index 16f4a66ff0b..86f2748e4c4 100644 --- a/src/librustc/middle/freevars.rs +++ b/src/librustc/middle/freevars.rs @@ -76,7 +76,7 @@ fn collect_freevars(def_map: resolve::DefMap, blk: ast::blk) let v = visit::mk_vt(@{visit_item: ignore_item, visit_expr: walk_expr, .. *visit::default_visitor()}); - v.visit_block(blk, 1, v); + (v.visit_block)(blk, 1, v); return @*refs; } diff --git a/src/librustc/middle/liveness.rs b/src/librustc/middle/liveness.rs index 40b1e293351..86136d60d54 100644 --- a/src/librustc/middle/liveness.rs +++ b/src/librustc/middle/liveness.rs @@ -449,7 +449,7 @@ fn visit_fn(fk: visit::fn_kind, decl: fn_decl, body: blk, visit_arm: check_arm, .. *visit::default_visitor() }); - check_vt.visit_block(body, lsets, check_vt); + (check_vt.visit_block)(body, lsets, check_vt); lsets.check_ret(id, sp, fk, entry_ln); lsets.warn_about_unused_args(decl, entry_ln); } @@ -1512,7 +1512,7 @@ fn check_expr(expr: @expr, &&self: @Liveness, vt: vt<@Liveness>) { expr_assign(l, r) => { self.check_lvalue(l, vt); - vt.visit_expr(r, self, vt); + (vt.visit_expr)(r, self, vt); visit::visit_expr(expr, self, vt); } diff --git a/src/librustc/middle/region.rs b/src/librustc/middle/region.rs index 2950d7bd95d..fbbef2a3658 100644 --- a/src/librustc/middle/region.rs +++ b/src/librustc/middle/region.rs @@ -584,11 +584,13 @@ fn determine_rp_in_fn(fk: visit::fn_kind, visitor: visit::vt) { do cx.with(cx.item_id, false) { do cx.with_ambient_variance(rv_contravariant) { - for decl.inputs.each |a| { visitor.visit_ty(a.ty, cx, visitor); } + for decl.inputs.each |a| { + (visitor.visit_ty)(a.ty, cx, visitor); + } } - visitor.visit_ty(decl.output, cx, visitor); - visitor.visit_ty_params(visit::tps_of_fn(fk), cx, visitor); - visitor.visit_block(body, cx, visitor); + (visitor.visit_ty)(decl.output, cx, visitor); + (visitor.visit_ty_params)(visit::tps_of_fn(fk), cx, visitor); + (visitor.visit_block)(body, cx, visitor); } } @@ -695,7 +697,7 @@ fn determine_rp_in_ty(ty: @ast::Ty, // type parameters are---for now, anyway---always invariant do cx.with_ambient_variance(rv_invariant) { for path.types.each |tp| { - visitor.visit_ty(*tp, cx, visitor); + (visitor.visit_ty)(*tp, cx, visitor); } } } @@ -707,11 +709,11 @@ fn determine_rp_in_ty(ty: @ast::Ty, // parameters are contravariant do cx.with_ambient_variance(rv_contravariant) { for f.decl.inputs.each |a| { - visitor.visit_ty(a.ty, cx, visitor); + (visitor.visit_ty)(a.ty, cx, visitor); } } visit::visit_ty_param_bounds(f.bounds, cx, visitor); - visitor.visit_ty(f.decl.output, cx, visitor); + (visitor.visit_ty)(f.decl.output, cx, visitor); } } @@ -725,10 +727,10 @@ fn determine_rp_in_ty(ty: @ast::Ty, // mutability is invariant if mt.mutbl == ast::m_mutbl { do cx.with_ambient_variance(rv_invariant) { - visitor.visit_ty(mt.ty, cx, visitor); + (visitor.visit_ty)(mt.ty, cx, visitor); } } else { - visitor.visit_ty(mt.ty, cx, visitor); + (visitor.visit_ty)(mt.ty, cx, visitor); } } } diff --git a/src/librustc/middle/trans/base.rs b/src/librustc/middle/trans/base.rs index 7aac60c5f1d..8f77e100f80 100644 --- a/src/librustc/middle/trans/base.rs +++ b/src/librustc/middle/trans/base.rs @@ -1039,7 +1039,7 @@ fn new_block(cx: fn_ctxt, parent: Option, +kind: block_kind, -> block { let s = if cx.ccx.sess.opts.save_temps || cx.ccx.sess.opts.debuginfo { - cx.ccx.names(name) + (cx.ccx.names)(name) } else { special_idents::invalid }; let llbb: BasicBlockRef = str::as_c_str(cx.ccx.sess.str_of(s), |buf| { llvm::LLVMAppendBasicBlock(cx.llfn, buf) @@ -2067,7 +2067,7 @@ fn get_dtor_symbol(ccx: @crate_ctxt, path: path, id: ast::node_id, None if substs.is_none() => { let s = mangle_exported_name( ccx, - vec::append(path, ~[path_name(ccx.names(~"dtor"))]), + vec::append(path, ~[path_name((ccx.names)(~"dtor"))]), t); ccx.item_symbols.insert(id, s); s @@ -2081,7 +2081,7 @@ fn get_dtor_symbol(ccx: @crate_ctxt, path: path, id: ast::node_id, mangle_exported_name( ccx, vec::append(path, - ~[path_name(ccx.names(~"dtor"))]), + ~[path_name((ccx.names)(~"dtor"))]), mono_ty) } None => { @@ -2253,7 +2253,7 @@ fn get_item_val(ccx: @crate_ctxt, id: ast::node_id) -> ValueRef { fn register_method(ccx: @crate_ctxt, id: ast::node_id, pth: @ast_map::path, m: @ast::method) -> ValueRef { let mty = ty::node_id_to_type(ccx.tcx, id); - let pth = vec::append(*pth, ~[path_name(ccx.names(~"meth")), + let pth = vec::append(*pth, ~[path_name((ccx.names)(~"meth")), path_name(m.ident)]); let llfn = register_fn_full(ccx, m.span, pth, id, mty); set_inline_hint_if_appr(m.attrs, llfn); diff --git a/src/librustc/middle/trans/common.rs b/src/librustc/middle/trans/common.rs index 21f1b2d8698..73d6741feea 100644 --- a/src/librustc/middle/trans/common.rs +++ b/src/librustc/middle/trans/common.rs @@ -1049,7 +1049,7 @@ fn C_cstr(cx: @crate_ctxt, s: ~str) -> ValueRef { llvm::LLVMConstString(buf, str::len(s) as c_uint, False) }; let g = - str::as_c_str(fmt!("str%u", cx.names(~"str").repr), + str::as_c_str(fmt!("str%u", (cx.names)(~"str").repr), |buf| llvm::LLVMAddGlobal(cx.llmod, val_ty(sc), buf)); llvm::LLVMSetInitializer(g, sc); llvm::LLVMSetGlobalConstant(g, True); @@ -1111,7 +1111,7 @@ fn C_bytes_plus_null(bytes: ~[u8]) -> ValueRef unsafe { fn C_shape(ccx: @crate_ctxt, bytes: ~[u8]) -> ValueRef { let llshape = C_bytes_plus_null(bytes); - let name = fmt!("shape%u", ccx.names(~"shape").repr); + let name = fmt!("shape%u", (ccx.names)(~"shape").repr); let llglobal = str::as_c_str(name, |buf| { llvm::LLVMAddGlobal(ccx.llmod, val_ty(llshape), buf) }); diff --git a/src/librustc/middle/trans/debuginfo.rs b/src/librustc/middle/trans/debuginfo.rs index d4d1c8d3b2e..f2bae5a8bc8 100644 --- a/src/librustc/middle/trans/debuginfo.rs +++ b/src/librustc/middle/trans/debuginfo.rs @@ -395,7 +395,7 @@ fn create_record(cx: @crate_ctxt, t: ty::t, fields: ~[ast::ty_field], let file_node = create_file(cx, fname); let scx = create_structure(file_node, cx.sess.str_of( - cx.dbg_cx.get().names(~"rec")), + (cx.dbg_cx.get().names)(~"rec")), line_from_span(cx.sess.codemap, span) as int); for fields.each |field| { @@ -747,10 +747,10 @@ fn create_function(fcx: fn_ctxt) -> @metadata { ast_map::node_expr(expr) => { match expr.node { ast::expr_fn(_, decl, _, _) => { - (dbg_cx.names(~"fn"), decl.output, expr.id) + ((dbg_cx.names)(~"fn"), decl.output, expr.id) } ast::expr_fn_block(decl, _, _) => { - (dbg_cx.names(~"fn"), decl.output, expr.id) + ((dbg_cx.names)(~"fn"), decl.output, expr.id) } _ => fcx.ccx.sess.span_bug(expr.span, ~"create_function: \ diff --git a/src/librustc/middle/trans/glue.rs b/src/librustc/middle/trans/glue.rs index 0a44028c7df..e21c2056db4 100644 --- a/src/librustc/middle/trans/glue.rs +++ b/src/librustc/middle/trans/glue.rs @@ -605,7 +605,7 @@ fn declare_tydesc_addrspace(ccx: @crate_ctxt, t: ty::t) -> addrspace { // already correctly tagged with addrspaces. return default_addrspace; } else { - return ccx.next_addrspace(); + return (ccx.next_addrspace)(); } } diff --git a/src/librustc/middle/trans/meth.rs b/src/librustc/middle/trans/meth.rs index 616a193a9b4..4633310e606 100644 --- a/src/librustc/middle/trans/meth.rs +++ b/src/librustc/middle/trans/meth.rs @@ -607,7 +607,8 @@ fn get_vtable(ccx: @crate_ctxt, origin: typeck::vtable_origin) fn make_vtable(ccx: @crate_ctxt, ptrs: ~[ValueRef]) -> ValueRef { let _icx = ccx.insn_ctxt("impl::make_vtable"); let tbl = C_struct(ptrs); - let vt_gvar = str::as_c_str(ccx.sess.str_of(ccx.names(~"vtable")), |buf| { + let vt_gvar = + str::as_c_str(ccx.sess.str_of((ccx.names)(~"vtable")), |buf| { llvm::LLVMAddGlobal(ccx.llmod, val_ty(tbl), buf) }); llvm::LLVMSetInitializer(vt_gvar, tbl); diff --git a/src/librustc/middle/trans/monomorphize.rs b/src/librustc/middle/trans/monomorphize.rs index 2e18fb2a2e9..a05c42ee3fe 100644 --- a/src/librustc/middle/trans/monomorphize.rs +++ b/src/librustc/middle/trans/monomorphize.rs @@ -125,7 +125,7 @@ fn monomorphic_fn(ccx: @crate_ctxt, ccx.monomorphizing.insert(fn_id, depth + 1); let pt = vec::append(*pt, - ~[path_name(ccx.names(ccx.sess.str_of(name)))]); + ~[path_name((ccx.names)(ccx.sess.str_of(name)))]); let s = mangle_exported_name(ccx, pt, mono_ty); let mk_lldecl = || { diff --git a/src/librustc/middle/trans/reachable.rs b/src/librustc/middle/trans/reachable.rs index a99ef96b254..7b03460bb7f 100644 --- a/src/librustc/middle/trans/reachable.rs +++ b/src/librustc/middle/trans/reachable.rs @@ -142,7 +142,7 @@ fn traverse_ty(ty: @Ty, cx: ctx, v: visit::vt) { None => { /* do nothing -- but should we fail here? */ } } for p.types.each |t| { - v.visit_ty(*t, cx, v); + (v.visit_ty)(*t, cx, v); } } _ => visit::visit_ty(ty, cx, v) diff --git a/src/librustc/middle/trans/type_use.rs b/src/librustc/middle/trans/type_use.rs index 53889369361..14744c4cc9e 100644 --- a/src/librustc/middle/trans/type_use.rs +++ b/src/librustc/middle/trans/type_use.rs @@ -297,5 +297,5 @@ fn handle_body(cx: ctx, body: blk) { visit_item: |_i, _cx, _v| { }, ..*visit::default_visitor() }); - v.visit_block(body, cx, v); + (v.visit_block)(body, cx, v); } diff --git a/src/librustc/middle/typeck/check/mod.rs b/src/librustc/middle/typeck/check/mod.rs index 1c2cb4604e5..32d7181b40d 100644 --- a/src/librustc/middle/typeck/check/mod.rs +++ b/src/librustc/middle/typeck/check/mod.rs @@ -415,7 +415,7 @@ fn check_fn(ccx: @crate_ctxt, visit_block: visit_block, .. *visit::default_visitor()}); - visit.visit_block(body, (), visit); + (visit.visit_block)(body, (), visit); } } diff --git a/src/librustc/middle/typeck/check/regionck.rs b/src/librustc/middle/typeck/check/regionck.rs index 970e86d00de..b70c85474d5 100644 --- a/src/librustc/middle/typeck/check/regionck.rs +++ b/src/librustc/middle/typeck/check/regionck.rs @@ -90,7 +90,7 @@ impl @rcx { fn regionck_expr(fcx: @fn_ctxt, e: @ast::expr) { let rcx = rcx_({fcx:fcx, mut errors_reported: 0}); let v = regionck_visitor(); - v.visit_expr(e, @(move rcx), v); + (v.visit_expr)(e, @(move rcx), v); fcx.infcx().resolve_regions(); } @@ -99,7 +99,7 @@ fn regionck_fn(fcx: @fn_ctxt, blk: ast::blk) { let rcx = rcx_({fcx:fcx, mut errors_reported: 0}); let v = regionck_visitor(); - v.visit_block(blk, @(move rcx), v); + (v.visit_block)(blk, @(move rcx), v); fcx.infcx().resolve_regions(); } @@ -132,7 +132,7 @@ fn visit_local(l: @ast::local, &&rcx: @rcx, v: rvt) { // ref pattern, the variable is created with a suitable lower // bound. let e = rcx.errors_reported; - v.visit_pat(l.node.pat, rcx, v); + (v.visit_pat)(l.node.pat, rcx, v); let def_map = rcx.fcx.ccx.tcx.def_map; do pat_bindings(def_map, l.node.pat) |_bm, id, sp, _path| { visit_node(id, sp, rcx); @@ -141,9 +141,9 @@ fn visit_local(l: @ast::local, &&rcx: @rcx, v: rvt) { return; // if decl has errors, skip initializer expr } - v.visit_ty(l.node.ty, rcx, v); + (v.visit_ty)(l.node.ty, rcx, v); for l.node.init.each |i| { - v.visit_expr(*i, rcx, v); + (v.visit_expr)(*i, rcx, v); } } diff --git a/src/librustc/middle/typeck/check/writeback.rs b/src/librustc/middle/typeck/check/writeback.rs index 8000d2f7331..3ac94297191 100644 --- a/src/librustc/middle/typeck/check/writeback.rs +++ b/src/librustc/middle/typeck/check/writeback.rs @@ -217,7 +217,7 @@ fn mk_visitor() -> visit::vt { fn resolve_type_vars_in_expr(fcx: @fn_ctxt, e: @ast::expr) -> bool { let wbcx = {fcx: fcx, mut success: true}; let visit = mk_visitor(); - visit.visit_expr(e, wbcx, visit); + (visit.visit_expr)(e, wbcx, visit); return wbcx.success; } @@ -227,7 +227,7 @@ fn resolve_type_vars_in_fn(fcx: @fn_ctxt, self_info: Option) -> bool { let wbcx = {fcx: fcx, mut success: true}; let visit = mk_visitor(); - visit.visit_block(blk, wbcx, visit); + (visit.visit_block)(blk, wbcx, visit); for self_info.each |self_info| { if self_info.explicit_self.node == ast::sty_static { break; } resolve_type_vars_for_node(wbcx, self_info.explicit_self.span, diff --git a/src/librustdoc/attr_pass.rs b/src/librustdoc/attr_pass.rs index fd68c48a5a7..31ebc38c73e 100644 --- a/src/librustdoc/attr_pass.rs +++ b/src/librustdoc/attr_pass.rs @@ -31,7 +31,7 @@ fn run( fold_impl: fold_impl, .. *fold::default_any_fold(srv) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn fold_crate( diff --git a/src/librustdoc/desc_to_brief_pass.rs b/src/librustdoc/desc_to_brief_pass.rs index 0fbdc0f7e5b..b44efdfaf24 100644 --- a/src/librustdoc/desc_to_brief_pass.rs +++ b/src/librustdoc/desc_to_brief_pass.rs @@ -24,7 +24,7 @@ fn run( fold_impl: fold_impl, .. *fold::default_any_fold(()) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn fold_item(fold: &fold::Fold<()>, +doc: doc::ItemDoc) -> doc::ItemDoc { diff --git a/src/librustdoc/fold.rs b/src/librustdoc/fold.rs index 787d83306b5..85e9aeb86f1 100644 --- a/src/librustdoc/fold.rs +++ b/src/librustdoc/fold.rs @@ -144,7 +144,7 @@ pub fn default_seq_fold_doc(fold: &Fold, +doc: doc::Doc) -> doc::Doc { pages: do vec::map(doc.pages) |page| { match *page { doc::CratePage(doc) => { - doc::CratePage(fold.fold_crate(fold, doc)) + doc::CratePage((fold.fold_crate)(fold, doc)) } doc::ItemPage(doc) => { doc::ItemPage(fold_ItemTag(fold, doc)) @@ -160,7 +160,7 @@ pub fn default_seq_fold_crate( +doc: doc::CrateDoc ) -> doc::CrateDoc { { - topmod: fold.fold_mod(fold, doc.topmod) + topmod: (fold.fold_mod)(fold, doc.topmod) } } @@ -177,7 +177,7 @@ pub fn default_any_fold_mod( ) -> doc::ModDoc { let fold_copy = fold.clone(); doc::ModDoc_({ - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), items: par::map(doc.items, |ItemTag, move fold_copy| { fold_ItemTag(&fold_copy, *ItemTag) }), @@ -190,7 +190,7 @@ pub fn default_seq_fold_mod( +doc: doc::ModDoc ) -> doc::ModDoc { doc::ModDoc_({ - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), items: vec::map(doc.items, |ItemTag| { fold_ItemTag(fold, *ItemTag) }), @@ -204,7 +204,7 @@ pub fn default_par_fold_mod( ) -> doc::ModDoc { let fold_copy = fold.clone(); doc::ModDoc_({ - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), items: par::map(doc.items, |ItemTag, move fold_copy| { fold_ItemTag(&fold_copy, *ItemTag) }), @@ -218,9 +218,9 @@ pub fn default_any_fold_nmod( ) -> doc::NmodDoc { let fold_copy = fold.clone(); { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), fns: par::map(doc.fns, |FnDoc, move fold_copy| { - fold_copy.fold_fn(&fold_copy, *FnDoc) + (fold_copy.fold_fn)(&fold_copy, *FnDoc) }), .. doc } @@ -231,9 +231,9 @@ pub fn default_seq_fold_nmod( +doc: doc::NmodDoc ) -> doc::NmodDoc { { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), fns: vec::map(doc.fns, |FnDoc| { - fold.fold_fn(fold, *FnDoc) + (fold.fold_fn)(fold, *FnDoc) }), .. doc } @@ -245,9 +245,9 @@ pub fn default_par_fold_nmod( ) -> doc::NmodDoc { let fold_copy = fold.clone(); { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), fns: par::map(doc.fns, |FnDoc, move fold_copy| { - fold_copy.fold_fn(&fold_copy, *FnDoc) + (fold_copy.fold_fn)(&fold_copy, *FnDoc) }), .. doc } @@ -256,31 +256,31 @@ pub fn default_par_fold_nmod( pub fn fold_ItemTag(fold: &Fold, +doc: doc::ItemTag) -> doc::ItemTag { match doc { doc::ModTag(ModDoc) => { - doc::ModTag(fold.fold_mod(fold, ModDoc)) + doc::ModTag((fold.fold_mod)(fold, ModDoc)) } doc::NmodTag(nModDoc) => { - doc::NmodTag(fold.fold_nmod(fold, nModDoc)) + doc::NmodTag((fold.fold_nmod)(fold, nModDoc)) } doc::FnTag(FnDoc) => { - doc::FnTag(fold.fold_fn(fold, FnDoc)) + doc::FnTag((fold.fold_fn)(fold, FnDoc)) } doc::ConstTag(ConstDoc) => { - doc::ConstTag(fold.fold_const(fold, ConstDoc)) + doc::ConstTag((fold.fold_const)(fold, ConstDoc)) } doc::EnumTag(EnumDoc) => { - doc::EnumTag(fold.fold_enum(fold, EnumDoc)) + doc::EnumTag((fold.fold_enum)(fold, EnumDoc)) } doc::TraitTag(TraitDoc) => { - doc::TraitTag(fold.fold_trait(fold, TraitDoc)) + doc::TraitTag((fold.fold_trait)(fold, TraitDoc)) } doc::ImplTag(ImplDoc) => { - doc::ImplTag(fold.fold_impl(fold, ImplDoc)) + doc::ImplTag((fold.fold_impl)(fold, ImplDoc)) } doc::TyTag(TyDoc) => { - doc::TyTag(fold.fold_type(fold, TyDoc)) + doc::TyTag((fold.fold_type)(fold, TyDoc)) } doc::StructTag(StructDoc) => { - doc::StructTag(fold.fold_struct(fold, StructDoc)) + doc::StructTag((fold.fold_struct)(fold, StructDoc)) } } } @@ -290,7 +290,7 @@ pub fn default_seq_fold_fn( +doc: doc::FnDoc ) -> doc::FnDoc { { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. doc } } @@ -300,7 +300,7 @@ pub fn default_seq_fold_const( +doc: doc::ConstDoc ) -> doc::ConstDoc { { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. doc } } @@ -310,7 +310,7 @@ pub fn default_seq_fold_enum( +doc: doc::EnumDoc ) -> doc::EnumDoc { { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. doc } } @@ -320,7 +320,7 @@ pub fn default_seq_fold_trait( +doc: doc::TraitDoc ) -> doc::TraitDoc { { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. doc } } @@ -330,7 +330,7 @@ pub fn default_seq_fold_impl( +doc: doc::ImplDoc ) -> doc::ImplDoc { { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. doc } } @@ -340,7 +340,7 @@ pub fn default_seq_fold_type( +doc: doc::TyDoc ) -> doc::TyDoc { { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. doc } } @@ -350,7 +350,7 @@ pub fn default_seq_fold_struct( +doc: doc::StructDoc ) -> doc::StructDoc { { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. doc } } @@ -361,7 +361,7 @@ fn default_fold_should_produce_same_doc() { let ast = parse::from_str(source); let doc = extract::extract(ast, ~""); let fld = default_seq_fold(()); - let folded = fld.fold_doc(&fld, doc); + let folded = (fld.fold_doc)(&fld, doc); assert doc == folded; } @@ -371,7 +371,7 @@ fn default_fold_should_produce_same_consts() { let ast = parse::from_str(source); let doc = extract::extract(ast, ~""); let fld = default_seq_fold(()); - let folded = fld.fold_doc(&fld, doc); + let folded = (fld.fold_doc)(&fld, doc); assert doc == folded; } @@ -381,7 +381,7 @@ fn default_fold_should_produce_same_enums() { let ast = parse::from_str(source); let doc = extract::extract(ast, ~""); let fld = default_seq_fold(()); - let folded = fld.fold_doc(&fld, doc); + let folded = (fld.fold_doc)(&fld, doc); assert doc == folded; } @@ -391,6 +391,6 @@ fn default_parallel_fold_should_produce_same_doc() { let ast = parse::from_str(source); let doc = extract::extract(ast, ~""); let fld = default_par_fold(()); - let folded = fld.fold_doc(&fld, doc); + let folded = (fld.fold_doc)(&fld, doc); assert doc == folded; } diff --git a/src/librustdoc/markdown_index_pass.rs b/src/librustdoc/markdown_index_pass.rs index 42a222b8f5f..07120440c9a 100644 --- a/src/librustdoc/markdown_index_pass.rs +++ b/src/librustdoc/markdown_index_pass.rs @@ -21,7 +21,7 @@ fn run( fold_nmod: fold_nmod, .. *fold::default_any_fold(config) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn fold_mod( diff --git a/src/librustdoc/markdown_pass.rs b/src/librustdoc/markdown_pass.rs index 52e3d654a2b..0ba69a31b1e 100644 --- a/src/librustdoc/markdown_pass.rs +++ b/src/librustdoc/markdown_pass.rs @@ -38,9 +38,9 @@ fn run( // Sort the items so mods come last. All mods will be // output at the same header level so sorting mods last // makes the headers come out nested correctly. - let sorted_doc = sort_pass::mk_pass( + let sorted_doc = (sort_pass::mk_pass( ~"mods last", mods_last - ).f(srv, doc); + ).f)(srv, doc); write_markdown(sorted_doc, move writer_factory); diff --git a/src/librustdoc/page_pass.rs b/src/librustdoc/page_pass.rs index 05fd54fe7ea..307c7c2cd19 100644 --- a/src/librustdoc/page_pass.rs +++ b/src/librustdoc/page_pass.rs @@ -64,7 +64,7 @@ fn find_pages(doc: doc::Doc, page_chan: PageChan) { fold_nmod: fold_nmod, .. *fold::default_any_fold(NominalOp { op: page_chan }) }); - fold.fold_doc(&fold, doc); + (fold.fold_doc)(&fold, doc); comm::send(page_chan, None); } diff --git a/src/librustdoc/pass.rs b/src/librustdoc/pass.rs index 68ea4774fb5..0a61c497528 100644 --- a/src/librustdoc/pass.rs +++ b/src/librustdoc/pass.rs @@ -15,7 +15,7 @@ pub fn run_passes( passno += 1; log(debug, doc); do time(pass.name) { - pass.f(srv, doc) + (pass.f)(srv, doc) } } } diff --git a/src/librustdoc/path_pass.rs b/src/librustdoc/path_pass.rs index 34592a3669c..41117949fa3 100644 --- a/src/librustdoc/path_pass.rs +++ b/src/librustdoc/path_pass.rs @@ -31,7 +31,7 @@ fn run(srv: astsrv::Srv, +doc: doc::Doc) -> doc::Doc { fold_nmod: fold_nmod, .. *fold::default_any_fold(move ctxt) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn fold_item(fold: &fold::Fold, +doc: doc::ItemDoc) -> doc::ItemDoc { @@ -50,7 +50,7 @@ fn fold_mod(fold: &fold::Fold, +doc: doc::ModDoc) -> doc::ModDoc { if !is_topmod { fold.ctxt.path.pop(); } doc::ModDoc_({ - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. *doc }) } @@ -61,7 +61,7 @@ fn fold_nmod(fold: &fold::Fold, +doc: doc::NmodDoc) -> doc::NmodDoc { fold.ctxt.path.pop(); { - item: fold.fold_item(fold, doc.item), + item: (fold.fold_item)(fold, doc.item), .. doc } } diff --git a/src/librustdoc/prune_hidden_pass.rs b/src/librustdoc/prune_hidden_pass.rs index c86dbcba736..f9348d881da 100644 --- a/src/librustdoc/prune_hidden_pass.rs +++ b/src/librustdoc/prune_hidden_pass.rs @@ -15,7 +15,7 @@ fn run(srv: astsrv::Srv, +doc: doc::Doc) -> doc::Doc { fold_mod: fold_mod, .. *fold::default_any_fold(srv) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn fold_mod( diff --git a/src/librustdoc/prune_private_pass.rs b/src/librustdoc/prune_private_pass.rs index ebaca058fe0..2d60132b561 100644 --- a/src/librustdoc/prune_private_pass.rs +++ b/src/librustdoc/prune_private_pass.rs @@ -16,7 +16,7 @@ fn run(srv: astsrv::Srv, +doc: doc::Doc) -> doc::Doc { fold_mod: fold_mod, .. *fold::default_any_fold(srv) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn fold_mod( diff --git a/src/librustdoc/sectionalize_pass.rs b/src/librustdoc/sectionalize_pass.rs index 864522f419a..56db1cf5730 100644 --- a/src/librustdoc/sectionalize_pass.rs +++ b/src/librustdoc/sectionalize_pass.rs @@ -16,7 +16,7 @@ fn run(_srv: astsrv::Srv, +doc: doc::Doc) -> doc::Doc { fold_impl: fold_impl, .. *fold::default_any_fold(()) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn fold_item(fold: &fold::Fold<()>, +doc: doc::ItemDoc) -> doc::ItemDoc { diff --git a/src/librustdoc/sort_pass.rs b/src/librustdoc/sort_pass.rs index 485014a3833..362842f7832 100644 --- a/src/librustdoc/sort_pass.rs +++ b/src/librustdoc/sort_pass.rs @@ -27,7 +27,7 @@ fn run( fold_mod: fold_mod, .. *fold::default_any_fold(move lteq) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } #[allow(non_implicitly_copyable_typarams)] diff --git a/src/librustdoc/text_pass.rs b/src/librustdoc/text_pass.rs index 80104271f10..4a090bab9ba 100644 --- a/src/librustdoc/text_pass.rs +++ b/src/librustdoc/text_pass.rs @@ -30,11 +30,11 @@ fn run( fold_impl: fold_impl, .. *fold::default_any_fold(move op) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn maybe_apply_op(op: NominalOp, s: Option<~str>) -> Option<~str> { - s.map(|s| op.op(*s) ) + s.map(|s| (op.op)(*s) ) } fn fold_item( @@ -56,8 +56,8 @@ fn apply_to_sections( sections: ~[doc::Section] ) -> ~[doc::Section] { par::map(sections, |section, copy op| { - header: op.op(section.header), - body: op.op(section.body) + header: (op.op)(section.header), + body: (op.op)(section.body) }) } diff --git a/src/librustdoc/tystr_pass.rs b/src/librustdoc/tystr_pass.rs index 791caa44d81..4d0ef1aefe1 100644 --- a/src/librustdoc/tystr_pass.rs +++ b/src/librustdoc/tystr_pass.rs @@ -28,7 +28,7 @@ fn run( fold_struct: fold_struct, .. *fold::default_any_fold(srv) }); - fold.fold_doc(&fold, doc) + (fold.fold_doc)(&fold, doc) } fn fold_fn( diff --git a/src/libstd/net_tcp.rs b/src/libstd/net_tcp.rs index 2dd0c2b286d..96897790fcd 100644 --- a/src/libstd/net_tcp.rs +++ b/src/libstd/net_tcp.rs @@ -1059,7 +1059,7 @@ extern fn tcp_lfc_on_connection_cb(handle: *uv::ll::uv_tcp_t, let kill_ch = (*server_data_ptr).kill_ch; if (*server_data_ptr).active { match status { - 0i32 => (*server_data_ptr).on_connect_cb(handle), + 0i32 => ((*server_data_ptr).on_connect_cb)(handle), _ => { let loop_ptr = uv::ll::get_loop_for_uv_handle(handle); core::comm::send(kill_ch, diff --git a/src/libsyntax/ast_util.rs b/src/libsyntax/ast_util.rs index 5686ea11bc5..d0cd6ad54d1 100644 --- a/src/libsyntax/ast_util.rs +++ b/src/libsyntax/ast_util.rs @@ -369,8 +369,8 @@ impl inlined_item: inlined_item_utils { fn accept(e: E, v: visit::vt) { match self { - ii_item(i) => v.visit_item(i, e, v), - ii_foreign(i) => v.visit_foreign_item(i, e, v), + ii_item(i) => (v.visit_item)(i, e, v), + ii_foreign(i) => (v.visit_foreign_item)(i, e, v), ii_method(_, m) => visit::visit_method_helper(m, e, v), ii_dtor(dtor, _, tps, parent_id) => { visit::visit_class_dtor_helper(dtor, tps, parent_id, e, v); diff --git a/src/libsyntax/diagnostic.rs b/src/libsyntax/diagnostic.rs index 8784b3837f1..a8a013cb79c 100644 --- a/src/libsyntax/diagnostic.rs +++ b/src/libsyntax/diagnostic.rs @@ -74,11 +74,11 @@ impl codemap_t: span_handler { impl handler_t: handler { fn fatal(msg: &str) -> ! { - self.emit(None, msg, fatal); + (self.emit)(None, msg, fatal); fail; } fn err(msg: &str) { - self.emit(None, msg, error); + (self.emit)(None, msg, error); self.bump_err_count(); } fn bump_err_count() { @@ -98,17 +98,17 @@ impl handler_t: handler { self.fatal(s); } fn warn(msg: &str) { - self.emit(None, msg, warning); + (self.emit)(None, msg, warning); } fn note(msg: &str) { - self.emit(None, msg, note); + (self.emit)(None, msg, note); } fn bug(msg: &str) -> ! { self.fatal(ice_msg(msg)); } fn unimpl(msg: &str) -> ! { self.bug(~"unimplemented " + msg); } fn emit(cmsp: Option<(@codemap::CodeMap, span)>, msg: &str, lvl: level) { - self.emit(cmsp, msg, lvl); + (self.emit)(cmsp, msg, lvl); } } diff --git a/src/libsyntax/ext/expand.rs b/src/libsyntax/ext/expand.rs index a9390914829..c0bef1e6cde 100644 --- a/src/libsyntax/ext/expand.rs +++ b/src/libsyntax/ext/expand.rs @@ -235,7 +235,7 @@ fn expand_item_mac(exts: HashMap<~str, syntax_extension>, given '%s'", *extname, *cx.parse_sess().interner.get(it.ident))); } - (expand.expander(cx, it.span, tts), expand.span) + ((expand.expander)(cx, it.span, tts), expand.span) } Some(item_tt(expand)) => { if it.ident == parse::token::special_idents::invalid { @@ -243,7 +243,7 @@ fn expand_item_mac(exts: HashMap<~str, syntax_extension>, fmt!("macro %s! expects an ident argument", *extname)); } - (expand.expander(cx, it.span, it.ident, tts), expand.span) + ((expand.expander)(cx, it.span, it.ident, tts), expand.span) } _ => cx.span_fatal( it.span, fmt!("%s! is not legal in item position", *extname)) diff --git a/src/libsyntax/fold.rs b/src/libsyntax/fold.rs index b3ab5897045..9a1f3e7f04e 100644 --- a/src/libsyntax/fold.rs +++ b/src/libsyntax/fold.rs @@ -645,100 +645,100 @@ fn default_ast_fold() -> ast_fold_precursor { impl ast_fold_precursor: ast_fold { /* naturally, a macro to write these would be nice */ fn fold_crate(c: crate) -> crate { - let (n, s) = self.fold_crate(c.node, c.span, self as ast_fold); - return {node: n, span: self.new_span(s)}; + let (n, s) = (self.fold_crate)(c.node, c.span, self as ast_fold); + return {node: n, span: (self.new_span)(s)}; } fn fold_view_item(&&x: @view_item) -> @view_item { - return @{node: self.fold_view_item(x.node, self as ast_fold), + return @{node: (self.fold_view_item)(x.node, self as ast_fold), attrs: vec::map(x.attrs, |a| fold_attribute_(*a, self as ast_fold)), vis: x.vis, - span: self.new_span(x.span)}; + span: (self.new_span)(x.span)}; } fn fold_foreign_item(&&x: @foreign_item) -> @foreign_item { - return self.fold_foreign_item(x, self as ast_fold); + return (self.fold_foreign_item)(x, self as ast_fold); } fn fold_item(&&i: @item) -> Option<@item> { - return self.fold_item(i, self as ast_fold); + return (self.fold_item)(i, self as ast_fold); } fn fold_struct_field(&&sf: @struct_field) -> @struct_field { @{node: {kind: copy sf.node.kind, id: sf.node.id, ty: (self as ast_fold).fold_ty(sf.node.ty)}, - span: self.new_span(sf.span)} + span: (self.new_span)(sf.span)} } fn fold_item_underscore(i: item_) -> item_ { - return self.fold_item_underscore(i, self as ast_fold); + return (self.fold_item_underscore)(i, self as ast_fold); } fn fold_method(&&x: @method) -> @method { - return self.fold_method(x, self as ast_fold); + return (self.fold_method)(x, self as ast_fold); } fn fold_block(x: blk) -> blk { - let (n, s) = self.fold_block(x.node, x.span, self as ast_fold); - return {node: n, span: self.new_span(s)}; + let (n, s) = (self.fold_block)(x.node, x.span, self as ast_fold); + return {node: n, span: (self.new_span)(s)}; } fn fold_stmt(&&x: @stmt) -> @stmt { - let (n, s) = self.fold_stmt(x.node, x.span, self as ast_fold); - return @{node: n, span: self.new_span(s)}; + let (n, s) = (self.fold_stmt)(x.node, x.span, self as ast_fold); + return @{node: n, span: (self.new_span)(s)}; } fn fold_arm(x: arm) -> arm { - return self.fold_arm(x, self as ast_fold); + return (self.fold_arm)(x, self as ast_fold); } fn fold_pat(&&x: @pat) -> @pat { - let (n, s) = self.fold_pat(x.node, x.span, self as ast_fold); - return @{id: self.new_id(x.id), + let (n, s) = (self.fold_pat)(x.node, x.span, self as ast_fold); + return @{id: (self.new_id)(x.id), node: n, - span: self.new_span(s)}; + span: (self.new_span)(s)}; } fn fold_decl(&&x: @decl) -> @decl { - let (n, s) = self.fold_decl(x.node, x.span, self as ast_fold); - return @{node: n, span: self.new_span(s)}; + let (n, s) = (self.fold_decl)(x.node, x.span, self as ast_fold); + return @{node: n, span: (self.new_span)(s)}; } fn fold_expr(&&x: @expr) -> @expr { - let (n, s) = self.fold_expr(x.node, x.span, self as ast_fold); - return @{id: self.new_id(x.id), - callee_id: self.new_id(x.callee_id), + let (n, s) = (self.fold_expr)(x.node, x.span, self as ast_fold); + return @{id: (self.new_id)(x.id), + callee_id: (self.new_id)(x.callee_id), node: n, - span: self.new_span(s)}; + span: (self.new_span)(s)}; } fn fold_ty(&&x: @Ty) -> @Ty { - let (n, s) = self.fold_ty(x.node, x.span, self as ast_fold); - return @{id: self.new_id(x.id), node: n, span: self.new_span(s)}; + let (n, s) = (self.fold_ty)(x.node, x.span, self as ast_fold); + return @{id: (self.new_id)(x.id), node: n, span: (self.new_span)(s)}; } fn fold_mod(x: _mod) -> _mod { - return self.fold_mod(x, self as ast_fold); + return (self.fold_mod)(x, self as ast_fold); } fn fold_foreign_mod(x: foreign_mod) -> foreign_mod { - return self.fold_foreign_mod(x, self as ast_fold); + return (self.fold_foreign_mod)(x, self as ast_fold); } fn fold_variant(x: variant) -> variant { - let (n, s) = self.fold_variant(x.node, x.span, self as ast_fold); - return {node: n, span: self.new_span(s)}; + let (n, s) = (self.fold_variant)(x.node, x.span, self as ast_fold); + return {node: n, span: (self.new_span)(s)}; } fn fold_ident(&&x: ident) -> ident { - return self.fold_ident(x, self as ast_fold); + return (self.fold_ident)(x, self as ast_fold); } fn fold_path(&&x: @path) -> @path { - @self.fold_path(*x, self as ast_fold) + @(self.fold_path)(*x, self as ast_fold) } fn fold_local(&&x: @local) -> @local { - let (n, s) = self.fold_local(x.node, x.span, self as ast_fold); - return @{node: n, span: self.new_span(s)}; + let (n, s) = (self.fold_local)(x.node, x.span, self as ast_fold); + return @{node: n, span: (self.new_span)(s)}; } fn map_exprs(f: fn@(&&v: @expr) -> @expr, e: ~[@expr]) -> ~[@expr] { - self.map_exprs(f, e) + (self.map_exprs)(f, e) } fn new_id(node_id: ast::node_id) -> node_id { - self.new_id(node_id) + (self.new_id)(node_id) } fn new_span(span: span) -> span { - self.new_span(span) + (self.new_span)(span) } } diff --git a/src/libsyntax/print/pprust.rs b/src/libsyntax/print/pprust.rs index 75b962bcc93..5ad3c051c59 100644 --- a/src/libsyntax/print/pprust.rs +++ b/src/libsyntax/print/pprust.rs @@ -453,7 +453,7 @@ fn print_item(s: ps, &&item: @ast::item) { maybe_print_comment(s, item.span.lo); print_outer_attributes(s, item.attrs); let ann_node = node_item(s, item); - s.ann.pre(ann_node); + (s.ann.pre)(ann_node); match item.node { ast::item_const(ty, expr) => { head(s, visibility_qualified(item.vis, ~"const")); @@ -581,7 +581,7 @@ fn print_item(s: ps, &&item: @ast::item) { fail ~"invalid item-position syntax bit" } } - s.ann.post(ann_node); + (s.ann.post)(ann_node); } fn print_enum_def(s: ps, enum_definition: ast::enum_def, @@ -928,7 +928,7 @@ fn print_possibly_embedded_block_(s: ps, blk: ast::blk, embedded: embed_type, } maybe_print_comment(s, blk.span.lo); let ann_node = node_block(s, blk); - s.ann.pre(ann_node); + (s.ann.pre)(ann_node); match embedded { block_block_fn => end(s), block_normal => bopen(s) @@ -949,7 +949,7 @@ fn print_possibly_embedded_block_(s: ps, blk: ast::blk, embedded: embed_type, _ => () } bclose_maybe_open(s, blk.span, indented, close_box); - s.ann.post(ann_node); + (s.ann.post)(ann_node); } fn print_if(s: ps, test: @ast::expr, blk: ast::blk, @@ -1055,7 +1055,7 @@ fn print_expr(s: ps, &&expr: @ast::expr) { maybe_print_comment(s, expr.span.lo); ibox(s, indent_unit); let ann_node = node_expr(s, expr); - s.ann.pre(ann_node); + (s.ann.pre)(ann_node); match expr.node { ast::expr_vstore(e, v) => match v { ast::expr_vstore_fixed(_) => { @@ -1415,7 +1415,7 @@ fn print_expr(s: ps, &&expr: @ast::expr) { pclose(s); } } - s.ann.post(ann_node); + (s.ann.post)(ann_node); end(s); } @@ -1500,7 +1500,7 @@ fn print_path(s: ps, &&path: @ast::path, colons_before_params: bool) { fn print_pat(s: ps, &&pat: @ast::pat) { maybe_print_comment(s, pat.span.lo); let ann_node = node_pat(s, pat); - s.ann.pre(ann_node); + (s.ann.pre)(ann_node); /* Pat isn't normalized, but the beauty of it is that it doesn't matter */ match pat.node { @@ -1590,7 +1590,7 @@ fn print_pat(s: ps, &&pat: @ast::pat) { print_expr(s, end); } } - s.ann.post(ann_node); + (s.ann.post)(ann_node); } // Returns whether it printed anything diff --git a/src/libsyntax/visit.rs b/src/libsyntax/visit.rs index 2ddeba1f1cb..fbb1bc91172 100644 --- a/src/libsyntax/visit.rs +++ b/src/libsyntax/visit.rs @@ -90,66 +90,69 @@ fn default_visitor() -> visitor { } fn visit_crate(c: crate, e: E, v: vt) { - v.visit_mod(c.node.module, c.span, crate_node_id, e, v); + (v.visit_mod)(c.node.module, c.span, crate_node_id, e, v); } fn visit_mod(m: _mod, _sp: span, _id: node_id, e: E, v: vt) { - for m.view_items.each |vi| { v.visit_view_item(*vi, e, v); } - for m.items.each |i| { v.visit_item(*i, e, v); } + for m.view_items.each |vi| { (v.visit_view_item)(*vi, e, v); } + for m.items.each |i| { (v.visit_item)(*i, e, v); } } fn visit_view_item(_vi: @view_item, _e: E, _v: vt) { } fn visit_local(loc: @local, e: E, v: vt) { - v.visit_pat(loc.node.pat, e, v); - v.visit_ty(loc.node.ty, e, v); + (v.visit_pat)(loc.node.pat, e, v); + (v.visit_ty)(loc.node.ty, e, v); match loc.node.init { None => (), - Some(ex) => v.visit_expr(ex, e, v) + Some(ex) => (v.visit_expr)(ex, e, v) } } fn visit_item(i: @item, e: E, v: vt) { match i.node { - item_const(t, ex) => { v.visit_ty(t, e, v); v.visit_expr(ex, e, v); } + item_const(t, ex) => { + (v.visit_ty)(t, e, v); + (v.visit_expr)(ex, e, v); + } item_fn(decl, purity, tp, body) => { - v.visit_fn(fk_item_fn(/* FIXME (#2543) */ copy i.ident, + (v.visit_fn)(fk_item_fn(/* FIXME (#2543) */ copy i.ident, /* FIXME (#2543) */ copy tp, purity), decl, body, i.span, i.id, e, v); } - item_mod(m) => v.visit_mod(m, i.span, i.id, e, v), + item_mod(m) => (v.visit_mod)(m, i.span, i.id, e, v), item_foreign_mod(nm) => { - for nm.view_items.each |vi| { v.visit_view_item(*vi, e, v); } - for nm.items.each |ni| { v.visit_foreign_item(*ni, e, v); } + for nm.view_items.each |vi| { (v.visit_view_item)(*vi, e, v); } + for nm.items.each |ni| { (v.visit_foreign_item)(*ni, e, v); } } item_ty(t, tps) => { - v.visit_ty(t, e, v); - v.visit_ty_params(tps, e, v); + (v.visit_ty)(t, e, v); + (v.visit_ty_params)(tps, e, v); } item_enum(enum_definition, tps) => { - v.visit_ty_params(tps, e, v); + (v.visit_ty_params)(tps, e, v); visit_enum_def(enum_definition, tps, e, v); } item_impl(tps, traits, ty, methods) => { - v.visit_ty_params(tps, e, v); + (v.visit_ty_params)(tps, e, v); for traits.each |p| { visit_path(p.path, e, v); } - v.visit_ty(ty, e, v); + (v.visit_ty)(ty, e, v); for methods.each |m| { visit_method_helper(*m, e, v) } } item_class(struct_def, tps) => { - v.visit_ty_params(tps, e, v); - v.visit_struct_def(struct_def, i.ident, tps, i.id, e, v); + (v.visit_ty_params)(tps, e, v); + (v.visit_struct_def)(struct_def, i.ident, tps, i.id, e, v); } item_trait(tps, traits, methods) => { - v.visit_ty_params(tps, e, v); + (v.visit_ty_params)(tps, e, v); for traits.each |p| { visit_path(p.path, e, v); } for methods.each |m| { - v.visit_trait_method(*m, e, v); + (v.visit_trait_method)(*m, e, v); } } item_mac(m) => visit_mac(m, e, v) @@ -161,10 +164,10 @@ fn visit_enum_def(enum_definition: ast::enum_def, tps: ~[ast::ty_param], for enum_definition.variants.each |vr| { match vr.node.kind { tuple_variant_kind(variant_args) => { - for variant_args.each |va| { v.visit_ty(va.ty, e, v); } + for variant_args.each |va| { (v.visit_ty)(va.ty, e, v); } } struct_variant_kind(struct_def) => { - v.visit_struct_def(struct_def, vr.node.name, tps, + (v.visit_struct_def)(struct_def, vr.node.name, tps, vr.node.id, e, v); } enum_variant_kind(enum_definition) => { @@ -172,7 +175,7 @@ fn visit_enum_def(enum_definition: ast::enum_def, tps: ~[ast::ty_param], } } // Visit the disr expr if it exists - vr.node.disr_expr.iter(|ex| v.visit_expr(*ex, e, v)); + vr.node.disr_expr.iter(|ex| (v.visit_expr)(*ex, e, v)); } } @@ -182,21 +185,21 @@ fn visit_ty(t: @Ty, e: E, v: vt) { match t.node { ty_box(mt) | ty_uniq(mt) | ty_vec(mt) | ty_ptr(mt) | ty_rptr(_, mt) => { - v.visit_ty(mt.ty, e, v); + (v.visit_ty)(mt.ty, e, v); } ty_rec(flds) => for flds.each |f| { - v.visit_ty(f.node.mt.ty, e, v); + (v.visit_ty)(f.node.mt.ty, e, v); }, ty_tup(ts) => for ts.each |tt| { - v.visit_ty(*tt, e, v); + (v.visit_ty)(*tt, e, v); }, ty_fn(f) => { - for f.decl.inputs.each |a| { v.visit_ty(a.ty, e, v); } + for f.decl.inputs.each |a| { (v.visit_ty)(a.ty, e, v); } visit_ty_param_bounds(f.bounds, e, v); - v.visit_ty(f.decl.output, e, v); + (v.visit_ty)(f.decl.output, e, v); } ty_path(p, _) => visit_path(p, e, v), - ty_fixed_length_vec(mt, _) => v.visit_ty(mt.ty, e, v), + ty_fixed_length_vec(mt, _) => (v.visit_ty)(mt.ty, e, v), ty_nil | ty_bot | ty_mac(_) | @@ -205,7 +208,7 @@ fn visit_ty(t: @Ty, e: E, v: vt) { } fn visit_path(p: @path, e: E, v: vt) { - for p.types.each |tp| { v.visit_ty(*tp, e, v); } + for p.types.each |tp| { (v.visit_ty)(*tp, e, v); } } fn visit_pat(p: @pat, e: E, v: vt) { @@ -213,28 +216,31 @@ fn visit_pat(p: @pat, e: E, v: vt) { pat_enum(path, children) => { visit_path(path, e, v); do option::iter(&children) |children| { - for children.each |child| { v.visit_pat(*child, e, v); }} + for children.each |child| { (v.visit_pat)(*child, e, v); }} } pat_rec(fields, _) => for fields.each |f| { - v.visit_pat(f.pat, e, v) + (v.visit_pat)(f.pat, e, v) }, pat_struct(path, fields, _) => { visit_path(path, e, v); for fields.each |f| { - v.visit_pat(f.pat, e, v); + (v.visit_pat)(f.pat, e, v); } } pat_tup(elts) => for elts.each |elt| { - v.visit_pat(*elt, e, v) + (v.visit_pat)(*elt, e, v) }, pat_box(inner) | pat_uniq(inner) | pat_region(inner) => - v.visit_pat(inner, e, v), + (v.visit_pat)(inner, e, v), pat_ident(_, path, inner) => { visit_path(path, e, v); - do option::iter(&inner) |subpat| { v.visit_pat(*subpat, e, v)}; + do option::iter(&inner) |subpat| { (v.visit_pat)(*subpat, e, v)}; + } + pat_lit(ex) => (v.visit_expr)(ex, e, v), + pat_range(e1, e2) => { + (v.visit_expr)(e1, e, v); + (v.visit_expr)(e2, e, v); } - pat_lit(ex) => v.visit_expr(ex, e, v), - pat_range(e1, e2) => { v.visit_expr(e1, e, v); v.visit_expr(e2, e, v); } pat_wild => () } } @@ -242,18 +248,18 @@ fn visit_pat(p: @pat, e: E, v: vt) { fn visit_foreign_item(ni: @foreign_item, e: E, v: vt) { match ni.node { foreign_item_fn(fd, _, tps) => { - v.visit_ty_params(tps, e, v); + (v.visit_ty_params)(tps, e, v); visit_fn_decl(fd, e, v); } foreign_item_const(t) => { - v.visit_ty(t, e, v); + (v.visit_ty)(t, e, v); } } } fn visit_ty_param_bounds(bounds: @~[ty_param_bound], e: E, v: vt) { for vec::each(*bounds) |bound| { - v.visit_ty(**bound, e, v) + (v.visit_ty)(**bound, e, v) } } @@ -265,10 +271,10 @@ fn visit_ty_params(tps: ~[ty_param], e: E, v: vt) { fn visit_fn_decl(fd: fn_decl, e: E, v: vt) { for fd.inputs.each |a| { - v.visit_pat(a.pat, e, v); - v.visit_ty(a.ty, e, v); + (v.visit_pat)(a.pat, e, v); + (v.visit_ty)(a.ty, e, v); } - v.visit_ty(fd.output, e, v); + (v.visit_ty)(fd.output, e, v); } // Note: there is no visit_method() method in the visitor, instead override @@ -276,14 +282,14 @@ fn visit_fn_decl(fd: fn_decl, e: E, v: vt) { // because it is not a default impl of any method, though I doubt that really // clarifies anything. - Niko fn visit_method_helper(m: @method, e: E, v: vt) { - v.visit_fn(fk_method(/* FIXME (#2543) */ copy m.ident, + (v.visit_fn)(fk_method(/* FIXME (#2543) */ copy m.ident, /* FIXME (#2543) */ copy m.tps, m), m.decl, m.body, m.span, m.id, e, v); } fn visit_class_dtor_helper(dtor: class_dtor, tps: ~[ty_param], parent_id: def_id, e: E, v: vt) { - v.visit_fn(fk_dtor(/* FIXME (#2543) */ copy tps, dtor.node.attrs, + (v.visit_fn)(fk_dtor(/* FIXME (#2543) */ copy tps, dtor.node.attrs, dtor.node.self_id, parent_id), ast_util::dtor_dec(), dtor.node.body, dtor.span, dtor.node.id, e, v) @@ -292,19 +298,19 @@ fn visit_class_dtor_helper(dtor: class_dtor, tps: ~[ty_param], fn visit_fn(fk: fn_kind, decl: fn_decl, body: blk, _sp: span, _id: node_id, e: E, v: vt) { visit_fn_decl(decl, e, v); - v.visit_ty_params(tps_of_fn(fk), e, v); - v.visit_block(body, e, v); + (v.visit_ty_params)(tps_of_fn(fk), e, v); + (v.visit_block)(body, e, v); } fn visit_ty_method(m: ty_method, e: E, v: vt) { - for m.decl.inputs.each |a| { v.visit_ty(a.ty, e, v); } - v.visit_ty_params(m.tps, e, v); - v.visit_ty(m.decl.output, e, v); + for m.decl.inputs.each |a| { (v.visit_ty)(a.ty, e, v); } + (v.visit_ty_params)(m.tps, e, v); + (v.visit_ty)(m.decl.output, e, v); } fn visit_trait_method(m: trait_method, e: E, v: vt) { match m { - required(ty_m) => v.visit_ty_method(ty_m, e, v), + required(ty_m) => (v.visit_ty_method)(ty_m, e, v), provided(m) => visit_method_helper(m, e, v) } } @@ -312,10 +318,10 @@ fn visit_trait_method(m: trait_method, e: E, v: vt) { fn visit_struct_def(sd: @struct_def, _nm: ast::ident, tps: ~[ty_param], id: node_id, e: E, v: vt) { for sd.fields.each |f| { - v.visit_struct_field(*f, e, v); + (v.visit_struct_field)(*f, e, v); } for sd.methods.each |m| { - v.visit_struct_method(*m, e, v); + (v.visit_struct_method)(*m, e, v); } for sd.traits.each |p| { visit_path(p.path, e, v); @@ -326,7 +332,7 @@ fn visit_struct_def(sd: @struct_def, _nm: ast::ident, tps: ~[ty_param], } fn visit_struct_field(sf: @struct_field, e: E, v: vt) { - v.visit_ty(sf.node.ty, e, v); + (v.visit_ty)(sf.node.ty, e, v); } fn visit_struct_method(m: @method, e: E, v: vt) { @@ -335,19 +341,19 @@ fn visit_struct_method(m: @method, e: E, v: vt) { fn visit_block(b: ast::blk, e: E, v: vt) { for b.node.view_items.each |vi| { - v.visit_view_item(*vi, e, v); + (v.visit_view_item)(*vi, e, v); } for b.node.stmts.each |s| { - v.visit_stmt(*s, e, v); + (v.visit_stmt)(*s, e, v); } visit_expr_opt(b.node.expr, e, v); } fn visit_stmt(s: @stmt, e: E, v: vt) { match s.node { - stmt_decl(d, _) => v.visit_decl(d, e, v), - stmt_expr(ex, _) => v.visit_expr(ex, e, v), - stmt_semi(ex, _) => v.visit_expr(ex, e, v), + stmt_decl(d, _) => (v.visit_decl)(d, e, v), + stmt_expr(ex, _) => (v.visit_expr)(ex, e, v), + stmt_semi(ex, _) => (v.visit_expr)(ex, e, v), stmt_mac(mac, _) => visit_mac(mac, e, v) } } @@ -355,24 +361,24 @@ fn visit_stmt(s: @stmt, e: E, v: vt) { fn visit_decl(d: @decl, e: E, v: vt) { match d.node { decl_local(locs) => for locs.each |loc| { - v.visit_local(*loc, e, v) + (v.visit_local)(*loc, e, v) }, - decl_item(it) => v.visit_item(it, e, v) + decl_item(it) => (v.visit_item)(it, e, v) } } fn visit_expr_opt(eo: Option<@expr>, e: E, v: vt) { - match eo { None => (), Some(ex) => v.visit_expr(ex, e, v) } + match eo { None => (), Some(ex) => (v.visit_expr)(ex, e, v) } } fn visit_exprs(exprs: ~[@expr], e: E, v: vt) { - for exprs.each |ex| { v.visit_expr(*ex, e, v); } + for exprs.each |ex| { (v.visit_expr)(*ex, e, v); } } fn visit_mac(m: mac, e: E, v: vt) { match m.node { ast::mac_invoc(_, arg, _) => { - option::map(&arg, |arg| v.visit_expr(*arg, e, v)); } + option::map(&arg, |arg| (v.visit_expr)(*arg, e, v)); } ast::mac_invoc_tt(*) => { /* no user-serviceable parts inside */ } ast::mac_ellipsis => (), ast::mac_aq(*) => { /* FIXME: maybe visit (Issue #2340) */ } @@ -382,86 +388,95 @@ fn visit_mac(m: mac, e: E, v: vt) { fn visit_expr(ex: @expr, e: E, v: vt) { match ex.node { - expr_vstore(x, _) => v.visit_expr(x, e, v), + expr_vstore(x, _) => (v.visit_expr)(x, e, v), expr_vec(es, _) => visit_exprs(es, e, v), expr_repeat(element, count, _) => { - v.visit_expr(element, e, v); - v.visit_expr(count, e, v); + (v.visit_expr)(element, e, v); + (v.visit_expr)(count, e, v); } expr_rec(flds, base) => { - for flds.each |f| { v.visit_expr(f.node.expr, e, v); } + for flds.each |f| { (v.visit_expr)(f.node.expr, e, v); } visit_expr_opt(base, e, v); } expr_struct(p, flds, base) => { visit_path(p, e, v); - for flds.each |f| { v.visit_expr(f.node.expr, e, v); } + for flds.each |f| { (v.visit_expr)(f.node.expr, e, v); } visit_expr_opt(base, e, v); } - expr_tup(elts) => for elts.each |el| { v.visit_expr(*el, e, v); }, + expr_tup(elts) => for elts.each |el| { (v.visit_expr)(*el, e, v); }, expr_call(callee, args, _) => { visit_exprs(args, e, v); - v.visit_expr(callee, e, v); + (v.visit_expr)(callee, e, v); } expr_binary(_, a, b) => { - v.visit_expr(a, e, v); v.visit_expr(b, e, v); + (v.visit_expr)(a, e, v); (v.visit_expr)(b, e, v); } expr_addr_of(_, x) | expr_unary(_, x) | expr_loop_body(x) | expr_do_body(x) | - expr_assert(x) => v.visit_expr(x, e, v), + expr_assert(x) => (v.visit_expr)(x, e, v), expr_lit(_) => (), - expr_cast(x, t) => { v.visit_expr(x, e, v); v.visit_ty(t, e, v); } + expr_cast(x, t) => { (v.visit_expr)(x, e, v); (v.visit_ty)(t, e, v); } expr_if(x, b, eo) => { - v.visit_expr(x, e, v); - v.visit_block(b, e, v); + (v.visit_expr)(x, e, v); + (v.visit_block)(b, e, v); visit_expr_opt(eo, e, v); } - expr_while(x, b) => { v.visit_expr(x, e, v); v.visit_block(b, e, v); } - expr_loop(b, _) => v.visit_block(b, e, v), + expr_while(x, b) => { + (v.visit_expr)(x, e, v); + (v.visit_block)(b, e, v); + } + expr_loop(b, _) => (v.visit_block)(b, e, v), expr_match(x, arms) => { - v.visit_expr(x, e, v); - for arms.each |a| { v.visit_arm(*a, e, v); } + (v.visit_expr)(x, e, v); + for arms.each |a| { (v.visit_arm)(*a, e, v); } } expr_fn(proto, decl, body, cap_clause) => { - v.visit_fn(fk_anon(proto, cap_clause), decl, body, - ex.span, ex.id, e, v); + (v.visit_fn)(fk_anon(proto, cap_clause), decl, body, + ex.span, ex.id, e, v); } expr_fn_block(decl, body, cap_clause) => { - v.visit_fn(fk_fn_block(cap_clause), decl, body, - ex.span, ex.id, e, v); + (v.visit_fn)(fk_fn_block(cap_clause), decl, body, + ex.span, ex.id, e, v); } - expr_block(b) => v.visit_block(b, e, v), - expr_assign(a, b) => { v.visit_expr(b, e, v); v.visit_expr(a, e, v); } - expr_copy(a) => v.visit_expr(a, e, v), - expr_unary_move(a) => v.visit_expr(a, e, v), - expr_swap(a, b) => { v.visit_expr(a, e, v); v.visit_expr(b, e, v); } + expr_block(b) => (v.visit_block)(b, e, v), + expr_assign(a, b) => { + (v.visit_expr)(b, e, v); + (v.visit_expr)(a, e, v); + } + expr_copy(a) => (v.visit_expr)(a, e, v), + expr_unary_move(a) => (v.visit_expr)(a, e, v), + expr_swap(a, b) => { (v.visit_expr)(a, e, v); (v.visit_expr)(b, e, v); } expr_assign_op(_, a, b) => { - v.visit_expr(b, e, v); - v.visit_expr(a, e, v); + (v.visit_expr)(b, e, v); + (v.visit_expr)(a, e, v); } expr_field(x, _, tys) => { - v.visit_expr(x, e, v); - for tys.each |tp| { v.visit_ty(*tp, e, v); } + (v.visit_expr)(x, e, v); + for tys.each |tp| { (v.visit_ty)(*tp, e, v); } + } + expr_index(a, b) => { + (v.visit_expr)(a, e, v); + (v.visit_expr)(b, e, v); } - expr_index(a, b) => { v.visit_expr(a, e, v); v.visit_expr(b, e, v); } expr_path(p) => visit_path(p, e, v), expr_fail(eo) => visit_expr_opt(eo, e, v), expr_break(_) => (), expr_again(_) => (), expr_ret(eo) => visit_expr_opt(eo, e, v), expr_log(_, lv, x) => { - v.visit_expr(lv, e, v); - v.visit_expr(x, e, v); + (v.visit_expr)(lv, e, v); + (v.visit_expr)(x, e, v); } expr_mac(mac) => visit_mac(mac, e, v), - expr_paren(x) => v.visit_expr(x, e, v), + expr_paren(x) => (v.visit_expr)(x, e, v), } - v.visit_expr_post(ex, e, v); + (v.visit_expr_post)(ex, e, v); } fn visit_arm(a: arm, e: E, v: vt) { - for a.pats.each |p| { v.visit_pat(*p, e, v); } + for a.pats.each |p| { (v.visit_pat)(*p, e, v); } visit_expr_opt(a.guard, e, v); - v.visit_block(a.body, e, v); + (v.visit_block)(a.body, e, v); } // Simpler, non-context passing interface. Always walks the whole tree, simply