/** * \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&) { } }