|  | 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; | 
|  |  | 
|  | #[derive(Diagnostic)] | 
|  | #[diag(codegen_llvm_dynamic_linking_with_lto)] | 
|  | #[note] | 
|  | pub(crate) struct DynamicLinkingWithLTO; | 
|  |  | 
|  | 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_disallowed)] | 
|  | pub(crate) struct LtoDisallowed; | 
|  |  | 
|  | #[derive(Diagnostic)] | 
|  | #[diag(codegen_llvm_lto_dylib)] | 
|  | pub(crate) struct LtoDylib; | 
|  |  | 
|  | #[derive(Diagnostic)] | 
|  | #[diag(codegen_llvm_lto_proc_macro)] | 
|  | pub(crate) struct LtoProcMacro; | 
|  |  | 
|  | #[derive(Diagnostic)] | 
|  | #[diag(codegen_llvm_lto_bitcode_from_rlib)] | 
|  | pub(crate) struct LtoBitcodeFromRlib { | 
|  | pub llvm_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; |