Skip to content

Commit 0a715cf

Browse files
bors[bot]Anatol Liu
andauthored
Merge #6472
6472: Add `static` modifier for associated functions r=matklad a=p3achyjr Adds static semantic token modifier to associated functions, resolves #6194 ## Info - Associated functions are more-or-less equivalent to static methods in other languages. This PR checks, for each function, whether that function has a self_param, and whether it's enclosed in a trait/impl. ## Changes - Added method ```is_associated``` to code_model::Function. This basically gets the source from the ast, and checks whether the enclosing scope is an impl or trait. - Added `static` to HighlightModifiers - Added unit test ## Tests - Ran ```cargo test``` Co-authored-by: Anatol Liu <[email protected]>
2 parents d5775b3 + 6b950d2 commit 0a715cf

File tree

7 files changed

+95
-3
lines changed

7 files changed

+95
-3
lines changed

crates/ide/src/syntax_highlighting.rs

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ pub(crate) mod tags;
66
#[cfg(test)]
77
mod tests;
88

9-
use hir::{Local, Name, Semantics, VariantDef};
9+
use hir::{AsAssocItem, Local, Name, Semantics, VariantDef};
1010
use ide_db::{
1111
defs::{Definition, NameClass, NameRefClass},
1212
RootDatabase,
@@ -746,6 +746,9 @@ fn highlight_def(db: &RootDatabase, def: Definition) -> Highlight {
746746
if func.is_unsafe(db) {
747747
h |= HighlightModifier::Unsafe;
748748
}
749+
if func.as_assoc_item(db).is_some() && func.self_param(db).is_none() {
750+
h |= HighlightModifier::Static;
751+
}
749752
return h;
750753
}
751754
hir::ModuleDef::Adt(hir::Adt::Struct(_)) => HighlightTag::Struct,

crates/ide/src/syntax_highlighting/tags.rs

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -65,6 +65,8 @@ pub enum HighlightModifier {
6565
Consuming,
6666
Unsafe,
6767
Callable,
68+
/// Used for associated functions
69+
Static,
6870
}
6971

7072
impl HighlightTag {
@@ -124,6 +126,7 @@ impl HighlightModifier {
124126
HighlightModifier::Consuming,
125127
HighlightModifier::Unsafe,
126128
HighlightModifier::Callable,
129+
HighlightModifier::Static,
127130
];
128131

129132
fn as_str(self) -> &'static str {
@@ -137,6 +140,7 @@ impl HighlightModifier {
137140
HighlightModifier::Consuming => "consuming",
138141
HighlightModifier::Unsafe => "unsafe",
139142
HighlightModifier::Callable => "callable",
143+
HighlightModifier::Static => "static",
140144
}
141145
}
142146

Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
2+
<style>
3+
body { margin: 0; }
4+
pre { color: #DCDCCC; background: #3F3F3F; font-size: 22px; padding: 0.4em; }
5+
6+
.lifetime { color: #DFAF8F; font-style: italic; }
7+
.comment { color: #7F9F7F; }
8+
.documentation { color: #629755; }
9+
.injected { opacity: 0.65 ; }
10+
.struct, .enum { color: #7CB8BB; }
11+
.enum_variant { color: #BDE0F3; }
12+
.string_literal { color: #CC9393; }
13+
.field { color: #94BFF3; }
14+
.function { color: #93E0E3; }
15+
.function.unsafe { color: #BC8383; }
16+
.operator.unsafe { color: #BC8383; }
17+
.parameter { color: #94BFF3; }
18+
.text { color: #DCDCCC; }
19+
.type { color: #7CB8BB; }
20+
.builtin_type { color: #8CD0D3; }
21+
.type_param { color: #DFAF8F; }
22+
.attribute { color: #94BFF3; }
23+
.numeric_literal { color: #BFEBBF; }
24+
.bool_literal { color: #BFE6EB; }
25+
.macro { color: #94BFF3; }
26+
.module { color: #AFD8AF; }
27+
.value_param { color: #DCDCCC; }
28+
.variable { color: #DCDCCC; }
29+
.format_specifier { color: #CC696B; }
30+
.mutable { text-decoration: underline; }
31+
.escape_sequence { color: #94BFF3; }
32+
.keyword { color: #F0DFAF; font-weight: bold; }
33+
.keyword.unsafe { color: #BC8383; font-weight: bold; }
34+
.control { font-style: italic; }
35+
36+
.unresolved_reference { color: #FC5555; text-decoration: wavy underline; }
37+
</style>
38+
<pre><code><span class="keyword">fn</span> <span class="function declaration">not_static</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="punctuation">{</span><span class="punctuation">}</span>
39+
40+
<span class="keyword">struct</span> <span class="struct declaration">foo</span> <span class="punctuation">{</span><span class="punctuation">}</span>
41+
42+
<span class="keyword">impl</span> <span class="struct">foo</span> <span class="punctuation">{</span>
43+
<span class="keyword">pub</span> <span class="keyword">fn</span> <span class="function declaration static">is_static</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="punctuation">{</span><span class="punctuation">}</span>
44+
<span class="keyword">pub</span> <span class="keyword">fn</span> <span class="function declaration">is_not_static</span><span class="punctuation">(</span><span class="operator">&</span><span class="self_keyword">self</span><span class="punctuation">)</span> <span class="punctuation">{</span><span class="punctuation">}</span>
45+
<span class="punctuation">}</span>
46+
47+
<span class="keyword">trait</span> <span class="trait declaration">t</span> <span class="punctuation">{</span>
48+
<span class="keyword">fn</span> <span class="function declaration static">t_is_static</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="punctuation">{</span><span class="punctuation">}</span>
49+
<span class="keyword">fn</span> <span class="function declaration">t_is_not_static</span><span class="punctuation">(</span><span class="operator">&</span><span class="self_keyword">self</span><span class="punctuation">)</span> <span class="punctuation">{</span><span class="punctuation">}</span>
50+
<span class="punctuation">}</span>
51+
52+
<span class="keyword">impl</span> <span class="trait">t</span> <span class="keyword">for</span> <span class="struct">foo</span> <span class="punctuation">{</span>
53+
<span class="keyword">pub</span> <span class="keyword">fn</span> <span class="function declaration static">is_static</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="punctuation">{</span><span class="punctuation">}</span>
54+
<span class="keyword">pub</span> <span class="keyword">fn</span> <span class="function declaration">is_not_static</span><span class="punctuation">(</span><span class="operator">&</span><span class="self_keyword">self</span><span class="punctuation">)</span> <span class="punctuation">{</span><span class="punctuation">}</span>
55+
<span class="punctuation">}</span>
56+
</code></pre>

crates/ide/src/syntax_highlighting/test_data/highlight_doctest.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -53,7 +53,7 @@
5353
<span class="comment documentation">/// #</span><span class="generic injected"> </span><span class="attribute injected">#</span><span class="attribute injected">!</span><span class="attribute injected">[</span><span class="function attribute injected">allow</span><span class="punctuation injected">(</span><span class="attribute injected">unused_mut</span><span class="punctuation injected">)</span><span class="attribute injected">]</span>
5454
<span class="comment documentation">/// </span><span class="keyword injected">let</span><span class="generic injected"> </span><span class="keyword injected">mut</span><span class="generic injected"> </span><span class="variable declaration injected mutable">foo</span><span class="punctuation injected">:</span><span class="generic injected"> </span><span class="struct injected">Foo</span><span class="generic injected"> </span><span class="operator injected">=</span><span class="generic injected"> </span><span class="struct injected">Foo</span><span class="operator injected">::</span><span class="function injected">new</span><span class="punctuation injected">(</span><span class="punctuation injected">)</span><span class="punctuation injected">;</span><span class="punctuation injected">
5555
</span> <span class="comment documentation">/// ```</span>
56-
<span class="keyword">pub</span> <span class="keyword">const</span> <span class="keyword">fn</span> <span class="function declaration">new</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="operator">-&gt;</span> <span class="struct">Foo</span> <span class="punctuation">{</span>
56+
<span class="keyword">pub</span> <span class="keyword">const</span> <span class="keyword">fn</span> <span class="function declaration static">new</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="operator">-&gt;</span> <span class="struct">Foo</span> <span class="punctuation">{</span>
5757
<span class="struct">Foo</span> <span class="punctuation">{</span> <span class="field">bar</span><span class="punctuation">:</span> <span class="bool_literal">true</span> <span class="punctuation">}</span>
5858
<span class="punctuation">}</span>
5959

crates/ide/src/syntax_highlighting/test_data/highlight_injection.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@
4040
<span class="keyword">fn</span> <span class="function declaration">main</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="punctuation">{</span>
4141
<span class="function">fixture</span><span class="punctuation">(</span><span class="string_literal">r#"</span>
4242
<span class="keyword">trait</span> <span class="trait declaration">Foo</span> <span class="punctuation">{</span>
43-
<span class="keyword">fn</span> <span class="function declaration">foo</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="punctuation">{</span>
43+
<span class="keyword">fn</span> <span class="function declaration static">foo</span><span class="punctuation">(</span><span class="punctuation">)</span> <span class="punctuation">{</span>
4444
<span class="macro">println!</span><span class="punctuation">(</span><span class="string_literal">"2 + 2 = {}"</span><span class="punctuation">,</span> <span class="numeric_literal">4</span><span class="punctuation">)</span><span class="punctuation">;</span>
4545
<span class="punctuation">}</span>
4646
<span class="punctuation">}</span><span class="string_literal">"#</span>

crates/ide/src/syntax_highlighting/tests.rs

Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -513,6 +513,34 @@ fn test_extern_crate() {
513513
);
514514
}
515515

516+
#[test]
517+
fn test_associated_function() {
518+
check_highlighting(
519+
r#"
520+
fn not_static() {}
521+
522+
struct foo {}
523+
524+
impl foo {
525+
pub fn is_static() {}
526+
pub fn is_not_static(&self) {}
527+
}
528+
529+
trait t {
530+
fn t_is_static() {}
531+
fn t_is_not_static(&self) {}
532+
}
533+
534+
impl t for foo {
535+
pub fn is_static() {}
536+
pub fn is_not_static(&self) {}
537+
}
538+
"#,
539+
expect_file!["./test_data/highlight_assoc_functions.html"],
540+
false,
541+
)
542+
}
543+
516544
/// Highlights the code given by the `ra_fixture` argument, renders the
517545
/// result as HTML, and compares it with the HTML file given as `snapshot`.
518546
/// Note that the `snapshot` file is overwritten by the rendered HTML.

crates/rust-analyzer/src/to_proto.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -426,6 +426,7 @@ fn semantic_token_type_and_modifiers(
426426
HighlightModifier::Consuming => semantic_tokens::CONSUMING,
427427
HighlightModifier::Unsafe => semantic_tokens::UNSAFE,
428428
HighlightModifier::Callable => semantic_tokens::CALLABLE,
429+
HighlightModifier::Static => lsp_types::SemanticTokenModifier::STATIC,
429430
};
430431
mods |= modifier;
431432
}

0 commit comments

Comments
 (0)