Security Scol plugin
|
Iterated hash base class. More...
#include <iterhash.h>
Public Types | |
typedef T_Endianness | ByteOrderClass |
typedef T_HashWordType | HashWordType |
![]() | |
typedef T | HashWordType |
Public Member Functions | |
CRYPTOPP_CONSTANT (BLOCKSIZE=T_BlockSize) | |
CRYPTOPP_COMPILE_ASSERT ((T_BlockSize &(T_BlockSize - 1))==0) | |
unsigned int | BlockSize () const |
Provides the block size of the hash. | |
ByteOrder | GetByteOrder () const |
Provides the byte order of the hash. | |
void | CorrectEndianess (HashWordType *out, const HashWordType *in, size_t byteCount) |
Adjusts the byte ordering of the hash. | |
![]() | |
IteratedHashBase () | |
Construct an IteratedHashBase. | |
unsigned int | OptimalBlockSize () const |
Provides the input block size most efficient for this cipher. | |
unsigned int | OptimalDataAlignment () const |
Provides input and output data alignment for optimal performance. | |
void | Update (const byte *input, size_t length) |
Updates a hash with additional input. | |
byte * | CreateUpdateSpace (size_t &size) |
Requests space which can be written into by the caller. | |
void | Restart () |
Restart the hash. | |
void | TruncatedFinal (byte *digest, size_t digestSize) |
Computes the hash of the current message. | |
virtual std::string | AlgorithmProvider () const |
Retrieve the provider of this algorithm. | |
Protected Types | |
enum | { Blocks = T_BlockSize/sizeof(T_HashWordType) } |
Protected Member Functions | |
T_HashWordType * | DataBuf () |
![]() | |
T | GetBitCountHi () const |
T | GetBitCountLo () const |
void | PadLastBlock (unsigned int lastBlockSize, byte padFirst=0x80) |
virtual void | Init ()=0 |
virtual void | HashEndianCorrectedBlock (const HashWordType *data)=0 |
virtual size_t | HashMultipleBlocks (const T *input, size_t length) |
void | HashBlock (const HashWordType *input) |
virtual T * | StateBuf ()=0 |
Protected Attributes | |
FixedSizeSecBlock< T_HashWordType, Blocks > | m_data |
Iterated hash base class.
T_HashWordType | Hash word type |
T_Endianness | Endianness type of hash |
T_BlockSize | Block size of the hash |
T_Base | HashTransformation derived class |
IteratedHash provides a default implementation for block-based iterated hashes
Definition at line 126 of file iterhash.h.
typedef T_Endianness IteratedHash< T_HashWordType, T_Endianness, T_BlockSize, T_Base >::ByteOrderClass |
Definition at line 129 of file iterhash.h.
typedef T_HashWordType IteratedHash< T_HashWordType, T_Endianness, T_BlockSize, T_Base >::HashWordType |
Definition at line 130 of file iterhash.h.
|
protected |
Definition at line 165 of file iterhash.h.
|
inlinevirtual |
Definition at line 136 of file iterhash.h.
|
inline |
Provides the block size of the hash.
BlockSize() returns T_BlockSize
.
Definition at line 141 of file iterhash.h.
|
inline |
Adjusts the byte ordering of the hash.
out | the output buffer |
in | the input buffer |
byteCount | the size of the buffers, in bytes |
CorrectEndianess() calls ConditionalByteReverse() using T_Endianness
.
Definition at line 154 of file iterhash.h.
|
inlineprotectedvirtual |
Implements IteratedHashBase< T, BASE >.
Definition at line 166 of file iterhash.h.
|
inlinevirtual |
Provides the byte order of the hash.
GetByteOrder() returns T_Endianness::ToEnum()
.
Implements IteratedHashBase< T, BASE >.
Definition at line 147 of file iterhash.h.
|
protected |
Definition at line 167 of file iterhash.h.