leave pre comment for self

This commit is contained in:
rchaser53 2019-02-24 15:18:46 +09:00
parent 6a75feedac
commit ae7330eea4
3 changed files with 73 additions and 2 deletions

View File

@ -20,7 +20,8 @@ use crate::expr::{
ExprType, RhsTactics,
};
use crate::lists::{
definitive_tactic, itemize_list, write_list, ListFormatting, ListItem, Separator,
definitive_tactic, extract_pre_comment, itemize_list, write_list, ListFormatting, ListItem,
Separator,
};
use crate::macros::{rewrite_macro, MacroPosition};
use crate::overflow;
@ -2291,9 +2292,15 @@ fn rewrite_args(
// Account for sugary self.
// FIXME: the comment for the self argument is dropped. This is blocked
// on rust issue #27522.
let mut comment_str = "";
let min_args = explicit_self
.and_then(|explicit_self| rewrite_explicit_self(explicit_self, args, context))
.map_or(1, |self_str| {
let comment_span = mk_sp(span.lo(), args[0].pat.span.lo());
comment_str = context
.snippet_provider
.span_to_snippet(comment_span)
.unwrap();
arg_item_strs[0] = self_str;
2
});
@ -2368,7 +2375,12 @@ fn rewrite_args(
&& (arg_items.is_empty()
|| arg_items.len() == 1 && arg_item_strs[0].len() <= one_line_budget);
for (item, arg) in arg_items.iter_mut().zip(arg_item_strs) {
for (index, (item, arg)) in arg_items.iter_mut().zip(arg_item_strs).enumerate() {
if index == 0 && explicit_self.is_some() {
let (pre_comment, pre_comment_style) = extract_pre_comment(comment_str);
item.pre_comment = pre_comment;
item.pre_comment_style = pre_comment_style;
}
item.item = Some(arg);
}

View File

@ -0,0 +1,40 @@
impl TestTrait {
fn foo_one(/* Important comment1 */
self) {
}
fn foo(
/* Important comment1 */
self,
/* Important comment2 */
a: i32,
) {
}
fn bar(
/* Important comment1 */
&mut self,
/* Important comment2 */
a: i32,
) {
}
fn baz(
/* Important comment1 */
self: X< 'a , 'b >,
/* Important comment2 */
a: i32,
) {
}
fn baz_tree(
/* Important comment1 */
self: X< 'a , 'b >,
/* Important comment2 */
a: i32,
/* Important comment3 */
b: i32,
) {
}
}

View File

@ -0,0 +1,19 @@
impl TestTrait {
fn foo_one(/* Important comment1 */ self) {}
fn foo(/* Important comment1 */ self, /* Important comment2 */ a: i32) {}
fn bar(/* Important comment1 */ &mut self, /* Important comment2 */ a: i32) {}
fn baz(/* Important comment1 */ self: X<'a, 'b>, /* Important comment2 */ a: i32) {}
fn baz_tree(
/* Important comment1 */
self: X<'a, 'b>,
/* Important comment2 */
a: i32,
/* Important comment3 */
b: i32,
) {
}
}