use super::WORD_SIZE;
pub struct AsWordsPadded<I>
where
    I: Iterator<Item = u8>,
{
    iter: I,
}
impl<I> Iterator for AsWordsPadded<I>
where
    I: Iterator<Item = u8>,
{
    type Item = u32;
    fn next(&mut self) -> Option<u32> {
        let mut word_bytes: [u8; WORD_SIZE] = [0; WORD_SIZE];
        for i in 0..WORD_SIZE {
            match self.iter.next() {
                Some(val) => {
                    word_bytes[i] = val;
                }
                None => {
                    if i == 0 {
                        return None;
                    }
                }
            }
        }
        Some(u32::from_le_bytes(word_bytes))
    }
}
pub fn as_words_padded<I: IntoIterator<Item = u8>>(
    iter: I,
) -> AsWordsPadded<core::iter::Fuse<I::IntoIter>> {
    AsWordsPadded {
        iter: iter.into_iter().fuse(),
    }
}
#[test]
pub fn test_pads() {
    use alloc::vec::Vec;
    let mut a: Vec<u32> = as_words_padded([]).collect();
    assert_eq!(a, Vec::<u32>::new());
    a = as_words_padded([1]).collect();
    assert_eq!(a, vec![1]);
    a = as_words_padded([1, 3]).collect();
    assert_eq!(a, vec![1 + 3 * 256]);
    a = as_words_padded([1, 3, 5]).collect();
    assert_eq!(a, vec![1 + 3 * 256 + 5 * 256 * 256]);
    a = as_words_padded([1, 3, 5, 7]).collect();
    assert_eq!(a, vec![1 + 3 * 256 + 5 * 256 * 256 + 7 * 256 * 256 * 256]);
    a = as_words_padded([1, 3, 5, 7, 9]).collect();
    assert_eq!(
        a,
        vec![1 + 3 * 256 + 5 * 256 * 256 + 7 * 256 * 256 * 256, 9]
    );
}