8#include <botan/internal/comb4p.h>
10#include <botan/exceptn.h>
11#include <botan/internal/fmt.h>
12#include <botan/internal/stl_util.h>
26 h1.update(in.data(), in.size());
27 h2.update(in.data(), in.size());
30 xor_buf(out.data(), h_buf.data(), std::min(out.size(), h_buf.size()));
33 xor_buf(out.data(), h_buf.data(), std::min(out.size(), h_buf.size()));
38Comb4P::Comb4P(std::unique_ptr<HashFunction> h1, std::unique_ptr<HashFunction> h2) :
39 m_hash1(std::move(h1)), m_hash2(std::move(h2)) {
40 if(m_hash1->name() == m_hash2->name()) {
41 throw Invalid_Argument(
"Comb4P: Must use two distinct hashes");
44 if(m_hash1->output_length() != m_hash2->output_length()) {
45 throw Invalid_Argument(fmt(
"Comb4P: Incompatible hashes {} and {}", m_hash1->name(), m_hash2->name()));
52 return fmt(
"Comb4P({},{})", m_hash1->name(), m_hash2->name());
56 return std::make_unique<Comb4P>(m_hash1->new_object(), m_hash2->new_object());
60 if(m_hash1->hash_block_size() == m_hash2->hash_block_size()) {
61 return m_hash1->hash_block_size();
82 std::unique_ptr<Comb4P> copy(
new Comb4P);
83 copy->m_hash1 = m_hash1->copy_state();
84 copy->m_hash2 = m_hash2->copy_state();
88void Comb4P::add_data(std::span<const uint8_t> input) {
89 m_hash1->update(input);
90 m_hash2->update(input);
93void Comb4P::final_result(std::span<uint8_t> output) {
98 xor_buf(h1.data(), h2.data(), std::min(h1.size(), h2.size()));
101 comb4p_round(h2, h1, 1, *m_hash1, *m_hash2);
104 comb4p_round(h1, h2, 2, *m_hash1, *m_hash2);
106 BufferStuffer out(output);
107 copy_mem(out.next(h1.size()).data(), h1.data(), h1.size());
108 copy_mem(out.next(h2.size()).data(), h2.data(), h2.size());
std::unique_ptr< HashFunction > new_object() const override
std::unique_ptr< HashFunction > copy_state() const override
std::string name() const override
size_t hash_block_size() const override
std::string fmt(std::string_view format, const T &... args)
constexpr void xor_buf(ranges::contiguous_output_range< uint8_t > auto &&out, ranges::contiguous_range< uint8_t > auto &&in)
std::vector< T, secure_allocator< T > > secure_vector
constexpr void copy_mem(T *out, const T *in, size_t n)