Fix separation of public vs internal parts of Location

This commit is contained in:
David Tolnay 2021-04-28 08:35:21 -07:00
parent d7c82ba4a1
commit 76e73b74a6
No known key found for this signature in database
GPG Key ID: F9BA143B95FF6D82

View File

@ -83,18 +83,6 @@ impl<'a> Location<'a> {
pub const fn caller() -> &'static Location<'static> {
crate::intrinsics::caller_location()
}
}
impl<'a> Location<'a> {
#![unstable(
feature = "panic_internals",
reason = "internal details of the implementation of the `panic!` and related macros",
issue = "none"
)]
#[doc(hidden)]
pub const fn internal_constructor(file: &'a str, line: u32, col: u32) -> Self {
Location { file, line, col }
}
/// Returns the name of the source file from which the panic originated.
///
@ -179,6 +167,18 @@ impl<'a> Location<'a> {
}
}
#[unstable(
feature = "panic_internals",
reason = "internal details of the implementation of the `panic!` and related macros",
issue = "none"
)]
impl<'a> Location<'a> {
#[doc(hidden)]
pub const fn internal_constructor(file: &'a str, line: u32, col: u32) -> Self {
Location { file, line, col }
}
}
#[stable(feature = "panic_hook_display", since = "1.26.0")]
impl fmt::Display for Location<'_> {
fn fmt(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result {