6 #ifndef CRYPTOPP_IMPORTS
11 const byte* recoverableMessage,
size_t recoverableMessageLength,
13 byte *representative,
size_t representativeBitLength)
const
15 CRYPTOPP_UNUSED(recoverableMessage), CRYPTOPP_UNUSED(recoverableMessageLength), CRYPTOPP_UNUSED(representativeBitLength);
16 assert(representativeBitLength >= MinRepresentativeBitLength(hashIdentifier.second, hash.
DigestSize()));
18 if (representativeBitLength % 8 != 7)
22 size_t representativeByteLength =
BitsToBytes(representativeBitLength);
24 representative[0] = messageEmpty ? 0x4b : 0x6b;
25 memset(representative+1, 0xbb, representativeByteLength-digestSize-4);
26 byte *afterP2 = representative+representativeByteLength-digestSize-3;
28 hash.
Final(afterP2+1);
29 representative[representativeByteLength-2] = *hashIdentifier.first;
30 representative[representativeByteLength-1] = 0xcc;