mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-01 07:48:45 +00:00
Deunwrap convert_comment_block
This commit is contained in:
parent
326f37ef1f
commit
9c6257138d
2 changed files with 36 additions and 26 deletions
|
@ -78,21 +78,26 @@ fn line_to_block(acc: &mut Assists, comment: ast::Comment) -> Option<()> {
|
||||||
// Establish the target of our edit based on the comments we found
|
// Establish the target of our edit based on the comments we found
|
||||||
let target = TextRange::new(
|
let target = TextRange::new(
|
||||||
comments[0].syntax().text_range().start(),
|
comments[0].syntax().text_range().start(),
|
||||||
comments.last().unwrap().syntax().text_range().end(),
|
comments.last()?.syntax().text_range().end(),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// We pick a single indentation level for the whole block comment based on the
|
||||||
|
// comment where the assist was invoked. This will be prepended to the
|
||||||
|
// contents of each line comment when they're put into the block comment.
|
||||||
|
let indentation = IndentLevel::from_token(comment.syntax());
|
||||||
|
|
||||||
|
let mut cms: Vec<String> = Vec::new();
|
||||||
|
for cm in comments {
|
||||||
|
let lcm = line_comment_text(indentation, cm)?;
|
||||||
|
cms.push(lcm);
|
||||||
|
}
|
||||||
|
|
||||||
acc.add(
|
acc.add(
|
||||||
AssistId("line_to_block", AssistKind::RefactorRewrite),
|
AssistId("line_to_block", AssistKind::RefactorRewrite),
|
||||||
"Replace line comments with a single block comment",
|
"Replace line comments with a single block comment",
|
||||||
target,
|
target,
|
||||||
|edit| {
|
|edit| {
|
||||||
// We pick a single indentation level for the whole block comment based on the
|
let block_comment_body = cms.into_iter().join("\n");
|
||||||
// comment where the assist was invoked. This will be prepended to the
|
|
||||||
// contents of each line comment when they're put into the block comment.
|
|
||||||
let indentation = IndentLevel::from_token(comment.syntax());
|
|
||||||
|
|
||||||
let block_comment_body =
|
|
||||||
comments.into_iter().map(|c| line_comment_text(indentation, c)).join("\n");
|
|
||||||
|
|
||||||
let block_prefix =
|
let block_prefix =
|
||||||
CommentKind { shape: CommentShape::Block, ..comment.kind() }.prefix();
|
CommentKind { shape: CommentShape::Block, ..comment.kind() }.prefix();
|
||||||
|
@ -159,15 +164,15 @@ pub(crate) fn relevant_line_comments(comment: &ast::Comment) -> Vec<Comment> {
|
||||||
// */
|
// */
|
||||||
//
|
//
|
||||||
// But since such comments aren't idiomatic we're okay with this.
|
// But since such comments aren't idiomatic we're okay with this.
|
||||||
pub(crate) fn line_comment_text(indentation: IndentLevel, comm: ast::Comment) -> String {
|
pub(crate) fn line_comment_text(indentation: IndentLevel, comm: ast::Comment) -> Option<String> {
|
||||||
let contents_without_prefix = comm.text().strip_prefix(comm.prefix()).unwrap();
|
let contents_without_prefix = comm.text().strip_prefix(comm.prefix())?;
|
||||||
let contents = contents_without_prefix.strip_prefix(' ').unwrap_or(contents_without_prefix);
|
let contents = contents_without_prefix.strip_prefix(' ').unwrap_or(contents_without_prefix);
|
||||||
|
|
||||||
// Don't add the indentation if the line is empty
|
// Don't add the indentation if the line is empty
|
||||||
if contents.is_empty() {
|
if contents.is_empty() {
|
||||||
contents.to_owned()
|
Some(contents.to_owned())
|
||||||
} else {
|
} else {
|
||||||
indentation.to_string() + contents
|
Some(indentation.to_string() + contents)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -57,25 +57,30 @@ pub(crate) fn desugar_doc_comment(acc: &mut Assists, ctx: &AssistContext<'_>) ->
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let text = match comments {
|
||||||
|
Either::Left(comment) => {
|
||||||
|
let text = comment.text();
|
||||||
|
text[comment.prefix().len()..(text.len() - "*/".len())]
|
||||||
|
.trim()
|
||||||
|
.lines()
|
||||||
|
.map(|l| l.strip_prefix(&indentation).unwrap_or(l))
|
||||||
|
.join("\n")
|
||||||
|
}
|
||||||
|
Either::Right(comments) => {
|
||||||
|
let mut cms: Vec<String> = Vec::new();
|
||||||
|
for cm in comments {
|
||||||
|
let lcm = line_comment_text(IndentLevel(0), cm)?;
|
||||||
|
cms.push(lcm);
|
||||||
|
}
|
||||||
|
cms.into_iter().join("\n")
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
acc.add(
|
acc.add(
|
||||||
AssistId("desugar_doc_comment", AssistKind::RefactorRewrite),
|
AssistId("desugar_doc_comment", AssistKind::RefactorRewrite),
|
||||||
"Desugar doc-comment to attribute macro",
|
"Desugar doc-comment to attribute macro",
|
||||||
target,
|
target,
|
||||||
|edit| {
|
|edit| {
|
||||||
let text = match comments {
|
|
||||||
Either::Left(comment) => {
|
|
||||||
let text = comment.text();
|
|
||||||
text[comment.prefix().len()..(text.len() - "*/".len())]
|
|
||||||
.trim()
|
|
||||||
.lines()
|
|
||||||
.map(|l| l.strip_prefix(&indentation).unwrap_or(l))
|
|
||||||
.join("\n")
|
|
||||||
}
|
|
||||||
Either::Right(comments) => {
|
|
||||||
comments.into_iter().map(|c| line_comment_text(IndentLevel(0), c)).join("\n")
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
let hashes = "#".repeat(required_hashes(&text));
|
let hashes = "#".repeat(required_hashes(&text));
|
||||||
|
|
||||||
let prefix = match placement {
|
let prefix = match placement {
|
||||||
|
|
Loading…
Reference in a new issue