mirror of
https://github.com/matrix-construct/construct
synced 2025-01-15 17:16:49 +01:00
ircd::crh: Improve hash related interface; comments etc.
This commit is contained in:
parent
deb40ae5c1
commit
5c69d3df5a
3 changed files with 64 additions and 20 deletions
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue