fix(3p/nix/hash): smart pointers in HashSink
Change-Id: Ib2aaf42c8b234ee343c4653eb03f328c113dea86 Reviewed-on: https://cl.tvl.fyi/c/depot/+/1492 Tested-by: BuildkiteCI Reviewed-by: glittershark <grfn@gws.fyi>
This commit is contained in:
parent
e8f893ee10
commit
addcba11b0
2 changed files with 18 additions and 17 deletions
27
third_party/nix/src/libutil/hash.cc
vendored
27
third_party/nix/src/libutil/hash.cc
vendored
|
@ -280,6 +280,8 @@ absl::StatusOr<Hash> Hash::deserialize(const std::string& s, HashType type) {
|
||||||
return dest;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace hash {
|
||||||
|
|
||||||
union Ctx {
|
union Ctx {
|
||||||
MD5_CTX md5;
|
MD5_CTX md5;
|
||||||
SHA_CTX sha1;
|
SHA_CTX sha1;
|
||||||
|
@ -324,8 +326,10 @@ static void finish(HashType ht, Ctx& ctx, unsigned char* hash) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} // namespace hash
|
||||||
|
|
||||||
Hash hashString(HashType ht, const std::string& s) {
|
Hash hashString(HashType ht, const std::string& s) {
|
||||||
Ctx ctx{};
|
hash::Ctx ctx{};
|
||||||
Hash hash(ht);
|
Hash hash(ht);
|
||||||
start(ht, ctx);
|
start(ht, ctx);
|
||||||
update(ht, ctx, reinterpret_cast<const unsigned char*>(s.data()), s.length());
|
update(ht, ctx, reinterpret_cast<const unsigned char*>(s.data()), s.length());
|
||||||
|
@ -334,7 +338,7 @@ Hash hashString(HashType ht, const std::string& s) {
|
||||||
}
|
}
|
||||||
|
|
||||||
Hash hashFile(HashType ht, const Path& path) {
|
Hash hashFile(HashType ht, const Path& path) {
|
||||||
Ctx ctx{};
|
hash::Ctx ctx{};
|
||||||
Hash hash(ht);
|
Hash hash(ht);
|
||||||
start(ht, ctx);
|
start(ht, ctx);
|
||||||
|
|
||||||
|
@ -357,34 +361,27 @@ Hash hashFile(HashType ht, const Path& path) {
|
||||||
return hash;
|
return hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
HashSink::HashSink(HashType ht) : ht(ht) {
|
HashSink::HashSink(HashType ht) : ht(ht), ctx(), bytes(0) { start(ht, *ctx); }
|
||||||
ctx = new Ctx;
|
|
||||||
bytes = 0;
|
|
||||||
start(ht, *ctx);
|
|
||||||
}
|
|
||||||
|
|
||||||
HashSink::~HashSink() {
|
HashSink::~HashSink() { bufPos = 0; }
|
||||||
bufPos = 0;
|
|
||||||
delete ctx;
|
|
||||||
}
|
|
||||||
|
|
||||||
void HashSink::write(const unsigned char* data, size_t len) {
|
void HashSink::write(const unsigned char* data, size_t len) {
|
||||||
bytes += len;
|
bytes += len;
|
||||||
update(ht, *ctx, data, len);
|
nix::hash::update(ht, *ctx, data, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
HashResult HashSink::finish() {
|
HashResult HashSink::finish() {
|
||||||
flush();
|
flush();
|
||||||
Hash hash(ht);
|
Hash hash(ht);
|
||||||
nix::finish(ht, *ctx, hash.hash);
|
nix::hash::finish(ht, *ctx, hash.hash);
|
||||||
return HashResult(hash, bytes);
|
return HashResult(hash, bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
HashResult HashSink::currentHash() {
|
HashResult HashSink::currentHash() {
|
||||||
flush();
|
flush();
|
||||||
Ctx ctx2 = *ctx;
|
nix::hash::Ctx ctx2 = *ctx;
|
||||||
Hash hash(ht);
|
Hash hash(ht);
|
||||||
nix::finish(ht, ctx2, hash.hash);
|
nix::hash::finish(ht, ctx2, hash.hash);
|
||||||
return HashResult(hash, bytes);
|
return HashResult(hash, bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
8
third_party/nix/src/libutil/hash.hh
vendored
8
third_party/nix/src/libutil/hash.hh
vendored
|
@ -88,9 +88,11 @@ Hash hashString(HashType ht, const std::string& s);
|
||||||
/* Compute the hash of the given file. */
|
/* Compute the hash of the given file. */
|
||||||
Hash hashFile(HashType ht, const Path& path);
|
Hash hashFile(HashType ht, const Path& path);
|
||||||
|
|
||||||
|
/* A pair of the Hash, and the number of bytes consumed. */
|
||||||
|
typedef std::pair<Hash, unsigned long long> HashResult;
|
||||||
|
|
||||||
/* Compute the hash of the given path. The hash is defined as
|
/* Compute the hash of the given path. The hash is defined as
|
||||||
(essentially) hashString(ht, dumpPath(path)). */
|
(essentially) hashString(ht, dumpPath(path)). */
|
||||||
typedef std::pair<Hash, unsigned long long> HashResult;
|
|
||||||
HashResult hashPath(HashType ht, const Path& path,
|
HashResult hashPath(HashType ht, const Path& path,
|
||||||
PathFilter& filter = defaultPathFilter);
|
PathFilter& filter = defaultPathFilter);
|
||||||
|
|
||||||
|
@ -104,12 +106,14 @@ HashType parseHashType(const std::string& s);
|
||||||
/* And the reverse. */
|
/* And the reverse. */
|
||||||
std::string printHashType(HashType ht);
|
std::string printHashType(HashType ht);
|
||||||
|
|
||||||
|
namespace hash {
|
||||||
union Ctx;
|
union Ctx;
|
||||||
|
}
|
||||||
|
|
||||||
class HashSink : public BufferedSink {
|
class HashSink : public BufferedSink {
|
||||||
private:
|
private:
|
||||||
HashType ht;
|
HashType ht;
|
||||||
Ctx* ctx;
|
std::unique_ptr<hash::Ctx> ctx;
|
||||||
unsigned long long bytes;
|
unsigned long long bytes;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
Loading…
Reference in a new issue