commit - 53bf0b541977b66862040d4b633fb6b5d3a3c6c8
commit + 87a3ab84d3eb87b790e3d34aeec2c344a8d7375b
blob - 6a161bc20df5aaa7789395593ab2ffc6fbe4b1fb
blob + 7672f9da04d627c9c0d625a0aeafe03183f72626
--- include/got_object.h
+++ include/got_object.h
#define GOT_OBJECT_ID_HEX_MAXLEN SHA1_DIGEST_STRING_LENGTH
+enum got_hash_algorithm {
+ GOT_HASH_SHA1,
+ GOT_HASH_SHA256,
+};
+
struct got_object_id {
u_int8_t sha1[SHA1_DIGEST_LENGTH];
};
blob - 141cb2590fa14834c63381929a0a7438ae3e4556
blob + 6cf096112b33a6a0627c71d31836cc10bedb3469
--- lib/got_lib_hash.h
+++ lib/got_lib_hash.h
*/
#define GOT_SHA1_STRING_ZERO "0000000000000000000000000000000000000000"
+#define GOT_SHA256_STRING_ZERO "0000000000000000000000000000000000000000000000000000000000000000"
int got_parse_xdigit(uint8_t *, const char *);
-int got_parse_sha1_digest(uint8_t *, const char *);
+
char *got_sha1_digest_to_str(const uint8_t *, char *, size_t);
+char *got_sha256_digest_to_str(const uint8_t *, char *, size_t);
+
+int got_parse_hash_digest(uint8_t *, const char *, enum got_hash_algorithm);
+int got_parse_object_id(struct got_object_id *, const char *,
+ enum got_hash_algorithm);
blob - fb4d3a30adf9281507aea3424f4c2711b1d3a28c
blob + 51a9a0ca1ab1e8d6bc5e9f6722d0595f2a3b5fe7
--- lib/hash.c
+++ lib/hash.c
*/
#include <sys/types.h>
+#include <sys/queue.h>
+
#include <sha1.h>
#include <sha2.h>
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
+#include <string.h>
#include <limits.h>
+#include "got_object.h"
+
#include "got_lib_hash.h"
int
return 1;
}
-int
-got_parse_sha1_digest(uint8_t *digest, const char *line)
+static int
+parse_digest(uint8_t *digest, int len, const char *line)
{
uint8_t b = 0;
char hex[3] = {'\0', '\0', '\0'};
int i, j;
- for (i = 0; i < SHA1_DIGEST_LENGTH; i++) {
+ for (i = 0; i < len; i++) {
if (line[0] == '\0' || line[1] == '\0')
return 0;
for (j = 0; j < 2; j++) {
return 1;
}
-char *
-got_sha1_digest_to_str(const uint8_t *digest, char *buf, size_t size)
+static char *
+digest_to_str(const uint8_t *digest, int len, char *buf)
{
char *p = buf;
char hex[3];
int i;
- if (size < SHA1_DIGEST_STRING_LENGTH)
- return NULL;
-
- for (i = 0; i < SHA1_DIGEST_LENGTH; i++) {
+ for (i = 0; i < len; i++) {
snprintf(hex, sizeof(hex), "%.2x", digest[i]);
p[0] = hex[0];
p[1] = hex[1];
return buf;
}
+
+char *
+got_sha1_digest_to_str(const uint8_t *digest, char *buf, size_t size)
+{
+ if (size < SHA1_DIGEST_STRING_LENGTH)
+ return NULL;
+ return digest_to_str(digest, SHA1_DIGEST_LENGTH, buf);
+}
+
+char *
+got_sha256_digest_to_str(const uint8_t *digest, char *buf, size_t size)
+{
+ if (size < SHA256_DIGEST_STRING_LENGTH)
+ return NULL;
+ return digest_to_str(digest, SHA256_DIGEST_LENGTH, buf);
+}
+
+int
+got_parse_hash_digest(uint8_t *digest, const char *line,
+ enum got_hash_algorithm algo)
+{
+ switch (algo) {
+ case GOT_HASH_SHA1:
+ return parse_digest(digest, SHA1_DIGEST_LENGTH, line);
+ case GOT_HASH_SHA256:
+ return parse_digest(digest, SHA256_DIGEST_LENGTH, line);
+ default:
+ return 0;
+ }
+}
+
+int
+got_parse_object_id(struct got_object_id *id, const char *line,
+ enum got_hash_algorithm algo)
+{
+ memset(id, 0, sizeof(*id));
+
+ /* XXX: temporary until we grow got_object_id */
+ if (algo != GOT_HASH_SHA1)
+ return 0;
+
+ return got_parse_hash_digest(id->sha1, line, algo);
+}
blob - f8b902a4c27338568c455eb639ecba5cbb38b8c2
blob + 8c8a840aeee11db19adfe359200c154280b12be0
--- lib/object.c
+++ lib/object.c
{
struct got_object_id id;
- if (!got_parse_sha1_digest(id.sha1, id_str))
+ if (!got_parse_object_id(&id, id_str, GOT_HASH_SHA1))
return got_error_path(id_str, GOT_ERR_BAD_OBJ_ID_STR);
return got_object_open(obj, repo, &id);
blob - 67c3bc37ea78571d6f3c25478ae3e612ee235f22
blob + 5efb32c22767820707ae2c11266b810d15999dfa
--- lib/object_parse.c
+++ lib/object_parse.c
if (err)
return err;
- if (!got_parse_sha1_digest(qid->id.sha1, id_str)) {
+ if (!got_parse_object_id(&qid->id, id_str, GOT_HASH_SHA1)) {
err = got_error(GOT_ERR_BAD_OBJ_DATA);
got_object_qid_free(qid);
return err;
size_t len)
{
const struct got_error *err = NULL;
+ enum got_hash_algorithm algo = GOT_HASH_SHA1;
char *s = buf;
size_t label_len;
ssize_t remain = (ssize_t)len;
goto done;
}
s += label_len;
- if (!got_parse_sha1_digest((*commit)->tree_id->sha1, s)) {
+ if (!got_parse_object_id((*commit)->tree_id, s, algo)) {
err = got_error(GOT_ERR_BAD_OBJ_DATA);
goto done;
}
got_object_parse_tag(struct got_tag_object **tag, uint8_t *buf, size_t len)
{
const struct got_error *err = NULL;
+ enum got_hash_algorithm algo = GOT_HASH_SHA1;
size_t remain = len;
char *s = buf;
size_t label_len;
goto done;
}
s += label_len;
- if (!got_parse_sha1_digest((*tag)->id.sha1, s)) {
+ if (!got_parse_object_id(&(*tag)->id, s, algo)) {
err = got_error(GOT_ERR_BAD_OBJ_DATA);
goto done;
}
blob - 92514335bde2a392e0211cb8f5903c931aac55d2
blob + 31cf23be95d9f14059addf8cc73a6b5538c9b774
--- lib/patch.c
+++ lib/patch.c
return err;
idptr = matched_id;
} else {
- if (!got_parse_sha1_digest(id.sha1, blobid))
+ if (!got_parse_object_id(&id, blobid, GOT_HASH_SHA1))
return got_error(GOT_ERR_BAD_OBJ_ID_STR);
idptr = &id;
}
blob - b7e19bcfc7a34cea70cf48a5c32ab66ee4acb857
blob + fd8aa92b4400836a36c9ff24e521107661b42342
--- lib/reference.c
+++ lib/reference.c
parse_ref_line(struct got_reference **ref, const char *name, const char *line,
time_t mtime)
{
+ enum got_hash_algorithm algo = GOT_HASH_SHA1;
struct got_object_id id;
if (strncmp(line, "ref: ", 5) == 0) {
return parse_symref(ref, name, line);
}
- if (!got_parse_sha1_digest(id.sha1, line))
+ if (!got_parse_object_id(&id, line, algo))
return got_error(GOT_ERR_BAD_REF_DATA);
return alloc_ref(ref, name, &id, 0, mtime);
parse_packed_ref_line(struct got_reference **ref, const char *abs_refname,
const char *line, time_t mtime)
{
+ enum got_hash_algorithm algo = GOT_HASH_SHA1;
struct got_object_id id;
const char *name;
if (line[0] == '#' || line[0] == '^')
return NULL;
- if (!got_parse_sha1_digest(id.sha1, line))
+ if (!got_parse_object_id(&id, line, algo))
return got_error(GOT_ERR_BAD_REF_DATA);
if (abs_refname) {
blob - abff91e2c234cdd1c87f05d07d2a9d02a0cc98e4
blob + bb181bc9236aba33630380d438c03cdfc85ae0d9
--- lib/repository.c
+++ lib/repository.c
}
while ((dent = readdir(dir)) != NULL) {
int cmp;
+ enum got_hash_algorithm algo = GOT_HASH_SHA1;
free(id_str);
id_str = NULL;
goto done;
}
- if (!got_parse_sha1_digest(id.sha1, id_str))
+ if (!got_parse_object_id(&id, id_str, algo))
continue;
/*
char *id_str;
int fd;
struct stat sb;
+ enum got_hash_algorithm algo = GOT_HASH_SHA1;
if (strcmp(dent->d_name, ".") == 0 ||
strcmp(dent->d_name, "..") == 0)
goto done;
}
- if (!got_parse_sha1_digest(id.sha1, id_str)) {
+ if (!got_parse_object_id(&id, id_str, algo)) {
free(id_str);
continue;
}
blob - d552b4a35a689baa8cf628c010eb5adfc9d57ce4
blob + 8608ef9dfd20957fb5e02caccfd03c8ca891ebc4
--- lib/repository_admin.c
+++ lib/repository_admin.c
goto done;
}
*dot = '\0';
- if (!got_parse_sha1_digest(id.sha1, p)) {
+ if (!got_parse_object_id(&id, p, GOT_HASH_SHA1)) {
err = got_error_fmt(GOT_ERR_BAD_PATH,
"'%s' is not a valid pack file name",
packfile_name);
goto done;
}
- memset(&id, 0, sizeof(id));
- if (!got_parse_sha1_digest(id.sha1, id_str)) {
+ if (!got_parse_object_id(&id, id_str,
+ GOT_HASH_SHA1)) {
free(id_str);
continue;
}
blob - ecd71cee9f0fb1d68f5a2341e98bfa386fb743c0
blob + 78941b351a05889c4da728c53e1bc922f5d5123e
--- lib/serve.c
+++ lib/serve.c
#include "got_path.h"
#include "got_version.h"
#include "got_reference.h"
+#include "got_object.h"
#include "got_lib_pkt.h"
#include "got_lib_dial.h"
if (err)
return err;
- if (!got_parse_sha1_digest(id, id_str)) {
+ if (!got_parse_hash_digest(id, id_str, GOT_HASH_SHA1)) {
err = got_error_msg(GOT_ERR_BAD_PACKET,
"want-line with bad object ID");
goto done;
if (err)
return err;
- if (!got_parse_sha1_digest(id, id_str)) {
+ if (!got_parse_hash_digest(id, id_str, GOT_HASH_SHA1)) {
err = got_error_msg(GOT_ERR_BAD_PACKET,
"have-line with bad object ID");
goto done;
if (err)
return err;
- if (!got_parse_sha1_digest(old_id, old_id_str) ||
- !got_parse_sha1_digest(new_id, new_id_str)) {
+ if (!got_parse_hash_digest(old_id, old_id_str, GOT_HASH_SHA1) ||
+ !got_parse_hash_digest(new_id, new_id_str, GOT_HASH_SHA1)) {
err = got_error_msg(GOT_ERR_BAD_PACKET,
"ref-update with bad object ID");
goto done;
blob - 9182db0e5c9f34de75291565e8162a16cda84db4
blob + 7d0e1dac2141bac1193dc36c27fc80b7cda09259
--- libexec/got-fetch-pack/got-fetch-pack.c
+++ libexec/got-fetch-pack/got-fetch-pack.c
const struct got_error *err;
char *theirs = NULL, *mine = NULL;
- if (!got_parse_sha1_digest(want->sha1, id_str)) {
+ if (!got_parse_object_id(want, id_str, GOT_HASH_SHA1)) {
err = got_error(GOT_ERR_BAD_OBJ_ID_STR);
goto done;
}
"unexpected message from server");
goto done;
}
- if (!got_parse_sha1_digest(common_id.sha1, buf + 4)) {
+ if (!got_parse_object_id(&common_id, buf + 4,
+ GOT_HASH_SHA1)) {
err = got_error_msg(GOT_ERR_BAD_PACKET,
"bad object ID in ACK packet from server");
goto done;
blob - 4849e5e3e5d7c3c90f43a4b6a30f2e39b23f2820
blob + a5fe8c2470856e960745214cc536ddbc804c7ef0
--- libexec/got-read-patch/got-read-patch.c
+++ libexec/got-read-patch/got-read-patch.c
if ((*blob = strndup(line, len)) == NULL)
return got_error_from_errno("strndup");
- if (!git && !got_parse_sha1_digest(digest, *blob)) {
+ if (!git && !got_parse_hash_digest(digest, *blob, GOT_HASH_SHA1)) {
/* silently ignore invalid blob ids */
free(*blob);
*blob = NULL;
blob - d1ffc719f8ca4925cb7bf8c3d4e5c8180824fb64
blob + 654cb49d9d96580f6af08455db5b1407f1483dbd
--- libexec/got-send-pack/got-send-pack.c
+++ libexec/got-send-pack/got-send-pack.c
err = got_error_from_errno("malloc");
goto done;
}
- if (!got_parse_sha1_digest(id->sha1, id_str)) {
+ if (!got_parse_object_id(id, id_str, GOT_HASH_SHA1)) {
err = got_error(GOT_ERR_BAD_OBJ_ID_STR);
goto done;
}
blob - 511fd016b578a9308aede2f46618c2b7b6a353c2
blob + 590110e141628fad3b6bacc7d6054bc81b3ceec8
--- regress/idset/idset_test.c
+++ regress/idset/idset_test.c
goto done;
}
- if (!got_parse_sha1_digest(id1.sha1, id_str1)) {
+ if (!got_parse_object_id(&id1, id_str1, GOT_HASH_SHA1)) {
err = got_error(GOT_ERR_BAD_OBJ_ID_STR);
goto done;
}
- if (!got_parse_sha1_digest(id2.sha1, id_str2)) {
+ if (!got_parse_object_id(&id2, id_str2, GOT_HASH_SHA1)) {
err = got_error(GOT_ERR_BAD_OBJ_ID_STR);
goto done;
}
- if (!got_parse_sha1_digest(id3.sha1, id_str3)) {
+ if (!got_parse_object_id(&id3, id_str3, GOT_HASH_SHA1)) {
err = got_error(GOT_ERR_BAD_OBJ_ID_STR);
goto done;
}