From 0c593583dccd88e90450972e6a1b9e6bc67e0911 Mon Sep 17 00:00:00 2001 From: Egor Tensin Date: Tue, 4 Aug 2015 04:37:12 +0300 Subject: utils: bugfix & refactoring --- utils/block_dumper.hpp | 108 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 108 insertions(+) create mode 100644 utils/block_dumper.hpp (limited to 'utils/block_dumper.hpp') diff --git a/utils/block_dumper.hpp b/utils/block_dumper.hpp new file mode 100644 index 0000000..a473cd1 --- /dev/null +++ b/utils/block_dumper.hpp @@ -0,0 +1,108 @@ +/** + * \file + * \author Egor Tensin + * \date 2015 + * \copyright This file is licensed under the terms of the MIT License. + * See LICENSE.txt for details. + */ + +#pragma once + +#include + +#include + +#include +#include + +namespace +{ + template + void dump_block(const char* name, const typename aesni::Types::Block& block) + { + std::cout << name << ": " << aesni::to_string(block) << "\n" << aesni::to_matrix_string(block) << "\n"; + } + + template + void dump_plaintext(const typename aesni::Types::Block& block) + { + dump_block("Plaintext", block); + } + + template + void dump_key(const typename aesni::Types::Key& key) + { + std::cout << "Key: " << aesni::to_string(key) << "\n\n"; + } + + template + void dump_ciphertext(const typename aesni::Types::Block& ciphertext) + { + dump_block("Ciphertext", ciphertext); + } + + template + void dump_iv(const typename aesni::Types::Block& iv) + { + dump_block("Initialization vector", iv); + } + + template + void dump_round_keys(const char* name, const typename aesni::Types::RoundKeys& round_keys) + { + std::cout << name << ":\n"; + for (std::size_t i = 0; i < aesni::get_number_of_rounds(); ++i) + std::cout << "\t[" << i << "]: " << aesni::to_string(round_keys.keys[i]) << "\n"; + std::cout << "\n"; + } + + template + void dump_encryption_keys(const typename aesni::Types::RoundKeys& round_keys) + { + dump_round_keys("Encryption round keys", round_keys); + } + + template + void dump_decryption_keys(const typename aesni::Types::RoundKeys& round_keys) + { + dump_round_keys("Decryption round keys", round_keys); + } + + template + void dump_wrapper( + const aesni::EncryptWrapper& wrapper) + { + dump_encryption_keys(wrapper.encryption_keys); + } + + template + void dump_wrapper( + const aesni::DecryptWrapper& wrapper) + { + dump_decryption_keys(wrapper.decryption_keys); + } + + template ::value>::type* = 0> + void dump_next_iv( + const aesni::EncryptWrapper& wrapper) + { + dump_block("Next initialization vector", wrapper.iv); + } + + template ::value>::type* = 0> + void dump_next_iv( + const aesni::EncryptWrapper&) + { } + + template ::value>::type* = 0> + void dump_next_iv( + const aesni::DecryptWrapper& wrapper) + { + dump_block("Next initialization vector", wrapper.iv); + } + + template ::value>::type* = 0> + void dump_next_iv( + const aesni::DecryptWrapper&) + { } +} -- cgit v1.2.3