diff options
| author | David Wood <david@davidtw.co> | 2018-09-06 13:07:14 +0200 |
|---|---|---|
| committer | David Wood <david@davidtw.co> | 2018-09-18 13:45:24 +0200 |
| commit | 874e08bdd802f527bc1e1e2c41442796e4d44c6b (patch) | |
| tree | 263d27e1b5120a93374c3b8c4246171c9bee9997 /src/librustc_errors | |
| parent | f004cae5360c4a3f365c7f7525b4293559201ce2 (diff) | |
| download | rust-874e08bdd802f527bc1e1e2c41442796e4d44c6b.tar.gz rust-874e08bdd802f527bc1e1e2c41442796e4d44c6b.zip | |
Log when buffering a diagnostic.
This is useful in debugging when and where errors are emitted in logs.
Diffstat (limited to 'src/librustc_errors')
| -rw-r--r-- | src/librustc_errors/Cargo.toml | 1 | ||||
| -rw-r--r-- | src/librustc_errors/diagnostic_builder.rs | 3 | ||||
| -rw-r--r-- | src/librustc_errors/lib.rs | 2 |
3 files changed, 6 insertions, 0 deletions
diff --git a/src/librustc_errors/Cargo.toml b/src/librustc_errors/Cargo.toml index 101ca0650c8..b24f8ddf4d9 100644 --- a/src/librustc_errors/Cargo.toml +++ b/src/librustc_errors/Cargo.toml @@ -9,6 +9,7 @@ path = "lib.rs" crate-type = ["dylib"] [dependencies] +log = "0.4" serialize = { path = "../libserialize" } syntax_pos = { path = "../libsyntax_pos" } rustc_data_structures = { path = "../librustc_data_structures" } diff --git a/src/librustc_errors/diagnostic_builder.rs b/src/librustc_errors/diagnostic_builder.rs index 5e962a4af32..a4b5b000f87 100644 --- a/src/librustc_errors/diagnostic_builder.rs +++ b/src/librustc_errors/diagnostic_builder.rs @@ -108,6 +108,9 @@ impl<'a> DiagnosticBuilder<'a> { diagnostic = ::std::ptr::read(&self.diagnostic); ::std::mem::forget(self); }; + // Logging here is useful to help track down where in logs an error was + // actually emitted. + debug!("buffer: diagnostic={:?}", diagnostic); buffered_diagnostics.push(diagnostic); } diff --git a/src/librustc_errors/lib.rs b/src/librustc_errors/lib.rs index d0ea6fba5eb..266aa326981 100644 --- a/src/librustc_errors/lib.rs +++ b/src/librustc_errors/lib.rs @@ -23,6 +23,8 @@ extern crate atty; extern crate termcolor; #[cfg(unix)] extern crate libc; +#[macro_use] +extern crate log; extern crate rustc_data_structures; extern crate serialize as rustc_serialize; extern crate syntax_pos; |
