From 585c57234f6f2dbab7d56ec1351e5aeb052d3edb Mon Sep 17 00:00:00 2001 From: Seo Sanghyeon Date: Mon, 25 Mar 2013 15:02:42 +0900 Subject: [PATCH] rustdoc: Show purity --- src/librustdoc/tystr_pass.rs | 9 ++++++--- src/libsyntax/print/pprust.rs | 31 +++++++++++-------------------- 2 files changed, 17 insertions(+), 23 deletions(-) diff --git a/src/librustdoc/tystr_pass.rs b/src/librustdoc/tystr_pass.rs index 1472f6777b4..8289de4e4e7 100644 --- a/src/librustdoc/tystr_pass.rs +++ b/src/librustdoc/tystr_pass.rs @@ -69,13 +69,13 @@ fn get_fn_sig(srv: astsrv::Srv, fn_id: doc::AstId) -> Option<~str> { match ctxt.ast_map.get(&fn_id) { ast_map::node_item(@ast::item { ident: ident, - node: ast::item_fn(ref decl, _, ref tys, _), _ + node: ast::item_fn(ref decl, purity, ref tys, _), _ }, _) | ast_map::node_foreign_item(@ast::foreign_item { ident: ident, - node: ast::foreign_item_fn(ref decl, _, ref tys), _ + node: ast::foreign_item_fn(ref decl, purity, ref tys), _ }, _, _, _) => { - Some(pprust::fun_to_str(decl, ident, None, tys, + Some(pprust::fun_to_str(decl, purity, ident, None, tys, extract::interner())) } _ => fail!(~"get_fn_sig: fn_id not bound to a fn item") @@ -214,6 +214,7 @@ fn get_method_sig( ast::required(ty_m) => { Some(pprust::fun_to_str( &ty_m.decl, + ty_m.purity, ty_m.ident, Some(ty_m.self_ty.node), &ty_m.generics, @@ -223,6 +224,7 @@ fn get_method_sig( ast::provided(m) => { Some(pprust::fun_to_str( &m.decl, + m.purity, m.ident, Some(m.self_ty.node), &m.generics, @@ -243,6 +245,7 @@ fn get_method_sig( Some(method) => { Some(pprust::fun_to_str( &method.decl, + method.purity, method.ident, Some(method.self_ty.node), &method.generics, diff --git a/src/libsyntax/print/pprust.rs b/src/libsyntax/print/pprust.rs index a8ff189fade..9a9834c488b 100644 --- a/src/libsyntax/print/pprust.rs +++ b/src/libsyntax/print/pprust.rs @@ -180,12 +180,12 @@ pub fn path_to_str(&&p: @ast::path, intr: @ident_interner) -> ~str { to_str(p, |a,b| print_path(a, b, false), intr) } -pub fn fun_to_str(decl: &ast::fn_decl, name: ast::ident, +pub fn fun_to_str(decl: &ast::fn_decl, purity: ast::purity, name: ast::ident, opt_self_ty: Option, generics: &ast::Generics, intr: @ident_interner) -> ~str { do io::with_str_writer |wr| { let s = rust_printer(wr, intr); - print_fn(s, decl, None, name, generics, opt_self_ty, ast::inherited); + print_fn(s, decl, purity, name, generics, opt_self_ty, ast::inherited); end(s); // Close the head box end(s); // Close the outer box eof(s.s); @@ -441,7 +441,7 @@ pub fn print_foreign_item(s: @ps, item: @ast::foreign_item) { print_outer_attributes(s, item.attrs); match item.node { ast::foreign_item_fn(ref decl, purity, ref generics) => { - print_fn(s, decl, Some(purity), item.ident, generics, None, + print_fn(s, decl, purity, item.ident, generics, None, ast::inherited); end(s); // end head-ibox word(s.s, ~";"); @@ -484,7 +484,7 @@ pub fn print_item(s: @ps, &&item: @ast::item) { print_fn( s, decl, - Some(purity), + purity, item.ident, typarams, None, @@ -815,7 +815,7 @@ pub fn print_method(s: @ps, meth: @ast::method) { hardbreak_if_not_bol(s); maybe_print_comment(s, meth.span.lo); print_outer_attributes(s, meth.attrs); - print_fn(s, &meth.decl, Some(meth.purity), + print_fn(s, &meth.decl, meth.purity, meth.ident, &meth.generics, Some(meth.self_ty.node), meth.vis); word(s.s, ~" "); @@ -1663,7 +1663,7 @@ pub fn print_self_ty(s: @ps, self_ty: ast::self_ty_) -> bool { pub fn print_fn(s: @ps, decl: &ast::fn_decl, - purity: Option, + purity: ast::purity, name: ast::ident, generics: &ast::Generics, opt_self_ty: Option, @@ -2158,16 +2158,6 @@ pub fn next_comment(s: @ps) -> Option { } } -pub fn print_opt_purity(s: @ps, opt_purity: Option) { - match opt_purity { - Some(ast::impure_fn) => { } - Some(purity) => { - word_nbsp(s, purity_to_str(purity)); - } - None => {} - } -} - pub fn print_opt_abi(s: @ps, opt_abi: Option) { match opt_abi { Some(ast::RustAbi) => { word_nbsp(s, ~"extern"); } @@ -2186,12 +2176,12 @@ pub fn print_opt_sigil(s: @ps, opt_sigil: Option) { pub fn print_fn_header_info(s: @ps, opt_sty: Option, - opt_purity: Option, + purity: ast::purity, onceness: ast::Onceness, opt_sigil: Option, vis: ast::visibility) { word(s.s, visibility_qualified(vis, ~"")); - print_opt_purity(s, opt_purity); + print_purity(s, purity); print_onceness(s, onceness); word(s.s, ~"fn"); print_opt_sigil(s, opt_sigil); @@ -2264,8 +2254,9 @@ pub mod test { cf: ast::return_val }; let generics = ast_util::empty_generics(); - assert_eq!(&fun_to_str(&decl, abba_ident, None, &generics, mock_interner), - &~"fn abba()"); + assert_eq!(&fun_to_str(&decl, ast::impure_fn, abba_ident, + None, &generics, mock_interner), + &~"fn abba()"); } #[test]