Skip to content

Commit

Permalink
Remove use of DiagnosticArgFromDisplay
Browse files Browse the repository at this point in the history
  • Loading branch information
SkiFire13 committed Aug 22, 2022
1 parent 0d80ee7 commit 645de5b
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 30 deletions.
22 changes: 12 additions & 10 deletions compiler/rustc_interface/src/errors.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
use rustc_errors::DiagnosticArgFromDisplay;
use rustc_macros::SessionDiagnostic;
use rustc_span::{Span, Symbol};

use std::io;
use std::path::Path;

#[derive(SessionDiagnostic)]
#[diag(interface::ferris_identifier)]
pub struct FerrisIdentifier {
Expand Down Expand Up @@ -34,21 +36,21 @@ pub struct ProcMacroDocWithoutArg;
#[derive(SessionDiagnostic)]
#[diag(interface::error_writing_dependencies)]
pub struct ErrorWritingDependencies<'a> {
pub path: DiagnosticArgFromDisplay<'a>,
pub error: DiagnosticArgFromDisplay<'a>,
pub path: &'a Path,
pub error: io::Error,
}

#[derive(SessionDiagnostic)]
#[diag(interface::input_file_would_be_overwritten)]
pub struct InputFileWouldBeOverWritten<'a> {
pub path: DiagnosticArgFromDisplay<'a>,
pub path: &'a Path,
}

#[derive(SessionDiagnostic)]
#[diag(interface::generated_file_conflicts_with_directory)]
pub struct GeneratedFileConflictsWithDirectory<'a> {
pub input_path: DiagnosticArgFromDisplay<'a>,
pub dir_path: DiagnosticArgFromDisplay<'a>,
pub input_path: &'a Path,
pub dir_path: &'a Path,
}

#[derive(SessionDiagnostic)]
Expand All @@ -61,8 +63,8 @@ pub struct OutDirError;

#[derive(SessionDiagnostic)]
#[diag(interface::cant_emit_mir)]
pub struct CantEmitMIR<'a> {
pub error: DiagnosticArgFromDisplay<'a>,
pub struct CantEmitMIR {
pub error: io::Error,
}

#[derive(SessionDiagnostic)]
Expand All @@ -82,6 +84,6 @@ pub struct RustcErrorUnexpectedAnnotation {
#[derive(SessionDiagnostic)]
#[diag(interface::failed_writing_file)]
pub struct FailedWritingFile<'a> {
pub path: DiagnosticArgFromDisplay<'a>,
pub error: DiagnosticArgFromDisplay<'a>,
pub path: &'a Path,
pub error: io::Error,
}
22 changes: 8 additions & 14 deletions compiler/rustc_interface/src/passes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -647,11 +647,8 @@ fn write_out_deps(
.emit_artifact_notification(&deps_filename, "dep-info");
}
}
Err(e) => {
sess.emit_fatal(ErrorWritingDependencies {
path: (&deps_filename.display()).into(),
error: (&e).into(),
});
Err(error) => {
sess.emit_fatal(ErrorWritingDependencies { path: &deps_filename, error });
}
}
}
Expand Down Expand Up @@ -682,15 +679,12 @@ pub fn prepare_outputs(
if let Some(ref input_path) = compiler.input_path {
if sess.opts.will_create_output_file() {
if output_contains_path(&output_paths, input_path) {
let reported = sess
.emit_err(InputFileWouldBeOverWritten { path: (&input_path.display()).into() });
let reported = sess.emit_err(InputFileWouldBeOverWritten { path: input_path });
return Err(reported);
}
if let Some(dir_path) = output_conflicts_with_dir(&output_paths) {
let reported = sess.emit_err(GeneratedFileConflictsWithDirectory {
input_path: (&input_path.display()).into(),
dir_path: (&dir_path.display()).into(),
});
if let Some(ref dir_path) = output_conflicts_with_dir(&output_paths) {
let reported =
sess.emit_err(GeneratedFileConflictsWithDirectory { input_path, dir_path });
return Err(reported);
}
}
Expand Down Expand Up @@ -994,8 +988,8 @@ pub fn start_codegen<'tcx>(
info!("Post-codegen\n{:?}", tcx.debug_stats());

if tcx.sess.opts.output_types.contains_key(&OutputType::Mir) {
if let Err(e) = rustc_mir_transform::dump_mir::emit_mir(tcx, outputs) {
tcx.sess.emit_err(CantEmitMIR { error: (&e).into() });
if let Err(error) = rustc_mir_transform::dump_mir::emit_mir(tcx, outputs) {
tcx.sess.emit_err(CantEmitMIR { error });
tcx.sess.abort_if_errors();
}
}
Expand Down
8 changes: 2 additions & 6 deletions compiler/rustc_interface/src/queries.rs
Original file line number Diff line number Diff line change
Expand Up @@ -357,12 +357,8 @@ impl Linker {
if sess.opts.unstable_opts.no_link {
let encoded = CodegenResults::serialize_rlink(&codegen_results);
let rlink_file = self.prepare_outputs.with_extension(config::RLINK_EXT);
std::fs::write(&rlink_file, encoded).map_err(|err| {
sess.emit_fatal(FailedWritingFile {
path: (&rlink_file.display()).into(),
error: (&err).into(),
})
})?;
std::fs::write(&rlink_file, encoded)
.map_err(|error| sess.emit_fatal(FailedWritingFile { path: &rlink_file, error }))?;
return Ok(());
}

Expand Down

0 comments on commit 645de5b

Please sign in to comment.