/* * Parallel Hash * (C) 1999-2009 Jack Lloyd * * Botan is released under the Simplified BSD License (see license.txt) */ #include #include namespace Botan { void Parallel::add_data(const uint8_t input[], size_t length) { for(auto&& hash : m_hashes) hash->update(input, length); } void Parallel::final_result(uint8_t out[]) { uint32_t offset = 0; for(auto&& hash : m_hashes) { hash->final(out + offset); offset += hash->output_length(); } } size_t Parallel::output_length() const { size_t sum = 0; for(auto&& hash : m_hashes) sum += hash->output_length(); return sum; } std::string Parallel::name() const { std::vector names; for(auto&& hash : m_hashes) names.push_back(hash->name()); return "Parallel(" + string_join(names, ',') + ")"; } HashFunction* Parallel::clone() const { std::vector> hash_copies; for(auto&& hash : m_hashes) hash_copies.push_back(std::unique_ptr(hash->clone())); return new Parallel(hash_copies); } std::unique_ptr Parallel::copy_state() const { std::vector> hash_clones; for(const std::unique_ptr& hash : m_hashes) { hash_clones.push_back(hash->copy_state()); } return std::unique_ptr(new Parallel(hash_clones)); } void Parallel::clear() { for(auto&& hash : m_hashes) hash->clear(); } Parallel::Parallel(std::vector>& h) { for(size_t i = 0; i != h.size(); ++i) { m_hashes.push_back(std::unique_ptr(h[i].release())); } } }