mirror of
				https://github.com/rust-lang/rust-analyzer.git
				synced 2025-10-29 19:17:12 +00:00 
			
		
		
		
	De-arc trait items query
This commit is contained in:
		
							parent
							
								
									70cbf8332a
								
							
						
					
					
						commit
						f25912c6f9
					
				
					 33 changed files with 110 additions and 107 deletions
				
			
		|  | @ -25,7 +25,7 @@ use crate::{ | ||||||
|     import_map::ImportMap, |     import_map::ImportMap, | ||||||
|     item_tree::{ItemTree, file_item_tree_query}, |     item_tree::{ItemTree, file_item_tree_query}, | ||||||
|     lang_item::{self, LangItem}, |     lang_item::{self, LangItem}, | ||||||
|     nameres::{assoc::TraitItems, crate_def_map, diagnostics::DefDiagnostics}, |     nameres::crate_def_map, | ||||||
|     signatures::{ |     signatures::{ | ||||||
|         ConstSignature, EnumSignature, FunctionSignature, ImplSignature, StaticSignature, |         ConstSignature, EnumSignature, FunctionSignature, ImplSignature, StaticSignature, | ||||||
|         StructSignature, TraitAliasSignature, TraitSignature, TypeAliasSignature, UnionSignature, |         StructSignature, TraitAliasSignature, TraitSignature, TypeAliasSignature, UnionSignature, | ||||||
|  | @ -119,13 +119,6 @@ pub trait DefDatabase: InternDatabase + ExpandDatabase + SourceDatabase { | ||||||
|         id: VariantId, |         id: VariantId, | ||||||
|     ) -> (Arc<VariantFields>, Arc<ExpressionStoreSourceMap>); |     ) -> (Arc<VariantFields>, Arc<ExpressionStoreSourceMap>); | ||||||
| 
 | 
 | ||||||
|     #[salsa::transparent] |  | ||||||
|     #[salsa::invoke(TraitItems::trait_items_query)] |  | ||||||
|     fn trait_items(&self, e: TraitId) -> Arc<TraitItems>; |  | ||||||
| 
 |  | ||||||
|     #[salsa::invoke(TraitItems::trait_items_with_diagnostics_query)] |  | ||||||
|     fn trait_items_with_diagnostics(&self, tr: TraitId) -> (Arc<TraitItems>, DefDiagnostics); |  | ||||||
| 
 |  | ||||||
|     #[salsa::tracked] |     #[salsa::tracked] | ||||||
|     fn variant_fields(&self, id: VariantId) -> Arc<VariantFields> { |     fn variant_fields(&self, id: VariantId) -> Arc<VariantFields> { | ||||||
|         self.variant_fields_with_source_map(id).0 |         self.variant_fields_with_source_map(id).0 | ||||||
|  |  | ||||||
|  | @ -16,7 +16,7 @@ use crate::{ | ||||||
|     AssocItemId, AttrDefId, Complete, FxIndexMap, ModuleDefId, ModuleId, TraitId, |     AssocItemId, AttrDefId, Complete, FxIndexMap, ModuleDefId, ModuleId, TraitId, | ||||||
|     db::DefDatabase, |     db::DefDatabase, | ||||||
|     item_scope::{ImportOrExternCrate, ItemInNs}, |     item_scope::{ImportOrExternCrate, ItemInNs}, | ||||||
|     nameres::{DefMap, crate_def_map}, |     nameres::{DefMap, assoc::TraitItems, crate_def_map}, | ||||||
|     visibility::Visibility, |     visibility::Visibility, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | @ -221,7 +221,7 @@ impl ImportMap { | ||||||
|         trait_import_info: &ImportInfo, |         trait_import_info: &ImportInfo, | ||||||
|     ) { |     ) { | ||||||
|         let _p = tracing::info_span!("collect_trait_assoc_items").entered(); |         let _p = tracing::info_span!("collect_trait_assoc_items").entered(); | ||||||
|         for &(ref assoc_item_name, item) in &db.trait_items(tr).items { |         for &(ref assoc_item_name, item) in &TraitItems::query(db, tr).items { | ||||||
|             let module_def_id = match item { |             let module_def_id = match item { | ||||||
|                 AssocItemId::FunctionId(f) => ModuleDefId::from(f), |                 AssocItemId::FunctionId(f) => ModuleDefId::from(f), | ||||||
|                 AssocItemId::ConstId(c) => ModuleDefId::from(c), |                 AssocItemId::ConstId(c) => ModuleDefId::from(c), | ||||||
|  | @ -482,7 +482,7 @@ mod tests { | ||||||
|     use expect_test::{Expect, expect}; |     use expect_test::{Expect, expect}; | ||||||
|     use test_fixture::WithFixture; |     use test_fixture::WithFixture; | ||||||
| 
 | 
 | ||||||
|     use crate::{ItemContainerId, Lookup, test_db::TestDB}; |     use crate::{ItemContainerId, Lookup, nameres::assoc::TraitItems, test_db::TestDB}; | ||||||
| 
 | 
 | ||||||
|     use super::*; |     use super::*; | ||||||
| 
 | 
 | ||||||
|  | @ -580,7 +580,7 @@ mod tests { | ||||||
| 
 | 
 | ||||||
|         let trait_info = dependency_imports.import_info_for(ItemInNs::Types(trait_id.into()))?; |         let trait_info = dependency_imports.import_info_for(ItemInNs::Types(trait_id.into()))?; | ||||||
| 
 | 
 | ||||||
|         let trait_items = db.trait_items(trait_id); |         let trait_items = TraitItems::query(db, trait_id); | ||||||
|         let (assoc_item_name, _) = trait_items |         let (assoc_item_name, _) = trait_items | ||||||
|             .items |             .items | ||||||
|             .iter() |             .iter() | ||||||
|  |  | ||||||
|  | @ -9,8 +9,10 @@ use triomphe::Arc; | ||||||
| 
 | 
 | ||||||
| use crate::{ | use crate::{ | ||||||
|     AdtId, AssocItemId, AttrDefId, Crate, EnumId, EnumVariantId, FunctionId, ImplId, ModuleDefId, |     AdtId, AssocItemId, AttrDefId, Crate, EnumId, EnumVariantId, FunctionId, ImplId, ModuleDefId, | ||||||
|     StaticId, StructId, TraitId, TypeAliasId, UnionId, db::DefDatabase, expr_store::path::Path, |     StaticId, StructId, TraitId, TypeAliasId, UnionId, | ||||||
|     nameres::crate_def_map, |     db::DefDatabase, | ||||||
|  |     expr_store::path::Path, | ||||||
|  |     nameres::{assoc::TraitItems, crate_def_map}, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] | #[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)] | ||||||
|  | @ -113,7 +115,8 @@ pub fn crate_lang_items(db: &dyn DefDatabase, krate: Crate) -> Option<Box<LangIt | ||||||
|             match def { |             match def { | ||||||
|                 ModuleDefId::TraitId(trait_) => { |                 ModuleDefId::TraitId(trait_) => { | ||||||
|                     lang_items.collect_lang_item(db, trait_, LangItemTarget::Trait); |                     lang_items.collect_lang_item(db, trait_, LangItemTarget::Trait); | ||||||
|                     db.trait_items(trait_).items.iter().for_each(|&(_, assoc_id)| match assoc_id { |                     TraitItems::query(db, trait_).items.iter().for_each(|&(_, assoc_id)| { | ||||||
|  |                         match assoc_id { | ||||||
|                             AssocItemId::FunctionId(f) => { |                             AssocItemId::FunctionId(f) => { | ||||||
|                                 lang_items.collect_lang_item(db, f, LangItemTarget::Function); |                                 lang_items.collect_lang_item(db, f, LangItemTarget::Function); | ||||||
|                             } |                             } | ||||||
|  | @ -121,6 +124,7 @@ pub fn crate_lang_items(db: &dyn DefDatabase, krate: Crate) -> Option<Box<LangIt | ||||||
|                                 lang_items.collect_lang_item(db, alias, LangItemTarget::TypeAlias) |                                 lang_items.collect_lang_item(db, alias, LangItemTarget::TypeAlias) | ||||||
|                             } |                             } | ||||||
|                             AssocItemId::ConstId(_) => {} |                             AssocItemId::ConstId(_) => {} | ||||||
|  |                         } | ||||||
|                     }); |                     }); | ||||||
|                 } |                 } | ||||||
|                 ModuleDefId::AdtId(AdtId::EnumId(e)) => { |                 ModuleDefId::AdtId(AdtId::EnumId(e)) => { | ||||||
|  |  | ||||||
|  | @ -89,7 +89,9 @@ use crate::{ | ||||||
|     db::DefDatabase, |     db::DefDatabase, | ||||||
|     hir::generics::{LocalLifetimeParamId, LocalTypeOrConstParamId}, |     hir::generics::{LocalLifetimeParamId, LocalTypeOrConstParamId}, | ||||||
|     nameres::{ |     nameres::{ | ||||||
|         LocalDefMap, assoc::ImplItems, block_def_map, crate_def_map, crate_local_def_map, |         LocalDefMap, | ||||||
|  |         assoc::{ImplItems, TraitItems}, | ||||||
|  |         block_def_map, crate_def_map, crate_local_def_map, | ||||||
|         diagnostics::DefDiagnostics, |         diagnostics::DefDiagnostics, | ||||||
|     }, |     }, | ||||||
|     signatures::{EnumVariants, InactiveEnumVariantCode, VariantFields}, |     signatures::{EnumVariants, InactiveEnumVariantCode, VariantFields}, | ||||||
|  | @ -282,6 +284,13 @@ impl_intern!(StaticId, StaticLoc, intern_static, lookup_intern_static); | ||||||
| pub type TraitLoc = ItemLoc<ast::Trait>; | pub type TraitLoc = ItemLoc<ast::Trait>; | ||||||
| impl_intern!(TraitId, TraitLoc, intern_trait, lookup_intern_trait); | impl_intern!(TraitId, TraitLoc, intern_trait, lookup_intern_trait); | ||||||
| 
 | 
 | ||||||
|  | impl TraitId { | ||||||
|  |     #[inline] | ||||||
|  |     pub fn trait_items(self, db: &dyn DefDatabase) -> &TraitItems { | ||||||
|  |         TraitItems::query(db, self) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| pub type TraitAliasLoc = ItemLoc<ast::TraitAlias>; | pub type TraitAliasLoc = ItemLoc<ast::TraitAlias>; | ||||||
| impl_intern!(TraitAliasId, TraitAliasLoc, intern_trait_alias, lookup_intern_trait_alias); | impl_intern!(TraitAliasId, TraitAliasLoc, intern_trait_alias, lookup_intern_trait_alias); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -38,16 +38,18 @@ pub struct TraitItems { | ||||||
|     pub macro_calls: ThinVec<(AstId<ast::Item>, MacroCallId)>, |     pub macro_calls: ThinVec<(AstId<ast::Item>, MacroCallId)>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #[salsa::tracked] | ||||||
| impl TraitItems { | impl TraitItems { | ||||||
|     #[inline] |     #[inline] | ||||||
|     pub(crate) fn trait_items_query(db: &dyn DefDatabase, tr: TraitId) -> Arc<TraitItems> { |     pub(crate) fn query(db: &dyn DefDatabase, tr: TraitId) -> &TraitItems { | ||||||
|         db.trait_items_with_diagnostics(tr).0 |         &Self::query_with_diagnostics(db, tr).0 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     pub(crate) fn trait_items_with_diagnostics_query( |     #[salsa::tracked(returns(ref))] | ||||||
|  |     pub fn query_with_diagnostics( | ||||||
|         db: &dyn DefDatabase, |         db: &dyn DefDatabase, | ||||||
|         tr: TraitId, |         tr: TraitId, | ||||||
|     ) -> (Arc<TraitItems>, DefDiagnostics) { |     ) -> (TraitItems, DefDiagnostics) { | ||||||
|         let ItemLoc { container: module_id, id: ast_id } = tr.lookup(db); |         let ItemLoc { container: module_id, id: ast_id } = tr.lookup(db); | ||||||
| 
 | 
 | ||||||
|         let collector = |         let collector = | ||||||
|  | @ -55,7 +57,7 @@ impl TraitItems { | ||||||
|         let source = ast_id.with_value(collector.ast_id_map.get(ast_id.value)).to_node(db); |         let source = ast_id.with_value(collector.ast_id_map.get(ast_id.value)).to_node(db); | ||||||
|         let (items, macro_calls, diagnostics) = collector.collect(source.assoc_item_list()); |         let (items, macro_calls, diagnostics) = collector.collect(source.assoc_item_list()); | ||||||
| 
 | 
 | ||||||
|         (Arc::new(TraitItems { macro_calls, items }), DefDiagnostics::new(diagnostics)) |         (TraitItems { macro_calls, items }, DefDiagnostics::new(diagnostics)) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     pub fn associated_types(&self) -> impl Iterator<Item = TypeAliasId> + '_ { |     pub fn associated_types(&self) -> impl Iterator<Item = TypeAliasId> + '_ { | ||||||
|  |  | ||||||
|  | @ -41,6 +41,7 @@ use crate::{ | ||||||
|     macro_call_as_call_id, |     macro_call_as_call_id, | ||||||
|     nameres::{ |     nameres::{ | ||||||
|         BuiltinShadowMode, DefMap, LocalDefMap, MacroSubNs, ModuleData, ModuleOrigin, ResolveMode, |         BuiltinShadowMode, DefMap, LocalDefMap, MacroSubNs, ModuleData, ModuleOrigin, ResolveMode, | ||||||
|  |         assoc::TraitItems, | ||||||
|         attr_resolution::{attr_macro_as_call_id, derive_macro_as_call_id}, |         attr_resolution::{attr_macro_as_call_id, derive_macro_as_call_id}, | ||||||
|         crate_def_map, |         crate_def_map, | ||||||
|         diagnostics::DefDiagnostic, |         diagnostics::DefDiagnostic, | ||||||
|  | @ -1020,8 +1021,7 @@ impl<'db> DefCollector<'db> { | ||||||
|                         let resolutions = if true { |                         let resolutions = if true { | ||||||
|                             vec![] |                             vec![] | ||||||
|                         } else { |                         } else { | ||||||
|                             self.db |                             TraitItems::query(self.db, it) | ||||||
|                                 .trait_items(it) |  | ||||||
|                                 .items |                                 .items | ||||||
|                                 .iter() |                                 .iter() | ||||||
|                                 .map(|&(ref name, variant)| { |                                 .map(|&(ref name, variant)| { | ||||||
|  |  | ||||||
|  | @ -24,8 +24,8 @@ use crate::{ | ||||||
|     item_scope::{BUILTIN_SCOPE, ImportOrExternCrate}, |     item_scope::{BUILTIN_SCOPE, ImportOrExternCrate}, | ||||||
|     item_tree::FieldsShape, |     item_tree::FieldsShape, | ||||||
|     nameres::{ |     nameres::{ | ||||||
|         BlockInfo, BuiltinShadowMode, DefMap, LocalDefMap, MacroSubNs, crate_def_map, |         BlockInfo, BuiltinShadowMode, DefMap, LocalDefMap, MacroSubNs, assoc::TraitItems, | ||||||
|         sub_namespace_match, |         crate_def_map, sub_namespace_match, | ||||||
|     }, |     }, | ||||||
|     per_ns::PerNs, |     per_ns::PerNs, | ||||||
|     visibility::{RawVisibility, Visibility}, |     visibility::{RawVisibility, Visibility}, | ||||||
|  | @ -584,8 +584,11 @@ impl DefMap { | ||||||
|                     // now resulting in a cycle.
 |                     // now resulting in a cycle.
 | ||||||
|                     // To properly implement this, trait item collection needs to be done in def map
 |                     // To properly implement this, trait item collection needs to be done in def map
 | ||||||
|                     // collection...
 |                     // collection...
 | ||||||
|                     let item = |                     let item = if true { | ||||||
|                         if true { None } else { db.trait_items(t).assoc_item_by_name(segment) }; |                         None | ||||||
|  |                     } else { | ||||||
|  |                         TraitItems::query(db, t).assoc_item_by_name(segment) | ||||||
|  |                     }; | ||||||
|                     return match item { |                     return match item { | ||||||
|                         Some(item) => ResolvePathResult::new( |                         Some(item) => ResolvePathResult::new( | ||||||
|                             match item { |                             match item { | ||||||
|  |  | ||||||
|  | @ -208,7 +208,7 @@ pub(crate) fn deref_by_trait( | ||||||
|     }; |     }; | ||||||
|     let trait_id = trait_id()?; |     let trait_id = trait_id()?; | ||||||
|     let target = |     let target = | ||||||
|         db.trait_items(trait_id).associated_type_by_name(&Name::new_symbol_root(sym::Target))?; |         trait_id.trait_items(db).associated_type_by_name(&Name::new_symbol_root(sym::Target))?; | ||||||
| 
 | 
 | ||||||
|     let projection = { |     let projection = { | ||||||
|         let b = TyBuilder::subst_for_def(db, trait_id, None); |         let b = TyBuilder::subst_for_def(db, trait_id, None); | ||||||
|  |  | ||||||
|  | @ -315,9 +315,8 @@ impl chalk_solve::RustIrDatabase<Interner> for ChalkContext<'_> { | ||||||
|             crate::ImplTraitId::AsyncBlockTypeImplTrait(..) => { |             crate::ImplTraitId::AsyncBlockTypeImplTrait(..) => { | ||||||
|                 if let Some((future_trait, future_output)) = |                 if let Some((future_trait, future_output)) = | ||||||
|                     LangItem::Future.resolve_trait(self.db, self.krate).and_then(|trait_| { |                     LangItem::Future.resolve_trait(self.db, self.krate).and_then(|trait_| { | ||||||
|                         let alias = self |                         let alias = trait_ | ||||||
|                             .db |                             .trait_items(self.db) | ||||||
|                             .trait_items(trait_) |  | ||||||
|                             .associated_type_by_name(&Name::new_symbol_root(sym::Output))?; |                             .associated_type_by_name(&Name::new_symbol_root(sym::Output))?; | ||||||
|                         Some((trait_, alias)) |                         Some((trait_, alias)) | ||||||
|                     }) |                     }) | ||||||
|  | @ -711,7 +710,7 @@ pub(crate) fn trait_datum_query( | ||||||
|     }; |     }; | ||||||
|     let where_clauses = convert_where_clauses(db, trait_.into(), &bound_vars); |     let where_clauses = convert_where_clauses(db, trait_.into(), &bound_vars); | ||||||
|     let associated_ty_ids = |     let associated_ty_ids = | ||||||
|         db.trait_items(trait_).associated_types().map(to_assoc_type_id).collect(); |         trait_.trait_items(db).associated_types().map(to_assoc_type_id).collect(); | ||||||
|     let trait_datum_bound = rust_ir::TraitDatumBound { where_clauses }; |     let trait_datum_bound = rust_ir::TraitDatumBound { where_clauses }; | ||||||
|     let well_known = db.lang_attr(trait_.into()).and_then(well_known_trait_from_lang_item); |     let well_known = db.lang_attr(trait_.into()).and_then(well_known_trait_from_lang_item); | ||||||
|     let trait_datum = TraitDatum { |     let trait_datum = TraitDatum { | ||||||
|  | @ -879,7 +878,7 @@ fn impl_def_datum(db: &dyn HirDatabase, krate: Crate, impl_id: hir_def::ImplId) | ||||||
|     let polarity = if negative { rust_ir::Polarity::Negative } else { rust_ir::Polarity::Positive }; |     let polarity = if negative { rust_ir::Polarity::Negative } else { rust_ir::Polarity::Positive }; | ||||||
| 
 | 
 | ||||||
|     let impl_datum_bound = rust_ir::ImplDatumBound { trait_ref, where_clauses }; |     let impl_datum_bound = rust_ir::ImplDatumBound { trait_ref, where_clauses }; | ||||||
|     let trait_data = db.trait_items(trait_); |     let trait_data = trait_.trait_items(db); | ||||||
|     let associated_ty_value_ids = impl_id |     let associated_ty_value_ids = impl_id | ||||||
|         .impl_items(db) |         .impl_items(db) | ||||||
|         .items |         .items | ||||||
|  | @ -931,8 +930,9 @@ fn type_alias_associated_ty_value( | ||||||
|         .into_value_and_skipped_binders() |         .into_value_and_skipped_binders() | ||||||
|         .0; // we don't return any assoc ty values if the impl'd trait can't be resolved
 |         .0; // we don't return any assoc ty values if the impl'd trait can't be resolved
 | ||||||
| 
 | 
 | ||||||
|     let assoc_ty = db |     let assoc_ty = trait_ref | ||||||
|         .trait_items(trait_ref.hir_trait_id()) |         .hir_trait_id() | ||||||
|  |         .trait_items(db) | ||||||
|         .associated_type_by_name(&type_alias_data.name) |         .associated_type_by_name(&type_alias_data.name) | ||||||
|         .expect("assoc ty value should not exist"); // validated when building the impl data as well
 |         .expect("assoc ty value should not exist"); // validated when building the impl data as well
 | ||||||
|     let (ty, binders) = db.ty(type_alias.into()).into_value_and_skipped_binders(); |     let (ty, binders) = db.ty(type_alias.into()).into_value_and_skipped_binders(); | ||||||
|  |  | ||||||
|  | @ -494,7 +494,7 @@ impl FilterMapNextChecker { | ||||||
|                 Some(next_function_id), |                 Some(next_function_id), | ||||||
|                 match next_function_id.lookup(db).container { |                 match next_function_id.lookup(db).container { | ||||||
|                     ItemContainerId::TraitId(iterator_trait_id) => { |                     ItemContainerId::TraitId(iterator_trait_id) => { | ||||||
|                         let iterator_trait_items = &db.trait_items(iterator_trait_id).items; |                         let iterator_trait_items = &iterator_trait_id.trait_items(db).items; | ||||||
|                         iterator_trait_items.iter().find_map(|(name, it)| match it { |                         iterator_trait_items.iter().find_map(|(name, it)| match it { | ||||||
|                             &AssocItemId::FunctionId(id) if *name == sym::filter_map => Some(id), |                             &AssocItemId::FunctionId(id) if *name == sym::filter_map => Some(id), | ||||||
|                             _ => None, |                             _ => None, | ||||||
|  |  | ||||||
|  | @ -1394,7 +1394,7 @@ impl HirDisplay for Ty { | ||||||
|                         let future_trait = |                         let future_trait = | ||||||
|                             LangItem::Future.resolve_trait(db, body.module(db).krate()); |                             LangItem::Future.resolve_trait(db, body.module(db).krate()); | ||||||
|                         let output = future_trait.and_then(|t| { |                         let output = future_trait.and_then(|t| { | ||||||
|                             db.trait_items(t) |                             t.trait_items(db) | ||||||
|                                 .associated_type_by_name(&Name::new_symbol_root(sym::Output)) |                                 .associated_type_by_name(&Name::new_symbol_root(sym::Output)) | ||||||
|                         }); |                         }); | ||||||
|                         write!(f, "impl ")?; |                         write!(f, "impl ")?; | ||||||
|  |  | ||||||
|  | @ -101,7 +101,7 @@ where | ||||||
| 
 | 
 | ||||||
|     // rustc checks for non-lifetime binders here, but we don't support HRTB yet
 |     // rustc checks for non-lifetime binders here, but we don't support HRTB yet
 | ||||||
| 
 | 
 | ||||||
|     let trait_data = db.trait_items(trait_); |     let trait_data = trait_.trait_items(db); | ||||||
|     for (_, assoc_item) in &trait_data.items { |     for (_, assoc_item) in &trait_data.items { | ||||||
|         dyn_compatibility_violation_for_assoc_item(db, trait_, *assoc_item, cb)?; |         dyn_compatibility_violation_for_assoc_item(db, trait_, *assoc_item, cb)?; | ||||||
|     } |     } | ||||||
|  | @ -164,7 +164,7 @@ fn predicates_reference_self(db: &dyn HirDatabase, trait_: TraitId) -> bool { | ||||||
| 
 | 
 | ||||||
| // Same as the above, `predicates_reference_self`
 | // Same as the above, `predicates_reference_self`
 | ||||||
| fn bounds_reference_self(db: &dyn HirDatabase, trait_: TraitId) -> bool { | fn bounds_reference_self(db: &dyn HirDatabase, trait_: TraitId) -> bool { | ||||||
|     let trait_data = db.trait_items(trait_); |     let trait_data = trait_.trait_items(db); | ||||||
|     trait_data |     trait_data | ||||||
|         .items |         .items | ||||||
|         .iter() |         .iter() | ||||||
|  |  | ||||||
|  | @ -1813,7 +1813,7 @@ impl<'db> InferenceContext<'db> { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn resolve_output_on(&self, trait_: TraitId) -> Option<TypeAliasId> { |     fn resolve_output_on(&self, trait_: TraitId) -> Option<TypeAliasId> { | ||||||
|         self.db.trait_items(trait_).associated_type_by_name(&Name::new_symbol_root(sym::Output)) |         trait_.trait_items(self.db).associated_type_by_name(&Name::new_symbol_root(sym::Output)) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn resolve_lang_trait(&self, lang: LangItem) -> Option<TraitId> { |     fn resolve_lang_trait(&self, lang: LangItem) -> Option<TraitId> { | ||||||
|  |  | ||||||
|  | @ -1210,9 +1210,8 @@ impl InferenceContext<'_> { | ||||||
|                         if let Some(deref_trait) = |                         if let Some(deref_trait) = | ||||||
|                             self.resolve_lang_item(LangItem::DerefMut).and_then(|it| it.as_trait()) |                             self.resolve_lang_item(LangItem::DerefMut).and_then(|it| it.as_trait()) | ||||||
|                         { |                         { | ||||||
|                             if let Some(deref_fn) = self |                             if let Some(deref_fn) = deref_trait | ||||||
|                                 .db |                                 .trait_items(self.db) | ||||||
|                                 .trait_items(deref_trait) |  | ||||||
|                                 .method_by_name(&Name::new_symbol_root(sym::deref_mut)) |                                 .method_by_name(&Name::new_symbol_root(sym::deref_mut)) | ||||||
|                             { |                             { | ||||||
|                                 break 'b deref_fn == f; |                                 break 'b deref_fn == f; | ||||||
|  |  | ||||||
|  | @ -654,9 +654,8 @@ impl InferenceContext<'_> { | ||||||
|                 match op { |                 match op { | ||||||
|                     UnaryOp::Deref => { |                     UnaryOp::Deref => { | ||||||
|                         if let Some(deref_trait) = self.resolve_lang_trait(LangItem::Deref) { |                         if let Some(deref_trait) = self.resolve_lang_trait(LangItem::Deref) { | ||||||
|                             if let Some(deref_fn) = self |                             if let Some(deref_fn) = deref_trait | ||||||
|                                 .db |                                 .trait_items(self.db) | ||||||
|                                 .trait_items(deref_trait) |  | ||||||
|                                 .method_by_name(&Name::new_symbol_root(sym::deref)) |                                 .method_by_name(&Name::new_symbol_root(sym::deref)) | ||||||
|                             { |                             { | ||||||
|                                 // FIXME: this is wrong in multiple ways, subst is empty, and we emit it even for builtin deref (note that
 |                                 // FIXME: this is wrong in multiple ways, subst is empty, and we emit it even for builtin deref (note that
 | ||||||
|  | @ -813,9 +812,8 @@ impl InferenceContext<'_> { | ||||||
|                         self.table.new_lifetime_var(), |                         self.table.new_lifetime_var(), | ||||||
|                     )); |                     )); | ||||||
|                     self.write_expr_adj(*base, adj.into_boxed_slice()); |                     self.write_expr_adj(*base, adj.into_boxed_slice()); | ||||||
|                     if let Some(func) = self |                     if let Some(func) = index_trait | ||||||
|                         .db |                         .trait_items(self.db) | ||||||
|                         .trait_items(index_trait) |  | ||||||
|                         .method_by_name(&Name::new_symbol_root(sym::index)) |                         .method_by_name(&Name::new_symbol_root(sym::index)) | ||||||
|                     { |                     { | ||||||
|                         let subst = TyBuilder::subst_for_def(self.db, index_trait, None); |                         let subst = TyBuilder::subst_for_def(self.db, index_trait, None); | ||||||
|  | @ -1148,7 +1146,7 @@ impl InferenceContext<'_> { | ||||||
|         let Some(trait_) = fn_x.get_id(self.db, self.table.trait_env.krate) else { |         let Some(trait_) = fn_x.get_id(self.db, self.table.trait_env.krate) else { | ||||||
|             return; |             return; | ||||||
|         }; |         }; | ||||||
|         let trait_data = self.db.trait_items(trait_); |         let trait_data = trait_.trait_items(self.db); | ||||||
|         if let Some(func) = trait_data.method_by_name(&fn_x.method_name()) { |         if let Some(func) = trait_data.method_by_name(&fn_x.method_name()) { | ||||||
|             let subst = TyBuilder::subst_for_def(self.db, trait_, None) |             let subst = TyBuilder::subst_for_def(self.db, trait_, None) | ||||||
|                 .push(callee_ty.clone()) |                 .push(callee_ty.clone()) | ||||||
|  | @ -1316,7 +1314,7 @@ impl InferenceContext<'_> { | ||||||
| 
 | 
 | ||||||
|         let trait_func = lang_items_for_bin_op(op).and_then(|(name, lang_item)| { |         let trait_func = lang_items_for_bin_op(op).and_then(|(name, lang_item)| { | ||||||
|             let trait_id = self.resolve_lang_item(lang_item)?.as_trait()?; |             let trait_id = self.resolve_lang_item(lang_item)?.as_trait()?; | ||||||
|             let func = self.db.trait_items(trait_id).method_by_name(&name)?; |             let func = trait_id.trait_items(self.db).method_by_name(&name)?; | ||||||
|             Some((trait_id, func)) |             Some((trait_id, func)) | ||||||
|         }); |         }); | ||||||
|         let (trait_, func) = match trait_func { |         let (trait_, func) = match trait_func { | ||||||
|  |  | ||||||
|  | @ -129,9 +129,8 @@ impl InferenceContext<'_> { | ||||||
|                         if let Some(index_trait) = |                         if let Some(index_trait) = | ||||||
|                             LangItem::IndexMut.resolve_trait(self.db, self.table.trait_env.krate) |                             LangItem::IndexMut.resolve_trait(self.db, self.table.trait_env.krate) | ||||||
|                         { |                         { | ||||||
|                             if let Some(index_fn) = self |                             if let Some(index_fn) = index_trait | ||||||
|                                 .db |                                 .trait_items(self.db) | ||||||
|                                 .trait_items(index_trait) |  | ||||||
|                                 .method_by_name(&Name::new_symbol_root(sym::index_mut)) |                                 .method_by_name(&Name::new_symbol_root(sym::index_mut)) | ||||||
|                             { |                             { | ||||||
|                                 *f = index_fn; |                                 *f = index_fn; | ||||||
|  | @ -194,9 +193,8 @@ impl InferenceContext<'_> { | ||||||
|                             }); |                             }); | ||||||
|                             if is_mut_ptr { |                             if is_mut_ptr { | ||||||
|                                 mutability = Mutability::Not; |                                 mutability = Mutability::Not; | ||||||
|                             } else if let Some(deref_fn) = self |                             } else if let Some(deref_fn) = deref_trait | ||||||
|                                 .db |                                 .trait_items(self.db) | ||||||
|                                 .trait_items(deref_trait) |  | ||||||
|                                 .method_by_name(&Name::new_symbol_root(sym::deref_mut)) |                                 .method_by_name(&Name::new_symbol_root(sym::deref_mut)) | ||||||
|                             { |                             { | ||||||
|                                 *f = deref_fn; |                                 *f = deref_fn; | ||||||
|  |  | ||||||
|  | @ -278,7 +278,7 @@ impl InferenceContext<'_> { | ||||||
|     ) -> Option<(ValueNs, Substitution)> { |     ) -> Option<(ValueNs, Substitution)> { | ||||||
|         let trait_ = trait_ref.hir_trait_id(); |         let trait_ = trait_ref.hir_trait_id(); | ||||||
|         let item = |         let item = | ||||||
|             self.db.trait_items(trait_).items.iter().map(|(_name, id)| *id).find_map(|item| { |             trait_.trait_items(self.db).items.iter().map(|(_name, id)| *id).find_map(|item| { | ||||||
|                 match item { |                 match item { | ||||||
|                     AssocItemId::FunctionId(func) => { |                     AssocItemId::FunctionId(func) => { | ||||||
|                         if segment.name == &self.db.function_signature(func).name { |                         if segment.name == &self.db.function_signature(func).name { | ||||||
|  |  | ||||||
|  | @ -859,7 +859,7 @@ impl<'a> InferenceTable<'a> { | ||||||
|         ] { |         ] { | ||||||
|             let krate = self.trait_env.krate; |             let krate = self.trait_env.krate; | ||||||
|             let fn_trait = fn_trait_name.get_id(self.db, krate)?; |             let fn_trait = fn_trait_name.get_id(self.db, krate)?; | ||||||
|             let trait_data = self.db.trait_items(fn_trait); |             let trait_data = fn_trait.trait_items(self.db); | ||||||
|             let output_assoc_type = |             let output_assoc_type = | ||||||
|                 trait_data.associated_type_by_name(&Name::new_symbol_root(output_assoc_name))?; |                 trait_data.associated_type_by_name(&Name::new_symbol_root(output_assoc_name))?; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -891,8 +891,8 @@ pub fn callable_sig_from_fn_trait( | ||||||
| ) -> Option<(FnTrait, CallableSig)> { | ) -> Option<(FnTrait, CallableSig)> { | ||||||
|     let krate = trait_env.krate; |     let krate = trait_env.krate; | ||||||
|     let fn_once_trait = FnTrait::FnOnce.get_id(db, krate)?; |     let fn_once_trait = FnTrait::FnOnce.get_id(db, krate)?; | ||||||
|     let output_assoc_type = db |     let output_assoc_type = fn_once_trait | ||||||
|         .trait_items(fn_once_trait) |         .trait_items(db) | ||||||
|         .associated_type_by_name(&Name::new_symbol_root(sym::Output))?; |         .associated_type_by_name(&Name::new_symbol_root(sym::Output))?; | ||||||
| 
 | 
 | ||||||
|     let mut table = InferenceTable::new(db, trait_env.clone()); |     let mut table = InferenceTable::new(db, trait_env.clone()); | ||||||
|  |  | ||||||
|  | @ -805,7 +805,7 @@ fn named_associated_type_shorthand_candidates<R>( | ||||||
| ) -> Option<R> { | ) -> Option<R> { | ||||||
|     let mut search = |t| { |     let mut search = |t| { | ||||||
|         all_super_trait_refs(db, t, |t| { |         all_super_trait_refs(db, t, |t| { | ||||||
|             let data = db.trait_items(t.hir_trait_id()); |             let data = t.hir_trait_id().trait_items(db); | ||||||
| 
 | 
 | ||||||
|             for (name, assoc_id) in &data.items { |             for (name, assoc_id) in &data.items { | ||||||
|                 if let AssocItemId::TypeAliasId(alias) = assoc_id { |                 if let AssocItemId::TypeAliasId(alias) = assoc_id { | ||||||
|  | @ -957,7 +957,7 @@ pub(crate) fn generic_predicates_for_param_query( | ||||||
|                     }; |                     }; | ||||||
| 
 | 
 | ||||||
|                     all_super_traits(db, tr).iter().any(|tr| { |                     all_super_traits(db, tr).iter().any(|tr| { | ||||||
|                         db.trait_items(*tr).items.iter().any(|(name, item)| { |                         tr.trait_items(db).items.iter().any(|(name, item)| { | ||||||
|                             matches!(item, AssocItemId::TypeAliasId(_)) && name == assoc_name |                             matches!(item, AssocItemId::TypeAliasId(_)) && name == assoc_name | ||||||
|                         }) |                         }) | ||||||
|                     }) |                     }) | ||||||
|  |  | ||||||
|  | @ -173,7 +173,7 @@ impl<'a, 'b> PathLoweringContext<'a, 'b> { | ||||||
|                         self.skip_resolved_segment(); |                         self.skip_resolved_segment(); | ||||||
|                         let segment = self.current_or_prev_segment; |                         let segment = self.current_or_prev_segment; | ||||||
|                         let found = |                         let found = | ||||||
|                             self.ctx.db.trait_items(trait_).associated_type_by_name(segment.name); |                             trait_.trait_items(self.ctx.db).associated_type_by_name(segment.name); | ||||||
| 
 | 
 | ||||||
|                         match found { |                         match found { | ||||||
|                             Some(associated_ty) => { |                             Some(associated_ty) => { | ||||||
|  |  | ||||||
|  | @ -1302,7 +1302,7 @@ fn iterate_trait_method_candidates( | ||||||
|         // trait, but if we find out it doesn't, we'll skip the rest of the
 |         // trait, but if we find out it doesn't, we'll skip the rest of the
 | ||||||
|         // iteration
 |         // iteration
 | ||||||
|         let mut known_implemented = false; |         let mut known_implemented = false; | ||||||
|         for &(_, item) in db.trait_items(t).items.iter() { |         for &(_, item) in t.trait_items(db).items.iter() { | ||||||
|             // Don't pass a `visible_from_module` down to `is_valid_candidate`,
 |             // Don't pass a `visible_from_module` down to `is_valid_candidate`,
 | ||||||
|             // since only inherent methods should be included into visibility checking.
 |             // since only inherent methods should be included into visibility checking.
 | ||||||
|             let visible = |             let visible = | ||||||
|  | @ -1429,7 +1429,7 @@ fn iterate_inherent_methods( | ||||||
|     ) -> ControlFlow<()> { |     ) -> ControlFlow<()> { | ||||||
|         let db = table.db; |         let db = table.db; | ||||||
|         for t in traits { |         for t in traits { | ||||||
|             let data = db.trait_items(t); |             let data = t.trait_items(db); | ||||||
|             for &(_, item) in data.items.iter() { |             for &(_, item) in data.items.iter() { | ||||||
|                 // We don't pass `visible_from_module` as all trait items should be visible.
 |                 // We don't pass `visible_from_module` as all trait items should be visible.
 | ||||||
|                 let visible = match is_valid_trait_method_candidate( |                 let visible = match is_valid_trait_method_candidate( | ||||||
|  |  | ||||||
|  | @ -657,12 +657,12 @@ impl Evaluator<'_> { | ||||||
|             cached_ptr_size, |             cached_ptr_size, | ||||||
|             cached_fn_trait_func: LangItem::Fn |             cached_fn_trait_func: LangItem::Fn | ||||||
|                 .resolve_trait(db, crate_id) |                 .resolve_trait(db, crate_id) | ||||||
|                 .and_then(|x| db.trait_items(x).method_by_name(&Name::new_symbol_root(sym::call))), |                 .and_then(|x| x.trait_items(db).method_by_name(&Name::new_symbol_root(sym::call))), | ||||||
|             cached_fn_mut_trait_func: LangItem::FnMut.resolve_trait(db, crate_id).and_then(|x| { |             cached_fn_mut_trait_func: LangItem::FnMut.resolve_trait(db, crate_id).and_then(|x| { | ||||||
|                 db.trait_items(x).method_by_name(&Name::new_symbol_root(sym::call_mut)) |                 x.trait_items(db).method_by_name(&Name::new_symbol_root(sym::call_mut)) | ||||||
|             }), |             }), | ||||||
|             cached_fn_once_trait_func: LangItem::FnOnce.resolve_trait(db, crate_id).and_then(|x| { |             cached_fn_once_trait_func: LangItem::FnOnce.resolve_trait(db, crate_id).and_then(|x| { | ||||||
|                 db.trait_items(x).method_by_name(&Name::new_symbol_root(sym::call_once)) |                 x.trait_items(db).method_by_name(&Name::new_symbol_root(sym::call_once)) | ||||||
|             }), |             }), | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
|  | @ -2808,7 +2808,7 @@ impl Evaluator<'_> { | ||||||
|     ) -> Result<()> { |     ) -> Result<()> { | ||||||
|         let Some(drop_fn) = (|| { |         let Some(drop_fn) = (|| { | ||||||
|             let drop_trait = LangItem::Drop.resolve_trait(self.db, self.crate_id)?; |             let drop_trait = LangItem::Drop.resolve_trait(self.db, self.crate_id)?; | ||||||
|             self.db.trait_items(drop_trait).method_by_name(&Name::new_symbol_root(sym::drop)) |             drop_trait.trait_items(self.db).method_by_name(&Name::new_symbol_root(sym::drop)) | ||||||
|         })() else { |         })() else { | ||||||
|             // in some tests we don't have drop trait in minicore, and
 |             // in some tests we don't have drop trait in minicore, and
 | ||||||
|             // we can ignore drop in them.
 |             // we can ignore drop in them.
 | ||||||
|  | @ -2918,7 +2918,7 @@ pub fn render_const_using_debug_impl( | ||||||
|         not_supported!("core::fmt::Debug not found"); |         not_supported!("core::fmt::Debug not found"); | ||||||
|     }; |     }; | ||||||
|     let Some(debug_fmt_fn) = |     let Some(debug_fmt_fn) = | ||||||
|         db.trait_items(debug_trait).method_by_name(&Name::new_symbol_root(sym::fmt)) |         debug_trait.trait_items(db).method_by_name(&Name::new_symbol_root(sym::fmt)) | ||||||
|     else { |     else { | ||||||
|         not_supported!("core::fmt::Debug::fmt not found"); |         not_supported!("core::fmt::Debug::fmt not found"); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  | @ -1257,9 +1257,8 @@ impl Evaluator<'_> { | ||||||
|                     args.push(IntervalAndTy::new(addr, field, self, locals)?); |                     args.push(IntervalAndTy::new(addr, field, self, locals)?); | ||||||
|                 } |                 } | ||||||
|                 if let Some(target) = LangItem::FnOnce.resolve_trait(self.db, self.crate_id) { |                 if let Some(target) = LangItem::FnOnce.resolve_trait(self.db, self.crate_id) { | ||||||
|                     if let Some(def) = self |                     if let Some(def) = target | ||||||
|                         .db |                         .trait_items(self.db) | ||||||
|                         .trait_items(target) |  | ||||||
|                         .method_by_name(&Name::new_symbol_root(sym::call_once)) |                         .method_by_name(&Name::new_symbol_root(sym::call_once)) | ||||||
|                     { |                     { | ||||||
|                         self.exec_fn_trait( |                         self.exec_fn_trait( | ||||||
|  |  | ||||||
|  | @ -193,9 +193,8 @@ impl MirLowerCtx<'_> { | ||||||
|                                 if let Some(deref_trait) = |                                 if let Some(deref_trait) = | ||||||
|                                     self.resolve_lang_item(LangItem::DerefMut)?.as_trait() |                                     self.resolve_lang_item(LangItem::DerefMut)?.as_trait() | ||||||
|                                 { |                                 { | ||||||
|                                     if let Some(deref_fn) = self |                                     if let Some(deref_fn) = deref_trait | ||||||
|                                         .db |                                         .trait_items(self.db) | ||||||
|                                         .trait_items(deref_trait) |  | ||||||
|                                         .method_by_name(&Name::new_symbol_root(sym::deref_mut)) |                                         .method_by_name(&Name::new_symbol_root(sym::deref_mut)) | ||||||
|                                     { |                                     { | ||||||
|                                         break 'b deref_fn == f; |                                         break 'b deref_fn == f; | ||||||
|  | @ -347,9 +346,8 @@ impl MirLowerCtx<'_> { | ||||||
|             .resolve_lang_item(trait_lang_item)? |             .resolve_lang_item(trait_lang_item)? | ||||||
|             .as_trait() |             .as_trait() | ||||||
|             .ok_or(MirLowerError::LangItemNotFound(trait_lang_item))?; |             .ok_or(MirLowerError::LangItemNotFound(trait_lang_item))?; | ||||||
|         let deref_fn = self |         let deref_fn = deref_trait | ||||||
|             .db |             .trait_items(self.db) | ||||||
|             .trait_items(deref_trait) |  | ||||||
|             .method_by_name(&trait_method_name) |             .method_by_name(&trait_method_name) | ||||||
|             .ok_or(MirLowerError::LangItemNotFound(trait_lang_item))?; |             .ok_or(MirLowerError::LangItemNotFound(trait_lang_item))?; | ||||||
|         let deref_fn_op = Operand::const_zst( |         let deref_fn_op = Operand::const_zst( | ||||||
|  |  | ||||||
|  | @ -486,7 +486,7 @@ pub(crate) fn visit_module( | ||||||
|                     }); |                     }); | ||||||
|                 } |                 } | ||||||
|                 ModuleDefId::TraitId(it) => { |                 ModuleDefId::TraitId(it) => { | ||||||
|                     let trait_data = db.trait_items(it); |                     let trait_data = it.trait_items(db); | ||||||
|                     for &(_, item) in trait_data.items.iter() { |                     for &(_, item) in trait_data.items.iter() { | ||||||
|                         match item { |                         match item { | ||||||
|                             AssocItemId::FunctionId(it) => cb(it.into()), |                             AssocItemId::FunctionId(it) => cb(it.into()), | ||||||
|  |  | ||||||
|  | @ -567,7 +567,7 @@ fn main() { | ||||||
|                 "ast_id_map_shim", |                 "ast_id_map_shim", | ||||||
|                 "parse_shim", |                 "parse_shim", | ||||||
|                 "real_span_map_shim", |                 "real_span_map_shim", | ||||||
|                 "trait_items_with_diagnostics_shim", |                 "query_with_diagnostics_", | ||||||
|                 "body_shim", |                 "body_shim", | ||||||
|                 "body_with_source_map_shim", |                 "body_with_source_map_shim", | ||||||
|                 "attrs_shim", |                 "attrs_shim", | ||||||
|  | @ -674,7 +674,7 @@ fn main() { | ||||||
|                 "file_item_tree_query", |                 "file_item_tree_query", | ||||||
|                 "real_span_map_shim", |                 "real_span_map_shim", | ||||||
|                 "crate_local_def_map", |                 "crate_local_def_map", | ||||||
|                 "trait_items_with_diagnostics_shim", |                 "query_with_diagnostics_", | ||||||
|                 "body_with_source_map_shim", |                 "body_with_source_map_shim", | ||||||
|                 "attrs_shim", |                 "attrs_shim", | ||||||
|                 "body_shim", |                 "body_shim", | ||||||
|  |  | ||||||
|  | @ -218,7 +218,7 @@ pub(super) fn associated_type_by_name_including_super_traits( | ||||||
|     name: &Name, |     name: &Name, | ||||||
| ) -> Option<(TraitRef, TypeAliasId)> { | ) -> Option<(TraitRef, TypeAliasId)> { | ||||||
|     all_super_trait_refs(db, trait_ref, |t| { |     all_super_trait_refs(db, trait_ref, |t| { | ||||||
|         let assoc_type = db.trait_items(t.hir_trait_id()).associated_type_by_name(name)?; |         let assoc_type = t.hir_trait_id().trait_items(db).associated_type_by_name(name)?; | ||||||
|         Some((t, assoc_type)) |         Some((t, assoc_type)) | ||||||
|     }) |     }) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -207,7 +207,7 @@ fn resolve_assoc_or_field( | ||||||
|             // Doc paths in this context may only resolve to an item of this trait
 |             // Doc paths in this context may only resolve to an item of this trait
 | ||||||
|             // (i.e. no items of its supertraits), so we need to handle them here
 |             // (i.e. no items of its supertraits), so we need to handle them here
 | ||||||
|             // independently of others.
 |             // independently of others.
 | ||||||
|             return db.trait_items(id).items.iter().find(|it| it.0 == name).map(|(_, assoc_id)| { |             return id.trait_items(db).items.iter().find(|it| it.0 == name).map(|(_, assoc_id)| { | ||||||
|                 let def = match *assoc_id { |                 let def = match *assoc_id { | ||||||
|                     AssocItemId::FunctionId(it) => ModuleDef::Function(it.into()), |                     AssocItemId::FunctionId(it) => ModuleDef::Function(it.into()), | ||||||
|                     AssocItemId::ConstId(it) => ModuleDef::Const(it.into()), |                     AssocItemId::ConstId(it) => ModuleDef::Const(it.into()), | ||||||
|  |  | ||||||
|  | @ -54,7 +54,7 @@ use hir_def::{ | ||||||
|     }, |     }, | ||||||
|     item_tree::ImportAlias, |     item_tree::ImportAlias, | ||||||
|     layout::{self, ReprOptions, TargetDataLayout}, |     layout::{self, ReprOptions, TargetDataLayout}, | ||||||
|     nameres::{self, diagnostics::DefDiagnostic}, |     nameres::{self, assoc::TraitItems, diagnostics::DefDiagnostic}, | ||||||
|     per_ns::PerNs, |     per_ns::PerNs, | ||||||
|     resolver::{HasResolver, Resolver}, |     resolver::{HasResolver, Resolver}, | ||||||
|     signatures::{ImplFlags, StaticFlags, TraitFlags, VariantFields}, |     signatures::{ImplFlags, StaticFlags, TraitFlags, VariantFields}, | ||||||
|  | @ -649,7 +649,7 @@ impl Module { | ||||||
|                     acc.extend(def.diagnostics(db, style_lints)) |                     acc.extend(def.diagnostics(db, style_lints)) | ||||||
|                 } |                 } | ||||||
|                 ModuleDef::Trait(t) => { |                 ModuleDef::Trait(t) => { | ||||||
|                     for diag in db.trait_items_with_diagnostics(t.id).1.iter() { |                     for diag in TraitItems::query_with_diagnostics(db, t.id).1.iter() { | ||||||
|                         emit_def_diagnostic(db, acc, diag, edition); |                         emit_def_diagnostic(db, acc, diag, edition); | ||||||
|                     } |                     } | ||||||
| 
 | 
 | ||||||
|  | @ -822,7 +822,7 @@ impl Module { | ||||||
| 
 | 
 | ||||||
|             // Negative impls can't have items, don't emit missing items diagnostic for them
 |             // Negative impls can't have items, don't emit missing items diagnostic for them
 | ||||||
|             if let (false, Some(trait_)) = (impl_is_negative, trait_) { |             if let (false, Some(trait_)) = (impl_is_negative, trait_) { | ||||||
|                 let items = &db.trait_items(trait_.into()).items; |                 let items = &trait_.id.trait_items(db).items; | ||||||
|                 let required_items = items.iter().filter(|&(_, assoc)| match *assoc { |                 let required_items = items.iter().filter(|&(_, assoc)| match *assoc { | ||||||
|                     AssocItemId::FunctionId(it) => !db.function_signature(it).has_body(), |                     AssocItemId::FunctionId(it) => !db.function_signature(it).has_body(), | ||||||
|                     AssocItemId::ConstId(id) => !db.const_signature(id).has_body(), |                     AssocItemId::ConstId(id) => !db.const_signature(id).has_body(), | ||||||
|  | @ -2883,7 +2883,7 @@ impl Trait { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     pub fn function(self, db: &dyn HirDatabase, name: impl PartialEq<Name>) -> Option<Function> { |     pub fn function(self, db: &dyn HirDatabase, name: impl PartialEq<Name>) -> Option<Function> { | ||||||
|         db.trait_items(self.id).items.iter().find(|(n, _)| name == *n).and_then(|&(_, it)| match it |         self.id.trait_items(db).items.iter().find(|(n, _)| name == *n).and_then(|&(_, it)| match it | ||||||
|         { |         { | ||||||
|             AssocItemId::FunctionId(id) => Some(Function { id }), |             AssocItemId::FunctionId(id) => Some(Function { id }), | ||||||
|             _ => None, |             _ => None, | ||||||
|  | @ -2891,7 +2891,7 @@ impl Trait { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     pub fn items(self, db: &dyn HirDatabase) -> Vec<AssocItem> { |     pub fn items(self, db: &dyn HirDatabase) -> Vec<AssocItem> { | ||||||
|         db.trait_items(self.id).items.iter().map(|(_name, it)| (*it).into()).collect() |         self.id.trait_items(db).items.iter().map(|(_name, it)| (*it).into()).collect() | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     pub fn items_with_supertraits(self, db: &dyn HirDatabase) -> Vec<AssocItem> { |     pub fn items_with_supertraits(self, db: &dyn HirDatabase) -> Vec<AssocItem> { | ||||||
|  | @ -2939,7 +2939,7 @@ impl Trait { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn all_macro_calls(&self, db: &dyn HirDatabase) -> Box<[(AstId<ast::Item>, MacroCallId)]> { |     fn all_macro_calls(&self, db: &dyn HirDatabase) -> Box<[(AstId<ast::Item>, MacroCallId)]> { | ||||||
|         db.trait_items(self.id).macro_calls.to_vec().into_boxed_slice() |         self.id.trait_items(db).macro_calls.to_vec().into_boxed_slice() | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// `#[rust_analyzer::completions(...)]` mode.
 |     /// `#[rust_analyzer::completions(...)]` mode.
 | ||||||
|  | @ -5000,7 +5000,7 @@ impl<'db> Type<'db> { | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         let output_assoc_type = |         let output_assoc_type = | ||||||
|             db.trait_items(trait_).associated_type_by_name(&Name::new_symbol_root(sym::Output))?; |             trait_.trait_items(db).associated_type_by_name(&Name::new_symbol_root(sym::Output))?; | ||||||
|         self.normalize_trait_assoc_type(db, &[], output_assoc_type.into()) |         self.normalize_trait_assoc_type(db, &[], output_assoc_type.into()) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -5013,8 +5013,8 @@ impl<'db> Type<'db> { | ||||||
|     /// This does **not** resolve `IntoIterator`, only `Iterator`.
 |     /// This does **not** resolve `IntoIterator`, only `Iterator`.
 | ||||||
|     pub fn iterator_item(self, db: &'db dyn HirDatabase) -> Option<Type<'db>> { |     pub fn iterator_item(self, db: &'db dyn HirDatabase) -> Option<Type<'db>> { | ||||||
|         let iterator_trait = LangItem::Iterator.resolve_trait(db, self.env.krate)?; |         let iterator_trait = LangItem::Iterator.resolve_trait(db, self.env.krate)?; | ||||||
|         let iterator_item = db |         let iterator_item = iterator_trait | ||||||
|             .trait_items(iterator_trait) |             .trait_items(db) | ||||||
|             .associated_type_by_name(&Name::new_symbol_root(sym::Item))?; |             .associated_type_by_name(&Name::new_symbol_root(sym::Item))?; | ||||||
|         self.normalize_trait_assoc_type(db, &[], iterator_item.into()) |         self.normalize_trait_assoc_type(db, &[], iterator_item.into()) | ||||||
|     } |     } | ||||||
|  | @ -5044,8 +5044,8 @@ impl<'db> Type<'db> { | ||||||
|             return None; |             return None; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         let into_iter_assoc_type = db |         let into_iter_assoc_type = trait_ | ||||||
|             .trait_items(trait_) |             .trait_items(db) | ||||||
|             .associated_type_by_name(&Name::new_symbol_root(sym::IntoIter))?; |             .associated_type_by_name(&Name::new_symbol_root(sym::IntoIter))?; | ||||||
|         self.normalize_trait_assoc_type(db, &[], into_iter_assoc_type.into()) |         self.normalize_trait_assoc_type(db, &[], into_iter_assoc_type.into()) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -35,7 +35,7 @@ pub(crate) trait ChildBySource { | ||||||
| 
 | 
 | ||||||
| impl ChildBySource for TraitId { | impl ChildBySource for TraitId { | ||||||
|     fn child_by_source_to(&self, db: &dyn DefDatabase, res: &mut DynMap, file_id: HirFileId) { |     fn child_by_source_to(&self, db: &dyn DefDatabase, res: &mut DynMap, file_id: HirFileId) { | ||||||
|         let data = db.trait_items(*self); |         let data = self.trait_items(db); | ||||||
| 
 | 
 | ||||||
|         data.macro_calls().filter(|(ast_id, _)| ast_id.file_id == file_id).for_each( |         data.macro_calls().filter(|(ast_id, _)| ast_id.file_id == file_id).for_each( | ||||||
|             |(ast_id, call_id)| { |             |(ast_id, call_id)| { | ||||||
|  |  | ||||||
|  | @ -1423,7 +1423,7 @@ impl<'db> SourceAnalyzer<'db> { | ||||||
|         method_name: &Name, |         method_name: &Name, | ||||||
|     ) -> Option<(TraitId, FunctionId)> { |     ) -> Option<(TraitId, FunctionId)> { | ||||||
|         let trait_id = lang_trait.resolve_trait(db, self.resolver.krate())?; |         let trait_id = lang_trait.resolve_trait(db, self.resolver.krate())?; | ||||||
|         let fn_id = db.trait_items(trait_id).method_by_name(method_name)?; |         let fn_id = trait_id.trait_items(db).method_by_name(method_name)?; | ||||||
|         Some((trait_id, fn_id)) |         Some((trait_id, fn_id)) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -1580,7 +1580,7 @@ fn resolve_hir_path_( | ||||||
|         // within the trait's associated types.
 |         // within the trait's associated types.
 | ||||||
|         if let (Some(unresolved), &TypeNs::TraitId(trait_id)) = (&unresolved, &ty) { |         if let (Some(unresolved), &TypeNs::TraitId(trait_id)) = (&unresolved, &ty) { | ||||||
|             if let Some(type_alias_id) = |             if let Some(type_alias_id) = | ||||||
|                 db.trait_items(trait_id).associated_type_by_name(unresolved.name) |                 trait_id.trait_items(db).associated_type_by_name(unresolved.name) | ||||||
|             { |             { | ||||||
|                 return Some(PathResolution::Def(ModuleDefId::from(type_alias_id).into())); |                 return Some(PathResolution::Def(ModuleDefId::from(type_alias_id).into())); | ||||||
|             } |             } | ||||||
|  | @ -1731,7 +1731,7 @@ fn resolve_hir_path_qualifier( | ||||||
|         // within the trait's associated types.
 |         // within the trait's associated types.
 | ||||||
|         if let (Some(unresolved), &TypeNs::TraitId(trait_id)) = (&unresolved, &ty) { |         if let (Some(unresolved), &TypeNs::TraitId(trait_id)) = (&unresolved, &ty) { | ||||||
|             if let Some(type_alias_id) = |             if let Some(type_alias_id) = | ||||||
|                 db.trait_items(trait_id).associated_type_by_name(unresolved.name) |                 trait_id.trait_items(db).associated_type_by_name(unresolved.name) | ||||||
|             { |             { | ||||||
|                 return Some(PathResolution::Def(ModuleDefId::from(type_alias_id).into())); |                 return Some(PathResolution::Def(ModuleDefId::from(type_alias_id).into())); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  | @ -334,7 +334,7 @@ impl<'a> SymbolCollector<'a> { | ||||||
|     fn collect_from_trait(&mut self, trait_id: TraitId, trait_do_not_complete: Complete) { |     fn collect_from_trait(&mut self, trait_id: TraitId, trait_do_not_complete: Complete) { | ||||||
|         let trait_data = self.db.trait_signature(trait_id); |         let trait_data = self.db.trait_signature(trait_id); | ||||||
|         self.with_container_name(Some(trait_data.name.as_str().into()), |s| { |         self.with_container_name(Some(trait_data.name.as_str().into()), |s| { | ||||||
|             for &(ref name, assoc_item_id) in &self.db.trait_items(trait_id).items { |             for &(ref name, assoc_item_id) in &trait_id.trait_items(self.db).items { | ||||||
|                 s.push_assoc_item(assoc_item_id, name, Some(trait_do_not_complete)); |                 s.push_assoc_item(assoc_item_id, name, Some(trait_do_not_complete)); | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukas Wirth
						Lukas Wirth