2011-11-04 16:56:25 +11:00
|
|
|
/*
|
2018-08-04 15:14:06 +10:00
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
2011-11-04 16:56:25 +11:00
|
|
|
*
|
2016-06-20 16:37:43 +10:00
|
|
|
* Copyright 2010-2016 Danny Robson <danny@nerdcruft.net>
|
2011-11-04 16:56:25 +11:00
|
|
|
*/
|
|
|
|
|
2020-10-22 11:27:25 +10:00
|
|
|
#pragma once
|
2011-11-04 16:56:25 +11:00
|
|
|
|
2020-10-22 11:27:25 +10:00
|
|
|
#include "../types/sized.hpp"
|
2018-01-13 13:48:58 +11:00
|
|
|
#include "../view.hpp"
|
2011-11-04 16:56:25 +11:00
|
|
|
|
|
|
|
#include <cstdint>
|
|
|
|
#include <cstdlib>
|
|
|
|
|
2012-05-25 15:19:07 +10:00
|
|
|
|
2016-04-05 11:06:01 +10:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
2018-08-05 14:42:02 +10:00
|
|
|
namespace cruft::hash {
|
2018-01-13 13:48:58 +11:00
|
|
|
template <typename DigestT>
|
2016-06-20 16:37:43 +10:00
|
|
|
class fletcher {
|
|
|
|
public:
|
2018-01-13 13:48:58 +11:00
|
|
|
using digest_t = DigestT;
|
2020-10-22 11:27:25 +10:00
|
|
|
using part_t = typename types::sized::bytes<sizeof (digest_t) / 2>::uint;
|
2016-06-20 16:37:43 +10:00
|
|
|
|
|
|
|
fletcher (part_t modulus, part_t a, part_t b);
|
|
|
|
|
2018-01-13 13:48:58 +11:00
|
|
|
digest_t
|
2018-08-05 14:42:02 +10:00
|
|
|
operator() (cruft::view<const std::uint8_t*>) const noexcept;
|
2016-06-20 16:37:43 +10:00
|
|
|
|
|
|
|
private:
|
|
|
|
struct state_t {
|
|
|
|
part_t a, b;
|
|
|
|
};
|
|
|
|
|
2018-01-13 13:48:58 +11:00
|
|
|
const digest_t m_modulus;
|
2016-06-20 16:37:43 +10:00
|
|
|
const state_t m_initial;
|
|
|
|
};
|
2017-01-05 15:06:49 +11:00
|
|
|
}
|