mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-01 07:48:45 +00:00
Auto merge of #13570 - Veykril:dedup-crates-for, r=Veykril
minor: Remove code duplication
This commit is contained in:
commit
8a633fe986
2 changed files with 7 additions and 18 deletions
|
@ -1,9 +1,9 @@
|
||||||
//! This module generates [moniker](https://microsoft.github.io/language-server-protocol/specifications/lsif/0.6.0/specification/#exportsImports)
|
//! This module generates [moniker](https://microsoft.github.io/language-server-protocol/specifications/lsif/0.6.0/specification/#exportsImports)
|
||||||
//! for LSIF and LSP.
|
//! for LSIF and LSP.
|
||||||
|
|
||||||
use hir::{db::DefDatabase, AsAssocItem, AssocItemContainer, Crate, Name, Semantics};
|
use hir::{AsAssocItem, AssocItemContainer, Crate, Name, Semantics};
|
||||||
use ide_db::{
|
use ide_db::{
|
||||||
base_db::{CrateOrigin, FileId, FileLoader, FilePosition, LangCrateOrigin},
|
base_db::{CrateOrigin, FilePosition, LangCrateOrigin},
|
||||||
defs::{Definition, IdentClass},
|
defs::{Definition, IdentClass},
|
||||||
helpers::pick_best_token,
|
helpers::pick_best_token,
|
||||||
RootDatabase,
|
RootDatabase,
|
||||||
|
@ -11,7 +11,7 @@ use ide_db::{
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
use syntax::{AstNode, SyntaxKind::*, T};
|
use syntax::{AstNode, SyntaxKind::*, T};
|
||||||
|
|
||||||
use crate::{doc_links::token_as_doc_comment, RangeInfo};
|
use crate::{doc_links::token_as_doc_comment, parent_module::crates_for, RangeInfo};
|
||||||
|
|
||||||
#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
pub enum MonikerDescriptorKind {
|
pub enum MonikerDescriptorKind {
|
||||||
|
@ -77,25 +77,13 @@ pub struct PackageInformation {
|
||||||
pub version: Option<String>,
|
pub version: Option<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn crate_for_file(db: &RootDatabase, file_id: FileId) -> Option<Crate> {
|
|
||||||
for &krate in db.relevant_crates(file_id).iter() {
|
|
||||||
let crate_def_map = db.crate_def_map(krate);
|
|
||||||
for (_, data) in crate_def_map.modules() {
|
|
||||||
if data.origin.file_id() == Some(file_id) {
|
|
||||||
return Some(krate.into());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
None
|
|
||||||
}
|
|
||||||
|
|
||||||
pub(crate) fn moniker(
|
pub(crate) fn moniker(
|
||||||
db: &RootDatabase,
|
db: &RootDatabase,
|
||||||
FilePosition { file_id, offset }: FilePosition,
|
FilePosition { file_id, offset }: FilePosition,
|
||||||
) -> Option<RangeInfo<Vec<MonikerResult>>> {
|
) -> Option<RangeInfo<Vec<MonikerResult>>> {
|
||||||
let sema = &Semantics::new(db);
|
let sema = &Semantics::new(db);
|
||||||
let file = sema.parse(file_id).syntax().clone();
|
let file = sema.parse(file_id).syntax().clone();
|
||||||
let current_crate = crate_for_file(db, file_id)?;
|
let current_crate: hir::Crate = crates_for(db, file_id).pop()?.into();
|
||||||
let original_token = pick_best_token(file.token_at_offset(offset), |kind| match kind {
|
let original_token = pick_best_token(file.token_at_offset(offset), |kind| match kind {
|
||||||
IDENT
|
IDENT
|
||||||
| INT_NUMBER
|
| INT_NUMBER
|
||||||
|
|
|
@ -13,7 +13,8 @@ use syntax::{AstNode, SyntaxKind::*, SyntaxToken, TextRange, T};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
hover::hover_for_definition,
|
hover::hover_for_definition,
|
||||||
moniker::{crate_for_file, def_to_moniker, MonikerResult},
|
moniker::{def_to_moniker, MonikerResult},
|
||||||
|
parent_module::crates_for,
|
||||||
Analysis, Fold, HoverConfig, HoverDocFormat, HoverResult, InlayHint, InlayHintsConfig,
|
Analysis, Fold, HoverConfig, HoverDocFormat, HoverResult, InlayHint, InlayHintsConfig,
|
||||||
TryToNav,
|
TryToNav,
|
||||||
};
|
};
|
||||||
|
@ -99,7 +100,7 @@ fn all_modules(db: &dyn HirDatabase) -> Vec<Module> {
|
||||||
|
|
||||||
impl StaticIndex<'_> {
|
impl StaticIndex<'_> {
|
||||||
fn add_file(&mut self, file_id: FileId) {
|
fn add_file(&mut self, file_id: FileId) {
|
||||||
let current_crate = crate_for_file(self.db, file_id);
|
let current_crate = crates_for(self.db, file_id).pop().map(Into::into);
|
||||||
let folds = self.analysis.folding_ranges(file_id).unwrap();
|
let folds = self.analysis.folding_ranges(file_id).unwrap();
|
||||||
let inlay_hints = self
|
let inlay_hints = self
|
||||||
.analysis
|
.analysis
|
||||||
|
|
Loading…
Reference in a new issue