Add NatsupochiCrypt (untested)

This commit is contained in:
2026-04-09 12:56:18 +08:00
parent d4c5c76dc7
commit c81689961c
2 changed files with 57 additions and 1 deletions

View File

@@ -164,6 +164,7 @@ enum CryptType {
DameganeCrypt,
NephriteCrypt,
AlteredPinkCrypt,
NatsupochiCrypt,
}
#[derive(Clone, Debug, Deserialize)]
@@ -255,6 +256,7 @@ impl Schema {
CryptType::DameganeCrypt => Box::new(DameganeCrypt::new(self.base.clone())),
CryptType::NephriteCrypt => Box::new(NephriteCrypt::new(self.base.clone())),
CryptType::AlteredPinkCrypt => Box::new(AlteredPinkCrypt::new(self.base.clone())),
CryptType::NatsupochiCrypt => Box::new(NatsupochiCrypt::new(self.base.clone())),
})
}
}
@@ -880,7 +882,7 @@ impl<R: Read> Read for NephriteCryptReader<R> {
}
}
seek_crypt_filehash_key_u8_impl!(AlteredPinkCrypt, AlteredPinkCryptReader<T>);
seek_crypt_impl!(AlteredPinkCrypt, AlteredPinkCryptReader<T>);
impl<R: Read> Read for AlteredPinkCryptReader<R> {
fn read(&mut self, buf: &mut [u8]) -> std::io::Result<usize> {
@@ -894,6 +896,20 @@ impl<R: Read> Read for AlteredPinkCryptReader<R> {
}
}
seek_crypt_filehash_key_impl!(NatsupochiCrypt, NatsupochiCryptReader<T>);
impl<R: Read> Read for NatsupochiCryptReader<R> {
fn read(&mut self, buf: &mut [u8]) -> std::io::Result<usize> {
let readed = self.inner.read(buf)?;
let key = (self.key >> 3) as u8;
for t in (&mut buf[..readed]).iter_mut() {
*t ^= key;
}
self.pos += readed as u64;
Ok(readed)
}
}
#[test]
fn test_deserialize_crypt() {
for (key, schema) in CRYPT_SCHEMA.iter() {