mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-11 20:58:54 +00:00
Properly name the field
This commit is contained in:
parent
99952f3be2
commit
9d19e5b962
8 changed files with 26 additions and 24 deletions
|
@ -127,10 +127,11 @@ impl PartialEq for ProcMacro {
|
||||||
pub struct CrateData {
|
pub struct CrateData {
|
||||||
pub root_file_id: FileId,
|
pub root_file_id: FileId,
|
||||||
pub edition: Edition,
|
pub edition: Edition,
|
||||||
/// The name to display to the end user.
|
/// A name used in the package's project declaration: for Cargo projects, it's [package].name,
|
||||||
/// This actual crate name can be different in a particular dependent crate
|
/// can be different for other project types or even absent (a dummy crate for the code snippet, for example).
|
||||||
/// or may even be missing for some cases, such as a dummy crate for the code snippet.
|
/// NOTE: The crate can be referenced as a dependency under a different name,
|
||||||
pub display_name: Option<CrateName>,
|
/// this one should be used when working with crate hierarchies.
|
||||||
|
pub declaration_name: Option<CrateName>,
|
||||||
pub cfg_options: CfgOptions,
|
pub cfg_options: CfgOptions,
|
||||||
pub env: Env,
|
pub env: Env,
|
||||||
pub dependencies: Vec<Dependency>,
|
pub dependencies: Vec<Dependency>,
|
||||||
|
@ -159,7 +160,7 @@ impl CrateGraph {
|
||||||
&mut self,
|
&mut self,
|
||||||
file_id: FileId,
|
file_id: FileId,
|
||||||
edition: Edition,
|
edition: Edition,
|
||||||
display_name: Option<CrateName>,
|
declaration_name: Option<CrateName>,
|
||||||
cfg_options: CfgOptions,
|
cfg_options: CfgOptions,
|
||||||
env: Env,
|
env: Env,
|
||||||
proc_macro: Vec<(SmolStr, Arc<dyn tt::TokenExpander>)>,
|
proc_macro: Vec<(SmolStr, Arc<dyn tt::TokenExpander>)>,
|
||||||
|
@ -170,7 +171,7 @@ impl CrateGraph {
|
||||||
let data = CrateData {
|
let data = CrateData {
|
||||||
root_file_id: file_id,
|
root_file_id: file_id,
|
||||||
edition,
|
edition,
|
||||||
display_name,
|
declaration_name,
|
||||||
cfg_options,
|
cfg_options,
|
||||||
env,
|
env,
|
||||||
proc_macro,
|
proc_macro,
|
||||||
|
|
|
@ -98,8 +98,8 @@ impl Crate {
|
||||||
db.crate_graph()[self.id].edition
|
db.crate_graph()[self.id].edition
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn display_name(self, db: &dyn HirDatabase) -> Option<CrateName> {
|
pub fn declaration_name(self, db: &dyn HirDatabase) -> Option<CrateName> {
|
||||||
db.crate_graph()[self.id].display_name.clone()
|
db.crate_graph()[self.id].declaration_name.clone()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn query_external_importables(
|
pub fn query_external_importables(
|
||||||
|
|
|
@ -334,14 +334,14 @@ mod tests {
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
fn check_search(ra_fixture: &str, krate_name: &str, query: Query, expect: Expect) {
|
fn check_search(ra_fixture: &str, crate_name: &str, query: Query, expect: Expect) {
|
||||||
let db = TestDB::with_files(ra_fixture);
|
let db = TestDB::with_files(ra_fixture);
|
||||||
let crate_graph = db.crate_graph();
|
let crate_graph = db.crate_graph();
|
||||||
let krate = crate_graph
|
let krate = crate_graph
|
||||||
.iter()
|
.iter()
|
||||||
.find(|krate| {
|
.find(|krate| {
|
||||||
crate_graph[*krate].display_name.as_ref().map(|n| n.to_string())
|
crate_graph[*krate].declaration_name.as_ref().map(|n| n.to_string())
|
||||||
== Some(krate_name.to_string())
|
== Some(crate_name.to_string())
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
|
@ -359,7 +359,7 @@ mod tests {
|
||||||
let path = map.path_of(item).unwrap();
|
let path = map.path_of(item).unwrap();
|
||||||
format!(
|
format!(
|
||||||
"{}::{} ({})\n",
|
"{}::{} ({})\n",
|
||||||
crate_graph[krate].display_name.as_ref().unwrap(),
|
crate_graph[krate].declaration_name.as_ref().unwrap(),
|
||||||
path,
|
path,
|
||||||
mark
|
mark
|
||||||
)
|
)
|
||||||
|
@ -400,7 +400,7 @@ mod tests {
|
||||||
.iter()
|
.iter()
|
||||||
.filter_map(|krate| {
|
.filter_map(|krate| {
|
||||||
let cdata = &crate_graph[krate];
|
let cdata = &crate_graph[krate];
|
||||||
let name = cdata.display_name.as_ref()?;
|
let name = cdata.declaration_name.as_ref()?;
|
||||||
|
|
||||||
let map = db.import_map(krate);
|
let map = db.import_map(krate);
|
||||||
|
|
||||||
|
|
|
@ -173,7 +173,7 @@ impl CrateDefMap {
|
||||||
pub(crate) fn crate_def_map_query(db: &dyn DefDatabase, krate: CrateId) -> Arc<CrateDefMap> {
|
pub(crate) fn crate_def_map_query(db: &dyn DefDatabase, krate: CrateId) -> Arc<CrateDefMap> {
|
||||||
let _p = profile::span("crate_def_map_query").detail(|| {
|
let _p = profile::span("crate_def_map_query").detail(|| {
|
||||||
db.crate_graph()[krate]
|
db.crate_graph()[krate]
|
||||||
.display_name
|
.declaration_name
|
||||||
.as_ref()
|
.as_ref()
|
||||||
.map(ToString::to_string)
|
.map(ToString::to_string)
|
||||||
.unwrap_or_default()
|
.unwrap_or_default()
|
||||||
|
|
|
@ -289,7 +289,7 @@ fn definition_owner_name(db: &RootDatabase, def: &Definition) -> Option<String>
|
||||||
|
|
||||||
fn render_path(db: &RootDatabase, module: Module, item_name: Option<String>) -> String {
|
fn render_path(db: &RootDatabase, module: Module, item_name: Option<String>) -> String {
|
||||||
let crate_name =
|
let crate_name =
|
||||||
db.crate_graph()[module.krate().into()].display_name.as_ref().map(ToString::to_string);
|
db.crate_graph()[module.krate().into()].declaration_name.as_ref().map(ToString::to_string);
|
||||||
let module_path = module
|
let module_path = module
|
||||||
.path_to_root(db)
|
.path_to_root(db)
|
||||||
.into_iter()
|
.into_iter()
|
||||||
|
|
|
@ -107,7 +107,7 @@ fn rewrite_intra_doc_link(
|
||||||
let krate = resolved.module(db)?.krate();
|
let krate = resolved.module(db)?.krate();
|
||||||
let canonical_path = resolved.canonical_path(db)?;
|
let canonical_path = resolved.canonical_path(db)?;
|
||||||
let new_target = get_doc_url(db, &krate)?
|
let new_target = get_doc_url(db, &krate)?
|
||||||
.join(&format!("{}/", krate.display_name(db)?))
|
.join(&format!("{}/", krate.declaration_name(db)?))
|
||||||
.ok()?
|
.ok()?
|
||||||
.join(&canonical_path.replace("::", "/"))
|
.join(&canonical_path.replace("::", "/"))
|
||||||
.ok()?
|
.ok()?
|
||||||
|
@ -127,7 +127,7 @@ fn rewrite_url_link(db: &RootDatabase, def: ModuleDef, target: &str) -> Option<S
|
||||||
let module = def.module(db)?;
|
let module = def.module(db)?;
|
||||||
let krate = module.krate();
|
let krate = module.krate();
|
||||||
let canonical_path = def.canonical_path(db)?;
|
let canonical_path = def.canonical_path(db)?;
|
||||||
let base = format!("{}/{}", krate.display_name(db)?, canonical_path.replace("::", "/"));
|
let base = format!("{}/{}", krate.declaration_name(db)?, canonical_path.replace("::", "/"));
|
||||||
|
|
||||||
get_doc_url(db, &krate)
|
get_doc_url(db, &krate)
|
||||||
.and_then(|url| url.join(&base).ok())
|
.and_then(|url| url.join(&base).ok())
|
||||||
|
@ -248,7 +248,7 @@ fn get_doc_url(db: &RootDatabase, krate: &Crate) -> Option<Url> {
|
||||||
//
|
//
|
||||||
// FIXME: clicking on the link should just open the file in the editor,
|
// FIXME: clicking on the link should just open the file in the editor,
|
||||||
// instead of falling back to external urls.
|
// instead of falling back to external urls.
|
||||||
Some(format!("https://docs.rs/{}/*/", krate.display_name(db)?))
|
Some(format!("https://docs.rs/{}/*/", krate.declaration_name(db)?))
|
||||||
})
|
})
|
||||||
.and_then(|s| Url::parse(&s).ok())
|
.and_then(|s| Url::parse(&s).ok())
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,7 +45,7 @@ pub(crate) fn status(db: &RootDatabase, file_id: Option<FileId>) -> String {
|
||||||
match krate {
|
match krate {
|
||||||
Some(krate) => {
|
Some(krate) => {
|
||||||
let crate_graph = db.crate_graph();
|
let crate_graph = db.crate_graph();
|
||||||
let display_crate = |krate: CrateId| match &crate_graph[krate].display_name {
|
let display_crate = |krate: CrateId| match &crate_graph[krate].declaration_name {
|
||||||
Some(it) => format!("{}({:?})", it, krate),
|
Some(it) => format!("{}({:?})", it, krate),
|
||||||
None => format!("{:?}", krate),
|
None => format!("{:?}", krate),
|
||||||
};
|
};
|
||||||
|
|
|
@ -36,11 +36,12 @@ pub fn diagnostics(path: &Path, load_output_dirs: bool, with_proc_macro: bool) -
|
||||||
for module in work {
|
for module in work {
|
||||||
let file_id = module.definition_source(db).file_id.original_file(db);
|
let file_id = module.definition_source(db).file_id.original_file(db);
|
||||||
if !visited_files.contains(&file_id) {
|
if !visited_files.contains(&file_id) {
|
||||||
let crate_name = if let Some(name) = module.krate().display_name(db) {
|
let crate_name = module
|
||||||
format!("{}", name)
|
.krate()
|
||||||
} else {
|
.declaration_name(db)
|
||||||
String::from("unknown")
|
.as_ref()
|
||||||
};
|
.map(ToString::to_string)
|
||||||
|
.unwrap_or_else(|| "unknown".to_string());
|
||||||
println!("processing crate: {}, module: {}", crate_name, _vfs.file_path(file_id));
|
println!("processing crate: {}, module: {}", crate_name, _vfs.file_path(file_id));
|
||||||
for diagnostic in analysis.diagnostics(&DiagnosticsConfig::default(), file_id).unwrap()
|
for diagnostic in analysis.diagnostics(&DiagnosticsConfig::default(), file_id).unwrap()
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue