Merge branch 'bc/object-id'
Conversion from uchar[20] to struct object_id continues. * bc/object-id: (25 commits) refs/files-backend: convert static functions to object_id refs: convert read_raw_ref backends to struct object_id refs: convert peel_object to struct object_id refs: convert resolve_ref_unsafe to struct object_id worktree: convert struct worktree to object_id refs: convert resolve_gitlink_ref to struct object_id Convert remaining callers of resolve_gitlink_ref to object_id sha1_file: convert index_path and index_fd to struct object_id refs: convert reflog_expire parameter to struct object_id refs: convert read_ref_at to struct object_id refs: convert peel_ref to struct object_id builtin/pack-objects: convert to struct object_id pack-bitmap: convert traverse_bitmap_commit_list to object_id refs: convert dwim_log to struct object_id builtin/reflog: convert remaining unsigned char uses to object_id refs: convert dwim_ref and expand_ref to struct object_id refs: convert read_ref and read_ref_full to object_id refs: convert resolve_refdup and refs_resolve_refdup to struct object_id Convert check_connected to use struct object_id refs: update ref transactions to use struct object_id ...
This commit is contained in:
32
sha1_file.c
32
sha1_file.c
@ -1661,7 +1661,7 @@ static void check_tag(const void *buf, size_t size)
|
||||
die("corrupt tag");
|
||||
}
|
||||
|
||||
static int index_mem(unsigned char *sha1, void *buf, size_t size,
|
||||
static int index_mem(struct object_id *oid, void *buf, size_t size,
|
||||
enum object_type type,
|
||||
const char *path, unsigned flags)
|
||||
{
|
||||
@ -1692,15 +1692,15 @@ static int index_mem(unsigned char *sha1, void *buf, size_t size,
|
||||
}
|
||||
|
||||
if (write_object)
|
||||
ret = write_sha1_file(buf, size, typename(type), sha1);
|
||||
ret = write_sha1_file(buf, size, typename(type), oid->hash);
|
||||
else
|
||||
ret = hash_sha1_file(buf, size, typename(type), sha1);
|
||||
ret = hash_sha1_file(buf, size, typename(type), oid->hash);
|
||||
if (re_allocated)
|
||||
free(buf);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int index_stream_convert_blob(unsigned char *sha1, int fd,
|
||||
static int index_stream_convert_blob(struct object_id *oid, int fd,
|
||||
const char *path, unsigned flags)
|
||||
{
|
||||
int ret;
|
||||
@ -1715,22 +1715,22 @@ static int index_stream_convert_blob(unsigned char *sha1, int fd,
|
||||
|
||||
if (write_object)
|
||||
ret = write_sha1_file(sbuf.buf, sbuf.len, typename(OBJ_BLOB),
|
||||
sha1);
|
||||
oid->hash);
|
||||
else
|
||||
ret = hash_sha1_file(sbuf.buf, sbuf.len, typename(OBJ_BLOB),
|
||||
sha1);
|
||||
oid->hash);
|
||||
strbuf_release(&sbuf);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int index_pipe(unsigned char *sha1, int fd, enum object_type type,
|
||||
static int index_pipe(struct object_id *oid, int fd, enum object_type type,
|
||||
const char *path, unsigned flags)
|
||||
{
|
||||
struct strbuf sbuf = STRBUF_INIT;
|
||||
int ret;
|
||||
|
||||
if (strbuf_read(&sbuf, fd, 4096) >= 0)
|
||||
ret = index_mem(sha1, sbuf.buf, sbuf.len, type, path, flags);
|
||||
ret = index_mem(oid, sbuf.buf, sbuf.len, type, path, flags);
|
||||
else
|
||||
ret = -1;
|
||||
strbuf_release(&sbuf);
|
||||
@ -1739,14 +1739,14 @@ static int index_pipe(unsigned char *sha1, int fd, enum object_type type,
|
||||
|
||||
#define SMALL_FILE_SIZE (32*1024)
|
||||
|
||||
static int index_core(unsigned char *sha1, int fd, size_t size,
|
||||
static int index_core(struct object_id *oid, int fd, size_t size,
|
||||
enum object_type type, const char *path,
|
||||
unsigned flags)
|
||||
{
|
||||
int ret;
|
||||
|
||||
if (!size) {
|
||||
ret = index_mem(sha1, "", size, type, path, flags);
|
||||
ret = index_mem(oid, "", size, type, path, flags);
|
||||
} else if (size <= SMALL_FILE_SIZE) {
|
||||
char *buf = xmalloc(size);
|
||||
ssize_t read_result = read_in_full(fd, buf, size);
|
||||
@ -1757,11 +1757,11 @@ static int index_core(unsigned char *sha1, int fd, size_t size,
|
||||
ret = error("short read while indexing %s",
|
||||
path ? path : "<unknown>");
|
||||
else
|
||||
ret = index_mem(sha1, buf, size, type, path, flags);
|
||||
ret = index_mem(oid, buf, size, type, path, flags);
|
||||
free(buf);
|
||||
} else {
|
||||
void *buf = xmmap(NULL, size, PROT_READ, MAP_PRIVATE, fd, 0);
|
||||
ret = index_mem(sha1, buf, size, type, path, flags);
|
||||
ret = index_mem(oid, buf, size, type, path, flags);
|
||||
munmap(buf, size);
|
||||
}
|
||||
return ret;
|
||||
@ -1799,12 +1799,12 @@ int index_fd(struct object_id *oid, int fd, struct stat *st,
|
||||
* die() for large files.
|
||||
*/
|
||||
if (type == OBJ_BLOB && path && would_convert_to_git_filter_fd(path))
|
||||
ret = index_stream_convert_blob(oid->hash, fd, path, flags);
|
||||
ret = index_stream_convert_blob(oid, fd, path, flags);
|
||||
else if (!S_ISREG(st->st_mode))
|
||||
ret = index_pipe(oid->hash, fd, type, path, flags);
|
||||
ret = index_pipe(oid, fd, type, path, flags);
|
||||
else if (st->st_size <= big_file_threshold || type != OBJ_BLOB ||
|
||||
(path && would_convert_to_git(&the_index, path)))
|
||||
ret = index_core(oid->hash, fd, xsize_t(st->st_size), type, path,
|
||||
ret = index_core(oid, fd, xsize_t(st->st_size), type, path,
|
||||
flags);
|
||||
else
|
||||
ret = index_stream(oid, fd, xsize_t(st->st_size), type, path,
|
||||
@ -1838,7 +1838,7 @@ int index_path(struct object_id *oid, const char *path, struct stat *st, unsigne
|
||||
strbuf_release(&sb);
|
||||
break;
|
||||
case S_IFDIR:
|
||||
return resolve_gitlink_ref(path, "HEAD", oid->hash);
|
||||
return resolve_gitlink_ref(path, "HEAD", oid);
|
||||
default:
|
||||
return error("%s: unsupported file type", path);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user