8#include <botan/internal/sha3.h>
10#include <botan/exceptn.h>
11#include <botan/internal/fmt.h>
12#include <botan/internal/keccak_perm.h>
13#include <botan/internal/loadstor.h>
17SHA_3::SHA_3(
size_t output_bits) : m_keccak(2 * output_bits, 2, 2), m_output_length(output_bits / 8) {
20 if(output_bits != 224 && output_bits != 256 && output_bits != 384 && output_bits != 512) {
26 return fmt(
"SHA-3({})", m_output_length * 8);
30 return m_keccak.provider();
34 return std::make_unique<SHA_3>(*
this);
38 return std::make_unique<SHA_3>(m_output_length * 8);
45void SHA_3::add_data(std::span<const uint8_t> input) {
49void SHA_3::final_result(std::span<uint8_t> output) {
void squeeze(std::span< uint8_t > output)
Expand output data from the current Keccak state.
void absorb(std::span< const uint8_t > input)
Absorb input data into the Keccak sponge.
void finish()
Add final padding (as provided in the constructor) and permute.
SHA_3(size_t output_bits)
std::unique_ptr< HashFunction > new_object() const override
std::string provider() const override
std::string name() const override
std::unique_ptr< HashFunction > copy_state() const override
std::string fmt(std::string_view format, const T &... args)