Remove rustc_symbol_mangling/messages.ftl
.
It contains a single message that (a) doesn't contain any natural language, and (b) is only used in tests.
This commit is contained in:
parent
99592fdfa1
commit
f4a9d29c50
@ -4543,9 +4543,7 @@ dependencies = [
|
|||||||
"rustc-demangle",
|
"rustc-demangle",
|
||||||
"rustc_data_structures",
|
"rustc_data_structures",
|
||||||
"rustc_errors",
|
"rustc_errors",
|
||||||
"rustc_fluent_macro",
|
|
||||||
"rustc_hir",
|
"rustc_hir",
|
||||||
"rustc_macros",
|
|
||||||
"rustc_middle",
|
"rustc_middle",
|
||||||
"rustc_session",
|
"rustc_session",
|
||||||
"rustc_span",
|
"rustc_span",
|
||||||
|
@ -137,7 +137,6 @@ pub static DEFAULT_LOCALE_RESOURCES: &[&str] = &[
|
|||||||
rustc_query_system::DEFAULT_LOCALE_RESOURCE,
|
rustc_query_system::DEFAULT_LOCALE_RESOURCE,
|
||||||
rustc_resolve::DEFAULT_LOCALE_RESOURCE,
|
rustc_resolve::DEFAULT_LOCALE_RESOURCE,
|
||||||
rustc_session::DEFAULT_LOCALE_RESOURCE,
|
rustc_session::DEFAULT_LOCALE_RESOURCE,
|
||||||
rustc_symbol_mangling::DEFAULT_LOCALE_RESOURCE,
|
|
||||||
rustc_trait_selection::DEFAULT_LOCALE_RESOURCE,
|
rustc_trait_selection::DEFAULT_LOCALE_RESOURCE,
|
||||||
rustc_ty_utils::DEFAULT_LOCALE_RESOURCE,
|
rustc_ty_utils::DEFAULT_LOCALE_RESOURCE,
|
||||||
// tidy-alphabetical-end
|
// tidy-alphabetical-end
|
||||||
|
@ -15,9 +15,7 @@ twox-hash = "1.6.3"
|
|||||||
rustc_span = { path = "../rustc_span" }
|
rustc_span = { path = "../rustc_span" }
|
||||||
rustc_middle = { path = "../rustc_middle" }
|
rustc_middle = { path = "../rustc_middle" }
|
||||||
rustc_hir = { path = "../rustc_hir" }
|
rustc_hir = { path = "../rustc_hir" }
|
||||||
rustc_fluent_macro = { path = "../rustc_fluent_macro" }
|
|
||||||
rustc_target = { path = "../rustc_target" }
|
rustc_target = { path = "../rustc_target" }
|
||||||
rustc_data_structures = { path = "../rustc_data_structures" }
|
rustc_data_structures = { path = "../rustc_data_structures" }
|
||||||
rustc_session = { path = "../rustc_session" }
|
rustc_session = { path = "../rustc_session" }
|
||||||
rustc_macros = { path = "../rustc_macros" }
|
|
||||||
rustc_errors = { path = "../rustc_errors" }
|
rustc_errors = { path = "../rustc_errors" }
|
||||||
|
@ -1 +0,0 @@
|
|||||||
symbol_mangling_test_output = {$kind}({$content})
|
|
@ -1,18 +1,32 @@
|
|||||||
//! Errors emitted by symbol_mangling.
|
//! Errors emitted by symbol_mangling.
|
||||||
|
|
||||||
use rustc_errors::{DiagnosticArgValue, IntoDiagnosticArg};
|
use rustc_errors::{ErrorGuaranteed, IntoDiagnostic};
|
||||||
use rustc_macros::Diagnostic;
|
|
||||||
use rustc_span::Span;
|
use rustc_span::Span;
|
||||||
|
use std::fmt;
|
||||||
|
|
||||||
#[derive(Diagnostic)]
|
|
||||||
#[diag(symbol_mangling_test_output)]
|
|
||||||
pub struct TestOutput {
|
pub struct TestOutput {
|
||||||
#[primary_span]
|
|
||||||
pub span: Span,
|
pub span: Span,
|
||||||
pub kind: Kind,
|
pub kind: Kind,
|
||||||
pub content: String,
|
pub content: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This diagnostic doesn't need translation because (a) it doesn't contain any
|
||||||
|
// natural language, and (b) it's only used in tests. So we construct it
|
||||||
|
// manually and avoid the fluent machinery.
|
||||||
|
impl IntoDiagnostic<'_> for TestOutput {
|
||||||
|
fn into_diagnostic(
|
||||||
|
self,
|
||||||
|
handler: &'_ rustc_errors::Handler,
|
||||||
|
) -> rustc_errors::DiagnosticBuilder<'_, ErrorGuaranteed> {
|
||||||
|
let TestOutput { span, kind, content } = self;
|
||||||
|
|
||||||
|
#[allow(rustc::untranslatable_diagnostic)]
|
||||||
|
let mut diag = handler.struct_err(format!("{kind}({content})"));
|
||||||
|
diag.set_span(span);
|
||||||
|
diag
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub enum Kind {
|
pub enum Kind {
|
||||||
SymbolName,
|
SymbolName,
|
||||||
Demangling,
|
Demangling,
|
||||||
@ -20,15 +34,13 @@ pub enum Kind {
|
|||||||
DefPath,
|
DefPath,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IntoDiagnosticArg for Kind {
|
impl fmt::Display for Kind {
|
||||||
fn into_diagnostic_arg(self) -> DiagnosticArgValue<'static> {
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
let kind = match self {
|
match self {
|
||||||
Kind::SymbolName => "symbol-name",
|
Kind::SymbolName => write!(f, "symbol-name"),
|
||||||
Kind::Demangling => "demangling",
|
Kind::Demangling => write!(f, "demangling"),
|
||||||
Kind::DemanglingAlt => "demangling-alt",
|
Kind::DemanglingAlt => write!(f, "demangling-alt"),
|
||||||
Kind::DefPath => "def-path",
|
Kind::DefPath => write!(f, "def-path"),
|
||||||
}
|
}
|
||||||
.into();
|
|
||||||
DiagnosticArgValue::Str(kind)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -103,8 +103,6 @@ extern crate rustc_middle;
|
|||||||
#[macro_use]
|
#[macro_use]
|
||||||
extern crate tracing;
|
extern crate tracing;
|
||||||
|
|
||||||
use rustc_errors::{DiagnosticMessage, SubdiagnosticMessage};
|
|
||||||
use rustc_fluent_macro::fluent_messages;
|
|
||||||
use rustc_hir::def::DefKind;
|
use rustc_hir::def::DefKind;
|
||||||
use rustc_hir::def_id::{CrateNum, LOCAL_CRATE};
|
use rustc_hir::def_id::{CrateNum, LOCAL_CRATE};
|
||||||
use rustc_middle::middle::codegen_fn_attrs::CodegenFnAttrFlags;
|
use rustc_middle::middle::codegen_fn_attrs::CodegenFnAttrFlags;
|
||||||
@ -121,8 +119,6 @@ pub mod errors;
|
|||||||
pub mod test;
|
pub mod test;
|
||||||
pub mod typeid;
|
pub mod typeid;
|
||||||
|
|
||||||
fluent_messages! { "../messages.ftl" }
|
|
||||||
|
|
||||||
/// This function computes the symbol name for the given `instance` and the
|
/// This function computes the symbol name for the given `instance` and the
|
||||||
/// given instantiating crate. That is, if you know that instance X is
|
/// given instantiating crate. That is, if you know that instance X is
|
||||||
/// instantiated in crate Y, this is the symbol name this instance would have.
|
/// instantiated in crate Y, this is the symbol name this instance would have.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user