Struct rustc_errors::emitter::EmitterWriter [−][src]
pub struct EmitterWriter {
dst: Destination,
sm: Option<Lrc<SourceMap>>,
short_message: bool,
teach: bool,
ui_testing: bool,
terminal_width: Option<usize>,
macro_backtrace: bool,
}
Expand description
Handles the writing of HumanReadableErrorType::Default
and HumanReadableErrorType::Short
Fields
dst: Destination
sm: Option<Lrc<SourceMap>>
short_message: bool
teach: bool
ui_testing: bool
terminal_width: Option<usize>
macro_backtrace: bool
Implementations
pub fn stderr(
color_config: ColorConfig,
source_map: Option<Lrc<SourceMap>>,
short_message: bool,
teach: bool,
terminal_width: Option<usize>,
macro_backtrace: bool
) -> EmitterWriter
pub fn new(
dst: Box<dyn Write + Send>,
source_map: Option<Lrc<SourceMap>>,
short_message: bool,
teach: bool,
colored: bool,
terminal_width: Option<usize>,
macro_backtrace: bool
) -> EmitterWriter
fn draw_line(
&self,
buffer: &mut StyledBuffer,
source_string: &str,
line_index: usize,
line_offset: usize,
width_offset: usize,
code_offset: usize,
margin: Margin
)
fn render_source_line(
&self,
buffer: &mut StyledBuffer,
file: Lrc<SourceFile>,
line: &Line,
width_offset: usize,
code_offset: usize,
margin: Margin
) -> Vec<(usize, Style)>
Adds a left margin to every line but the first, given a padding length and the label being displayed, keeping the provided highlighting.
fn emit_message_default(
&mut self,
msp: &MultiSpan,
msg: &[(String, Style)],
code: &Option<DiagnosticId>,
level: &Level,
max_line_num_len: usize,
is_secondary: bool
) -> Result<()>
fn emit_suggestion_default(
&mut self,
suggestion: &CodeSuggestion,
level: &Level,
max_line_num_len: usize
) -> Result<()>
fn emit_messages_default(
&mut self,
level: &Level,
message: &[(String, Style)],
code: &Option<DiagnosticId>,
span: &MultiSpan,
children: &[SubDiagnostic],
suggestions: &[CodeSuggestion]
)
Trait Implementations
Emit a structured diagnostic.
Checks if should show explanations about “rustc –explain”
Checks if we can use colors in the current output stream.
Emit a notification that an artifact has been output. This is currently only supported for the JSON format, other formats can, and will, simply ignore it. Read more
Emit list of unused externs
fn primary_span_formatted<'a>(
&mut self,
diag: &'a Diagnostic
) -> (MultiSpan, &'a [CodeSuggestion])
fn primary_span_formatted<'a>(
&mut self,
diag: &'a Diagnostic
) -> (MultiSpan, &'a [CodeSuggestion])
Formats the substitutions of the primary_span Read more
fn fix_multispans_in_extern_macros_and_render_macro_backtrace(
&self,
source_map: &Option<Lrc<SourceMap>>,
span: &mut MultiSpan,
children: &mut Vec<SubDiagnostic>,
level: &Level,
backtrace: bool
)
fn render_multispans_macro_backtrace(
&self,
span: &mut MultiSpan,
children: &mut Vec<SubDiagnostic>,
backtrace: bool
)
fn fix_multispans_in_extern_macros(
&self,
source_map: &Option<Lrc<SourceMap>>,
span: &mut MultiSpan,
children: &mut Vec<SubDiagnostic>
)
Auto Trait Implementations
impl !RefUnwindSafe for EmitterWriter
impl !Send for EmitterWriter
impl !Sync for EmitterWriter
impl Unpin for EmitterWriter
impl !UnwindSafe for EmitterWriter
Blanket Implementations
Layout
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference’s “Type Layout” chapter for details on type layout guarantees.
Size: 120 bytes