libcruft-util/hash/md5.hpp

57 lines
1.5 KiB
C++
Raw Normal View History

2013-03-11 20:45:53 +11:00
/*
2015-04-13 18:05:28 +10:00
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
2013-03-11 20:45:53 +11:00
*
2015-04-13 18:05:28 +10:00
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
2013-03-11 20:45:53 +11:00
*
* Copyright 2013 Danny Robson <danny@nerdcruft.net>
*/
#ifndef __UTIL_HASH_MD5_HPP
#define __UTIL_HASH_MD5_HPP
2013-03-11 20:45:53 +11:00
#include <array>
#include <cstdint>
#include <cstdlib>
2016-06-17 16:20:09 +10:00
///////////////////////////////////////////////////////////////////////////////
2017-01-05 15:06:49 +11:00
namespace util::hash {
2016-06-17 15:57:09 +10:00
class MD5 {
public:
typedef std::array<uint8_t,16> digest_t;
static const size_t BLOCK_SIZE = 64;
static const size_t DIGEST_SIZE = 16;
public:
MD5();
void update (const void *restrict data, size_t len) noexcept;
2016-06-17 15:57:09 +10:00
void update (const uint8_t *restrict first, const uint8_t *restrict last) noexcept;
void finish (void);
digest_t digest (void) const;
void reset (void);
private:
void transform (void);
uint64_t m_total;
std::array<uint32_t, 4> ABCD;
union {
uint32_t X [16];
uint8_t Xb[64];
2013-03-11 20:45:53 +11:00
};
2016-06-17 15:57:09 +10:00
};
2017-01-05 15:06:49 +11:00
}
2013-03-11 20:45:53 +11:00
#endif