Better debug display.

This commit is contained in:
Stephen Chung 2021-03-09 14:00:21 +08:00
parent 975bb3d6bf
commit b78c6ddf62
2 changed files with 25 additions and 6 deletions

View File

@ -1102,7 +1102,7 @@ pub struct OpAssignment {
/// # Volatile Data Structure /// # Volatile Data Structure
/// ///
/// This type is volatile and may change. /// This type is volatile and may change.
#[derive(Debug, Clone, Copy, Eq, PartialEq, Hash, Default)] #[derive(Clone, Copy, Eq, PartialEq, Hash, Default)]
pub struct FnHash { pub struct FnHash {
/// Pre-calculated hash for a script-defined function ([`None`] if native functions only). /// Pre-calculated hash for a script-defined function ([`None`] if native functions only).
script: Option<u64>, script: Option<u64>,
@ -1110,6 +1110,20 @@ pub struct FnHash {
native: u64, native: u64,
} }
impl fmt::Debug for FnHash {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
if let Some(script) = self.script {
if script == self.native {
write!(f, "({}=={})", script, self.native)
} else {
write!(f, "({}, {})", script, self.native)
}
} else {
write!(f, "{}", self.native)
}
}
}
impl FnHash { impl FnHash {
/// Create a [`FnHash`] with only the native Rust hash. /// Create a [`FnHash`] with only the native Rust hash.
#[inline(always)] #[inline(always)]

View File

@ -2022,13 +2022,18 @@ pub struct NamespaceRef {
impl fmt::Debug for NamespaceRef { impl fmt::Debug for NamespaceRef {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt::Debug::fmt(&self.path, f)?;
if let Some(index) = self.index { if let Some(index) = self.index {
write!(f, " -> {}", index) write!(f, "{} -> ", index)?;
} else {
Ok(())
} }
f.write_str(
&self
.path
.iter()
.map(|Ident { name, .. }| name.as_str())
.collect::<Vec<_>>()
.join("::"),
)
} }
} }