mirror of
https://github.com/lifegpc/msg-tool.git
synced 2026-06-07 05:18:44 +08:00
Add NephriteCrypt (tested game: https://vndb.org/v15822 )
This commit is contained in:
@@ -162,6 +162,7 @@ enum CryptType {
|
||||
OkibaCrypt,
|
||||
DieselmineCrypt,
|
||||
DameganeCrypt,
|
||||
NephriteCrypt,
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, Deserialize)]
|
||||
@@ -251,6 +252,7 @@ impl Schema {
|
||||
CryptType::OkibaCrypt => Box::new(OkibaCrypt::new(self.base.clone())),
|
||||
CryptType::DieselmineCrypt => Box::new(DieselmineCrypt::new(self.base.clone())),
|
||||
CryptType::DameganeCrypt => Box::new(DameganeCrypt::new(self.base.clone())),
|
||||
CryptType::NephriteCrypt => Box::new(NephriteCrypt::new(self.base.clone())),
|
||||
})
|
||||
}
|
||||
}
|
||||
@@ -857,6 +859,25 @@ impl<R: Read> Read for DameganeCryptReader<R> {
|
||||
}
|
||||
}
|
||||
|
||||
seek_crypt_filehash_key_u8_impl!(NephriteCrypt, NephriteCryptReader<T>);
|
||||
|
||||
impl<R: Read> Read for NephriteCryptReader<R> {
|
||||
fn read(&mut self, buf: &mut [u8]) -> std::io::Result<usize> {
|
||||
let readed = self.inner.read(buf)?;
|
||||
for (i, t) in (&mut buf[..readed]).iter_mut().enumerate() {
|
||||
let offset = self.seg_start + self.pos + i as u64;
|
||||
let key = if offset & 1 == 0 {
|
||||
self.key
|
||||
} else {
|
||||
offset as u8
|
||||
};
|
||||
*t ^= key;
|
||||
}
|
||||
self.pos += readed as u64;
|
||||
Ok(readed)
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_deserialize_crypt() {
|
||||
for (key, schema) in CRYPT_SCHEMA.iter() {
|
||||
|
||||
Reference in New Issue
Block a user