cipher 0.5.1

Traits for describing block ciphers and stream ciphers
Documentation
use common::{Block, BlockSizeUser, array::ArraySize};
use inout::InOut;

use super::{
    Tweak, TweakBlockCipherDecBackend, TweakBlockCipherDecClosure, TweakBlockCipherEncBackend,
    TweakBlockCipherEncClosure, TweakSizeUser,
};

/// Closure used in methods which operate over separate blocks.
pub(super) struct BlockCtx<'a, TS: ArraySize, BS: ArraySize> {
    pub tweak: &'a Tweak<Self>,
    pub block: InOut<'a, 'a, Block<Self>>,
}

impl<TS: ArraySize, BS: ArraySize> BlockSizeUser for BlockCtx<'_, TS, BS> {
    type BlockSize = BS;
}

impl<TS: ArraySize, BS: ArraySize> TweakSizeUser for BlockCtx<'_, TS, BS> {
    type TweakSize = TS;
}

impl<TS: ArraySize, BS: ArraySize> TweakBlockCipherEncClosure for BlockCtx<'_, TS, BS> {
    #[inline]
    fn call<B>(self, backend: &B)
    where
        B: TweakBlockCipherEncBackend<BlockSize = BS, TweakSize = TS>,
    {
        backend.encrypt_block_inout(self.tweak, self.block);
    }
}

impl<TS: ArraySize, BS: ArraySize> TweakBlockCipherDecClosure for BlockCtx<'_, TS, BS> {
    #[inline]
    fn call<B>(self, backend: &B)
    where
        B: TweakBlockCipherDecBackend<BlockSize = BS, TweakSize = TS>,
    {
        backend.decrypt_block_inout(self.tweak, self.block);
    }
}