
The `fluent_messages!` macro produces uses of `crate::{D,Subd}iagnosticMessage`, which means that every crate using the macro must have this import: ``` use rustc_errors::{DiagnosticMessage, SubdiagnosticMessage}; ``` This commit changes the macro to instead use `rustc_errors::{D,Subd}iagnosticMessage`, which avoids the need for the imports.
46 lines
1.3 KiB
Rust
46 lines
1.3 KiB
Rust
//! This crates defines the type inference engine.
|
|
//!
|
|
//! - **Type inference.** The type inference code can be found in the `infer` module;
|
|
//! this code handles low-level equality and subtyping operations. The
|
|
//! type check pass in the compiler is found in the `rustc_hir_analysis` crate.
|
|
//!
|
|
//! For more information about how rustc works, see the [rustc dev guide].
|
|
//!
|
|
//! [rustc dev guide]: https://rustc-dev-guide.rust-lang.org/
|
|
//!
|
|
//! # Note
|
|
//!
|
|
//! This API is completely unstable and subject to change.
|
|
|
|
#![doc(html_root_url = "https://doc.rust-lang.org/nightly/nightly-rustc/")]
|
|
#![doc(rust_logo)]
|
|
#![feature(rustdoc_internals)]
|
|
#![allow(internal_features)]
|
|
#![feature(associated_type_bounds)]
|
|
#![feature(box_patterns)]
|
|
#![feature(control_flow_enum)]
|
|
#![feature(extend_one)]
|
|
#![feature(let_chains)]
|
|
#![feature(if_let_guard)]
|
|
#![feature(min_specialization)]
|
|
#![feature(never_type)]
|
|
#![feature(try_blocks)]
|
|
#![recursion_limit = "512"] // For rustdoc
|
|
|
|
#[macro_use]
|
|
extern crate rustc_macros;
|
|
#[cfg(all(target_arch = "x86_64", target_pointer_width = "64"))]
|
|
#[macro_use]
|
|
extern crate rustc_data_structures;
|
|
#[macro_use]
|
|
extern crate tracing;
|
|
#[macro_use]
|
|
extern crate rustc_middle;
|
|
|
|
use rustc_fluent_macro::fluent_messages;
|
|
|
|
mod errors;
|
|
pub mod infer;
|
|
pub mod traits;
|
|
|
|
fluent_messages! { "../messages.ftl" }
|