Add highlighting support for doc comments

This commit is contained in:
Paul Daniel Faria 2020-06-15 20:17:26 -04:00
parent 931f317399
commit aae26bc5b8
5 changed files with 56 additions and 41 deletions

View file

@ -38,48 +38,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>() -&gt; <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>() -&gt; <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>) -&gt; <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>) -&gt; <span class="builtin_type">bool</span> {
<span class="bool_literal">true</span> <span class="bool_literal">true</span>
} }

View file

@ -475,7 +475,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)?;
if comment.kind().doc.is_some() {
Highlight::from(HighlightTag::Comment) | HighlightModifier::Documentation
} else {
HighlightTag::Comment.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(),

View file

@ -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, Highlight, HighlightModifier, HighlightTag,
HighlightedRange, RootDatabase,
};
use super::HighlightedRangeStack; use super::HighlightedRangeStack;
@ -118,7 +121,8 @@ 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: Highlight::from(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();

View file

@ -55,6 +55,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,
} }
@ -106,6 +107,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,
]; ];
@ -115,6 +117,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",
} }

View file

@ -330,6 +330,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,