mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 14:13:58 +00:00
Merge #4903
4903: Add highlighting support for doc comments r=matklad a=Nashenas88 The language server protocol includes a semantic modifier for documentation. This change exports that modifier for doc comments so users can choose to highlight them differently compared to regular comments. Example: <img width="375" alt="Screen Shot 2020-06-16 at 10 34 14 AM" src="https://user-images.githubusercontent.com/1673130/84788271-f6599580-afbc-11ea-96e5-7a0215da620b.png"> CC @woody77 Co-authored-by: Paul Daniel Faria <Nashenas88@users.noreply.github.com>
This commit is contained in:
commit
f7f627d342
5 changed files with 56 additions and 41 deletions
|
@ -39,48 +39,48 @@ pre { color: #DCDCCC; background: #3F3F3F; font-size: 22px; padd
|
||||||
<span class="keyword">impl</span> <span class="struct">Foo</span> {
|
<span class="keyword">impl</span> <span class="struct">Foo</span> {
|
||||||
<span class="keyword">pub</span> <span class="keyword">const</span> <span class="constant declaration">bar</span>: <span class="builtin_type">bool</span> = <span class="bool_literal">true</span>;
|
<span class="keyword">pub</span> <span class="keyword">const</span> <span class="constant declaration">bar</span>: <span class="builtin_type">bool</span> = <span class="bool_literal">true</span>;
|
||||||
|
|
||||||
<span class="comment">/// Constructs a new `Foo`.</span>
|
<span class="comment documentation">/// Constructs a new `Foo`.</span>
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// # Examples</span>
|
<span class="comment documentation">/// # Examples</span>
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// ```</span>
|
<span class="comment documentation">/// ```</span>
|
||||||
<span class="comment">/// #</span> <span class="attribute">#![</span><span class="function attribute">allow</span><span class="attribute">(unused_mut)]</span>
|
<span class="comment documentation">/// #</span> <span class="attribute">#![</span><span class="function attribute">allow</span><span class="attribute">(unused_mut)]</span>
|
||||||
<span class="comment">/// </span><span class="keyword">let</span> <span class="keyword">mut</span> <span class="variable declaration mutable">foo</span>: <span class="struct">Foo</span> = <span class="struct">Foo</span>::<span class="function">new</span>();
|
<span class="comment documentation">/// </span><span class="keyword">let</span> <span class="keyword">mut</span> <span class="variable declaration mutable">foo</span>: <span class="struct">Foo</span> = <span class="struct">Foo</span>::<span class="function">new</span>();
|
||||||
<span class="comment">/// ```</span>
|
<span class="comment documentation">/// ```</span>
|
||||||
<span class="keyword">pub</span> <span class="keyword">const</span> <span class="keyword">fn</span> <span class="function declaration">new</span>() -> <span class="struct">Foo</span> {
|
<span class="keyword">pub</span> <span class="keyword">const</span> <span class="keyword">fn</span> <span class="function declaration">new</span>() -> <span class="struct">Foo</span> {
|
||||||
<span class="struct">Foo</span> { <span class="field">bar</span>: <span class="bool_literal">true</span> }
|
<span class="struct">Foo</span> { <span class="field">bar</span>: <span class="bool_literal">true</span> }
|
||||||
}
|
}
|
||||||
|
|
||||||
<span class="comment">/// `bar` method on `Foo`.</span>
|
<span class="comment documentation">/// `bar` method on `Foo`.</span>
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// # Examples</span>
|
<span class="comment documentation">/// # Examples</span>
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// ```</span>
|
<span class="comment documentation">/// ```</span>
|
||||||
<span class="comment">/// </span><span class="keyword">use</span> <span class="module">x</span>::<span class="module">y</span>;
|
<span class="comment documentation">/// </span><span class="keyword">use</span> <span class="module">x</span>::<span class="module">y</span>;
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// </span><span class="keyword">let</span> <span class="variable declaration">foo</span> = <span class="struct">Foo</span>::<span class="function">new</span>();
|
<span class="comment documentation">/// </span><span class="keyword">let</span> <span class="variable declaration">foo</span> = <span class="struct">Foo</span>::<span class="function">new</span>();
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// </span><span class="comment">// calls bar on foo</span>
|
<span class="comment documentation">/// </span><span class="comment">// calls bar on foo</span>
|
||||||
<span class="comment">/// </span><span class="macro">assert!</span>(foo.bar());
|
<span class="comment documentation">/// </span><span class="macro">assert!</span>(foo.bar());
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// </span><span class="keyword">let</span> <span class="variable declaration">bar</span> = <span class="variable">foo</span>.<span class="field">bar</span> || <span class="struct">Foo</span>::<span class="constant">bar</span>;
|
<span class="comment documentation">/// </span><span class="keyword">let</span> <span class="variable declaration">bar</span> = <span class="variable">foo</span>.<span class="field">bar</span> || <span class="struct">Foo</span>::<span class="constant">bar</span>;
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// </span><span class="comment">/* multi-line
|
<span class="comment documentation">/// </span><span class="comment">/* multi-line
|
||||||
</span><span class="comment">/// </span><span class="comment"> comment */</span>
|
</span><span class="comment documentation">/// </span><span class="comment"> comment */</span>
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// </span><span class="keyword">let</span> <span class="variable declaration">multi_line_string</span> = <span class="string_literal">"Foo
|
<span class="comment documentation">/// </span><span class="keyword">let</span> <span class="variable declaration">multi_line_string</span> = <span class="string_literal">"Foo
|
||||||
</span><span class="comment">/// </span><span class="string_literal"> bar
|
</span><span class="comment documentation">/// </span><span class="string_literal"> bar
|
||||||
</span><span class="comment">/// </span><span class="string_literal"> "</span>;
|
</span><span class="comment documentation">/// </span><span class="string_literal"> "</span>;
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// ```</span>
|
<span class="comment documentation">/// ```</span>
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// ```rust,no_run</span>
|
<span class="comment documentation">/// ```rust,no_run</span>
|
||||||
<span class="comment">/// </span><span class="keyword">let</span> <span class="variable declaration">foobar</span> = <span class="struct">Foo</span>::<span class="function">new</span>().<span class="function">bar</span>();
|
<span class="comment documentation">/// </span><span class="keyword">let</span> <span class="variable declaration">foobar</span> = <span class="struct">Foo</span>::<span class="function">new</span>().<span class="function">bar</span>();
|
||||||
<span class="comment">/// ```</span>
|
<span class="comment documentation">/// ```</span>
|
||||||
<span class="comment">///</span>
|
<span class="comment documentation">///</span>
|
||||||
<span class="comment">/// ```sh</span>
|
<span class="comment documentation">/// ```sh</span>
|
||||||
<span class="comment">/// echo 1</span>
|
<span class="comment documentation">/// echo 1</span>
|
||||||
<span class="comment">/// ```</span>
|
<span class="comment documentation">/// ```</span>
|
||||||
<span class="keyword">pub</span> <span class="keyword">fn</span> <span class="function declaration">foo</span>(&<span class="self_keyword">self</span>) -> <span class="builtin_type">bool</span> {
|
<span class="keyword">pub</span> <span class="keyword">fn</span> <span class="function declaration">foo</span>(&<span class="self_keyword">self</span>) -> <span class="builtin_type">bool</span> {
|
||||||
<span class="bool_literal">true</span>
|
<span class="bool_literal">true</span>
|
||||||
}
|
}
|
||||||
|
|
|
@ -489,7 +489,14 @@ fn highlight_element(
|
||||||
}
|
}
|
||||||
|
|
||||||
// Simple token-based highlighting
|
// Simple token-based highlighting
|
||||||
COMMENT => HighlightTag::Comment.into(),
|
COMMENT => {
|
||||||
|
let comment = element.into_token().and_then(ast::Comment::cast)?;
|
||||||
|
let h = HighlightTag::Comment;
|
||||||
|
match comment.kind().doc {
|
||||||
|
Some(_) => h | HighlightModifier::Documentation,
|
||||||
|
None => h.into(),
|
||||||
|
}
|
||||||
|
}
|
||||||
STRING | RAW_STRING | RAW_BYTE_STRING | BYTE_STRING => HighlightTag::StringLiteral.into(),
|
STRING | RAW_STRING | RAW_BYTE_STRING | BYTE_STRING => HighlightTag::StringLiteral.into(),
|
||||||
ATTR => HighlightTag::Attribute.into(),
|
ATTR => HighlightTag::Attribute.into(),
|
||||||
INT_NUMBER | FLOAT_NUMBER => HighlightTag::NumericLiteral.into(),
|
INT_NUMBER | FLOAT_NUMBER => HighlightTag::NumericLiteral.into(),
|
||||||
|
|
|
@ -7,7 +7,10 @@ use hir::Semantics;
|
||||||
use ra_syntax::{ast, AstToken, SyntaxNode, SyntaxToken, TextRange, TextSize};
|
use ra_syntax::{ast, AstToken, SyntaxNode, SyntaxToken, TextRange, TextSize};
|
||||||
use stdx::SepBy;
|
use stdx::SepBy;
|
||||||
|
|
||||||
use crate::{call_info::ActiveParameter, Analysis, HighlightTag, HighlightedRange, RootDatabase};
|
use crate::{
|
||||||
|
call_info::ActiveParameter, Analysis, HighlightModifier, HighlightTag, HighlightedRange,
|
||||||
|
RootDatabase,
|
||||||
|
};
|
||||||
|
|
||||||
use super::HighlightedRangeStack;
|
use super::HighlightedRangeStack;
|
||||||
|
|
||||||
|
@ -118,7 +121,7 @@ pub(super) fn extract_doc_comments(
|
||||||
range.start(),
|
range.start(),
|
||||||
range.start() + TextSize::try_from(pos).unwrap(),
|
range.start() + TextSize::try_from(pos).unwrap(),
|
||||||
),
|
),
|
||||||
highlight: HighlightTag::Comment.into(),
|
highlight: HighlightTag::Comment | HighlightModifier::Documentation,
|
||||||
binding_hash: None,
|
binding_hash: None,
|
||||||
});
|
});
|
||||||
line_start += range.len() - TextSize::try_from(pos).unwrap();
|
line_start += range.len() - TextSize::try_from(pos).unwrap();
|
||||||
|
@ -164,6 +167,7 @@ pub(super) fn highlight_doc_comment(
|
||||||
h.range.start() + start_offset,
|
h.range.start() + start_offset,
|
||||||
h.range.end() + end_offset.unwrap_or(start_offset),
|
h.range.end() + end_offset.unwrap_or(start_offset),
|
||||||
);
|
);
|
||||||
|
|
||||||
stack.add(h);
|
stack.add(h);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,6 +56,7 @@ pub enum HighlightModifier {
|
||||||
/// `foo` in `fn foo(x: i32)` is a definition, `foo` in `foo(90 + 2)` is
|
/// `foo` in `fn foo(x: i32)` is a definition, `foo` in `foo(90 + 2)` is
|
||||||
/// not.
|
/// not.
|
||||||
Definition,
|
Definition,
|
||||||
|
Documentation,
|
||||||
Mutable,
|
Mutable,
|
||||||
Unsafe,
|
Unsafe,
|
||||||
}
|
}
|
||||||
|
@ -108,6 +109,7 @@ impl HighlightModifier {
|
||||||
HighlightModifier::Attribute,
|
HighlightModifier::Attribute,
|
||||||
HighlightModifier::ControlFlow,
|
HighlightModifier::ControlFlow,
|
||||||
HighlightModifier::Definition,
|
HighlightModifier::Definition,
|
||||||
|
HighlightModifier::Documentation,
|
||||||
HighlightModifier::Mutable,
|
HighlightModifier::Mutable,
|
||||||
HighlightModifier::Unsafe,
|
HighlightModifier::Unsafe,
|
||||||
];
|
];
|
||||||
|
@ -117,6 +119,7 @@ impl HighlightModifier {
|
||||||
HighlightModifier::Attribute => "attribute",
|
HighlightModifier::Attribute => "attribute",
|
||||||
HighlightModifier::ControlFlow => "control",
|
HighlightModifier::ControlFlow => "control",
|
||||||
HighlightModifier::Definition => "declaration",
|
HighlightModifier::Definition => "declaration",
|
||||||
|
HighlightModifier::Documentation => "documentation",
|
||||||
HighlightModifier::Mutable => "mutable",
|
HighlightModifier::Mutable => "mutable",
|
||||||
HighlightModifier::Unsafe => "unsafe",
|
HighlightModifier::Unsafe => "unsafe",
|
||||||
}
|
}
|
||||||
|
|
|
@ -331,6 +331,7 @@ fn semantic_token_type_and_modifiers(
|
||||||
let modifier = match modifier {
|
let modifier = match modifier {
|
||||||
HighlightModifier::Attribute => semantic_tokens::ATTRIBUTE_MODIFIER,
|
HighlightModifier::Attribute => semantic_tokens::ATTRIBUTE_MODIFIER,
|
||||||
HighlightModifier::Definition => lsp_types::SemanticTokenModifier::DECLARATION,
|
HighlightModifier::Definition => lsp_types::SemanticTokenModifier::DECLARATION,
|
||||||
|
HighlightModifier::Documentation => lsp_types::SemanticTokenModifier::DOCUMENTATION,
|
||||||
HighlightModifier::ControlFlow => semantic_tokens::CONTROL_FLOW,
|
HighlightModifier::ControlFlow => semantic_tokens::CONTROL_FLOW,
|
||||||
HighlightModifier::Mutable => semantic_tokens::MUTABLE,
|
HighlightModifier::Mutable => semantic_tokens::MUTABLE,
|
||||||
HighlightModifier::Unsafe => semantic_tokens::UNSAFE,
|
HighlightModifier::Unsafe => semantic_tokens::UNSAFE,
|
||||||
|
|
Loading…
Reference in a new issue