mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +00:00
Don't parse source files to generate macro completion details
This commit is contained in:
parent
b1ab5770c9
commit
6c8c02f625
15 changed files with 157 additions and 204 deletions
|
@ -18,8 +18,8 @@ use syntax::SmolStr;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
Adt, Const, ConstParam, Enum, Field, Function, GenericParam, HasCrate, HasVisibility,
|
Adt, Const, ConstParam, Enum, Field, Function, GenericParam, HasCrate, HasVisibility,
|
||||||
LifetimeParam, Module, Static, Struct, Trait, TyBuilder, Type, TypeAlias, TypeOrConstParam,
|
LifetimeParam, Macro, Module, Static, Struct, Trait, TyBuilder, Type, TypeAlias,
|
||||||
TypeParam, Union, Variant,
|
TypeOrConstParam, TypeParam, Union, Variant,
|
||||||
};
|
};
|
||||||
|
|
||||||
impl HirDisplay for Function {
|
impl HirDisplay for Function {
|
||||||
|
@ -509,3 +509,14 @@ impl HirDisplay for Module {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl HirDisplay for Macro {
|
||||||
|
fn hir_fmt(&self, f: &mut HirFormatter) -> Result<(), HirDisplayError> {
|
||||||
|
match self.id {
|
||||||
|
hir_def::MacroId::Macro2Id(_) => write!(f, "macro"),
|
||||||
|
hir_def::MacroId::MacroRulesId(_) => write!(f, "macro_rules!"),
|
||||||
|
hir_def::MacroId::ProcMacroId(_) => write!(f, "proc_macro"),
|
||||||
|
}?;
|
||||||
|
write!(f, " {}", self.name(f.db))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
use std::fmt::Display;
|
use std::fmt::Display;
|
||||||
|
|
||||||
use either::Either;
|
use either::Either;
|
||||||
use hir::{AsAssocItem, AttributeTemplate, HasAttrs, HasSource, HirDisplay, Semantics, TypeInfo};
|
use hir::{AsAssocItem, AttributeTemplate, HasAttrs, HirDisplay, Semantics, TypeInfo};
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::SourceDatabase,
|
base_db::SourceDatabase,
|
||||||
defs::Definition,
|
defs::Definition,
|
||||||
|
@ -13,9 +13,7 @@ use ide_db::{
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
use stdx::format_to;
|
use stdx::format_to;
|
||||||
use syntax::{
|
use syntax::{
|
||||||
algo, ast,
|
algo, ast, match_ast, AstNode, Direction,
|
||||||
display::{fn_as_proc_macro_label, macro_label},
|
|
||||||
match_ast, AstNode, Direction,
|
|
||||||
SyntaxKind::{LET_EXPR, LET_STMT},
|
SyntaxKind::{LET_EXPR, LET_STMT},
|
||||||
SyntaxToken, T,
|
SyntaxToken, T,
|
||||||
};
|
};
|
||||||
|
@ -342,14 +340,8 @@ pub(super) fn definition(
|
||||||
) -> Option<Markup> {
|
) -> Option<Markup> {
|
||||||
let mod_path = definition_mod_path(db, &def);
|
let mod_path = definition_mod_path(db, &def);
|
||||||
let (label, docs) = match def {
|
let (label, docs) = match def {
|
||||||
Definition::Macro(it) => (
|
Definition::Macro(it) => label_and_docs(db, it),
|
||||||
match &it.source(db)?.value {
|
Definition::Field(it) => label_and_docs(db, it),
|
||||||
Either::Left(mac) => macro_label(mac),
|
|
||||||
Either::Right(mac_fn) => fn_as_proc_macro_label(mac_fn),
|
|
||||||
},
|
|
||||||
it.attrs(db).docs(),
|
|
||||||
),
|
|
||||||
Definition::Field(def) => label_and_docs(db, def),
|
|
||||||
Definition::Module(it) => label_and_docs(db, it),
|
Definition::Module(it) => label_and_docs(db, it),
|
||||||
Definition::Function(it) => label_and_docs(db, it),
|
Definition::Function(it) => label_and_docs(db, it),
|
||||||
Definition::Adt(it) => label_and_docs(db, it),
|
Definition::Adt(it) => label_and_docs(db, it),
|
||||||
|
|
|
@ -4102,16 +4102,16 @@ identity!{
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
*Copy*
|
*Copy*
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
test
|
test
|
||||||
```
|
```
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
pub macro Copy
|
macro Copy
|
||||||
```
|
```
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4126,16 +4126,16 @@ pub macro Copy {}
|
||||||
struct Foo;
|
struct Foo;
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
*Copy*
|
*Copy*
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
test
|
test
|
||||||
```
|
```
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
pub macro Copy
|
macro Copy
|
||||||
```
|
```
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
check(
|
check(
|
||||||
r#"
|
r#"
|
||||||
|
@ -4148,16 +4148,16 @@ mod foo {
|
||||||
struct Foo;
|
struct Foo;
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
*Copy*
|
*Copy*
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
test::foo
|
test::foo
|
||||||
```
|
```
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
pub macro Copy
|
macro Copy
|
||||||
```
|
```
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -421,10 +421,10 @@ macro_rules! foo { () => {} }
|
||||||
|
|
||||||
fn main() { let _ = crate::$0 }
|
fn main() { let _ = crate::$0 }
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
fn main() fn()
|
fn main() fn()
|
||||||
ma foo!(…) #[macro_export] macro_rules! foo
|
ma foo!(…) macro_rules! foo
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -208,12 +208,12 @@ mod macros {
|
||||||
macro_rules! concat { }
|
macro_rules! concat { }
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
fn f() fn()
|
fn f() fn()
|
||||||
ma concat!(…) #[macro_export] macro_rules! concat
|
ma concat!(…) macro_rules! concat
|
||||||
md std
|
md std
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,12 +1,8 @@
|
||||||
//! Renderer for macro invocations.
|
//! Renderer for macro invocations.
|
||||||
|
|
||||||
use either::Either;
|
use hir::{Documentation, HirDisplay};
|
||||||
use hir::{Documentation, HasSource, InFile, Semantics};
|
use ide_db::SymbolKind;
|
||||||
use ide_db::{RootDatabase, SymbolKind};
|
use syntax::SmolStr;
|
||||||
use syntax::{
|
|
||||||
display::{fn_as_proc_macro_label, macro_label},
|
|
||||||
SmolStr,
|
|
||||||
};
|
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
context::PathKind,
|
context::PathKind,
|
||||||
|
@ -52,7 +48,7 @@ fn render(
|
||||||
label(&ctx, needs_bang, bra, ket, &name),
|
label(&ctx, needs_bang, bra, ket, &name),
|
||||||
);
|
);
|
||||||
item.set_deprecated(ctx.is_deprecated(macro_))
|
item.set_deprecated(ctx.is_deprecated(macro_))
|
||||||
.set_detail(detail(&completion.sema, macro_))
|
.detail(macro_.display(completion.db).to_string())
|
||||||
.set_documentation(docs)
|
.set_documentation(docs)
|
||||||
.set_relevance(ctx.completion_relevance());
|
.set_relevance(ctx.completion_relevance());
|
||||||
|
|
||||||
|
@ -103,18 +99,6 @@ fn banged_name(name: &str) -> SmolStr {
|
||||||
SmolStr::from_iter([name, "!"])
|
SmolStr::from_iter([name, "!"])
|
||||||
}
|
}
|
||||||
|
|
||||||
fn detail(sema: &Semantics<RootDatabase>, macro_: hir::Macro) -> Option<String> {
|
|
||||||
// FIXME: This is parsing the file!
|
|
||||||
let InFile { file_id, value } = macro_.source(sema.db)?;
|
|
||||||
let _ = sema.parse_or_expand(file_id);
|
|
||||||
let detail = match value {
|
|
||||||
Either::Left(node) => macro_label(&node),
|
|
||||||
// FIXME: this should render with the derive name, not the function name
|
|
||||||
Either::Right(node) => fn_as_proc_macro_label(&node),
|
|
||||||
};
|
|
||||||
Some(detail)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn guess_macro_braces(macro_name: &str, docs: &str) -> (&'static str, &'static str) {
|
fn guess_macro_braces(macro_name: &str, docs: &str) -> (&'static str, &'static str) {
|
||||||
let mut votes = [0, 0, 0];
|
let mut votes = [0, 0, 0];
|
||||||
for (idx, s) in docs.match_indices(¯o_name) {
|
for (idx, s) in docs.match_indices(¯o_name) {
|
||||||
|
|
|
@ -62,7 +62,7 @@ fn proc_macros_qualified() {
|
||||||
struct Foo;
|
struct Foo;
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
at identity pub macro identity
|
at identity proc_macro identity
|
||||||
"#]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -302,7 +302,7 @@ struct Foo;
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
md core
|
md core
|
||||||
at derive pub macro derive
|
at derive macro derive
|
||||||
kw self::
|
kw self::
|
||||||
kw super::
|
kw super::
|
||||||
kw crate::
|
kw crate::
|
||||||
|
@ -689,12 +689,12 @@ mod derive {
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
md core
|
md core
|
||||||
de Default pub macro Default
|
de Default macro Default
|
||||||
de Clone, Copy
|
de Clone, Copy
|
||||||
de PartialEq pub macro PartialEq
|
de PartialEq macro PartialEq
|
||||||
de PartialEq, Eq
|
de PartialEq, Eq
|
||||||
de PartialEq, Eq, PartialOrd, Ord
|
de PartialEq, Eq, PartialOrd, Ord
|
||||||
de Clone pub macro Clone
|
de Clone macro Clone
|
||||||
de PartialEq, PartialOrd
|
de PartialEq, PartialOrd
|
||||||
kw self::
|
kw self::
|
||||||
kw super::
|
kw super::
|
||||||
|
@ -712,11 +712,11 @@ mod derive {
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
md core
|
md core
|
||||||
de Default pub macro Default
|
de Default macro Default
|
||||||
de Clone, Copy
|
de Clone, Copy
|
||||||
de Eq
|
de Eq
|
||||||
de Eq, PartialOrd, Ord
|
de Eq, PartialOrd, Ord
|
||||||
de Clone pub macro Clone
|
de Clone macro Clone
|
||||||
de PartialOrd
|
de PartialOrd
|
||||||
kw self::
|
kw self::
|
||||||
kw super::
|
kw super::
|
||||||
|
@ -734,17 +734,17 @@ mod derive {
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
md core
|
md core
|
||||||
de Default pub macro Default
|
de Default macro Default
|
||||||
de Clone, Copy
|
de Clone, Copy
|
||||||
de Eq
|
de Eq
|
||||||
de Eq, PartialOrd, Ord
|
de Eq, PartialOrd, Ord
|
||||||
de Clone pub macro Clone
|
de Clone macro Clone
|
||||||
de PartialOrd
|
de PartialOrd
|
||||||
kw self::
|
kw self::
|
||||||
kw super::
|
kw super::
|
||||||
kw crate::
|
kw crate::
|
||||||
"#]],
|
"#]],
|
||||||
)
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -761,7 +761,7 @@ mod derive {
|
||||||
kw self::
|
kw self::
|
||||||
kw super::
|
kw super::
|
||||||
kw crate::
|
kw crate::
|
||||||
de DeriveIdentity (use proc_macros::DeriveIdentity) pub macro derive_identity
|
de DeriveIdentity (use proc_macros::DeriveIdentity) proc_macro DeriveIdentity
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
check_derive(
|
check_derive(
|
||||||
|
@ -772,7 +772,7 @@ use proc_macros::DeriveIdentity;
|
||||||
#[derive(der$0)] struct Test;
|
#[derive(der$0)] struct Test;
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
de DeriveIdentity pub macro derive_identity
|
de DeriveIdentity proc_macro DeriveIdentity
|
||||||
md proc_macros
|
md proc_macros
|
||||||
md core
|
md core
|
||||||
kw self::
|
kw self::
|
||||||
|
@ -808,7 +808,7 @@ use proc_macros::DeriveIdentity;
|
||||||
#[derive(proc_macros::$0)] struct Test;
|
#[derive(proc_macros::$0)] struct Test;
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
de DeriveIdentity pub macro derive_identity
|
de DeriveIdentity proc_macro DeriveIdentity
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
check_derive(
|
check_derive(
|
||||||
|
@ -818,7 +818,7 @@ use proc_macros::DeriveIdentity;
|
||||||
#[derive(proc_macros::C$0)] struct Test;
|
#[derive(proc_macros::C$0)] struct Test;
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
de DeriveIdentity pub macro derive_identity
|
de DeriveIdentity proc_macro DeriveIdentity
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,7 +30,7 @@ fn baz() {
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
// This should not contain `FooDesc {…}`.
|
// This should not contain `FooDesc {…}`.
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw unsafe
|
kw unsafe
|
||||||
kw match
|
kw match
|
||||||
kw while
|
kw while
|
||||||
|
@ -57,13 +57,13 @@ fn baz() {
|
||||||
fn baz() fn()
|
fn baz() fn()
|
||||||
st Unit
|
st Unit
|
||||||
md _69latrick
|
md _69latrick
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
fn function() fn()
|
fn function() fn()
|
||||||
sc STATIC
|
sc STATIC
|
||||||
un Union
|
un Union
|
||||||
ev TupleV(…) (u32)
|
ev TupleV(…) (u32)
|
||||||
ct CONST
|
ct CONST
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@ impl Unit {
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
// `self` is in here twice, once as the module, once as the local
|
// `self` is in here twice, once as the module, once as the local
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
me self.foo() fn(self)
|
me self.foo() fn(self)
|
||||||
kw unsafe
|
kw unsafe
|
||||||
kw fn
|
kw fn
|
||||||
|
@ -166,14 +166,14 @@ impl Unit {
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
md qualified
|
md qualified
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
?? Unresolved
|
?? Unresolved
|
||||||
fn function() fn()
|
fn function() fn()
|
||||||
sc STATIC
|
sc STATIC
|
||||||
un Union
|
un Union
|
||||||
ev TupleV(…) (u32)
|
ev TupleV(…) (u32)
|
||||||
ct CONST
|
ct CONST
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
check(
|
check(
|
||||||
r#"
|
r#"
|
||||||
|
@ -187,7 +187,7 @@ impl Unit {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
tt Trait
|
tt Trait
|
||||||
en Enum
|
en Enum
|
||||||
st Record
|
st Record
|
||||||
|
@ -195,14 +195,14 @@ impl Unit {
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
md qualified
|
md qualified
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
?? Unresolved
|
?? Unresolved
|
||||||
fn function() fn()
|
fn function() fn()
|
||||||
sc STATIC
|
sc STATIC
|
||||||
un Union
|
un Union
|
||||||
ev TupleV(…) (u32)
|
ev TupleV(…) (u32)
|
||||||
ct CONST
|
ct CONST
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1108,7 +1108,7 @@ fn flyimport_attribute() {
|
||||||
struct Foo;
|
struct Foo;
|
||||||
"#,
|
"#,
|
||||||
expect![[r#"
|
expect![[r#"
|
||||||
at identity (use proc_macros::identity) pub macro identity
|
at identity (use proc_macros::identity) proc_macro identity
|
||||||
"#]],
|
"#]],
|
||||||
);
|
);
|
||||||
check_edit(
|
check_edit(
|
||||||
|
|
|
@ -17,7 +17,7 @@ fn target_type_or_trait_in_impl_block() {
|
||||||
r#"
|
r#"
|
||||||
impl Tra$0
|
impl Tra$0
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -27,10 +27,10 @@ impl Tra$0
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ fn target_type_in_trait_impl_block() {
|
||||||
r#"
|
r#"
|
||||||
impl Trait for Str$0
|
impl Trait for Str$0
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -50,10 +50,10 @@ impl Trait for Str$0
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@ fn after_struct_name() {
|
||||||
// FIXME: This should emit `kw where` only
|
// FIXME: This should emit `kw where` only
|
||||||
check(
|
check(
|
||||||
r"struct Struct $0",
|
r"struct Struct $0",
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw pub(crate)
|
kw pub(crate)
|
||||||
kw pub(super)
|
kw pub(super)
|
||||||
kw pub
|
kw pub
|
||||||
|
@ -109,8 +109,8 @@ fn after_struct_name() {
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,7 +119,7 @@ fn after_fn_name() {
|
||||||
// FIXME: This should emit `kw where` only
|
// FIXME: This should emit `kw where` only
|
||||||
check(
|
check(
|
||||||
r"fn func() $0",
|
r"fn func() $0",
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw pub(crate)
|
kw pub(crate)
|
||||||
kw pub(super)
|
kw pub(super)
|
||||||
kw pub
|
kw pub
|
||||||
|
@ -143,8 +143,8 @@ fn after_fn_name() {
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@ fn check(ra_fixture: &str, expect: Expect) {
|
||||||
fn in_mod_item_list() {
|
fn in_mod_item_list() {
|
||||||
check(
|
check(
|
||||||
r#"mod tests { $0 }"#,
|
r#"mod tests { $0 }"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw pub(crate)
|
kw pub(crate)
|
||||||
kw pub(super)
|
kw pub(super)
|
||||||
kw pub
|
kw pub
|
||||||
|
@ -35,8 +35,8 @@ fn in_mod_item_list() {
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,7 +44,7 @@ fn in_mod_item_list() {
|
||||||
fn in_source_file_item_list() {
|
fn in_source_file_item_list() {
|
||||||
check(
|
check(
|
||||||
r#"$0"#,
|
r#"$0"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw pub(crate)
|
kw pub(crate)
|
||||||
kw pub(super)
|
kw pub(super)
|
||||||
kw pub
|
kw pub
|
||||||
|
@ -68,8 +68,8 @@ fn in_source_file_item_list() {
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,10 +106,10 @@ fn in_qualified_path() {
|
||||||
cov_mark::check!(no_keyword_completion_in_non_trivial_path);
|
cov_mark::check!(no_keyword_completion_in_non_trivial_path);
|
||||||
check(
|
check(
|
||||||
r#"crate::$0"#,
|
r#"crate::$0"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,7 +162,7 @@ fn after_visibility_unsafe() {
|
||||||
fn in_impl_assoc_item_list() {
|
fn in_impl_assoc_item_list() {
|
||||||
check(
|
check(
|
||||||
r#"impl Struct { $0 }"#,
|
r#"impl Struct { $0 }"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw pub(crate)
|
kw pub(crate)
|
||||||
kw pub(super)
|
kw pub(super)
|
||||||
kw pub
|
kw pub
|
||||||
|
@ -174,8 +174,8 @@ fn in_impl_assoc_item_list() {
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -199,7 +199,7 @@ fn in_impl_assoc_item_list_after_attr() {
|
||||||
fn in_trait_assoc_item_list() {
|
fn in_trait_assoc_item_list() {
|
||||||
check(
|
check(
|
||||||
r"trait Foo { $0 }",
|
r"trait Foo { $0 }",
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw unsafe
|
kw unsafe
|
||||||
kw fn
|
kw fn
|
||||||
kw const
|
kw const
|
||||||
|
@ -208,8 +208,8 @@ fn in_trait_assoc_item_list() {
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -233,7 +233,7 @@ impl Test for () {
|
||||||
$0
|
$0
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw pub(crate)
|
kw pub(crate)
|
||||||
kw pub(super)
|
kw pub(super)
|
||||||
kw pub
|
kw pub
|
||||||
|
@ -245,7 +245,7 @@ impl Test for () {
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,7 +102,7 @@ fn foo() {
|
||||||
if let a$0
|
if let a$0
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw ref
|
kw ref
|
||||||
kw mut
|
kw mut
|
||||||
en Enum
|
en Enum
|
||||||
|
@ -112,11 +112,11 @@ fn foo() {
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
bn TupleV TupleV($1)$0
|
bn TupleV TupleV($1)$0
|
||||||
ev TupleV
|
ev TupleV
|
||||||
ct CONST
|
ct CONST
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -132,7 +132,7 @@ fn foo() {
|
||||||
let a$0
|
let a$0
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw ref
|
kw ref
|
||||||
kw mut
|
kw mut
|
||||||
bn Record Record { field$1 }$0
|
bn Record Record { field$1 }$0
|
||||||
|
@ -142,8 +142,8 @@ fn foo() {
|
||||||
ev Variant
|
ev Variant
|
||||||
en SingleVariantEnum
|
en SingleVariantEnum
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,7 +154,7 @@ fn in_param() {
|
||||||
fn foo(a$0) {
|
fn foo(a$0) {
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw ref
|
kw ref
|
||||||
kw mut
|
kw mut
|
||||||
bn Record Record { field$1 }: Record$0
|
bn Record Record { field$1 }: Record$0
|
||||||
|
@ -162,15 +162,15 @@ fn foo(a$0) {
|
||||||
bn Tuple Tuple($1): Tuple$0
|
bn Tuple Tuple($1): Tuple$0
|
||||||
st Tuple
|
st Tuple
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
check(
|
check(
|
||||||
r#"
|
r#"
|
||||||
fn foo(a$0: Tuple) {
|
fn foo(a$0: Tuple) {
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw ref
|
kw ref
|
||||||
kw mut
|
kw mut
|
||||||
bn Record Record { field$1 }$0
|
bn Record Record { field$1 }$0
|
||||||
|
@ -178,8 +178,8 @@ fn foo(a$0: Tuple) {
|
||||||
bn Tuple Tuple($1)$0
|
bn Tuple Tuple($1)$0
|
||||||
st Tuple
|
st Tuple
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@ fn predicate_start() {
|
||||||
r#"
|
r#"
|
||||||
struct Foo<'lt, T, const C: usize> where $0 {}
|
struct Foo<'lt, T, const C: usize> where $0 {}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -26,10 +26,10 @@ struct Foo<'lt, T, const C: usize> where $0 {}
|
||||||
md module
|
md module
|
||||||
st Foo<…>
|
st Foo<…>
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,14 +39,14 @@ fn bound_for_type_pred() {
|
||||||
r#"
|
r#"
|
||||||
struct Foo<'lt, T, const C: usize> where T: $0 {}
|
struct Foo<'lt, T, const C: usize> where T: $0 {}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
tt Trait
|
tt Trait
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,14 +58,14 @@ fn bound_for_lifetime_pred() {
|
||||||
r#"
|
r#"
|
||||||
struct Foo<'lt, T, const C: usize> where 'lt: $0 {}
|
struct Foo<'lt, T, const C: usize> where 'lt: $0 {}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
tt Trait
|
tt Trait
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,14 +75,14 @@ fn bound_for_for_pred() {
|
||||||
r#"
|
r#"
|
||||||
struct Foo<'lt, T, const C: usize> where for<'a> T: $0 {}
|
struct Foo<'lt, T, const C: usize> where for<'a> T: $0 {}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
tt Trait
|
tt Trait
|
||||||
md module
|
md module
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -92,7 +92,7 @@ fn param_list_for_for_pred() {
|
||||||
r#"
|
r#"
|
||||||
struct Foo<'lt, T, const C: usize> where for<'a> $0 {}
|
struct Foo<'lt, T, const C: usize> where for<'a> $0 {}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -103,10 +103,10 @@ struct Foo<'lt, T, const C: usize> where for<'a> $0 {}
|
||||||
md module
|
md module
|
||||||
st Foo<…>
|
st Foo<…>
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ impl Record {
|
||||||
fn method(self) where $0 {}
|
fn method(self) where $0 {}
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -129,9 +129,9 @@ impl Record {
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ struct Foo<'lt, T, const C: usize> {
|
||||||
f: $0
|
f: $0
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -29,10 +29,10 @@ struct Foo<'lt, T, const C: usize> {
|
||||||
md module
|
md module
|
||||||
st Foo<…>
|
st Foo<…>
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ fn tuple_struct_field() {
|
||||||
r#"
|
r#"
|
||||||
struct Foo<'lt, T, const C: usize>(f$0);
|
struct Foo<'lt, T, const C: usize>(f$0);
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw pub(crate)
|
kw pub(crate)
|
||||||
kw pub(super)
|
kw pub(super)
|
||||||
kw pub
|
kw pub
|
||||||
|
@ -58,10 +58,10 @@ struct Foo<'lt, T, const C: usize>(f$0);
|
||||||
md module
|
md module
|
||||||
st Foo<…>
|
st Foo<…>
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,7 +71,7 @@ fn fn_return_type() {
|
||||||
r#"
|
r#"
|
||||||
fn x<'lt, T, const C: usize>() -> $0
|
fn x<'lt, T, const C: usize>() -> $0
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -82,10 +82,10 @@ fn x<'lt, T, const C: usize>() -> $0
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,7 +98,7 @@ fn foo<'lt, T, const C: usize>() {
|
||||||
let _: $0;
|
let _: $0;
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -109,10 +109,10 @@ fn foo<'lt, T, const C: usize>() {
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
check(
|
check(
|
||||||
r#"
|
r#"
|
||||||
|
@ -121,16 +121,16 @@ fn foo<'lt, T, const C: usize>() {
|
||||||
let _: self::$0;
|
let _: self::$0;
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
tt Trait
|
tt Trait
|
||||||
en Enum
|
en Enum
|
||||||
st Record
|
st Record
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
un Union
|
un Union
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -144,7 +144,7 @@ trait Trait2 {
|
||||||
|
|
||||||
fn foo<'lt, T: Trait2<$0>, const CONST_PARAM: usize>(_: T) {}
|
fn foo<'lt, T: Trait2<$0>, const CONST_PARAM: usize>(_: T) {}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
kw self
|
kw self
|
||||||
kw super
|
kw super
|
||||||
kw crate
|
kw crate
|
||||||
|
@ -157,12 +157,12 @@ fn foo<'lt, T: Trait2<$0>, const CONST_PARAM: usize>(_: T) {}
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
tt Trait2
|
tt Trait2
|
||||||
un Union
|
un Union
|
||||||
ct CONST
|
ct CONST
|
||||||
bt u32
|
bt u32
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
check(
|
check(
|
||||||
r#"
|
r#"
|
||||||
|
@ -172,18 +172,18 @@ trait Trait2 {
|
||||||
|
|
||||||
fn foo<'lt, T: Trait2<self::$0>, const CONST_PARAM: usize>(_: T) {}
|
fn foo<'lt, T: Trait2<self::$0>, const CONST_PARAM: usize>(_: T) {}
|
||||||
"#,
|
"#,
|
||||||
expect![[r##"
|
expect![[r#"
|
||||||
tt Trait
|
tt Trait
|
||||||
en Enum
|
en Enum
|
||||||
st Record
|
st Record
|
||||||
st Tuple
|
st Tuple
|
||||||
md module
|
md module
|
||||||
st Unit
|
st Unit
|
||||||
ma makro!(…) #[macro_export] macro_rules! makro
|
ma makro!(…) macro_rules! makro
|
||||||
tt Trait2
|
tt Trait2
|
||||||
un Union
|
un Union
|
||||||
ct CONST
|
ct CONST
|
||||||
"##]],
|
"#]],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
//! This module contains utilities for rendering syntax nodes into a string representing their signature.
|
//! This module contains utilities for rendering syntax nodes into a string representing their signature.
|
||||||
|
|
||||||
use crate::ast::{self, HasAttrs, HasGenericParams, HasName};
|
use crate::ast::{self, HasGenericParams, HasName};
|
||||||
|
|
||||||
use ast::HasVisibility;
|
use ast::HasVisibility;
|
||||||
use stdx::format_to;
|
use stdx::format_to;
|
||||||
|
@ -49,37 +49,3 @@ pub fn function_declaration(node: &ast::Fn) -> String {
|
||||||
}
|
}
|
||||||
buf
|
buf
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn macro_label(node: &ast::Macro) -> String {
|
|
||||||
let name = node.name();
|
|
||||||
let mut s = String::new();
|
|
||||||
match node {
|
|
||||||
ast::Macro::MacroRules(node) => {
|
|
||||||
let vis = if node.has_atom_attr("macro_export") { "#[macro_export] " } else { "" };
|
|
||||||
format_to!(s, "{}macro_rules!", vis);
|
|
||||||
}
|
|
||||||
ast::Macro::MacroDef(node) => {
|
|
||||||
if let Some(vis) = node.visibility() {
|
|
||||||
format_to!(s, "{} ", vis);
|
|
||||||
}
|
|
||||||
format_to!(s, "macro");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if let Some(name) = name {
|
|
||||||
format_to!(s, " {}", name);
|
|
||||||
}
|
|
||||||
s
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn fn_as_proc_macro_label(node: &ast::Fn) -> String {
|
|
||||||
let name = node.name();
|
|
||||||
let mut s = String::new();
|
|
||||||
if let Some(vis) = node.visibility() {
|
|
||||||
format_to!(s, "{} ", vis);
|
|
||||||
}
|
|
||||||
format_to!(s, "macro");
|
|
||||||
if let Some(name) = name {
|
|
||||||
format_to!(s, " {}", name);
|
|
||||||
}
|
|
||||||
s
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue