guix/src/libutil/hash.hh

62 lines
1.3 KiB
C++
Raw Normal View History

2003-06-15 13:41:32 +00:00
#ifndef __HASH_H
#define __HASH_H
#include <string>
#include "util.hh"
using namespace std;
typedef enum { htMD5, htSHA1, htSHA256 } HashType;
2005-01-13 15:44:44 +00:00
const int md5HashSize = 16;
const int sha1HashSize = 20;
const int sha256HashSize = 32;
2005-01-13 15:44:44 +00:00
2003-06-15 13:41:32 +00:00
struct Hash
{
static const unsigned int maxHashSize = 32;
2005-01-13 15:44:44 +00:00
unsigned int hashSize;
unsigned char hash[maxHashSize];
HashType type;
2003-06-15 13:41:32 +00:00
/* Create a zeroed hash object. */
2005-01-13 15:44:44 +00:00
Hash(HashType type);
/* Check whether two hash are equal. */
2003-07-15 22:28:27 +00:00
bool operator == (const Hash & h2) const;
/* Check whether two hash are not equal. */
2003-07-15 22:28:27 +00:00
bool operator != (const Hash & h2) const;
/* For sorting. */
bool operator < (const Hash & h) const;
/* Convert a hash code into a hexadecimal representation. */
2003-06-15 13:41:32 +00:00
operator string() const;
};
/* Parse a hexadecimal representation of a hash code. */
2003-06-15 13:41:32 +00:00
Hash parseHash(const string & s);
/* Verify that the given string is a valid hash code. */
2003-06-15 13:41:32 +00:00
bool isHash(const string & s);
/* Compute the hash of the given string. */
Hash hashString(const string & s, HashType ht);
/* Compute the hash of the given file. */
Hash hashFile(const Path & path, HashType ht);
2003-06-15 13:41:32 +00:00
/* Compute the hash of the given path. The hash is defined as
md5(dump(path)). */
Hash hashPath(const Path & path, HashType ht);
2003-06-16 15:59:23 +00:00
2003-06-15 13:41:32 +00:00
#endif /* !__HASH_H */