mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-10-30 03:27:44 +00:00
Merge Trait and TraitAlias handling
This commit is contained in:
parent
a9450ebba3
commit
82f174fbd9
74 changed files with 68 additions and 577 deletions
|
|
@ -33,7 +33,7 @@ use tt::TextRange;
|
|||
|
||||
use crate::{
|
||||
AdtId, BlockId, BlockLoc, DefWithBodyId, FunctionId, GenericDefId, ImplId, MacroId,
|
||||
ModuleDefId, ModuleId, TraitAliasId, TraitId, TypeAliasId, UnresolvedMacro,
|
||||
ModuleDefId, ModuleId, TraitId, TypeAliasId, UnresolvedMacro,
|
||||
builtin_type::BuiltinUint,
|
||||
db::DefDatabase,
|
||||
expr_store::{
|
||||
|
|
@ -252,28 +252,6 @@ pub(crate) fn lower_trait(
|
|||
(store, source_map, params)
|
||||
}
|
||||
|
||||
pub(crate) fn lower_trait_alias(
|
||||
db: &dyn DefDatabase,
|
||||
module: ModuleId,
|
||||
trait_syntax: InFile<ast::TraitAlias>,
|
||||
trait_id: TraitAliasId,
|
||||
) -> (ExpressionStore, ExpressionStoreSourceMap, Arc<GenericParams>) {
|
||||
let mut expr_collector = ExprCollector::new(db, module, trait_syntax.file_id);
|
||||
let mut collector = generics::GenericParamsCollector::with_self_param(
|
||||
&mut expr_collector,
|
||||
trait_id.into(),
|
||||
trait_syntax.value.type_bound_list(),
|
||||
);
|
||||
collector.lower(
|
||||
&mut expr_collector,
|
||||
trait_syntax.value.generic_param_list(),
|
||||
trait_syntax.value.where_clause(),
|
||||
);
|
||||
let params = collector.finish();
|
||||
let (store, source_map) = expr_collector.store.finish();
|
||||
(store, source_map, params)
|
||||
}
|
||||
|
||||
pub(crate) fn lower_type_alias(
|
||||
db: &dyn DefDatabase,
|
||||
module: ModuleId,
|
||||
|
|
|
|||
|
|
@ -183,7 +183,6 @@ pub fn print_signature(db: &dyn DefDatabase, owner: GenericDefId, edition: Editi
|
|||
}
|
||||
GenericDefId::ImplId(id) => format!("unimplemented {id:?}"),
|
||||
GenericDefId::StaticId(id) => format!("unimplemented {id:?}"),
|
||||
GenericDefId::TraitAliasId(id) => format!("unimplemented {id:?}"),
|
||||
GenericDefId::TraitId(id) => format!("unimplemented {id:?}"),
|
||||
GenericDefId::TypeAliasId(id) => format!("unimplemented {id:?}"),
|
||||
}
|
||||
|
|
|
|||
|
|
@ -24,7 +24,6 @@ fn lower_and_print(#[rust_analyzer::rust_fixture] ra_fixture: &str, expect: Expe
|
|||
ModuleDefId::ConstId(id) => id.into(),
|
||||
ModuleDefId::StaticId(id) => id.into(),
|
||||
ModuleDefId::TraitId(id) => id.into(),
|
||||
ModuleDefId::TraitAliasId(id) => id.into(),
|
||||
ModuleDefId::TypeAliasId(id) => id.into(),
|
||||
ModuleDefId::EnumVariantId(_) => continue,
|
||||
ModuleDefId::BuiltinType(_) => continue,
|
||||
|
|
@ -51,7 +50,6 @@ fn lower_and_print(#[rust_analyzer::rust_fixture] ra_fixture: &str, expect: Expe
|
|||
|
||||
GenericDefId::ImplId(_id) => (),
|
||||
GenericDefId::StaticId(_id) => (),
|
||||
GenericDefId::TraitAliasId(_id) => (),
|
||||
GenericDefId::TraitId(_id) => (),
|
||||
GenericDefId::TypeAliasId(_id) => (),
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue