0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-25 05:49:58 +01:00

ircd::crh: Improve hash related interface; comments etc.

This commit is contained in:
Jason Volk 2017-10-05 18:33:46 -07:00
parent deb40ae5c1
commit 5c69d3df5a
3 changed files with 64 additions and 20 deletions

View file

@ -38,8 +38,7 @@ namespace ircd
size_t hash(const std::u16string &str, const size_t i = 0); size_t hash(const std::u16string &str, const size_t i = 0);
size_t hash(const std::string_view &str, const size_t i = 0); size_t hash(const std::string_view &str, const size_t i = 0);
/// ircd reserves the $ character (in our namespace of course) as an alias /// ircd:: reserves the $ character over a string as an alias for hash()
/// for hashing string literals at compile time.
template<class string> template<class string>
constexpr size_t $(string&& s) constexpr size_t $(string&& s)
{ {
@ -71,25 +70,39 @@ namespace ircd
/// Use this type when dealing with algorithm-agnostic hashing. /// Use this type when dealing with algorithm-agnostic hashing.
struct ircd::crh::hash struct ircd::crh::hash
{ {
/// Returns the byte length of the mutable_raw_buffer for digests
virtual size_t length() const = 0; virtual size_t length() const = 0;
virtual void finalize(const mutable_raw_buffer &) = 0;
virtual void extract(const mutable_raw_buffer &) const = 0; /// Samples the digest at the current state (without modifying)
virtual void digest(const mutable_raw_buffer &) const = 0;
/// Samples the digest and modifies the state (depending on impl)
virtual void finalize(const mutable_raw_buffer &b)
{
digest(b);
}
/// Appends to the message
virtual void update(const const_raw_buffer &) = 0; virtual void update(const const_raw_buffer &) = 0;
// conveniences // conveniences for output
void finalize(const mutable_raw_buffer &) const; template<size_t SIZE> fixed_const_raw_buffer<SIZE> digest() const;
template<size_t SIZE> operator fixed_const_raw_buffer<SIZE>() const;
// conveniences for input
void operator()(const mutable_raw_buffer &out, const const_raw_buffer &in); void operator()(const mutable_raw_buffer &out, const const_raw_buffer &in);
hash &operator+=(const const_raw_buffer &); hash &operator+=(const const_raw_buffer &);
virtual ~hash() noexcept; virtual ~hash() noexcept;
}; };
/// SHA-256 hashing device.
struct ircd::crh::sha256 struct ircd::crh::sha256
:hash :hash
{ {
struct ctx; struct ctx;
static constexpr const size_t bytes static constexpr const size_t digest_size
{ {
256 / 8 256 / 8
}; };
@ -98,16 +111,43 @@ struct ircd::crh::sha256
std::unique_ptr<ctx> ctx; std::unique_ptr<ctx> ctx;
public: public:
size_t length() const override; size_t length() const override final;
void finalize(const mutable_raw_buffer &) override; void digest(const mutable_raw_buffer &) const override final;
void extract(const mutable_raw_buffer &) const override; void finalize(const mutable_raw_buffer &) override final;
void update(const const_raw_buffer &) override; void update(const const_raw_buffer &) override final;
sha256(const mutable_raw_buffer &, const const_raw_buffer &); sha256(const mutable_raw_buffer &, const const_raw_buffer &);
sha256(const const_raw_buffer &);
sha256(); sha256();
~sha256() noexcept; ~sha256() noexcept;
}; };
/// Automatic gratification from hash::digest()
template<size_t SIZE>
ircd::crh::hash::operator
fixed_const_raw_buffer<SIZE>()
const
{
return digest<SIZE>();
}
/// Digests the hash into the buffer of the specified SIZE and returns it
template<size_t SIZE>
ircd::fixed_const_raw_buffer<SIZE>
ircd::crh::hash::digest()
const
{
assert(SIZE >= length());
return fixed_const_raw_buffer<SIZE>
{
[this](const auto &buffer)
{
this->digest(buffer);
}
};
}
/// Runtime hashing of a string_view. Non-cryptographic.
inline size_t inline size_t
ircd::hash(const std::string_view &str, ircd::hash(const std::string_view &str,
const size_t i) const size_t i)
@ -115,6 +155,7 @@ ircd::hash(const std::string_view &str,
return i >= str.size()? 7681ULL : (hash(str, i+1) * 33ULL) ^ str.at(i); return i >= str.size()? 7681ULL : (hash(str, i+1) * 33ULL) ^ str.at(i);
} }
/// Runtime hashing of a std::u16string (for js). Non-cryptographic.
inline size_t inline size_t
ircd::hash(const std::u16string &str, ircd::hash(const std::u16string &str,
const size_t i) const size_t i)
@ -122,6 +163,7 @@ ircd::hash(const std::u16string &str,
return i >= str.size()? 7681ULL : (hash(str, i+1) * 33ULL) ^ str.at(i); return i >= str.size()? 7681ULL : (hash(str, i+1) * 33ULL) ^ str.at(i);
} }
/// Runtime hashing of a std::string. Non-cryptographic.
inline size_t inline size_t
ircd::hash(const std::string &str, ircd::hash(const std::string &str,
const size_t i) const size_t i)
@ -129,6 +171,7 @@ ircd::hash(const std::string &str,
return i >= str.size()? 7681ULL : (hash(str, i+1) * 33ULL) ^ str.at(i); return i >= str.size()? 7681ULL : (hash(str, i+1) * 33ULL) ^ str.at(i);
} }
/// Compile-time hashing of a wider string literal (for js). Non-cryptographic.
constexpr size_t constexpr size_t
ircd::hash(const char16_t *const &str, ircd::hash(const char16_t *const &str,
const size_t i) const size_t i)
@ -136,6 +179,7 @@ ircd::hash(const char16_t *const &str,
return !str[i]? 7681ULL : (hash(str, i+1) * 33ULL) ^ str[i]; return !str[i]? 7681ULL : (hash(str, i+1) * 33ULL) ^ str[i];
} }
/// Compile-time hashing of a string literal. Non-cryptographic.
constexpr size_t constexpr size_t
ircd::hash(const char *const &str, ircd::hash(const char *const &str,
const size_t i) const size_t i)

View file

@ -44,13 +44,6 @@ ircd::crh::hash::operator()(const mutable_raw_buffer &out,
finalize(out); finalize(out);
} }
void
ircd::crh::hash::finalize(const mutable_raw_buffer &buf)
const
{
extract(buf);
}
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
// //
// rand.h // rand.h

View file

@ -76,6 +76,13 @@ ircd::crh::sha256::sha256()
{ {
} }
/// One-shot functor. Immediately calls update(); no output
ircd::crh::sha256::sha256(const const_raw_buffer &in)
:sha256{}
{
update(in);
}
/// One-shot functor. Immediately calls operator(). /// One-shot functor. Immediately calls operator().
ircd::crh::sha256::sha256(const mutable_raw_buffer &out, ircd::crh::sha256::sha256(const mutable_raw_buffer &out,
const const_raw_buffer &in) const const_raw_buffer &in)
@ -96,7 +103,7 @@ ircd::crh::sha256::update(const const_raw_buffer &buf)
} }
void void
ircd::crh::sha256::extract(const mutable_raw_buffer &buf) ircd::crh::sha256::digest(const mutable_raw_buffer &buf)
const const
{ {
auto copy(*ctx); auto copy(*ctx);
@ -113,7 +120,7 @@ size_t
ircd::crh::sha256::length() ircd::crh::sha256::length()
const const
{ {
return bytes; return digest_size;
} }
void void