Adler32.cpp 493 B

1234567891011121314151617181920212223242526
  1. /*
  2. * Copyright (c) 2020, the SerenityOS developers.
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <AK/Span.h>
  7. #include <AK/Types.h>
  8. #include <LibCrypto/Checksum/Adler32.h>
  9. namespace Crypto::Checksum {
  10. void Adler32::update(ReadonlyBytes data)
  11. {
  12. for (size_t i = 0; i < data.size(); i++) {
  13. m_state_a = (m_state_a + data.at(i)) % 65521;
  14. m_state_b = (m_state_b + m_state_a) % 65521;
  15. }
  16. }
  17. u32 Adler32::digest()
  18. {
  19. return (m_state_b << 16) | m_state_a;
  20. }
  21. }