libcruft-util/hash/ripemd.hpp

59 lines
1.5 KiB
C++
Raw Normal View History

2015-04-13 18:06:08 +10:00
/*
2016-02-26 13:36:01 +11: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
2014-04-10 21:04:07 +10:00
*
2016-02-26 13:36:01 +11:00
* http://www.apache.org/licenses/LICENSE-2.0
2014-04-10 21:04:07 +10:00
*
2016-02-26 13:36:01 +11:00
* 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.
*
* Copyright:
* 2014, Danny Robson <danny@nerdcruft.net>
2014-04-10 21:04:07 +10:00
*/
#ifndef __UTIL_HASH_RIPEMD_HPP
#define __UTIL_HASH_RIPEMD_HPP
#include <array>
2016-06-17 16:20:09 +10:00
///////////////////////////////////////////////////////////////////////////////
2016-06-17 15:57:09 +10:00
namespace util { namespace hash {
class RIPEMD {
public:
typedef std::array<uint8_t,20> digest_t;
public:
RIPEMD();
void update (const void *restrict, size_t) noexcept;
2016-06-17 15:57:09 +10:00
void update (const uint8_t *restrict first, const uint8_t *restrict last) noexcept;
digest_t digest (void) const;
void finish (void);
void reset (void);
protected:
void transform ();
bool m_finished;
uint32_t m_state[5];
uint64_t m_length;
struct {
union {
uint32_t d32[16];
uint8_t d08[64];
};
size_t size;
} m_buffer;
};
} }
2014-04-10 21:04:07 +10:00
#endif