Refactor application of library semantic token modifier
This commit is contained in:
@@ -283,35 +283,11 @@ pub(super) fn element(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition) -> Highlight {
|
fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition) -> Highlight {
|
||||||
match def {
|
let mut h = match def {
|
||||||
Definition::Macro(m) => {
|
Definition::Macro(_) => Highlight::new(HlTag::Symbol(SymbolKind::Macro)),
|
||||||
let mut h = Highlight::new(HlTag::Symbol(SymbolKind::Macro));
|
Definition::Field(_) => Highlight::new(HlTag::Symbol(SymbolKind::Field)),
|
||||||
|
|
||||||
if m.module(db).map(hir::Module::krate) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
|
||||||
}
|
|
||||||
Definition::Field(field) => {
|
|
||||||
let mut h = Highlight::new(HlTag::Symbol(SymbolKind::Field));
|
|
||||||
|
|
||||||
if Some(field.parent_def(db).module(db).krate()) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
|
||||||
}
|
|
||||||
Definition::ModuleDef(def) => match def {
|
Definition::ModuleDef(def) => match def {
|
||||||
hir::ModuleDef::Module(module) => {
|
hir::ModuleDef::Module(_) => Highlight::new(HlTag::Symbol(SymbolKind::Module)),
|
||||||
let mut h = Highlight::new(HlTag::Symbol(SymbolKind::Module));
|
|
||||||
|
|
||||||
if Some(module.krate()) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
|
||||||
}
|
|
||||||
hir::ModuleDef::Function(func) => {
|
hir::ModuleDef::Function(func) => {
|
||||||
let mut h = Highlight::new(HlTag::Symbol(SymbolKind::Function));
|
let mut h = Highlight::new(HlTag::Symbol(SymbolKind::Function));
|
||||||
if let Some(item) = func.as_assoc_item(db) {
|
if let Some(item) = func.as_assoc_item(db) {
|
||||||
@@ -343,9 +319,6 @@ fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition)
|
|||||||
if func.is_async(db) {
|
if func.is_async(db) {
|
||||||
h |= HlMod::Async;
|
h |= HlMod::Async;
|
||||||
}
|
}
|
||||||
if Some(func.module(db).krate()) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
h
|
||||||
}
|
}
|
||||||
@@ -355,23 +328,10 @@ fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition)
|
|||||||
hir::Adt::Enum(_) => HlTag::Symbol(SymbolKind::Enum),
|
hir::Adt::Enum(_) => HlTag::Symbol(SymbolKind::Enum),
|
||||||
hir::Adt::Union(_) => HlTag::Symbol(SymbolKind::Union),
|
hir::Adt::Union(_) => HlTag::Symbol(SymbolKind::Union),
|
||||||
};
|
};
|
||||||
let mut h = Highlight::new(h);
|
|
||||||
|
|
||||||
if Some(adt.module(db).krate()) != krate {
|
Highlight::new(h)
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
|
||||||
}
|
|
||||||
hir::ModuleDef::Variant(variant) => {
|
|
||||||
let mut h = Highlight::new(HlTag::Symbol(SymbolKind::Variant));
|
|
||||||
|
|
||||||
if Some(variant.module(db).krate()) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
|
||||||
}
|
}
|
||||||
|
hir::ModuleDef::Variant(_) => Highlight::new(HlTag::Symbol(SymbolKind::Variant)),
|
||||||
hir::ModuleDef::Const(konst) => {
|
hir::ModuleDef::Const(konst) => {
|
||||||
let mut h = Highlight::new(HlTag::Symbol(SymbolKind::Const));
|
let mut h = Highlight::new(HlTag::Symbol(SymbolKind::Const));
|
||||||
|
|
||||||
@@ -389,10 +349,6 @@ fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if Some(konst.module(db).krate()) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
h
|
||||||
}
|
}
|
||||||
hir::ModuleDef::Trait(trait_) => {
|
hir::ModuleDef::Trait(trait_) => {
|
||||||
@@ -402,10 +358,6 @@ fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition)
|
|||||||
h |= HlMod::Unsafe;
|
h |= HlMod::Unsafe;
|
||||||
}
|
}
|
||||||
|
|
||||||
if Some(trait_.module(db).krate()) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
h
|
||||||
}
|
}
|
||||||
hir::ModuleDef::TypeAlias(type_) => {
|
hir::ModuleDef::TypeAlias(type_) => {
|
||||||
@@ -425,10 +377,6 @@ fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if Some(type_.module(db).krate()) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
h
|
||||||
}
|
}
|
||||||
hir::ModuleDef::BuiltinType(_) => Highlight::new(HlTag::BuiltinType),
|
hir::ModuleDef::BuiltinType(_) => Highlight::new(HlTag::BuiltinType),
|
||||||
@@ -440,10 +388,6 @@ fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition)
|
|||||||
h |= HlMod::Unsafe;
|
h |= HlMod::Unsafe;
|
||||||
}
|
}
|
||||||
|
|
||||||
if Some(s.module(db).krate()) != krate {
|
|
||||||
h |= HlMod::Library;
|
|
||||||
}
|
|
||||||
|
|
||||||
h
|
h
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -476,7 +420,16 @@ fn highlight_def(db: &RootDatabase, krate: Option<hir::Crate>, def: Definition)
|
|||||||
h
|
h
|
||||||
}
|
}
|
||||||
Definition::Label(_) => Highlight::new(HlTag::Symbol(SymbolKind::Label)),
|
Definition::Label(_) => Highlight::new(HlTag::Symbol(SymbolKind::Label)),
|
||||||
|
};
|
||||||
|
|
||||||
|
let is_from_other_crate = def.module(db).map(hir::Module::krate) != krate;
|
||||||
|
let is_builtin_type = matches!(def, Definition::ModuleDef(hir::ModuleDef::BuiltinType(_)));
|
||||||
|
|
||||||
|
if is_from_other_crate && !is_builtin_type {
|
||||||
|
h |= HlMod::Library;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
h
|
||||||
}
|
}
|
||||||
|
|
||||||
fn highlight_func_by_name_ref(
|
fn highlight_func_by_name_ref(
|
||||||
|
|||||||
Reference in New Issue
Block a user