mirror of
https://github.com/Xevion/easy7zip.git
synced 2025-12-07 18:06:55 -06:00
4.44 beta
This commit is contained in:
committed by
Kornel Lesiński
parent
804edc5756
commit
d9666cf046
39
CPP/7zip/Crypto/AES/AES_CBC.h
Executable file
39
CPP/7zip/Crypto/AES/AES_CBC.h
Executable file
@@ -0,0 +1,39 @@
|
||||
// AES_CBC.h
|
||||
|
||||
#ifndef __AES_CBC_H
|
||||
#define __AES_CBC_H
|
||||
|
||||
#include "aescpp.h"
|
||||
|
||||
class CAES_CBC: public AESclass
|
||||
{
|
||||
protected:
|
||||
Byte _prevBlock[16];
|
||||
public:
|
||||
void Init(const Byte *iv)
|
||||
{
|
||||
for (int i = 0; i < 16; i++)
|
||||
_prevBlock[i] = iv[i];
|
||||
}
|
||||
void Encode(const Byte *inBlock, Byte *outBlock)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; i < 16; i++)
|
||||
_prevBlock[i] ^= inBlock[i];
|
||||
enc_blk(_prevBlock, outBlock);
|
||||
for (i = 0; i < 16; i++)
|
||||
_prevBlock[i] = outBlock[i];
|
||||
}
|
||||
|
||||
void Decode(const Byte *inBlock, Byte *outBlock)
|
||||
{
|
||||
dec_blk(inBlock, outBlock);
|
||||
int i;
|
||||
for (i = 0; i < 16; i++)
|
||||
outBlock[i] ^= _prevBlock[i];
|
||||
for (i = 0; i < 16; i++)
|
||||
_prevBlock[i] = inBlock[i];
|
||||
}
|
||||
};
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user