2017-12-06 18:13:51 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <array>
|
|
|
|
#include <cstring>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
namespace dxvk {
|
|
|
|
|
|
|
|
using Sha1Digest = std::array<uint8_t, 20>;
|
|
|
|
|
|
|
|
class Sha1Hash {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
Sha1Hash() { }
|
|
|
|
Sha1Hash(const Sha1Digest& digest)
|
|
|
|
: m_digest(digest) { }
|
|
|
|
|
|
|
|
std::string toString() const;
|
|
|
|
|
2018-05-03 19:32:08 +02:00
|
|
|
uint32_t dword(uint32_t id) const {
|
|
|
|
return uint32_t(m_digest[4 + id + 0]) << 0
|
|
|
|
| uint32_t(m_digest[4 + id + 1]) << 8
|
|
|
|
| uint32_t(m_digest[4 + id + 2]) << 16
|
|
|
|
| uint32_t(m_digest[4 + id + 3]) << 24;
|
2018-04-06 17:54:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bool operator == (const Sha1Hash& other) const {
|
|
|
|
return !std::memcmp(
|
|
|
|
this->m_digest.data(),
|
|
|
|
other.m_digest.data(),
|
|
|
|
other.m_digest.size());
|
|
|
|
}
|
|
|
|
|
2017-12-06 18:13:51 +01:00
|
|
|
static Sha1Hash compute(
|
|
|
|
const uint8_t* data,
|
|
|
|
size_t size);
|
|
|
|
|
2018-09-21 23:24:17 +02:00
|
|
|
template<typename T>
|
|
|
|
static Sha1Hash compute(const T& data) {
|
|
|
|
auto bytes = reinterpret_cast<const uint8_t*>(&data);
|
|
|
|
return compute(bytes, sizeof(T));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-12-06 18:13:51 +01:00
|
|
|
private:
|
|
|
|
|
|
|
|
Sha1Digest m_digest;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|