| use std::ffi::CString; |
| use std::path::Path; |
| |
| use rustc_data_structures::small_c_str::SmallCStr; |
| use rustc_errors::{Diag, DiagCtxtHandle, Diagnostic, EmissionGuarantee, Level}; |
| use rustc_macros::Diagnostic; |
| use rustc_span::Span; |
| |
| use crate::fluent_generated as fluent; |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_symbol_already_defined)] |
| pub(crate) struct SymbolAlreadyDefined<'a> { |
| #[primary_span] |
| pub span: Span, |
| pub symbol_name: &'a str, |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_sanitizer_memtag_requires_mte)] |
| pub(crate) struct SanitizerMemtagRequiresMte; |
| |
| pub(crate) struct ParseTargetMachineConfig<'a>(pub LlvmError<'a>); |
| |
| impl<G: EmissionGuarantee> Diagnostic<'_, G> for ParseTargetMachineConfig<'_> { |
| fn into_diag(self, dcx: DiagCtxtHandle<'_>, level: Level) -> Diag<'_, G> { |
| let diag: Diag<'_, G> = self.0.into_diag(dcx, level); |
| let (message, _) = diag.messages.first().expect("`LlvmError` with no message"); |
| let message = dcx.eagerly_translate_to_string(message.clone(), diag.args.iter()); |
| Diag::new(dcx, level, fluent::codegen_llvm_parse_target_machine_config) |
| .with_arg("error", message) |
| } |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_autodiff_without_enable)] |
| pub(crate) struct AutoDiffWithoutEnable; |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_lto_bitcode_from_rlib)] |
| pub(crate) struct LtoBitcodeFromRlib { |
| pub err: String, |
| } |
| |
| #[derive(Diagnostic)] |
| pub enum LlvmError<'a> { |
| #[diag(codegen_llvm_write_output)] |
| WriteOutput { path: &'a Path }, |
| #[diag(codegen_llvm_target_machine)] |
| CreateTargetMachine { triple: SmallCStr }, |
| #[diag(codegen_llvm_run_passes)] |
| RunLlvmPasses, |
| #[diag(codegen_llvm_serialize_module)] |
| SerializeModule { name: &'a str }, |
| #[diag(codegen_llvm_write_ir)] |
| WriteIr { path: &'a Path }, |
| #[diag(codegen_llvm_prepare_thin_lto_context)] |
| PrepareThinLtoContext, |
| #[diag(codegen_llvm_load_bitcode)] |
| LoadBitcode { name: CString }, |
| #[diag(codegen_llvm_write_thinlto_key)] |
| WriteThinLtoKey { err: std::io::Error }, |
| #[diag(codegen_llvm_prepare_thin_lto_module)] |
| PrepareThinLtoModule, |
| #[diag(codegen_llvm_parse_bitcode)] |
| ParseBitcode, |
| #[diag(codegen_llvm_prepare_autodiff)] |
| PrepareAutoDiff { src: String, target: String, error: String }, |
| } |
| |
| pub(crate) struct WithLlvmError<'a>(pub LlvmError<'a>, pub String); |
| |
| impl<G: EmissionGuarantee> Diagnostic<'_, G> for WithLlvmError<'_> { |
| fn into_diag(self, dcx: DiagCtxtHandle<'_>, level: Level) -> Diag<'_, G> { |
| use LlvmError::*; |
| let msg_with_llvm_err = match &self.0 { |
| WriteOutput { .. } => fluent::codegen_llvm_write_output_with_llvm_err, |
| CreateTargetMachine { .. } => fluent::codegen_llvm_target_machine_with_llvm_err, |
| RunLlvmPasses => fluent::codegen_llvm_run_passes_with_llvm_err, |
| SerializeModule { .. } => fluent::codegen_llvm_serialize_module_with_llvm_err, |
| WriteIr { .. } => fluent::codegen_llvm_write_ir_with_llvm_err, |
| PrepareThinLtoContext => fluent::codegen_llvm_prepare_thin_lto_context_with_llvm_err, |
| LoadBitcode { .. } => fluent::codegen_llvm_load_bitcode_with_llvm_err, |
| WriteThinLtoKey { .. } => fluent::codegen_llvm_write_thinlto_key_with_llvm_err, |
| PrepareThinLtoModule => fluent::codegen_llvm_prepare_thin_lto_module_with_llvm_err, |
| ParseBitcode => fluent::codegen_llvm_parse_bitcode_with_llvm_err, |
| PrepareAutoDiff { .. } => fluent::codegen_llvm_prepare_autodiff_with_llvm_err, |
| }; |
| self.0 |
| .into_diag(dcx, level) |
| .with_primary_message(msg_with_llvm_err) |
| .with_arg("llvm_err", self.1) |
| } |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_from_llvm_optimization_diag)] |
| pub(crate) struct FromLlvmOptimizationDiag<'a> { |
| pub filename: &'a str, |
| pub line: std::ffi::c_uint, |
| pub column: std::ffi::c_uint, |
| pub pass_name: &'a str, |
| pub kind: &'a str, |
| pub message: &'a str, |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_from_llvm_diag)] |
| pub(crate) struct FromLlvmDiag { |
| pub message: String, |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_write_bytecode)] |
| pub(crate) struct WriteBytecode<'a> { |
| pub path: &'a Path, |
| pub err: std::io::Error, |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_copy_bitcode)] |
| pub(crate) struct CopyBitcode { |
| pub err: std::io::Error, |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_unknown_debuginfo_compression)] |
| pub(crate) struct UnknownCompression { |
| pub algorithm: &'static str, |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_mismatch_data_layout)] |
| pub(crate) struct MismatchedDataLayout<'a> { |
| pub rustc_target: &'a str, |
| pub rustc_layout: &'a str, |
| pub llvm_target: &'a str, |
| pub llvm_layout: &'a str, |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_fixed_x18_invalid_arch)] |
| pub(crate) struct FixedX18InvalidArch<'a> { |
| pub arch: &'a str, |
| } |
| |
| #[derive(Diagnostic)] |
| #[diag(codegen_llvm_sanitizer_kcfi_arity_requires_llvm_21_0_0)] |
| pub(crate) struct SanitizerKcfiArityRequiresLLVM2100; |