mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-26 03:45:04 +00:00
switch log
crate to tracing
This commit is contained in:
parent
d15f646ff1
commit
ba0947dded
48 changed files with 277 additions and 239 deletions
35
Cargo.lock
generated
35
Cargo.lock
generated
|
@ -324,15 +324,6 @@ dependencies = [
|
||||||
"log",
|
"log",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "env_logger"
|
|
||||||
version = "0.9.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "0b2cf0344971ee6c64c31be0d530793fba457d322dfec2810c453d0ef228f9c3"
|
|
||||||
dependencies = [
|
|
||||||
"log",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "expect-test"
|
name = "expect-test"
|
||||||
version = "1.1.0"
|
version = "1.1.0"
|
||||||
|
@ -380,12 +371,12 @@ dependencies = [
|
||||||
"cargo_metadata",
|
"cargo_metadata",
|
||||||
"crossbeam-channel",
|
"crossbeam-channel",
|
||||||
"jod-thread",
|
"jod-thread",
|
||||||
"log",
|
|
||||||
"paths",
|
"paths",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"stdx",
|
"stdx",
|
||||||
"toolchain",
|
"toolchain",
|
||||||
|
"tracing",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -462,7 +453,6 @@ dependencies = [
|
||||||
"hir_ty",
|
"hir_ty",
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"itertools",
|
"itertools",
|
||||||
"log",
|
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"profile",
|
"profile",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
@ -490,7 +480,6 @@ dependencies = [
|
||||||
"itertools",
|
"itertools",
|
||||||
"la-arena",
|
"la-arena",
|
||||||
"limit",
|
"limit",
|
||||||
"log",
|
|
||||||
"mbe",
|
"mbe",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"profile",
|
"profile",
|
||||||
|
@ -499,6 +488,7 @@ dependencies = [
|
||||||
"stdx",
|
"stdx",
|
||||||
"syntax",
|
"syntax",
|
||||||
"test_utils",
|
"test_utils",
|
||||||
|
"tracing",
|
||||||
"tt",
|
"tt",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -514,13 +504,13 @@ dependencies = [
|
||||||
"itertools",
|
"itertools",
|
||||||
"la-arena",
|
"la-arena",
|
||||||
"limit",
|
"limit",
|
||||||
"log",
|
|
||||||
"mbe",
|
"mbe",
|
||||||
"parser",
|
"parser",
|
||||||
"profile",
|
"profile",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
"syntax",
|
"syntax",
|
||||||
"test_utils",
|
"test_utils",
|
||||||
|
"tracing",
|
||||||
"tt",
|
"tt",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -541,7 +531,6 @@ dependencies = [
|
||||||
"itertools",
|
"itertools",
|
||||||
"la-arena",
|
"la-arena",
|
||||||
"limit",
|
"limit",
|
||||||
"log",
|
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"profile",
|
"profile",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
@ -581,7 +570,6 @@ dependencies = [
|
||||||
"ide_ssr",
|
"ide_ssr",
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"itertools",
|
"itertools",
|
||||||
"log",
|
|
||||||
"oorandom",
|
"oorandom",
|
||||||
"profile",
|
"profile",
|
||||||
"pulldown-cmark",
|
"pulldown-cmark",
|
||||||
|
@ -591,6 +579,7 @@ dependencies = [
|
||||||
"syntax",
|
"syntax",
|
||||||
"test_utils",
|
"test_utils",
|
||||||
"text_edit",
|
"text_edit",
|
||||||
|
"tracing",
|
||||||
"url",
|
"url",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -625,7 +614,6 @@ dependencies = [
|
||||||
"hir",
|
"hir",
|
||||||
"ide_db",
|
"ide_db",
|
||||||
"itertools",
|
"itertools",
|
||||||
"log",
|
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"profile",
|
"profile",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
@ -634,6 +622,7 @@ dependencies = [
|
||||||
"syntax",
|
"syntax",
|
||||||
"test_utils",
|
"test_utils",
|
||||||
"text_edit",
|
"text_edit",
|
||||||
|
"tracing",
|
||||||
"xshell",
|
"xshell",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -649,7 +638,6 @@ dependencies = [
|
||||||
"hir",
|
"hir",
|
||||||
"itertools",
|
"itertools",
|
||||||
"limit",
|
"limit",
|
||||||
"log",
|
|
||||||
"once_cell",
|
"once_cell",
|
||||||
"profile",
|
"profile",
|
||||||
"rayon",
|
"rayon",
|
||||||
|
@ -658,6 +646,7 @@ dependencies = [
|
||||||
"syntax",
|
"syntax",
|
||||||
"test_utils",
|
"test_utils",
|
||||||
"text_edit",
|
"text_edit",
|
||||||
|
"tracing",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -889,7 +878,6 @@ version = "0.0.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cov-mark",
|
"cov-mark",
|
||||||
"expect-test",
|
"expect-test",
|
||||||
"log",
|
|
||||||
"parser",
|
"parser",
|
||||||
"profile",
|
"profile",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
@ -897,6 +885,7 @@ dependencies = [
|
||||||
"stdx",
|
"stdx",
|
||||||
"syntax",
|
"syntax",
|
||||||
"test_utils",
|
"test_utils",
|
||||||
|
"tracing",
|
||||||
"tt",
|
"tt",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -1121,7 +1110,6 @@ version = "0.0.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"crossbeam-channel",
|
"crossbeam-channel",
|
||||||
"jod-thread",
|
"jod-thread",
|
||||||
"log",
|
|
||||||
"memmap2",
|
"memmap2",
|
||||||
"object",
|
"object",
|
||||||
"paths",
|
"paths",
|
||||||
|
@ -1130,6 +1118,7 @@ dependencies = [
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"snap",
|
"snap",
|
||||||
"stdx",
|
"stdx",
|
||||||
|
"tracing",
|
||||||
"tt",
|
"tt",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -1188,7 +1177,6 @@ dependencies = [
|
||||||
"cfg",
|
"cfg",
|
||||||
"expect-test",
|
"expect-test",
|
||||||
"la-arena",
|
"la-arena",
|
||||||
"log",
|
|
||||||
"paths",
|
"paths",
|
||||||
"profile",
|
"profile",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
@ -1197,6 +1185,7 @@ dependencies = [
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"stdx",
|
"stdx",
|
||||||
"toolchain",
|
"toolchain",
|
||||||
|
"tracing",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -1308,7 +1297,6 @@ dependencies = [
|
||||||
"cfg",
|
"cfg",
|
||||||
"crossbeam-channel",
|
"crossbeam-channel",
|
||||||
"dissimilar",
|
"dissimilar",
|
||||||
"env_logger",
|
|
||||||
"expect-test",
|
"expect-test",
|
||||||
"flycheck",
|
"flycheck",
|
||||||
"hir",
|
"hir",
|
||||||
|
@ -1319,7 +1307,6 @@ dependencies = [
|
||||||
"ide_ssr",
|
"ide_ssr",
|
||||||
"itertools",
|
"itertools",
|
||||||
"jod-thread",
|
"jod-thread",
|
||||||
"log",
|
|
||||||
"lsp-server",
|
"lsp-server",
|
||||||
"lsp-types",
|
"lsp-types",
|
||||||
"mbe",
|
"mbe",
|
||||||
|
@ -1343,6 +1330,7 @@ dependencies = [
|
||||||
"tikv-jemallocator",
|
"tikv-jemallocator",
|
||||||
"toolchain",
|
"toolchain",
|
||||||
"tracing",
|
"tracing",
|
||||||
|
"tracing-log",
|
||||||
"tracing-subscriber",
|
"tracing-subscriber",
|
||||||
"tracing-tree",
|
"tracing-tree",
|
||||||
"tt",
|
"tt",
|
||||||
|
@ -1737,6 +1725,7 @@ dependencies = [
|
||||||
"thread_local",
|
"thread_local",
|
||||||
"tracing",
|
"tracing",
|
||||||
"tracing-core",
|
"tracing-core",
|
||||||
|
"tracing-log",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -1838,10 +1827,10 @@ version = "0.0.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"crossbeam-channel",
|
"crossbeam-channel",
|
||||||
"jod-thread",
|
"jod-thread",
|
||||||
"log",
|
|
||||||
"notify",
|
"notify",
|
||||||
"paths",
|
"paths",
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
|
"tracing",
|
||||||
"vfs",
|
"vfs",
|
||||||
"walkdir",
|
"walkdir",
|
||||||
]
|
]
|
||||||
|
|
|
@ -10,7 +10,7 @@ doctest = false
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
crossbeam-channel = "0.5.0"
|
crossbeam-channel = "0.5.0"
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
cargo_metadata = "0.14"
|
cargo_metadata = "0.14"
|
||||||
serde = { version = "1.0.106", features = ["derive"] }
|
serde = { version = "1.0.106", features = ["derive"] }
|
||||||
serde_json = "1.0.48"
|
serde_json = "1.0.48"
|
||||||
|
|
|
@ -163,7 +163,7 @@ impl FlycheckActor {
|
||||||
self.cancel_check_process();
|
self.cancel_check_process();
|
||||||
|
|
||||||
let mut command = self.check_command();
|
let mut command = self.check_command();
|
||||||
log::info!("restart flycheck {:?}", command);
|
tracing::info!("restart flycheck {:?}", command);
|
||||||
command.stdout(Stdio::piped()).stderr(Stdio::null()).stdin(Stdio::null());
|
command.stdout(Stdio::piped()).stderr(Stdio::null()).stdin(Stdio::null());
|
||||||
if let Ok(child) = command.spawn().map(JodChild) {
|
if let Ok(child) = command.spawn().map(JodChild) {
|
||||||
self.cargo_handle = Some(CargoHandle::spawn(child));
|
self.cargo_handle = Some(CargoHandle::spawn(child));
|
||||||
|
@ -176,7 +176,7 @@ impl FlycheckActor {
|
||||||
let cargo_handle = self.cargo_handle.take().unwrap();
|
let cargo_handle = self.cargo_handle.take().unwrap();
|
||||||
let res = cargo_handle.join();
|
let res = cargo_handle.join();
|
||||||
if res.is_err() {
|
if res.is_err() {
|
||||||
log::error!(
|
tracing::error!(
|
||||||
"Flycheck failed to run the following command: {:?}",
|
"Flycheck failed to run the following command: {:?}",
|
||||||
self.check_command()
|
self.check_command()
|
||||||
)
|
)
|
||||||
|
@ -319,7 +319,7 @@ impl CargoActor {
|
||||||
let message = match message {
|
let message = match message {
|
||||||
Ok(message) => message,
|
Ok(message) => message,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
log::error!("Invalid json from cargo check, ignoring ({})", err);
|
tracing::error!("Invalid json from cargo check, ignoring ({})", err);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -9,7 +9,6 @@ edition = "2018"
|
||||||
doctest = false
|
doctest = false
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
log = "0.4.8"
|
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
either = "1.5.3"
|
either = "1.5.3"
|
||||||
arrayvec = "0.7"
|
arrayvec = "0.7"
|
||||||
|
|
|
@ -11,7 +11,7 @@ doctest = false
|
||||||
[dependencies]
|
[dependencies]
|
||||||
cov-mark = "2.0.0-pre.1"
|
cov-mark = "2.0.0-pre.1"
|
||||||
dashmap = { version = "4.0.2", features = ["raw-api"] }
|
dashmap = { version = "4.0.2", features = ["raw-api"] }
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
once_cell = "1.3.1"
|
once_cell = "1.3.1"
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
either = "1.5.3"
|
either = "1.5.3"
|
||||||
|
|
|
@ -135,7 +135,7 @@ impl Expander {
|
||||||
None => {
|
None => {
|
||||||
// Only `None` if the macro expansion produced no usable AST.
|
// Only `None` if the macro expansion produced no usable AST.
|
||||||
if err.is_none() {
|
if err.is_none() {
|
||||||
log::warn!("no error despite `parse_or_expand` failing");
|
tracing::warn!("no error despite `parse_or_expand` failing");
|
||||||
}
|
}
|
||||||
|
|
||||||
return Ok(ExpandResult::only_err(err.unwrap_or_else(|| {
|
return Ok(ExpandResult::only_err(err.unwrap_or_else(|| {
|
||||||
|
@ -152,7 +152,7 @@ impl Expander {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
log::debug!("macro expansion {:#?}", node.syntax());
|
tracing::debug!("macro expansion {:#?}", node.syntax());
|
||||||
|
|
||||||
self.recursion_limit += 1;
|
self.recursion_limit += 1;
|
||||||
let mark = Mark {
|
let mark = Mark {
|
||||||
|
|
|
@ -64,7 +64,7 @@ pub(super) fn collect_defs(
|
||||||
if block.is_none() {
|
if block.is_none() {
|
||||||
// populate external prelude
|
// populate external prelude
|
||||||
for dep in &crate_graph[def_map.krate].dependencies {
|
for dep in &crate_graph[def_map.krate].dependencies {
|
||||||
log::debug!("crate dep {:?} -> {:?}", dep.name, dep.crate_id);
|
tracing::debug!("crate dep {:?} -> {:?}", dep.name, dep.crate_id);
|
||||||
let dep_def_map = db.crate_def_map(dep.crate_id);
|
let dep_def_map = db.crate_def_map(dep.crate_id);
|
||||||
def_map
|
def_map
|
||||||
.extern_prelude
|
.extern_prelude
|
||||||
|
@ -358,7 +358,7 @@ impl DefCollector<'_> {
|
||||||
|
|
||||||
i += 1;
|
i += 1;
|
||||||
if FIXED_POINT_LIMIT.check(i).is_err() {
|
if FIXED_POINT_LIMIT.check(i).is_err() {
|
||||||
log::error!("name resolution is stuck");
|
tracing::error!("name resolution is stuck");
|
||||||
break 'outer;
|
break 'outer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -510,7 +510,7 @@ impl DefCollector<'_> {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
log::debug!(
|
tracing::debug!(
|
||||||
"could not resolve prelude path `{}` to module (resolved to {:?})",
|
"could not resolve prelude path `{}` to module (resolved to {:?})",
|
||||||
path,
|
path,
|
||||||
per_ns.types
|
per_ns.types
|
||||||
|
@ -654,7 +654,7 @@ impl DefCollector<'_> {
|
||||||
current_module_id: LocalModuleId,
|
current_module_id: LocalModuleId,
|
||||||
extern_crate: &item_tree::ExternCrate,
|
extern_crate: &item_tree::ExternCrate,
|
||||||
) {
|
) {
|
||||||
log::debug!(
|
tracing::debug!(
|
||||||
"importing macros from extern crate: {:?} ({:?})",
|
"importing macros from extern crate: {:?} ({:?})",
|
||||||
extern_crate,
|
extern_crate,
|
||||||
self.def_map.edition,
|
self.def_map.edition,
|
||||||
|
@ -718,7 +718,7 @@ impl DefCollector<'_> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn resolve_import(&self, module_id: LocalModuleId, import: &Import) -> PartialResolvedImport {
|
fn resolve_import(&self, module_id: LocalModuleId, import: &Import) -> PartialResolvedImport {
|
||||||
log::debug!("resolving import: {:?} ({:?})", import, self.def_map.edition);
|
tracing::debug!("resolving import: {:?} ({:?})", import, self.def_map.edition);
|
||||||
if import.is_extern_crate {
|
if import.is_extern_crate {
|
||||||
let res = self.def_map.resolve_name_in_extern_prelude(
|
let res = self.def_map.resolve_name_in_extern_prelude(
|
||||||
self.db,
|
self.db,
|
||||||
|
@ -794,7 +794,7 @@ impl DefCollector<'_> {
|
||||||
def.macros = None;
|
def.macros = None;
|
||||||
}
|
}
|
||||||
|
|
||||||
log::debug!("resolved import {:?} ({:?}) to {:?}", name, import, def);
|
tracing::debug!("resolved import {:?} ({:?}) to {:?}", name, import, def);
|
||||||
|
|
||||||
// extern crates in the crate root are special-cased to insert entries into the extern prelude: rust-lang/rust#54658
|
// extern crates in the crate root are special-cased to insert entries into the extern prelude: rust-lang/rust#54658
|
||||||
if import.is_extern_crate && module_id == self.def_map.root {
|
if import.is_extern_crate && module_id == self.def_map.root {
|
||||||
|
@ -806,7 +806,7 @@ impl DefCollector<'_> {
|
||||||
self.update(module_id, &[(name, def)], vis, ImportType::Named);
|
self.update(module_id, &[(name, def)], vis, ImportType::Named);
|
||||||
}
|
}
|
||||||
ImportKind::Glob => {
|
ImportKind::Glob => {
|
||||||
log::debug!("glob import: {:?}", import);
|
tracing::debug!("glob import: {:?}", import);
|
||||||
match def.take_types() {
|
match def.take_types() {
|
||||||
Some(ModuleDefId::ModuleId(m)) => {
|
Some(ModuleDefId::ModuleId(m)) => {
|
||||||
if import.is_prelude {
|
if import.is_prelude {
|
||||||
|
@ -895,10 +895,10 @@ impl DefCollector<'_> {
|
||||||
self.update(module_id, &resolutions, vis, ImportType::Glob);
|
self.update(module_id, &resolutions, vis, ImportType::Glob);
|
||||||
}
|
}
|
||||||
Some(d) => {
|
Some(d) => {
|
||||||
log::debug!("glob import {:?} from non-module/enum {:?}", import, d);
|
tracing::debug!("glob import {:?} from non-module/enum {:?}", import, d);
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
log::debug!("glob import {:?} didn't resolve as type", import);
|
tracing::debug!("glob import {:?} didn't resolve as type", import);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -947,7 +947,7 @@ impl DefCollector<'_> {
|
||||||
let tr = match res.take_types() {
|
let tr = match res.take_types() {
|
||||||
Some(ModuleDefId::TraitId(tr)) => tr,
|
Some(ModuleDefId::TraitId(tr)) => tr,
|
||||||
Some(other) => {
|
Some(other) => {
|
||||||
log::debug!("non-trait `_` import of {:?}", other);
|
tracing::debug!("non-trait `_` import of {:?}", other);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
None => continue,
|
None => continue,
|
||||||
|
@ -1167,7 +1167,7 @@ impl DefCollector<'_> {
|
||||||
) {
|
) {
|
||||||
if EXPANSION_DEPTH_LIMIT.check(depth).is_err() {
|
if EXPANSION_DEPTH_LIMIT.check(depth).is_err() {
|
||||||
cov_mark::hit!(macro_expansion_overflow);
|
cov_mark::hit!(macro_expansion_overflow);
|
||||||
log::warn!("macro expansion is too deep");
|
tracing::warn!("macro expansion is too deep");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let file_id = macro_call_id.as_file();
|
let file_id = macro_call_id.as_file();
|
||||||
|
@ -1694,7 +1694,7 @@ impl ModCollector<'_, '_> {
|
||||||
} else if self.is_builtin_or_registered_attr(&attr.path) {
|
} else if self.is_builtin_or_registered_attr(&attr.path) {
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
log::debug!("non-builtin attribute {}", attr.path);
|
tracing::debug!("non-builtin attribute {}", attr.path);
|
||||||
|
|
||||||
let ast_id = AstIdWithPath::new(
|
let ast_id = AstIdWithPath::new(
|
||||||
self.file_id(),
|
self.file_id(),
|
||||||
|
@ -1768,7 +1768,7 @@ impl ModCollector<'_, '_> {
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
// FIXME: diagnose
|
// FIXME: diagnose
|
||||||
log::debug!("malformed derive: {:?}", attr);
|
tracing::debug!("malformed derive: {:?}", attr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,7 +27,7 @@ impl ModDir {
|
||||||
fn child(&self, dir_path: DirPath, root_non_dir_owner: bool) -> Option<ModDir> {
|
fn child(&self, dir_path: DirPath, root_non_dir_owner: bool) -> Option<ModDir> {
|
||||||
let depth = self.depth + 1;
|
let depth = self.depth + 1;
|
||||||
if MOD_DEPTH_LIMIT.check(depth as usize).is_err() {
|
if MOD_DEPTH_LIMIT.check(depth as usize).is_err() {
|
||||||
log::error!("MOD_DEPTH_LIMIT exceeded");
|
tracing::error!("MOD_DEPTH_LIMIT exceeded");
|
||||||
cov_mark::hit!(circular_mods);
|
cov_mark::hit!(circular_mods);
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
|
|
|
@ -116,7 +116,7 @@ impl DefMap {
|
||||||
if self.block_id() != m.block {
|
if self.block_id() != m.block {
|
||||||
cov_mark::hit!(adjust_vis_in_block_def_map);
|
cov_mark::hit!(adjust_vis_in_block_def_map);
|
||||||
vis = Visibility::Module(self.module_id(self.root()));
|
vis = Visibility::Module(self.module_id(self.root()));
|
||||||
log::debug!("visibility {:?} points outside DefMap, adjusting to {:?}", m, vis);
|
tracing::debug!("visibility {:?} points outside DefMap, adjusting to {:?}", m, vis);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -204,7 +204,7 @@ impl DefMap {
|
||||||
Some((idx, segment)) => (idx, segment),
|
Some((idx, segment)) => (idx, segment),
|
||||||
None => return ResolvePathResult::empty(ReachedFixedPoint::Yes),
|
None => return ResolvePathResult::empty(ReachedFixedPoint::Yes),
|
||||||
};
|
};
|
||||||
log::debug!("resolving {:?} in crate root (+ extern prelude)", segment);
|
tracing::debug!("resolving {:?} in crate root (+ extern prelude)", segment);
|
||||||
self.resolve_name_in_crate_root_or_extern_prelude(db, segment)
|
self.resolve_name_in_crate_root_or_extern_prelude(db, segment)
|
||||||
}
|
}
|
||||||
PathKind::Plain => {
|
PathKind::Plain => {
|
||||||
|
@ -221,7 +221,7 @@ impl DefMap {
|
||||||
let prefer_module =
|
let prefer_module =
|
||||||
if path.segments().len() == 1 { shadow } else { BuiltinShadowMode::Module };
|
if path.segments().len() == 1 { shadow } else { BuiltinShadowMode::Module };
|
||||||
|
|
||||||
log::debug!("resolving {:?} in module", segment);
|
tracing::debug!("resolving {:?} in module", segment);
|
||||||
self.resolve_name_in_module(db, original_module, segment, prefer_module)
|
self.resolve_name_in_module(db, original_module, segment, prefer_module)
|
||||||
}
|
}
|
||||||
PathKind::Super(lvl) => {
|
PathKind::Super(lvl) => {
|
||||||
|
@ -236,7 +236,11 @@ impl DefMap {
|
||||||
PathKind::Super(lvl - i),
|
PathKind::Super(lvl - i),
|
||||||
path.segments().to_vec(),
|
path.segments().to_vec(),
|
||||||
);
|
);
|
||||||
log::debug!("`super` path: {} -> {} in parent map", path, new_path);
|
tracing::debug!(
|
||||||
|
"`super` path: {} -> {} in parent map",
|
||||||
|
path,
|
||||||
|
new_path
|
||||||
|
);
|
||||||
return block.parent.def_map(db).resolve_path_fp_with_macro(
|
return block.parent.def_map(db).resolve_path_fp_with_macro(
|
||||||
db,
|
db,
|
||||||
mode,
|
mode,
|
||||||
|
@ -246,7 +250,7 @@ impl DefMap {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
log::debug!("super path in root module");
|
tracing::debug!("super path in root module");
|
||||||
return ResolvePathResult::empty(ReachedFixedPoint::Yes);
|
return ResolvePathResult::empty(ReachedFixedPoint::Yes);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -270,7 +274,7 @@ impl DefMap {
|
||||||
None => return ResolvePathResult::empty(ReachedFixedPoint::Yes),
|
None => return ResolvePathResult::empty(ReachedFixedPoint::Yes),
|
||||||
};
|
};
|
||||||
if let Some(def) = self.extern_prelude.get(segment) {
|
if let Some(def) = self.extern_prelude.get(segment) {
|
||||||
log::debug!("absolute path {:?} resolved to crate {:?}", path, def);
|
tracing::debug!("absolute path {:?} resolved to crate {:?}", path, def);
|
||||||
PerNs::types(*def, Visibility::Public)
|
PerNs::types(*def, Visibility::Public)
|
||||||
} else {
|
} else {
|
||||||
return ResolvePathResult::empty(ReachedFixedPoint::No); // extern crate declarations can add to the extern prelude
|
return ResolvePathResult::empty(ReachedFixedPoint::No); // extern crate declarations can add to the extern prelude
|
||||||
|
@ -299,7 +303,7 @@ impl DefMap {
|
||||||
PathKind::Super(0),
|
PathKind::Super(0),
|
||||||
path.segments()[i..].iter().cloned(),
|
path.segments()[i..].iter().cloned(),
|
||||||
);
|
);
|
||||||
log::debug!("resolving {:?} in other crate", path);
|
tracing::debug!("resolving {:?} in other crate", path);
|
||||||
let defp_map = module.def_map(db);
|
let defp_map = module.def_map(db);
|
||||||
let (def, s) = defp_map.resolve_path(db, module.local_id, &path, shadow);
|
let (def, s) = defp_map.resolve_path(db, module.local_id, &path, shadow);
|
||||||
return ResolvePathResult::with(
|
return ResolvePathResult::with(
|
||||||
|
@ -351,7 +355,7 @@ impl DefMap {
|
||||||
s => {
|
s => {
|
||||||
// could be an inherent method call in UFCS form
|
// could be an inherent method call in UFCS form
|
||||||
// (`Struct::method`), or some other kind of associated item
|
// (`Struct::method`), or some other kind of associated item
|
||||||
log::debug!(
|
tracing::debug!(
|
||||||
"path segment {:?} resolved to non-module {:?}, but is not last",
|
"path segment {:?} resolved to non-module {:?}, but is not last",
|
||||||
segment,
|
segment,
|
||||||
curr,
|
curr,
|
||||||
|
|
|
@ -70,7 +70,7 @@ impl Attrs {
|
||||||
}
|
}
|
||||||
|
|
||||||
_ => {
|
_ => {
|
||||||
log::trace!("malformed `#[proc_macro_derive]`: {}", derive);
|
tracing::trace!("malformed `#[proc_macro_derive]`: {}", derive);
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ doctest = false
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
cov-mark = "2.0.0-pre.1"
|
cov-mark = "2.0.0-pre.1"
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
either = "1.5.3"
|
either = "1.5.3"
|
||||||
rustc-hash = "1.0.0"
|
rustc-hash = "1.0.0"
|
||||||
la-arena = { version = "0.2.0", path = "../../lib/arena" }
|
la-arena = { version = "0.2.0", path = "../../lib/arena" }
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
//! Builtin derives.
|
//! Builtin derives.
|
||||||
|
|
||||||
use log::debug;
|
use tracing::debug;
|
||||||
|
|
||||||
use mbe::ExpandResult;
|
use mbe::ExpandResult;
|
||||||
use parser::FragmentKind;
|
use parser::FragmentKind;
|
||||||
|
|
|
@ -203,7 +203,7 @@ fn parse_macro_expansion(
|
||||||
.collect::<Vec<_>>()
|
.collect::<Vec<_>>()
|
||||||
.join("\n");
|
.join("\n");
|
||||||
|
|
||||||
log::warn!(
|
tracing::warn!(
|
||||||
"fail on macro_parse: (reason: {:?} macro_call: {:#}) parents: {}",
|
"fail on macro_parse: (reason: {:?} macro_call: {:#}) parents: {}",
|
||||||
err,
|
err,
|
||||||
node.value,
|
node.value,
|
||||||
|
@ -217,13 +217,13 @@ fn parse_macro_expansion(
|
||||||
|
|
||||||
let fragment_kind = macro_fragment_kind(db, macro_file.macro_call_id);
|
let fragment_kind = macro_fragment_kind(db, macro_file.macro_call_id);
|
||||||
|
|
||||||
log::debug!("expanded = {}", tt.as_debug_string());
|
tracing::debug!("expanded = {}", tt.as_debug_string());
|
||||||
log::debug!("kind = {:?}", fragment_kind);
|
tracing::debug!("kind = {:?}", fragment_kind);
|
||||||
|
|
||||||
let (parse, rev_token_map) = match mbe::token_tree_to_syntax_node(&tt, fragment_kind) {
|
let (parse, rev_token_map) = match mbe::token_tree_to_syntax_node(&tt, fragment_kind) {
|
||||||
Ok(it) => it,
|
Ok(it) => it,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
log::debug!(
|
tracing::debug!(
|
||||||
"failed to parse expansion to {:?} = {}",
|
"failed to parse expansion to {:?} = {}",
|
||||||
fragment_kind,
|
fragment_kind,
|
||||||
tt.as_debug_string()
|
tt.as_debug_string()
|
||||||
|
@ -250,7 +250,7 @@ fn parse_macro_expansion(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
log::debug!("parse = {:?}", parse.syntax_node().kind());
|
tracing::debug!("parse = {:?}", parse.syntax_node().kind());
|
||||||
ExpandResult { value: Some((parse, Arc::new(rev_token_map))), err: None }
|
ExpandResult { value: Some((parse, Arc::new(rev_token_map))), err: None }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -321,7 +321,7 @@ fn macro_def(db: &dyn AstDatabase, id: MacroDefId) -> Option<Arc<TokenExpander>>
|
||||||
Ok(it) => it,
|
Ok(it) => it,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
let name = macro_rules.name().map(|n| n.to_string()).unwrap_or_default();
|
let name = macro_rules.name().map(|n| n.to_string()).unwrap_or_default();
|
||||||
log::warn!("fail on macro_def parse ({}): {:?} {:#?}", name, err, tt);
|
tracing::warn!("fail on macro_def parse ({}): {:?} {:#?}", name, err, tt);
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -334,7 +334,7 @@ fn macro_def(db: &dyn AstDatabase, id: MacroDefId) -> Option<Arc<TokenExpander>>
|
||||||
Ok(it) => it,
|
Ok(it) => it,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
let name = macro_def.name().map(|n| n.to_string()).unwrap_or_default();
|
let name = macro_def.name().map(|n| n.to_string()).unwrap_or_default();
|
||||||
log::warn!("fail on macro_def parse ({}): {:?} {:#?}", name, err, tt);
|
tracing::warn!("fail on macro_def parse ({}): {:?} {:#?}", name, err, tt);
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -561,7 +561,7 @@ impl<'a> InFile<&'a SyntaxNode> {
|
||||||
Some(range) => {
|
Some(range) => {
|
||||||
let original_file = range.file_id.original_file(db);
|
let original_file = range.file_id.original_file(db);
|
||||||
if range.file_id != original_file.into() {
|
if range.file_id != original_file.into() {
|
||||||
log::error!("Failed mapping up more for {:?}", range);
|
tracing::error!("Failed mapping up more for {:?}", range);
|
||||||
}
|
}
|
||||||
Some(FileRange { file_id: original_file, range: range.value })
|
Some(FileRange { file_id: original_file, range: range.value })
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ itertools = "0.10.0"
|
||||||
arrayvec = "0.7"
|
arrayvec = "0.7"
|
||||||
smallvec = "1.2.0"
|
smallvec = "1.2.0"
|
||||||
ena = "0.14.0"
|
ena = "0.14.0"
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
scoped-tls = "1"
|
scoped-tls = "1"
|
||||||
chalk-solve = { version = "0.70", default-features = false }
|
chalk-solve = { version = "0.70", default-features = false }
|
||||||
|
|
|
@ -10,7 +10,7 @@ use chalk_ir::{cast::Cast, fold::Fold, interner::HasInterner, VariableKind};
|
||||||
use hir_def::lang_item::LangItemTarget;
|
use hir_def::lang_item::LangItemTarget;
|
||||||
use hir_expand::name::name;
|
use hir_expand::name::name;
|
||||||
use limit::Limit;
|
use limit::Limit;
|
||||||
use log::{info, warn};
|
use tracing::{info, warn};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
db::HirDatabase, static_lifetime, AliasEq, AliasTy, BoundVar, Canonical, CanonicalVarKinds,
|
db::HirDatabase, static_lifetime, AliasEq, AliasTy, BoundVar, Canonical, CanonicalVarKinds,
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
use cov_mark::hit;
|
use cov_mark::hit;
|
||||||
use log::debug;
|
use tracing::debug;
|
||||||
|
|
||||||
use chalk_ir::{cast::Cast, fold::shift::Shift, CanonicalVarKinds};
|
use chalk_ir::{cast::Cast, fold::shift::Shift, CanonicalVarKinds};
|
||||||
use chalk_solve::rust_ir::{self, OpaqueTyDatumBound, WellKnownTrait};
|
use chalk_solve::rust_ir::{self, OpaqueTyDatumBound, WellKnownTrait};
|
||||||
|
|
|
@ -28,7 +28,10 @@ impl ConstExt for Const {
|
||||||
chalk_ir::ConstValue::Concrete(..) => false,
|
chalk_ir::ConstValue::Concrete(..) => false,
|
||||||
|
|
||||||
_ => {
|
_ => {
|
||||||
log::error!("is_unknown was called on a non-concrete constant value! {:?}", self);
|
tracing::error!(
|
||||||
|
"is_unknown was called on a non-concrete constant value! {:?}",
|
||||||
|
self
|
||||||
|
);
|
||||||
true
|
true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,7 +81,7 @@ pub(crate) fn trait_solve_query(
|
||||||
GoalData::DomainGoal(DomainGoal::Holds(WhereClause::AliasEq(_))) => "alias_eq".to_string(),
|
GoalData::DomainGoal(DomainGoal::Holds(WhereClause::AliasEq(_))) => "alias_eq".to_string(),
|
||||||
_ => "??".to_string(),
|
_ => "??".to_string(),
|
||||||
});
|
});
|
||||||
log::info!("trait_solve_query({:?})", goal.value.goal);
|
tracing::info!("trait_solve_query({:?})", goal.value.goal);
|
||||||
|
|
||||||
if let GoalData::DomainGoal(DomainGoal::Holds(WhereClause::AliasEq(AliasEq {
|
if let GoalData::DomainGoal(DomainGoal::Holds(WhereClause::AliasEq(AliasEq {
|
||||||
alias: AliasTy::Projection(projection_ty),
|
alias: AliasTy::Projection(projection_ty),
|
||||||
|
@ -106,7 +106,7 @@ fn solve(
|
||||||
goal: &chalk_ir::UCanonical<chalk_ir::InEnvironment<chalk_ir::Goal<Interner>>>,
|
goal: &chalk_ir::UCanonical<chalk_ir::InEnvironment<chalk_ir::Goal<Interner>>>,
|
||||||
) -> Option<chalk_solve::Solution<Interner>> {
|
) -> Option<chalk_solve::Solution<Interner>> {
|
||||||
let context = ChalkContext { db, krate };
|
let context = ChalkContext { db, krate };
|
||||||
log::debug!("solve goal: {:?}", goal);
|
tracing::debug!("solve goal: {:?}", goal);
|
||||||
let mut solver = create_chalk_solver();
|
let mut solver = create_chalk_solver();
|
||||||
|
|
||||||
let fuel = std::cell::Cell::new(CHALK_SOLVER_FUEL);
|
let fuel = std::cell::Cell::new(CHALK_SOLVER_FUEL);
|
||||||
|
@ -116,7 +116,7 @@ fn solve(
|
||||||
let remaining = fuel.get();
|
let remaining = fuel.get();
|
||||||
fuel.set(remaining - 1);
|
fuel.set(remaining - 1);
|
||||||
if remaining == 0 {
|
if remaining == 0 {
|
||||||
log::debug!("fuel exhausted");
|
tracing::debug!("fuel exhausted");
|
||||||
}
|
}
|
||||||
remaining > 0
|
remaining > 0
|
||||||
};
|
};
|
||||||
|
@ -136,7 +136,7 @@ fn solve(
|
||||||
solver.solve_limited(&context, goal, &should_continue)
|
solver.solve_limited(&context, goal, &should_continue)
|
||||||
};
|
};
|
||||||
|
|
||||||
log::debug!("solve({:?}) => {:?}", goal, solution);
|
tracing::debug!("solve({:?}) => {:?}", goal, solution);
|
||||||
|
|
||||||
solution
|
solution
|
||||||
};
|
};
|
||||||
|
|
|
@ -13,7 +13,7 @@ cov-mark = "2.0.0-pre.1"
|
||||||
either = "1.5.3"
|
either = "1.5.3"
|
||||||
indexmap = "1.4.0"
|
indexmap = "1.4.0"
|
||||||
itertools = "0.10.0"
|
itertools = "0.10.0"
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
oorandom = "11.1.2"
|
oorandom = "11.1.2"
|
||||||
pulldown-cmark-to-cmark = "6.0.0"
|
pulldown-cmark-to-cmark = "6.0.0"
|
||||||
|
|
|
@ -353,7 +353,7 @@ impl TryToNav for hir::MacroDef {
|
||||||
Either::Left(it) => it,
|
Either::Left(it) => it,
|
||||||
Either::Right(it) => it,
|
Either::Right(it) => it,
|
||||||
};
|
};
|
||||||
log::debug!("nav target {:#?}", name_owner.syntax());
|
tracing::debug!("nav target {:#?}", name_owner.syntax());
|
||||||
let mut res = NavigationTarget::from_named(
|
let mut res = NavigationTarget::from_named(
|
||||||
db,
|
db,
|
||||||
src.as_ref().with_value(name_owner),
|
src.as_ref().with_value(name_owner),
|
||||||
|
|
|
@ -11,7 +11,7 @@ doctest = false
|
||||||
[dependencies]
|
[dependencies]
|
||||||
cov-mark = "2.0.0-pre.1"
|
cov-mark = "2.0.0-pre.1"
|
||||||
itertools = "0.10.0"
|
itertools = "0.10.0"
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
either = "1.6.1"
|
either = "1.6.1"
|
||||||
once_cell = "1.7"
|
once_cell = "1.7"
|
||||||
|
|
|
@ -10,7 +10,7 @@ doctest = false
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
cov-mark = "2.0.0-pre.1"
|
cov-mark = "2.0.0-pre.1"
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
rayon = "1.5.0"
|
rayon = "1.5.0"
|
||||||
fst = { version = "0.4", default-features = false }
|
fst = { version = "0.4", default-features = false }
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
|
|
|
@ -20,7 +20,7 @@ impl RootDatabase {
|
||||||
pub fn apply_change(&mut self, change: Change) {
|
pub fn apply_change(&mut self, change: Change) {
|
||||||
let _p = profile::span("RootDatabase::apply_change");
|
let _p = profile::span("RootDatabase::apply_change");
|
||||||
self.request_cancellation();
|
self.request_cancellation();
|
||||||
log::info!("apply_change {:?}", change);
|
tracing::info!("apply_change {:?}", change);
|
||||||
if let Some(roots) = &change.roots {
|
if let Some(roots) = &change.roots {
|
||||||
let mut local_roots = FxHashSet::default();
|
let mut local_roots = FxHashSet::default();
|
||||||
let mut library_roots = FxHashSet::default();
|
let mut library_roots = FxHashSet::default();
|
||||||
|
|
|
@ -12,8 +12,8 @@ doctest = false
|
||||||
cov-mark = "2.0.0-pre.1"
|
cov-mark = "2.0.0-pre.1"
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
smallvec = "1.2.0"
|
smallvec = "1.2.0"
|
||||||
log = "0.4.8"
|
|
||||||
expect-test = "1.1"
|
expect-test = "1.1"
|
||||||
|
tracing = "0.1"
|
||||||
|
|
||||||
syntax = { path = "../syntax", version = "0.0.0" }
|
syntax = { path = "../syntax", version = "0.0.0" }
|
||||||
parser = { path = "../parser", version = "0.0.0" }
|
parser = { path = "../parser", version = "0.0.0" }
|
||||||
|
|
|
@ -174,7 +174,11 @@ fn expand_repeat(
|
||||||
|
|
||||||
counter += 1;
|
counter += 1;
|
||||||
if counter == limit {
|
if counter == limit {
|
||||||
log::warn!("expand_tt in repeat pattern exceed limit => {:#?}\n{:#?}", template, ctx);
|
tracing::warn!(
|
||||||
|
"expand_tt in repeat pattern exceed limit => {:#?}\n{:#?}",
|
||||||
|
template,
|
||||||
|
ctx
|
||||||
|
);
|
||||||
return ExpandResult {
|
return ExpandResult {
|
||||||
value: Fragment::Tokens(Subtree::default().into()),
|
value: Fragment::Tokens(Subtree::default().into()),
|
||||||
err: Some(ExpandError::Other("Expand exceed limit".to_string())),
|
err: Some(ExpandError::Other("Expand exceed limit".to_string())),
|
||||||
|
|
|
@ -11,7 +11,7 @@ doctest = false
|
||||||
[dependencies]
|
[dependencies]
|
||||||
serde = { version = "1.0", features = ["derive"] }
|
serde = { version = "1.0", features = ["derive"] }
|
||||||
serde_json = { version = "1.0", features = ["unbounded_depth"] }
|
serde_json = { version = "1.0", features = ["unbounded_depth"] }
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
crossbeam-channel = "0.5.0"
|
crossbeam-channel = "0.5.0"
|
||||||
jod-thread = "0.1.1"
|
jod-thread = "0.1.1"
|
||||||
memmap2 = "0.3.0"
|
memmap2 = "0.3.0"
|
||||||
|
|
|
@ -93,7 +93,7 @@ fn read_json<'a>(
|
||||||
// Some ill behaved macro try to use stdout for debugging
|
// Some ill behaved macro try to use stdout for debugging
|
||||||
// We ignore it here
|
// We ignore it here
|
||||||
if !buf.starts_with('{') {
|
if !buf.starts_with('{') {
|
||||||
log::error!("proc-macro tried to print : {}", buf);
|
tracing::error!("proc-macro tried to print : {}", buf);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,7 +102,7 @@ fn read_json<'a>(
|
||||||
}
|
}
|
||||||
|
|
||||||
fn write_json(out: &mut impl Write, msg: &str) -> io::Result<()> {
|
fn write_json(out: &mut impl Write, msg: &str) -> io::Result<()> {
|
||||||
log::debug!("> {}", msg);
|
tracing::debug!("> {}", msg);
|
||||||
out.write_all(msg.as_bytes())?;
|
out.write_all(msg.as_bytes())?;
|
||||||
out.write_all(b"\n")?;
|
out.write_all(b"\n")?;
|
||||||
out.flush()?;
|
out.flush()?;
|
||||||
|
|
|
@ -54,7 +54,7 @@ impl ProcMacroProcessSrv {
|
||||||
Ok(res) => res,
|
Ok(res) => res,
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
let result = self.process.child.try_wait();
|
let result = self.process.child.try_wait();
|
||||||
log::error!(
|
tracing::error!(
|
||||||
"proc macro server crashed, server process state: {:?}, server request error: {:?}",
|
"proc macro server crashed, server process state: {:?}, server request error: {:?}",
|
||||||
result,
|
result,
|
||||||
err
|
err
|
||||||
|
|
|
@ -9,7 +9,7 @@ edition = "2018"
|
||||||
doctest = false
|
doctest = false
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
rustc-hash = "1.1.0"
|
rustc-hash = "1.1.0"
|
||||||
cargo_metadata = "0.14"
|
cargo_metadata = "0.14"
|
||||||
semver = "1"
|
semver = "1"
|
||||||
|
|
|
@ -283,7 +283,7 @@ impl CargoWorkspace {
|
||||||
let meta = from_value::<PackageMetadata>(metadata.clone()).unwrap_or_default();
|
let meta = from_value::<PackageMetadata>(metadata.clone()).unwrap_or_default();
|
||||||
let is_member = ws_members.contains(id);
|
let is_member = ws_members.contains(id);
|
||||||
let edition = edition.parse::<Edition>().unwrap_or_else(|err| {
|
let edition = edition.parse::<Edition>().unwrap_or_else(|err| {
|
||||||
log::error!("Failed to parse edition {}", err);
|
tracing::error!("Failed to parse edition {}", err);
|
||||||
Edition::CURRENT
|
Edition::CURRENT
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -322,7 +322,7 @@ impl CargoWorkspace {
|
||||||
// https://github.com/rust-lang/cargo/issues/7841
|
// https://github.com/rust-lang/cargo/issues/7841
|
||||||
// is fixed and hits stable (around 1.43-is probably?).
|
// is fixed and hits stable (around 1.43-is probably?).
|
||||||
None => {
|
None => {
|
||||||
log::error!("Node id do not match in cargo metadata, ignoring {}", node.id);
|
tracing::error!("Node id do not match in cargo metadata, ignoring {}", node.id);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -335,7 +335,7 @@ impl CargoWorkspace {
|
||||||
let pkg = match pkg_by_id.get(&dep_node.pkg) {
|
let pkg = match pkg_by_id.get(&dep_node.pkg) {
|
||||||
Some(&pkg) => pkg,
|
Some(&pkg) => pkg,
|
||||||
None => {
|
None => {
|
||||||
log::error!(
|
tracing::error!(
|
||||||
"Dep node id do not match in cargo metadata, ignoring {}",
|
"Dep node id do not match in cargo metadata, ignoring {}",
|
||||||
dep_node.pkg
|
dep_node.pkg
|
||||||
);
|
);
|
||||||
|
@ -385,7 +385,7 @@ impl CargoWorkspace {
|
||||||
fn rustc_discover_host_triple(cargo_toml: &ManifestPath) -> Option<String> {
|
fn rustc_discover_host_triple(cargo_toml: &ManifestPath) -> Option<String> {
|
||||||
let mut rustc = Command::new(toolchain::rustc());
|
let mut rustc = Command::new(toolchain::rustc());
|
||||||
rustc.current_dir(cargo_toml.parent()).arg("-vV");
|
rustc.current_dir(cargo_toml.parent()).arg("-vV");
|
||||||
log::debug!("Discovering host platform by {:?}", rustc);
|
tracing::debug!("Discovering host platform by {:?}", rustc);
|
||||||
match utf8_stdout(rustc) {
|
match utf8_stdout(rustc) {
|
||||||
Ok(stdout) => {
|
Ok(stdout) => {
|
||||||
let field = "host: ";
|
let field = "host: ";
|
||||||
|
@ -394,12 +394,12 @@ fn rustc_discover_host_triple(cargo_toml: &ManifestPath) -> Option<String> {
|
||||||
Some(target.to_string())
|
Some(target.to_string())
|
||||||
} else {
|
} else {
|
||||||
// If we fail to resolve the host platform, it's not the end of the world.
|
// If we fail to resolve the host platform, it's not the end of the world.
|
||||||
log::info!("rustc -vV did not report host platform, got:\n{}", stdout);
|
tracing::info!("rustc -vV did not report host platform, got:\n{}", stdout);
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
log::warn!("Failed to discover host platform: {}", e);
|
tracing::warn!("Failed to discover host platform: {}", e);
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -412,7 +412,7 @@ fn cargo_config_build_target(cargo_toml: &ManifestPath) -> Option<String> {
|
||||||
.args(&["-Z", "unstable-options", "config", "get", "build.target"])
|
.args(&["-Z", "unstable-options", "config", "get", "build.target"])
|
||||||
.env("RUSTC_BOOTSTRAP", "1");
|
.env("RUSTC_BOOTSTRAP", "1");
|
||||||
// if successful we receive `build.target = "target-triple"`
|
// if successful we receive `build.target = "target-triple"`
|
||||||
log::debug!("Discovering cargo config target by {:?}", cargo_config);
|
tracing::debug!("Discovering cargo config target by {:?}", cargo_config);
|
||||||
match utf8_stdout(cargo_config) {
|
match utf8_stdout(cargo_config) {
|
||||||
Ok(stdout) => stdout
|
Ok(stdout) => stdout
|
||||||
.strip_prefix("build.target = \"")
|
.strip_prefix("build.target = \"")
|
||||||
|
|
|
@ -20,7 +20,7 @@ pub(crate) fn get(cargo_toml: Option<&ManifestPath>, target: Option<&str>) -> Ve
|
||||||
|
|
||||||
match get_rust_cfgs(cargo_toml, target) {
|
match get_rust_cfgs(cargo_toml, target) {
|
||||||
Ok(rustc_cfgs) => res.extend(rustc_cfgs.lines().map(|it| it.parse().unwrap())),
|
Ok(rustc_cfgs) => res.extend(rustc_cfgs.lines().map(|it| it.parse().unwrap())),
|
||||||
Err(e) => log::error!("failed to get rustc cfgs: {:#}", e),
|
Err(e) => tracing::error!("failed to get rustc cfgs: {:#}", e),
|
||||||
}
|
}
|
||||||
|
|
||||||
res
|
res
|
||||||
|
|
|
@ -54,7 +54,7 @@ impl Sysroot {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn discover(dir: &AbsPath) -> Result<Sysroot> {
|
pub fn discover(dir: &AbsPath) -> Result<Sysroot> {
|
||||||
log::debug!("Discovering sysroot for {}", dir.display());
|
tracing::debug!("Discovering sysroot for {}", dir.display());
|
||||||
let sysroot_dir = discover_sysroot_dir(dir)?;
|
let sysroot_dir = discover_sysroot_dir(dir)?;
|
||||||
let sysroot_src_dir = discover_sysroot_src_dir(&sysroot_dir, dir)?;
|
let sysroot_src_dir = discover_sysroot_src_dir(&sysroot_dir, dir)?;
|
||||||
let res = Sysroot::load(sysroot_src_dir)?;
|
let res = Sysroot::load(sysroot_src_dir)?;
|
||||||
|
@ -62,7 +62,7 @@ impl Sysroot {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn discover_rustc(cargo_toml: &ManifestPath) -> Option<ManifestPath> {
|
pub fn discover_rustc(cargo_toml: &ManifestPath) -> Option<ManifestPath> {
|
||||||
log::debug!("Discovering rustc source for {}", cargo_toml.display());
|
tracing::debug!("Discovering rustc source for {}", cargo_toml.display());
|
||||||
let current_dir = cargo_toml.parent();
|
let current_dir = cargo_toml.parent();
|
||||||
discover_sysroot_dir(current_dir).ok().and_then(|sysroot_dir| get_rustc_src(&sysroot_dir))
|
discover_sysroot_dir(current_dir).ok().and_then(|sysroot_dir| get_rustc_src(&sysroot_dir))
|
||||||
}
|
}
|
||||||
|
@ -132,7 +132,7 @@ impl Sysroot {
|
||||||
fn discover_sysroot_dir(current_dir: &AbsPath) -> Result<AbsPathBuf> {
|
fn discover_sysroot_dir(current_dir: &AbsPath) -> Result<AbsPathBuf> {
|
||||||
let mut rustc = Command::new(toolchain::rustc());
|
let mut rustc = Command::new(toolchain::rustc());
|
||||||
rustc.current_dir(current_dir).args(&["--print", "sysroot"]);
|
rustc.current_dir(current_dir).args(&["--print", "sysroot"]);
|
||||||
log::debug!("Discovering sysroot by {:?}", rustc);
|
tracing::debug!("Discovering sysroot by {:?}", rustc);
|
||||||
let stdout = utf8_stdout(rustc)?;
|
let stdout = utf8_stdout(rustc)?;
|
||||||
Ok(AbsPathBuf::assert(PathBuf::from(stdout)))
|
Ok(AbsPathBuf::assert(PathBuf::from(stdout)))
|
||||||
}
|
}
|
||||||
|
@ -146,10 +146,10 @@ fn discover_sysroot_src_dir(
|
||||||
.map_err(|path| format_err!("RUST_SRC_PATH must be absolute: {}", path.display()))?;
|
.map_err(|path| format_err!("RUST_SRC_PATH must be absolute: {}", path.display()))?;
|
||||||
let core = path.join("core");
|
let core = path.join("core");
|
||||||
if fs::metadata(&core).is_ok() {
|
if fs::metadata(&core).is_ok() {
|
||||||
log::debug!("Discovered sysroot by RUST_SRC_PATH: {}", path.display());
|
tracing::debug!("Discovered sysroot by RUST_SRC_PATH: {}", path.display());
|
||||||
return Ok(path);
|
return Ok(path);
|
||||||
}
|
}
|
||||||
log::debug!("RUST_SRC_PATH is set, but is invalid (no core: {:?}), ignoring", core);
|
tracing::debug!("RUST_SRC_PATH is set, but is invalid (no core: {:?}), ignoring", core);
|
||||||
}
|
}
|
||||||
|
|
||||||
get_rust_src(sysroot_path)
|
get_rust_src(sysroot_path)
|
||||||
|
@ -174,7 +174,7 @@ try installing the Rust source the same way you installed rustc",
|
||||||
fn get_rustc_src(sysroot_path: &AbsPath) -> Option<ManifestPath> {
|
fn get_rustc_src(sysroot_path: &AbsPath) -> Option<ManifestPath> {
|
||||||
let rustc_src = sysroot_path.join("lib/rustlib/rustc-src/rust/compiler/rustc/Cargo.toml");
|
let rustc_src = sysroot_path.join("lib/rustlib/rustc-src/rust/compiler/rustc/Cargo.toml");
|
||||||
let rustc_src = ManifestPath::try_from(rustc_src).ok()?;
|
let rustc_src = ManifestPath::try_from(rustc_src).ok()?;
|
||||||
log::debug!("Checking for rustc source code: {}", rustc_src.display());
|
tracing::debug!("Checking for rustc source code: {}", rustc_src.display());
|
||||||
if fs::metadata(&rustc_src).is_ok() {
|
if fs::metadata(&rustc_src).is_ok() {
|
||||||
Some(rustc_src)
|
Some(rustc_src)
|
||||||
} else {
|
} else {
|
||||||
|
@ -185,7 +185,10 @@ fn get_rustc_src(sysroot_path: &AbsPath) -> Option<ManifestPath> {
|
||||||
fn get_rust_src(sysroot_path: &AbsPath) -> Option<AbsPathBuf> {
|
fn get_rust_src(sysroot_path: &AbsPath) -> Option<AbsPathBuf> {
|
||||||
// Try the new path first since the old one still exists.
|
// Try the new path first since the old one still exists.
|
||||||
let rust_src = sysroot_path.join("lib/rustlib/src/rust");
|
let rust_src = sysroot_path.join("lib/rustlib/src/rust");
|
||||||
log::debug!("Checking sysroot (looking for `library` and `src` dirs): {}", rust_src.display());
|
tracing::debug!(
|
||||||
|
"Checking sysroot (looking for `library` and `src` dirs): {}",
|
||||||
|
rust_src.display()
|
||||||
|
);
|
||||||
["library", "src"].iter().map(|it| rust_src.join(it)).find(|it| fs::metadata(it).is_ok())
|
["library", "src"].iter().map(|it| rust_src.join(it)).find(|it| fs::metadata(it).is_ok())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -384,9 +384,9 @@ impl ProjectWorkspace {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
if crate_graph.patch_cfg_if() {
|
if crate_graph.patch_cfg_if() {
|
||||||
log::debug!("Patched std to depend on cfg-if")
|
tracing::debug!("Patched std to depend on cfg-if")
|
||||||
} else {
|
} else {
|
||||||
log::debug!("Did not patch std to depend on cfg-if")
|
tracing::debug!("Did not patch std to depend on cfg-if")
|
||||||
}
|
}
|
||||||
crate_graph
|
crate_graph
|
||||||
}
|
}
|
||||||
|
@ -623,7 +623,7 @@ fn detached_files_to_crate_graph(
|
||||||
let file_id = match load(detached_file) {
|
let file_id = match load(detached_file) {
|
||||||
Some(file_id) => file_id,
|
Some(file_id) => file_id,
|
||||||
None => {
|
None => {
|
||||||
log::error!("Failed to load detached file {:?}", detached_file);
|
tracing::error!("Failed to load detached file {:?}", detached_file);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -847,7 +847,7 @@ fn sysroot_to_crate_graph(
|
||||||
|
|
||||||
fn add_dep(graph: &mut CrateGraph, from: CrateId, name: CrateName, to: CrateId) {
|
fn add_dep(graph: &mut CrateGraph, from: CrateId, name: CrateName, to: CrateId) {
|
||||||
if let Err(err) = graph.add_dep(from, name, to) {
|
if let Err(err) = graph.add_dep(from, name, to) {
|
||||||
log::error!("{}", err)
|
tracing::error!("{}", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,10 +20,8 @@ path = "src/bin/main.rs"
|
||||||
anyhow = "1.0.26"
|
anyhow = "1.0.26"
|
||||||
crossbeam-channel = "0.5.0"
|
crossbeam-channel = "0.5.0"
|
||||||
dissimilar = "1.0.2"
|
dissimilar = "1.0.2"
|
||||||
env_logger = { version = "0.9", default-features = false }
|
|
||||||
itertools = "0.10.0"
|
itertools = "0.10.0"
|
||||||
jod-thread = "0.1.0"
|
jod-thread = "0.1.0"
|
||||||
log = "0.4.8"
|
|
||||||
lsp-types = { version = "0.89.0", features = ["proposed"] }
|
lsp-types = { version = "0.89.0", features = ["proposed"] }
|
||||||
parking_lot = "0.11.0"
|
parking_lot = "0.11.0"
|
||||||
xflags = "0.2.1"
|
xflags = "0.2.1"
|
||||||
|
@ -36,7 +34,8 @@ rayon = "1.5"
|
||||||
mimalloc = { version = "0.1.19", default-features = false, optional = true }
|
mimalloc = { version = "0.1.19", default-features = false, optional = true }
|
||||||
lsp-server = "0.5.1"
|
lsp-server = "0.5.1"
|
||||||
tracing = "0.1"
|
tracing = "0.1"
|
||||||
tracing-subscriber = { version = "0.2", default-features = false, features = ["env-filter", "registry"] }
|
tracing-subscriber = { version = "0.2", default-features = false, features = ["env-filter", "registry", "fmt", "tracing-log"] }
|
||||||
|
tracing-log = "0.1.2"
|
||||||
tracing-tree = { version = "0.1.4" }
|
tracing-tree = { version = "0.1.4" }
|
||||||
always-assert = "0.1"
|
always-assert = "0.1"
|
||||||
|
|
||||||
|
|
|
@ -1,88 +1,142 @@
|
||||||
//! Simple logger that logs either to stderr or to a file, using `env_logger`
|
//! Simple logger that logs either to stderr or to a file, using `tracing_subscriber`
|
||||||
//! filter syntax. Amusingly, there's no crates.io crate that can do this and
|
//! filter syntax and `tracing_appender` for non blocking output.
|
||||||
//! only this.
|
|
||||||
|
|
||||||
use std::{
|
use std::{
|
||||||
|
fmt::{self, Write},
|
||||||
fs::File,
|
fs::File,
|
||||||
io::{self, BufWriter, Write},
|
io,
|
||||||
|
sync::Arc,
|
||||||
};
|
};
|
||||||
|
|
||||||
use env_logger::filter::{Builder, Filter};
|
use rust_analyzer::Result;
|
||||||
use log::{Log, Metadata, Record};
|
use tracing::{level_filters::LevelFilter, Event, Subscriber};
|
||||||
use parking_lot::Mutex;
|
use tracing_log::NormalizeEvent;
|
||||||
|
use tracing_subscriber::{
|
||||||
|
fmt::{writer::BoxMakeWriter, FmtContext, FormatEvent, FormatFields, FormattedFields},
|
||||||
|
layer::SubscriberExt,
|
||||||
|
registry::LookupSpan,
|
||||||
|
util::SubscriberInitExt,
|
||||||
|
EnvFilter, Registry,
|
||||||
|
};
|
||||||
|
use tracing_tree::HierarchicalLayer;
|
||||||
|
|
||||||
pub(crate) struct Logger {
|
pub(crate) struct Logger {
|
||||||
filter: Filter,
|
filter: EnvFilter,
|
||||||
file: Option<Mutex<BufWriter<File>>>,
|
file: Option<File>,
|
||||||
no_buffering: bool,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Logger {
|
impl Logger {
|
||||||
pub(crate) fn new(log_file: Option<File>, no_buffering: bool, filter: Option<&str>) -> Logger {
|
pub(crate) fn new(file: Option<File>, filter: Option<&str>) -> Logger {
|
||||||
let filter = {
|
let filter = filter.map_or(EnvFilter::default(), |dirs| EnvFilter::new(dirs));
|
||||||
let mut builder = Builder::new();
|
|
||||||
if let Some(filter) = filter {
|
|
||||||
builder.parse(filter);
|
|
||||||
}
|
|
||||||
builder.build()
|
|
||||||
};
|
|
||||||
|
|
||||||
let file = log_file.map(|it| Mutex::new(BufWriter::new(it)));
|
Logger { filter, file }
|
||||||
|
|
||||||
Logger { filter, file, no_buffering }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn install(self) {
|
pub(crate) fn install(self) -> Result<()> {
|
||||||
let max_level = self.filter.filter();
|
// The meaning of CHALK_DEBUG I suspected is to tell chalk crates
|
||||||
let _ = log::set_boxed_logger(Box::new(self)).map(|()| log::set_max_level(max_level));
|
// (i.e. chalk-solve, chalk-ir, chalk-recursive) how to filter tracing
|
||||||
|
// logs. But now we can only have just one filter, which means we have to
|
||||||
|
// merge chalk filter to our main filter (from RA_LOG env).
|
||||||
|
//
|
||||||
|
// The acceptable syntax of CHALK_DEBUG is `target[span{field=value}]=level`.
|
||||||
|
// As the value should only affect chalk crates, we'd better mannually
|
||||||
|
// specify the target. And for simplicity, CHALK_DEBUG only accept the value
|
||||||
|
// that specify level.
|
||||||
|
let chalk_level_dir = std::env::var("CHALK_DEBUG")
|
||||||
|
.map(|val| {
|
||||||
|
val.parse::<LevelFilter>().expect(
|
||||||
|
"invalid CHALK_DEBUG value, expect right log level (like debug or trace)",
|
||||||
|
)
|
||||||
|
})
|
||||||
|
.ok();
|
||||||
|
|
||||||
|
let chalk_layer = HierarchicalLayer::default()
|
||||||
|
.with_indent_lines(true)
|
||||||
|
.with_ansi(false)
|
||||||
|
.with_indent_amount(2)
|
||||||
|
.with_writer(std::io::stderr);
|
||||||
|
|
||||||
|
let writer = match self.file {
|
||||||
|
Some(file) => BoxMakeWriter::new(Arc::new(file)),
|
||||||
|
None => BoxMakeWriter::new(io::stderr),
|
||||||
|
};
|
||||||
|
let ra_fmt_layer =
|
||||||
|
tracing_subscriber::fmt::layer().event_format(LoggerFormatter).with_writer(writer);
|
||||||
|
|
||||||
|
match chalk_level_dir {
|
||||||
|
Some(val) => {
|
||||||
|
Registry::default()
|
||||||
|
.with(
|
||||||
|
self.filter
|
||||||
|
.add_directive(format!("chalk_solve={}", val).parse()?)
|
||||||
|
.add_directive(format!("chalk_ir={}", val).parse()?)
|
||||||
|
.add_directive(format!("chalk_recursive={}", val).parse()?),
|
||||||
|
)
|
||||||
|
.with(ra_fmt_layer)
|
||||||
|
.with(chalk_layer)
|
||||||
|
.init();
|
||||||
|
}
|
||||||
|
None => {
|
||||||
|
Registry::default().with(self.filter).with(ra_fmt_layer).init();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Log for Logger {
|
#[derive(Debug)]
|
||||||
fn enabled(&self, metadata: &Metadata) -> bool {
|
struct LoggerFormatter;
|
||||||
self.filter.enabled(metadata)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn log(&self, record: &Record) {
|
impl<S, N> FormatEvent<S, N> for LoggerFormatter
|
||||||
if !self.filter.matches(record) {
|
where
|
||||||
return;
|
S: Subscriber + for<'a> LookupSpan<'a>,
|
||||||
}
|
N: for<'a> FormatFields<'a> + 'static,
|
||||||
|
{
|
||||||
|
fn format_event(
|
||||||
|
&self,
|
||||||
|
ctx: &FmtContext<'_, S, N>,
|
||||||
|
writer: &mut dyn Write,
|
||||||
|
event: &Event<'_>,
|
||||||
|
) -> fmt::Result {
|
||||||
|
// Write level and target
|
||||||
|
let level = *event.metadata().level();
|
||||||
|
|
||||||
match &self.file {
|
// If this event is issued from `log` crate, then the value of target is
|
||||||
Some(w) => {
|
// always "log". `tracing-log` has hard coded it for some reason, so we
|
||||||
let mut writer = w.lock();
|
// need to extract it using `normalized_metadata` method which is part of
|
||||||
let _ = writeln!(
|
// `tracing_log::NormalizeEvent`.
|
||||||
writer,
|
let target = match event.normalized_metadata() {
|
||||||
"[{} {}] {}",
|
// This event is issued from `log` crate
|
||||||
record.level(),
|
Some(log) => log.target(),
|
||||||
record.module_path().unwrap_or_default(),
|
None => event.metadata().target(),
|
||||||
record.args(),
|
|
||||||
);
|
|
||||||
|
|
||||||
if self.no_buffering {
|
|
||||||
let _ = writer.flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
None => {
|
|
||||||
let message = format!(
|
|
||||||
"[{} {}] {}\n",
|
|
||||||
record.level(),
|
|
||||||
record.module_path().unwrap_or_default(),
|
|
||||||
record.args(),
|
|
||||||
);
|
|
||||||
eprint!("{}", message);
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
}
|
write!(writer, "[{} {}] ", level, target)?;
|
||||||
|
|
||||||
fn flush(&self) {
|
// Write spans and fields of each span
|
||||||
match &self.file {
|
ctx.visit_spans(|span| {
|
||||||
Some(w) => {
|
write!(writer, "{}", span.name())?;
|
||||||
let _ = w.lock().flush();
|
|
||||||
|
let ext = span.extensions();
|
||||||
|
|
||||||
|
// `FormattedFields` is a a formatted representation of the span's
|
||||||
|
// fields, which is stored in its extensions by the `fmt` layer's
|
||||||
|
// `new_span` method. The fields will have been formatted
|
||||||
|
// by the same field formatter that's provided to the event
|
||||||
|
// formatter in the `FmtContext`.
|
||||||
|
let fields = &ext.get::<FormattedFields<N>>().expect("will never be `None`");
|
||||||
|
|
||||||
|
if !fields.is_empty() {
|
||||||
|
write!(writer, "{{{}}}", fields)?;
|
||||||
}
|
}
|
||||||
None => {
|
write!(writer, ": ")?;
|
||||||
let _ = io::stderr().flush();
|
|
||||||
}
|
Ok(())
|
||||||
}
|
})?;
|
||||||
|
|
||||||
|
// Write fields on the event
|
||||||
|
ctx.field_format().format_fields(writer, event)?;
|
||||||
|
|
||||||
|
writeln!(writer)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,7 +35,7 @@ fn main() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Err(err) = try_main() {
|
if let Err(err) = try_main() {
|
||||||
log::error!("Unexpected error: {}", err);
|
tracing::error!("Unexpected error: {}", err);
|
||||||
eprintln!("{}", err);
|
eprintln!("{}", err);
|
||||||
process::exit(101);
|
process::exit(101);
|
||||||
}
|
}
|
||||||
|
@ -60,7 +60,7 @@ fn try_main() -> Result<()> {
|
||||||
log_file = Some(Path::new(env_log_file));
|
log_file = Some(Path::new(env_log_file));
|
||||||
}
|
}
|
||||||
|
|
||||||
setup_logging(log_file, flags.no_log_buffering)?;
|
setup_logging(log_file)?;
|
||||||
let verbosity = flags.verbosity();
|
let verbosity = flags.verbosity();
|
||||||
|
|
||||||
match flags.subcommand {
|
match flags.subcommand {
|
||||||
|
@ -91,7 +91,7 @@ fn try_main() -> Result<()> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn setup_logging(log_file: Option<&Path>, no_buffering: bool) -> Result<()> {
|
fn setup_logging(log_file: Option<&Path>) -> Result<()> {
|
||||||
env::set_var("RUST_BACKTRACE", "short");
|
env::set_var("RUST_BACKTRACE", "short");
|
||||||
|
|
||||||
let log_file = match log_file {
|
let log_file = match log_file {
|
||||||
|
@ -104,42 +104,20 @@ fn setup_logging(log_file: Option<&Path>, no_buffering: bool) -> Result<()> {
|
||||||
None => None,
|
None => None,
|
||||||
};
|
};
|
||||||
let filter = env::var("RA_LOG").ok();
|
let filter = env::var("RA_LOG").ok();
|
||||||
logger::Logger::new(log_file, no_buffering, filter.as_deref()).install();
|
logger::Logger::new(log_file, filter.as_deref()).install()?;
|
||||||
|
|
||||||
tracing_setup::setup_tracing()?;
|
|
||||||
|
|
||||||
profile::init();
|
profile::init();
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
mod tracing_setup {
|
|
||||||
use tracing::subscriber;
|
|
||||||
use tracing_subscriber::layer::SubscriberExt;
|
|
||||||
use tracing_subscriber::EnvFilter;
|
|
||||||
use tracing_subscriber::Registry;
|
|
||||||
use tracing_tree::HierarchicalLayer;
|
|
||||||
|
|
||||||
pub(crate) fn setup_tracing() -> super::Result<()> {
|
|
||||||
let filter = EnvFilter::from_env("CHALK_DEBUG");
|
|
||||||
let layer = HierarchicalLayer::default()
|
|
||||||
.with_indent_lines(true)
|
|
||||||
.with_ansi(false)
|
|
||||||
.with_indent_amount(2)
|
|
||||||
.with_writer(std::io::stderr);
|
|
||||||
let subscriber = Registry::default().with(filter).with(layer);
|
|
||||||
subscriber::set_global_default(subscriber)?;
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn run_server() -> Result<()> {
|
fn run_server() -> Result<()> {
|
||||||
log::info!("server version {} will start", env!("REV"));
|
tracing::info!("server version {} will start", env!("REV"));
|
||||||
|
|
||||||
let (connection, io_threads) = Connection::stdio();
|
let (connection, io_threads) = Connection::stdio();
|
||||||
|
|
||||||
let (initialize_id, initialize_params) = connection.initialize_start()?;
|
let (initialize_id, initialize_params) = connection.initialize_start()?;
|
||||||
log::info!("InitializeParams: {}", initialize_params);
|
tracing::info!("InitializeParams: {}", initialize_params);
|
||||||
let initialize_params =
|
let initialize_params =
|
||||||
from_json::<lsp_types::InitializeParams>("InitializeParams", initialize_params)?;
|
from_json::<lsp_types::InitializeParams>("InitializeParams", initialize_params)?;
|
||||||
|
|
||||||
|
@ -176,7 +154,7 @@ fn run_server() -> Result<()> {
|
||||||
connection.initialize_finish(initialize_id, initialize_result)?;
|
connection.initialize_finish(initialize_id, initialize_result)?;
|
||||||
|
|
||||||
if let Some(client_info) = initialize_params.client_info {
|
if let Some(client_info) = initialize_params.client_info {
|
||||||
log::info!("Client '{}' {}", client_info.name, client_info.version.unwrap_or_default());
|
tracing::info!("Client '{}' {}", client_info.name, client_info.version.unwrap_or_default());
|
||||||
}
|
}
|
||||||
|
|
||||||
if config.linked_projects().is_empty() && config.detached_files().is_empty() {
|
if config.linked_projects().is_empty() && config.detached_files().is_empty() {
|
||||||
|
@ -193,9 +171,9 @@ fn run_server() -> Result<()> {
|
||||||
.unwrap_or_else(|| vec![config.root_path.clone()]);
|
.unwrap_or_else(|| vec![config.root_path.clone()]);
|
||||||
|
|
||||||
let discovered = ProjectManifest::discover_all(&workspace_roots);
|
let discovered = ProjectManifest::discover_all(&workspace_roots);
|
||||||
log::info!("discovered projects: {:?}", discovered);
|
tracing::info!("discovered projects: {:?}", discovered);
|
||||||
if discovered.is_empty() {
|
if discovered.is_empty() {
|
||||||
log::error!("failed to find any projects in {:?}", workspace_roots);
|
tracing::error!("failed to find any projects in {:?}", workspace_roots);
|
||||||
}
|
}
|
||||||
config.discovered_projects = Some(discovered);
|
config.discovered_projects = Some(discovered);
|
||||||
}
|
}
|
||||||
|
@ -203,6 +181,6 @@ fn run_server() -> Result<()> {
|
||||||
rust_analyzer::main_loop(config, connection)?;
|
rust_analyzer::main_loop(config, connection)?;
|
||||||
|
|
||||||
io_threads.join()?;
|
io_threads.join()?;
|
||||||
log::info!("server did shut down");
|
tracing::info!("server did shut down");
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -131,7 +131,7 @@ fn completions_resolve_provider(client_caps: &ClientCapabilities) -> Option<bool
|
||||||
if completion_item_edit_resolve(client_caps) {
|
if completion_item_edit_resolve(client_caps) {
|
||||||
Some(true)
|
Some(true)
|
||||||
} else {
|
} else {
|
||||||
log::info!("No `additionalTextEdits` completion resolve capability was found in the client capabilities, autoimport completion is disabled");
|
tracing::info!("No `additionalTextEdits` completion resolve capability was found in the client capabilities, autoimport completion is disabled");
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -85,7 +85,7 @@ pub fn load_workspace(
|
||||||
version: 0,
|
version: 0,
|
||||||
});
|
});
|
||||||
|
|
||||||
log::debug!("crate graph: {:?}", crate_graph);
|
tracing::debug!("crate graph: {:?}", crate_graph);
|
||||||
let host =
|
let host =
|
||||||
load_crate_graph(crate_graph, project_folders.source_root_config, &mut vfs, &receiver);
|
load_crate_graph(crate_graph, project_folders.source_root_config, &mut vfs, &receiver);
|
||||||
|
|
||||||
|
|
|
@ -432,7 +432,7 @@ impl Config {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
pub fn update(&mut self, mut json: serde_json::Value) {
|
pub fn update(&mut self, mut json: serde_json::Value) {
|
||||||
log::info!("updating config from JSON: {:#}", json);
|
tracing::info!("updating config from JSON: {:#}", json);
|
||||||
if json.is_null() || json.as_object().map_or(false, |it| it.is_empty()) {
|
if json.is_null() || json.as_object().map_or(false, |it| it.is_empty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -478,7 +478,9 @@ impl Config {
|
||||||
ManifestOrProjectJson::Manifest(it) => {
|
ManifestOrProjectJson::Manifest(it) => {
|
||||||
let path = self.root_path.join(it);
|
let path = self.root_path.join(it);
|
||||||
ProjectManifest::from_manifest_file(path)
|
ProjectManifest::from_manifest_file(path)
|
||||||
.map_err(|e| log::error!("failed to load linked project: {}", e))
|
.map_err(|e| {
|
||||||
|
tracing::error!("failed to load linked project: {}", e)
|
||||||
|
})
|
||||||
.ok()?
|
.ok()?
|
||||||
.into()
|
.into()
|
||||||
}
|
}
|
||||||
|
|
|
@ -88,7 +88,7 @@ impl<'a> RequestDispatcher<'a> {
|
||||||
|
|
||||||
pub(crate) fn finish(&mut self) {
|
pub(crate) fn finish(&mut self) {
|
||||||
if let Some(req) = self.req.take() {
|
if let Some(req) = self.req.take() {
|
||||||
log::error!("unknown request: {:?}", req);
|
tracing::error!("unknown request: {:?}", req);
|
||||||
let response = lsp_server::Response::new_err(
|
let response = lsp_server::Response::new_err(
|
||||||
req.id,
|
req.id,
|
||||||
lsp_server::ErrorCode::MethodNotFound as i32,
|
lsp_server::ErrorCode::MethodNotFound as i32,
|
||||||
|
@ -208,7 +208,7 @@ impl<'a> NotificationDispatcher<'a> {
|
||||||
pub(crate) fn finish(&mut self) {
|
pub(crate) fn finish(&mut self) {
|
||||||
if let Some(not) = &self.not {
|
if let Some(not) = &self.not {
|
||||||
if !not.method.starts_with("$/") {
|
if !not.method.starts_with("$/") {
|
||||||
log::error!("unhandled notification: {:?}", not);
|
tracing::error!("unhandled notification: {:?}", not);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -271,7 +271,7 @@ impl GlobalState {
|
||||||
}
|
}
|
||||||
|
|
||||||
let duration = start.elapsed();
|
let duration = start.elapsed();
|
||||||
log::info!("handled {} - ({}) in {:0.2?}", method, response.id, duration);
|
tracing::info!("handled {} - ({}) in {:0.2?}", method, response.id, duration);
|
||||||
self.send(response.into());
|
self.send(response.into());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1651,7 +1651,7 @@ fn run_rustfmt(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
log::error!(
|
tracing::error!(
|
||||||
"Unable to get file path for {}, rustfmt.toml might be ignored",
|
"Unable to get file path for {}, rustfmt.toml might be ignored",
|
||||||
text_document.uri
|
text_document.uri
|
||||||
);
|
);
|
||||||
|
@ -1721,7 +1721,7 @@ fn run_rustfmt(
|
||||||
// formatting because otherwise an error is surfaced to the user on top of the
|
// formatting because otherwise an error is surfaced to the user on top of the
|
||||||
// syntax error diagnostics they're already receiving. This is especially jarring
|
// syntax error diagnostics they're already receiving. This is especially jarring
|
||||||
// if they have format on save enabled.
|
// if they have format on save enabled.
|
||||||
log::info!("rustfmt exited with status 1, assuming parse error and ignoring");
|
tracing::info!("rustfmt exited with status 1, assuming parse error and ignoring");
|
||||||
Ok(None)
|
Ok(None)
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
|
|
|
@ -27,7 +27,7 @@ use crate::{
|
||||||
};
|
};
|
||||||
|
|
||||||
pub fn main_loop(config: Config, connection: Connection) -> Result<()> {
|
pub fn main_loop(config: Config, connection: Connection) -> Result<()> {
|
||||||
log::info!("initial config: {:#?}", config);
|
tracing::info!("initial config: {:#?}", config);
|
||||||
|
|
||||||
// Windows scheduler implements priority boosts: if thread waits for an
|
// Windows scheduler implements priority boosts: if thread waits for an
|
||||||
// event (like a condvar), and event fires, priority of the thread is
|
// event (like a condvar), and event fires, priority of the thread is
|
||||||
|
@ -182,10 +182,10 @@ impl GlobalState {
|
||||||
// NOTE: don't count blocking select! call as a loop-turn time
|
// NOTE: don't count blocking select! call as a loop-turn time
|
||||||
let _p = profile::span("GlobalState::handle_event");
|
let _p = profile::span("GlobalState::handle_event");
|
||||||
|
|
||||||
log::info!("handle_event({:?})", event);
|
tracing::info!("handle_event({:?})", event);
|
||||||
let task_queue_len = self.task_pool.handle.len();
|
let task_queue_len = self.task_pool.handle.len();
|
||||||
if task_queue_len > 0 {
|
if task_queue_len > 0 {
|
||||||
log::info!("task queue len: {}", task_queue_len);
|
tracing::info!("task queue len: {}", task_queue_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
let was_quiescent = self.is_quiescent();
|
let was_quiescent = self.is_quiescent();
|
||||||
|
@ -359,7 +359,7 @@ impl GlobalState {
|
||||||
diag.fixes,
|
diag.fixes,
|
||||||
),
|
),
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
log::error!(
|
tracing::error!(
|
||||||
"File with cargo diagnostic not found in VFS: {}",
|
"File with cargo diagnostic not found in VFS: {}",
|
||||||
err
|
err
|
||||||
);
|
);
|
||||||
|
@ -380,7 +380,7 @@ impl GlobalState {
|
||||||
flycheck::Progress::DidCancel => (Progress::End, None),
|
flycheck::Progress::DidCancel => (Progress::End, None),
|
||||||
flycheck::Progress::DidFinish(result) => {
|
flycheck::Progress::DidFinish(result) => {
|
||||||
if let Err(err) = result {
|
if let Err(err) = result {
|
||||||
log::error!("cargo check failed: {}", err)
|
tracing::error!("cargo check failed: {}", err)
|
||||||
}
|
}
|
||||||
(Progress::End, None)
|
(Progress::End, None)
|
||||||
}
|
}
|
||||||
|
@ -486,7 +486,7 @@ impl GlobalState {
|
||||||
|
|
||||||
let loop_duration = loop_start.elapsed();
|
let loop_duration = loop_start.elapsed();
|
||||||
if loop_duration > Duration::from_millis(100) {
|
if loop_duration > Duration::from_millis(100) {
|
||||||
log::warn!("overly long loop turn: {:?}", loop_duration);
|
tracing::warn!("overly long loop turn: {:?}", loop_duration);
|
||||||
self.poke_rust_analyzer_developer(format!(
|
self.poke_rust_analyzer_developer(format!(
|
||||||
"overly long loop turn: {:?}",
|
"overly long loop turn: {:?}",
|
||||||
loop_duration
|
loop_duration
|
||||||
|
@ -617,7 +617,7 @@ impl GlobalState {
|
||||||
.insert(path.clone(), DocumentData::new(params.text_document.version))
|
.insert(path.clone(), DocumentData::new(params.text_document.version))
|
||||||
.is_err()
|
.is_err()
|
||||||
{
|
{
|
||||||
log::error!("duplicate DidOpenTextDocument: {}", path)
|
tracing::error!("duplicate DidOpenTextDocument: {}", path)
|
||||||
}
|
}
|
||||||
this.vfs
|
this.vfs
|
||||||
.write()
|
.write()
|
||||||
|
@ -635,7 +635,7 @@ impl GlobalState {
|
||||||
doc.version = params.text_document.version;
|
doc.version = params.text_document.version;
|
||||||
}
|
}
|
||||||
None => {
|
None => {
|
||||||
log::error!("expected DidChangeTextDocument: {}", path);
|
tracing::error!("expected DidChangeTextDocument: {}", path);
|
||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -652,7 +652,7 @@ impl GlobalState {
|
||||||
.on::<lsp_types::notification::DidCloseTextDocument>(|this, params| {
|
.on::<lsp_types::notification::DidCloseTextDocument>(|this, params| {
|
||||||
if let Ok(path) = from_proto::vfs_path(¶ms.text_document.uri) {
|
if let Ok(path) = from_proto::vfs_path(¶ms.text_document.uri) {
|
||||||
if this.mem_docs.remove(&path).is_err() {
|
if this.mem_docs.remove(&path).is_err() {
|
||||||
log::error!("orphan DidCloseTextDocument: {}", path);
|
tracing::error!("orphan DidCloseTextDocument: {}", path);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.semantic_tokens_cache.lock().remove(¶ms.text_document.uri);
|
this.semantic_tokens_cache.lock().remove(¶ms.text_document.uri);
|
||||||
|
@ -683,12 +683,12 @@ impl GlobalState {
|
||||||
}],
|
}],
|
||||||
},
|
},
|
||||||
|this, resp| {
|
|this, resp| {
|
||||||
log::debug!("config update response: '{:?}", resp);
|
tracing::debug!("config update response: '{:?}", resp);
|
||||||
let lsp_server::Response { error, result, .. } = resp;
|
let lsp_server::Response { error, result, .. } = resp;
|
||||||
|
|
||||||
match (error, result) {
|
match (error, result) {
|
||||||
(Some(err), _) => {
|
(Some(err), _) => {
|
||||||
log::error!("failed to fetch the server settings: {:?}", err)
|
tracing::error!("failed to fetch the server settings: {:?}", err)
|
||||||
}
|
}
|
||||||
(None, Some(mut configs)) => {
|
(None, Some(mut configs)) => {
|
||||||
if let Some(json) = configs.get_mut(0) {
|
if let Some(json) = configs.get_mut(0) {
|
||||||
|
@ -699,7 +699,7 @@ impl GlobalState {
|
||||||
this.update_configuration(config);
|
this.update_configuration(config);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
(None, None) => log::error!(
|
(None, None) => tracing::error!(
|
||||||
"received empty server settings response from the client"
|
"received empty server settings response from the client"
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
|
@ -727,7 +727,7 @@ impl GlobalState {
|
||||||
.map(|path| self.vfs.read().0.file_id(path).unwrap())
|
.map(|path| self.vfs.read().0.file_id(path).unwrap())
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
|
|
||||||
log::trace!("updating notifications for {:?}", subscriptions);
|
tracing::trace!("updating notifications for {:?}", subscriptions);
|
||||||
|
|
||||||
let snapshot = self.snapshot();
|
let snapshot = self.snapshot();
|
||||||
self.task_pool.handle.spawn(move || {
|
self.task_pool.handle.spawn(move || {
|
||||||
|
@ -737,7 +737,7 @@ impl GlobalState {
|
||||||
handlers::publish_diagnostics(&snapshot, file_id)
|
handlers::publish_diagnostics(&snapshot, file_id)
|
||||||
.map_err(|err| {
|
.map_err(|err| {
|
||||||
if !is_cancelled(&*err) {
|
if !is_cancelled(&*err) {
|
||||||
log::error!("failed to compute diagnostics: {:?}", err);
|
tracing::error!("failed to compute diagnostics: {:?}", err);
|
||||||
}
|
}
|
||||||
()
|
()
|
||||||
})
|
})
|
||||||
|
|
|
@ -61,7 +61,7 @@ impl GlobalState {
|
||||||
if !changes.iter().any(|(path, kind)| is_interesting(path, *kind)) {
|
if !changes.iter().any(|(path, kind)| is_interesting(path, *kind)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
log::info!(
|
tracing::info!(
|
||||||
"Requesting workspace reload because of the following changes: {}",
|
"Requesting workspace reload because of the following changes: {}",
|
||||||
itertools::join(
|
itertools::join(
|
||||||
changes
|
changes
|
||||||
|
@ -153,7 +153,7 @@ impl GlobalState {
|
||||||
if !self.fetch_workspaces_queue.should_start_op() {
|
if !self.fetch_workspaces_queue.should_start_op() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
log::info!("will fetch workspaces");
|
tracing::info!("will fetch workspaces");
|
||||||
|
|
||||||
self.task_pool.handle.spawn_with_sender({
|
self.task_pool.handle.spawn_with_sender({
|
||||||
let linked_projects = self.config.linked_projects();
|
let linked_projects = self.config.linked_projects();
|
||||||
|
@ -196,7 +196,7 @@ impl GlobalState {
|
||||||
.push(project_model::ProjectWorkspace::load_detached_files(detached_files));
|
.push(project_model::ProjectWorkspace::load_detached_files(detached_files));
|
||||||
}
|
}
|
||||||
|
|
||||||
log::info!("did fetch workspaces {:?}", workspaces);
|
tracing::info!("did fetch workspaces {:?}", workspaces);
|
||||||
sender
|
sender
|
||||||
.send(Task::FetchWorkspace(ProjectWorkspaceProgress::End(workspaces)))
|
.send(Task::FetchWorkspace(ProjectWorkspaceProgress::End(workspaces)))
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
@ -245,10 +245,10 @@ impl GlobalState {
|
||||||
|
|
||||||
pub(crate) fn switch_workspaces(&mut self) {
|
pub(crate) fn switch_workspaces(&mut self) {
|
||||||
let _p = profile::span("GlobalState::switch_workspaces");
|
let _p = profile::span("GlobalState::switch_workspaces");
|
||||||
log::info!("will switch workspaces");
|
tracing::info!("will switch workspaces");
|
||||||
|
|
||||||
if let Some(error_message) = self.fetch_workspace_error() {
|
if let Some(error_message) = self.fetch_workspace_error() {
|
||||||
log::error!("failed to switch workspaces: {}", error_message);
|
tracing::error!("failed to switch workspaces: {}", error_message);
|
||||||
if !self.workspaces.is_empty() {
|
if !self.workspaces.is_empty() {
|
||||||
// It only makes sense to switch to a partially broken workspace
|
// It only makes sense to switch to a partially broken workspace
|
||||||
// if we don't have any workspace at all yet.
|
// if we don't have any workspace at all yet.
|
||||||
|
@ -257,7 +257,7 @@ impl GlobalState {
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(error_message) = self.fetch_build_data_error() {
|
if let Some(error_message) = self.fetch_build_data_error() {
|
||||||
log::error!("failed to switch build data: {}", error_message);
|
tracing::error!("failed to switch build data: {}", error_message);
|
||||||
}
|
}
|
||||||
|
|
||||||
let workspaces = self
|
let workspaces = self
|
||||||
|
@ -367,7 +367,7 @@ impl GlobalState {
|
||||||
Some((path, args)) => match ProcMacroClient::extern_process(path.clone(), args) {
|
Some((path, args)) => match ProcMacroClient::extern_process(path.clone(), args) {
|
||||||
Ok(it) => Some(it),
|
Ok(it) => Some(it),
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
log::error!(
|
tracing::error!(
|
||||||
"Failed to run proc_macro_srv from path {}, error: {:?}",
|
"Failed to run proc_macro_srv from path {}, error: {:?}",
|
||||||
path.display(),
|
path.display(),
|
||||||
err
|
err
|
||||||
|
@ -407,7 +407,7 @@ impl GlobalState {
|
||||||
}
|
}
|
||||||
let res = vfs.file_id(&vfs_path);
|
let res = vfs.file_id(&vfs_path);
|
||||||
if res.is_none() {
|
if res.is_none() {
|
||||||
log::warn!("failed to load {}", path.display())
|
tracing::warn!("failed to load {}", path.display())
|
||||||
}
|
}
|
||||||
res
|
res
|
||||||
};
|
};
|
||||||
|
@ -425,7 +425,7 @@ impl GlobalState {
|
||||||
self.analysis_host.apply_change(change);
|
self.analysis_host.apply_change(change);
|
||||||
self.process_changes();
|
self.process_changes();
|
||||||
self.reload_flycheck();
|
self.reload_flycheck();
|
||||||
log::info!("did switch workspaces");
|
tracing::info!("did switch workspaces");
|
||||||
}
|
}
|
||||||
|
|
||||||
fn fetch_workspace_error(&self) -> Option<String> {
|
fn fetch_workspace_error(&self) -> Option<String> {
|
||||||
|
|
|
@ -71,7 +71,10 @@ impl<'a> Project<'a> {
|
||||||
let tmp_dir = self.tmp_dir.unwrap_or_else(TestDir::new);
|
let tmp_dir = self.tmp_dir.unwrap_or_else(TestDir::new);
|
||||||
static INIT: Once = Once::new();
|
static INIT: Once = Once::new();
|
||||||
INIT.call_once(|| {
|
INIT.call_once(|| {
|
||||||
env_logger::builder().is_test(true).parse_env("RA_LOG").try_init().unwrap();
|
tracing_subscriber::fmt()
|
||||||
|
.with_test_writer()
|
||||||
|
.with_env_filter(tracing_subscriber::EnvFilter::from_env("RA_LOG"))
|
||||||
|
.init();
|
||||||
profile::init_from(crate::PROFILE);
|
profile::init_from(crate::PROFILE);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ edition = "2018"
|
||||||
doctest = false
|
doctest = false
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
log = "0.4.8"
|
tracing = "0.1"
|
||||||
rustc-hash = "1.0"
|
rustc-hash = "1.0"
|
||||||
jod-thread = "0.1.0"
|
jod-thread = "0.1.0"
|
||||||
walkdir = "2.3.1"
|
walkdir = "2.3.1"
|
||||||
|
|
|
@ -76,7 +76,7 @@ impl NotifyActor {
|
||||||
}
|
}
|
||||||
fn run(mut self, inbox: Receiver<Message>) {
|
fn run(mut self, inbox: Receiver<Message>) {
|
||||||
while let Some(event) = self.next_event(&inbox) {
|
while let Some(event) = self.next_event(&inbox) {
|
||||||
log::debug!("vfs-notify event: {:?}", event);
|
tracing::debug!("vfs-notify event: {:?}", event);
|
||||||
match event {
|
match event {
|
||||||
Event::Message(msg) => match msg {
|
Event::Message(msg) => match msg {
|
||||||
Message::Config(config) => {
|
Message::Config(config) => {
|
||||||
|
@ -227,5 +227,5 @@ fn read(path: &AbsPath) -> Option<Vec<u8>> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn log_notify_error<T>(res: notify::Result<T>) -> Option<T> {
|
fn log_notify_error<T>(res: notify::Result<T>) -> Option<T> {
|
||||||
res.map_err(|err| log::warn!("notify error: {}", err)).ok()
|
res.map_err(|err| tracing::warn!("notify error: {}", err)).ok()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue