use std::str::FromStr;
use hex::FromHex;
use hex::ToHex;
use serde_with::DeserializeFromStr;
use serde_with::SerializeDisplay;
use crate::RANDOMX_RESULT_SIZE;
pub type DifficultyInner = [u8; RANDOMX_RESULT_SIZE];
#[derive(Copy, Clone, Hash, PartialEq, Eq, SerializeDisplay, DeserializeFromStr, Default)]
#[repr(transparent)]
pub struct Difficulty(DifficultyInner);
impl Difficulty {
pub fn new(inner: DifficultyInner) -> Self {
Self(inner)
}
}
impl AsRef<DifficultyInner> for Difficulty {
fn as_ref(&self) -> &DifficultyInner {
&self.0
}
}
impl FromHex for Difficulty {
type Error = <DifficultyInner as FromHex>::Error;
fn from_hex<T: AsRef<[u8]>>(hex: T) -> Result<Self, Self::Error> {
DifficultyInner::from_hex(hex).map(Self)
}
}
impl PartialEq<Difficulty> for DifficultyInner {
fn eq(&self, other: &Difficulty) -> bool {
self.eq(&other.0)
}
}
impl PartialOrd<Difficulty> for DifficultyInner {
fn partial_cmp(&self, other: &Difficulty) -> Option<std::cmp::Ordering> {
self.partial_cmp(&other.0)
}
}
impl ToHex for Difficulty {
fn encode_hex<T: std::iter::FromIterator<char>>(&self) -> T {
ToHex::encode_hex(&self.0)
}
fn encode_hex_upper<T: std::iter::FromIterator<char>>(&self) -> T {
ToHex::encode_hex_upper(&self.0)
}
}
impl FromStr for Difficulty {
type Err = hex::FromHexError;
fn from_str(s: &str) -> Result<Self, Self::Err> {
FromHex::from_hex(s)
}
}
use std::fmt;
impl fmt::Display for Difficulty {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.write_str(&self.encode_hex::<String>())
}
}
impl fmt::Debug for Difficulty {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.debug_tuple("Difficulty")
.field(&self.to_string())
.finish()
}
}