Skip to content

Commit 9b43441

Browse files
authored
Merge pull request rust-lang#3466 from topecongiro/discard-error-to-sink
Discard error report in silent_emitter
2 parents cc26c5e + 037cf2c commit 9b43441

File tree

1 file changed

+12
-10
lines changed

1 file changed

+12
-10
lines changed

src/formatting.rs

+12-10
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@ use std::rc::Rc;
77
use std::time::{Duration, Instant};
88

99
use syntax::ast;
10-
use syntax::errors::emitter::{ColorConfig, EmitterWriter};
10+
use syntax::errors::emitter::{ColorConfig, Emitter};
1111
use syntax::errors::{DiagnosticBuilder, Handler};
1212
use syntax::parse::{self, ParseSess};
1313
use syntax::source_map::{FilePathMapping, SourceMap, Span, DUMMY_SP};
@@ -90,7 +90,7 @@ fn format_project<T: FormatHandler>(
9090
timer = timer.done_parsing();
9191

9292
// Suppress error output if we have to do any further parsing.
93-
let silent_emitter = silent_emitter(source_map);
93+
let silent_emitter = silent_emitter();
9494
parse_session.span_diagnostic = Handler::with_emitter(true, None, silent_emitter);
9595

9696
let mut context = FormatContext::new(&krate, report, parse_session, config, handler);
@@ -672,18 +672,20 @@ fn parse_crate(
672672
Err(ErrorKind::ParseError)
673673
}
674674

675-
fn silent_emitter(source_map: Rc<SourceMap>) -> Box<EmitterWriter> {
676-
Box::new(EmitterWriter::new(
677-
Box::new(Vec::new()),
678-
Some(source_map),
679-
false,
680-
false,
681-
))
675+
/// Emitter which discards every error.
676+
struct SilentEmitter;
677+
678+
impl Emitter for SilentEmitter {
679+
fn emit(&mut self, _db: &DiagnosticBuilder<'_>) {}
680+
}
681+
682+
fn silent_emitter() -> Box<SilentEmitter> {
683+
Box::new(SilentEmitter {})
682684
}
683685

684686
fn make_parse_sess(source_map: Rc<SourceMap>, config: &Config) -> ParseSess {
685687
let tty_handler = if config.hide_parse_errors() {
686-
let silent_emitter = silent_emitter(source_map.clone());
688+
let silent_emitter = silent_emitter();
687689
Handler::with_emitter(true, None, silent_emitter)
688690
} else {
689691
let supports_color = term::stderr().map_or(false, |term| term.supports_color());

0 commit comments

Comments
 (0)