use alloc::string::String;
use alloc::vec::Vec;
#[inline]
pub fn get_leading_zero_bits<T>(h: T) -> u8
where
T: AsRef<[u8]>,
{
let mut res: u8 = 0u8;
for b in h.as_ref().iter() {
if *b == 0 {
res += 8;
} else {
res += b.leading_zeros() as u8;
return res;
}
}
res
}
pub fn get_prefixes_for_difficulty(leading_zero_bits: u8) -> Vec<String> {
let mut r = Vec::new();
if leading_zero_bits == 0 {
return r;
}
let prefix_hex_len = if leading_zero_bits % 4 == 0 {
leading_zero_bits / 4
} else {
leading_zero_bits / 4 + 1
};
let prefix_bits: u16 = prefix_hex_len as u16 * 4;
for i in 0..2_u8.pow((prefix_bits - leading_zero_bits as u16) as u32) {
let p = format!("{:01$x}", i, prefix_hex_len as usize); r.push(p);
}
r
}
#[cfg(test)]
pub mod tests {
use core::str::FromStr;
use hashes::sha256::Hash as Sha256Hash;
use super::*;
#[test]
fn check_get_leading_zeroes() {
assert_eq!(
4,
get_leading_zero_bits(
Sha256Hash::from_str(
"0fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
3,
get_leading_zero_bits(
Sha256Hash::from_str(
"1fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"2fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"3fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
1,
get_leading_zero_bits(
Sha256Hash::from_str(
"4fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
1,
get_leading_zero_bits(
Sha256Hash::from_str(
"5fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
1,
get_leading_zero_bits(
Sha256Hash::from_str(
"6fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
1,
get_leading_zero_bits(
Sha256Hash::from_str(
"7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
0,
get_leading_zero_bits(
Sha256Hash::from_str(
"8fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
0,
get_leading_zero_bits(
Sha256Hash::from_str(
"9fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
0,
get_leading_zero_bits(
Sha256Hash::from_str(
"afffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
0,
get_leading_zero_bits(
Sha256Hash::from_str(
"bfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
0,
get_leading_zero_bits(
Sha256Hash::from_str(
"cfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
0,
get_leading_zero_bits(
Sha256Hash::from_str(
"dfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
0,
get_leading_zero_bits(
Sha256Hash::from_str(
"efffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
0,
get_leading_zero_bits(
Sha256Hash::from_str(
"ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"20ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"21ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"22ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"23ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"24ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"25ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"26ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"27ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"28ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"29ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"2affffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"2bffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"2cffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"2dffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"2effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
2,
get_leading_zero_bits(
Sha256Hash::from_str(
"2fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
)
.unwrap()
)
);
assert_eq!(
248,
get_leading_zero_bits(
Sha256Hash::from_str(
"00000000000000000000000000000000000000000000000000000000000000ff"
)
.unwrap()
)
);
assert_eq!(
252,
get_leading_zero_bits(
Sha256Hash::from_str(
"000000000000000000000000000000000000000000000000000000000000000f"
)
.unwrap()
)
);
assert_eq!(
255,
get_leading_zero_bits(
Sha256Hash::from_str(
"0000000000000000000000000000000000000000000000000000000000000001"
)
.unwrap()
)
);
}
#[test]
fn check_find_prefixes_for_pow() {
assert!(get_prefixes_for_difficulty(0).is_empty());
assert_eq!(
get_prefixes_for_difficulty(1),
vec!["0", "1", "2", "3", "4", "5", "6", "7"]
);
assert_eq!(get_prefixes_for_difficulty(2), vec!["0", "1", "2", "3"]);
assert_eq!(get_prefixes_for_difficulty(3), vec!["0", "1"]);
assert_eq!(get_prefixes_for_difficulty(4), vec!["0"]);
assert_eq!(
get_prefixes_for_difficulty(5),
vec!["00", "01", "02", "03", "04", "05", "06", "07"]
);
assert_eq!(get_prefixes_for_difficulty(6), vec!["00", "01", "02", "03"]);
assert_eq!(get_prefixes_for_difficulty(7), vec!["00", "01"]);
assert_eq!(get_prefixes_for_difficulty(8), vec!["00"]);
assert_eq!(
get_prefixes_for_difficulty(9),
vec!["000", "001", "002", "003", "004", "005", "006", "007"]
);
assert_eq!(
get_prefixes_for_difficulty(10),
vec!["000", "001", "002", "003"]
);
assert_eq!(get_prefixes_for_difficulty(11), vec!["000", "001"]);
assert_eq!(get_prefixes_for_difficulty(12), vec!["000"]);
assert_eq!(
get_prefixes_for_difficulty(254),
vec![
"0000000000000000000000000000000000000000000000000000000000000000",
"0000000000000000000000000000000000000000000000000000000000000001",
"0000000000000000000000000000000000000000000000000000000000000002",
"0000000000000000000000000000000000000000000000000000000000000003"
]
);
assert_eq!(
get_prefixes_for_difficulty(255),
vec![
"0000000000000000000000000000000000000000000000000000000000000000",
"0000000000000000000000000000000000000000000000000000000000000001"
]
);
}
}