dir: convert struct sha1_stat to use object_id

Convert the declaration of struct sha1_stat. Adjust all usages of this
struct and replace hash{clr,cmp,cpy} with oid{clr,cmp,cpy} wherever
possible.  Rename it to struct oid_stat.

Rename static function load_sha1_stat to load_oid_stat.

Remove macro EMPTY_BLOB_SHA1_BIN, as it's no longer used.

Signed-off-by: Patryk Obara <patryk.obara@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Patryk Obara 2018-01-28 01:13:12 +01:00 committed by Junio C Hamano
parent 829e5c3b92
commit 4b33e60201
4 changed files with 58 additions and 64 deletions

View File

@ -1047,8 +1047,6 @@ extern const struct object_id empty_tree_oid;
"\xe6\x9d\xe2\x9b\xb2\xd1\xd6\x43\x4b\x8b" \ "\xe6\x9d\xe2\x9b\xb2\xd1\xd6\x43\x4b\x8b" \
"\x29\xae\x77\x5a\xd8\xc2\xe4\x8c\x53\x91" "\x29\xae\x77\x5a\xd8\xc2\xe4\x8c\x53\x91"
extern const struct object_id empty_blob_oid; extern const struct object_id empty_blob_oid;
#define EMPTY_BLOB_SHA1_BIN (empty_blob_oid.hash)



static inline int is_empty_blob_sha1(const unsigned char *sha1) static inline int is_empty_blob_sha1(const unsigned char *sha1)
{ {

104
dir.c
View File

@ -231,12 +231,10 @@ int within_depth(const char *name, int namelen,
* 1 along with { data, size } of the (possibly augmented) buffer * 1 along with { data, size } of the (possibly augmented) buffer
* when successful. * when successful.
* *
* Optionally updates the given sha1_stat with the given OID (when valid). * Optionally updates the given oid_stat with the given OID (when valid).
*/ */
static int do_read_blob(const struct object_id *oid, static int do_read_blob(const struct object_id *oid, struct oid_stat *oid_stat,
struct sha1_stat *sha1_stat, size_t *size_out, char **data_out)
size_t *size_out,
char **data_out)
{ {
enum object_type type; enum object_type type;
unsigned long sz; unsigned long sz;
@ -251,9 +249,9 @@ static int do_read_blob(const struct object_id *oid,
return -1; return -1;
} }


if (sha1_stat) { if (oid_stat) {
memset(&sha1_stat->stat, 0, sizeof(sha1_stat->stat)); memset(&oid_stat->stat, 0, sizeof(oid_stat->stat));
hashcpy(sha1_stat->sha1, oid->hash); oidcpy(&oid_stat->oid, oid);
} }


if (sz == 0) { if (sz == 0) {
@ -654,9 +652,8 @@ void add_exclude(const char *string, const char *base,


static int read_skip_worktree_file_from_index(const struct index_state *istate, static int read_skip_worktree_file_from_index(const struct index_state *istate,
const char *path, const char *path,
size_t *size_out, size_t *size_out, char **data_out,
char **data_out, struct oid_stat *oid_stat)
struct sha1_stat *sha1_stat)
{ {
int pos, len; int pos, len;


@ -667,7 +664,7 @@ static int read_skip_worktree_file_from_index(const struct index_state *istate,
if (!ce_skip_worktree(istate->cache[pos])) if (!ce_skip_worktree(istate->cache[pos]))
return -1; return -1;


return do_read_blob(&istate->cache[pos]->oid, sha1_stat, size_out, data_out); return do_read_blob(&istate->cache[pos]->oid, oid_stat, size_out, data_out);
} }


/* /*
@ -795,9 +792,8 @@ static int add_excludes_from_buffer(char *buf, size_t size,
* ss_valid is non-zero, "ss" must contain good value as input. * ss_valid is non-zero, "ss" must contain good value as input.
*/ */
static int add_excludes(const char *fname, const char *base, int baselen, static int add_excludes(const char *fname, const char *base, int baselen,
struct exclude_list *el, struct exclude_list *el, struct index_state *istate,
struct index_state *istate, struct oid_stat *oid_stat)
struct sha1_stat *sha1_stat)
{ {
struct stat st; struct stat st;
int r; int r;
@ -815,16 +811,16 @@ static int add_excludes(const char *fname, const char *base, int baselen,
return -1; return -1;
r = read_skip_worktree_file_from_index(istate, fname, r = read_skip_worktree_file_from_index(istate, fname,
&size, &buf, &size, &buf,
sha1_stat); oid_stat);
if (r != 1) if (r != 1)
return r; return r;
} else { } else {
size = xsize_t(st.st_size); size = xsize_t(st.st_size);
if (size == 0) { if (size == 0) {
if (sha1_stat) { if (oid_stat) {
fill_stat_data(&sha1_stat->stat, &st); fill_stat_data(&oid_stat->stat, &st);
hashcpy(sha1_stat->sha1, EMPTY_BLOB_SHA1_BIN); oidcpy(&oid_stat->oid, &empty_blob_oid);
sha1_stat->valid = 1; oid_stat->valid = 1;
} }
close(fd); close(fd);
return 0; return 0;
@ -837,22 +833,23 @@ static int add_excludes(const char *fname, const char *base, int baselen,
} }
buf[size++] = '\n'; buf[size++] = '\n';
close(fd); close(fd);
if (sha1_stat) { if (oid_stat) {
int pos; int pos;
if (sha1_stat->valid && if (oid_stat->valid &&
!match_stat_data_racy(istate, &sha1_stat->stat, &st)) !match_stat_data_racy(istate, &oid_stat->stat, &st))
; /* no content change, ss->sha1 still good */ ; /* no content change, ss->sha1 still good */
else if (istate && else if (istate &&
(pos = index_name_pos(istate, fname, strlen(fname))) >= 0 && (pos = index_name_pos(istate, fname, strlen(fname))) >= 0 &&
!ce_stage(istate->cache[pos]) && !ce_stage(istate->cache[pos]) &&
ce_uptodate(istate->cache[pos]) && ce_uptodate(istate->cache[pos]) &&
!would_convert_to_git(istate, fname)) !would_convert_to_git(istate, fname))
hashcpy(sha1_stat->sha1, oidcpy(&oid_stat->oid,
istate->cache[pos]->oid.hash); &istate->cache[pos]->oid);
else else
hash_sha1_file(buf, size, "blob", sha1_stat->sha1); hash_sha1_file(buf, size, "blob",
fill_stat_data(&sha1_stat->stat, &st); oid_stat->oid.hash);
sha1_stat->valid = 1; fill_stat_data(&oid_stat->stat, &st);
oid_stat->valid = 1;
} }
} }


@ -930,7 +927,7 @@ struct exclude_list *add_exclude_list(struct dir_struct *dir,
* Used to set up core.excludesfile and .git/info/exclude lists. * Used to set up core.excludesfile and .git/info/exclude lists.
*/ */
static void add_excludes_from_file_1(struct dir_struct *dir, const char *fname, static void add_excludes_from_file_1(struct dir_struct *dir, const char *fname,
struct sha1_stat *sha1_stat) struct oid_stat *oid_stat)
{ {
struct exclude_list *el; struct exclude_list *el;
/* /*
@ -941,7 +938,7 @@ static void add_excludes_from_file_1(struct dir_struct *dir, const char *fname,
if (!dir->untracked) if (!dir->untracked)
dir->unmanaged_exclude_files++; dir->unmanaged_exclude_files++;
el = add_exclude_list(dir, EXC_FILE, fname); el = add_exclude_list(dir, EXC_FILE, fname);
if (add_excludes(fname, "", 0, el, NULL, sha1_stat) < 0) if (add_excludes(fname, "", 0, el, NULL, oid_stat) < 0)
die("cannot use %s as an exclude file", fname); die("cannot use %s as an exclude file", fname);
} }


@ -1180,7 +1177,7 @@ static void prep_exclude(struct dir_struct *dir,


while (current < baselen) { while (current < baselen) {
const char *cp; const char *cp;
struct sha1_stat sha1_stat; struct oid_stat oid_stat;


stk = xcalloc(1, sizeof(*stk)); stk = xcalloc(1, sizeof(*stk));
if (current < 0) { if (current < 0) {
@ -1223,8 +1220,8 @@ static void prep_exclude(struct dir_struct *dir,
} }


/* Try to read per-directory file */ /* Try to read per-directory file */
hashclr(sha1_stat.sha1); oidclr(&oid_stat.oid);
sha1_stat.valid = 0; oid_stat.valid = 0;
if (dir->exclude_per_dir && if (dir->exclude_per_dir &&
/* /*
* If we know that no files have been added in * If we know that no files have been added in
@ -1252,7 +1249,7 @@ static void prep_exclude(struct dir_struct *dir,
strbuf_addstr(&sb, dir->exclude_per_dir); strbuf_addstr(&sb, dir->exclude_per_dir);
el->src = strbuf_detach(&sb, NULL); el->src = strbuf_detach(&sb, NULL);
add_excludes(el->src, el->src, stk->baselen, el, istate, add_excludes(el->src, el->src, stk->baselen, el, istate,
untracked ? &sha1_stat : NULL); untracked ? &oid_stat : NULL);
} }
/* /*
* NEEDSWORK: when untracked cache is enabled, prep_exclude() * NEEDSWORK: when untracked cache is enabled, prep_exclude()
@ -1269,9 +1266,9 @@ static void prep_exclude(struct dir_struct *dir,
* order, though, if you do that. * order, though, if you do that.
*/ */
if (untracked && if (untracked &&
hashcmp(sha1_stat.sha1, untracked->exclude_sha1)) { hashcmp(oid_stat.oid.hash, untracked->exclude_sha1)) {
invalidate_gitignore(dir->untracked, untracked); invalidate_gitignore(dir->untracked, untracked);
hashcpy(untracked->exclude_sha1, sha1_stat.sha1); hashcpy(untracked->exclude_sha1, oid_stat.oid.hash);
} }
dir->exclude_stack = stk; dir->exclude_stack = stk;
current = stk->baselen; current = stk->baselen;
@ -2228,13 +2225,13 @@ static struct untracked_cache_dir *validate_untracked_cache(struct dir_struct *d


/* Validate $GIT_DIR/info/exclude and core.excludesfile */ /* Validate $GIT_DIR/info/exclude and core.excludesfile */
root = dir->untracked->root; root = dir->untracked->root;
if (hashcmp(dir->ss_info_exclude.sha1, if (oidcmp(&dir->ss_info_exclude.oid,
dir->untracked->ss_info_exclude.sha1)) { &dir->untracked->ss_info_exclude.oid)) {
invalidate_gitignore(dir->untracked, root); invalidate_gitignore(dir->untracked, root);
dir->untracked->ss_info_exclude = dir->ss_info_exclude; dir->untracked->ss_info_exclude = dir->ss_info_exclude;
} }
if (hashcmp(dir->ss_excludes_file.sha1, if (oidcmp(&dir->ss_excludes_file.oid,
dir->untracked->ss_excludes_file.sha1)) { &dir->untracked->ss_excludes_file.oid)) {
invalidate_gitignore(dir->untracked, root); invalidate_gitignore(dir->untracked, root);
dir->untracked->ss_excludes_file = dir->ss_excludes_file; dir->untracked->ss_excludes_file = dir->ss_excludes_file;
} }
@ -2638,8 +2635,8 @@ void write_untracked_extension(struct strbuf *out, struct untracked_cache *untra
FLEX_ALLOC_MEM(ouc, exclude_per_dir, untracked->exclude_per_dir, len); FLEX_ALLOC_MEM(ouc, exclude_per_dir, untracked->exclude_per_dir, len);
stat_data_to_disk(&ouc->info_exclude_stat, &untracked->ss_info_exclude.stat); stat_data_to_disk(&ouc->info_exclude_stat, &untracked->ss_info_exclude.stat);
stat_data_to_disk(&ouc->excludes_file_stat, &untracked->ss_excludes_file.stat); stat_data_to_disk(&ouc->excludes_file_stat, &untracked->ss_excludes_file.stat);
hashcpy(ouc->info_exclude_sha1, untracked->ss_info_exclude.sha1); hashcpy(ouc->info_exclude_sha1, untracked->ss_info_exclude.oid.hash);
hashcpy(ouc->excludes_file_sha1, untracked->ss_excludes_file.sha1); hashcpy(ouc->excludes_file_sha1, untracked->ss_excludes_file.oid.hash);
ouc->dir_flags = htonl(untracked->dir_flags); ouc->dir_flags = htonl(untracked->dir_flags);


varint_len = encode_varint(untracked->ident.len, varbuf); varint_len = encode_varint(untracked->ident.len, varbuf);
@ -2816,13 +2813,12 @@ static void read_sha1(size_t pos, void *cb)
rd->data += 20; rd->data += 20;
} }


static void load_sha1_stat(struct sha1_stat *sha1_stat, static void load_oid_stat(struct oid_stat *oid_stat, const unsigned char *data,
const unsigned char *data, const unsigned char *sha1)
const unsigned char *sha1)
{ {
stat_data_from_disk(&sha1_stat->stat, data); stat_data_from_disk(&oid_stat->stat, data);
hashcpy(sha1_stat->sha1, sha1); hashcpy(oid_stat->oid.hash, sha1);
sha1_stat->valid = 1; oid_stat->valid = 1;
} }


struct untracked_cache *read_untracked_extension(const void *data, unsigned long sz) struct untracked_cache *read_untracked_extension(const void *data, unsigned long sz)
@ -2850,12 +2846,12 @@ struct untracked_cache *read_untracked_extension(const void *data, unsigned long
uc = xcalloc(1, sizeof(*uc)); uc = xcalloc(1, sizeof(*uc));
strbuf_init(&uc->ident, ident_len); strbuf_init(&uc->ident, ident_len);
strbuf_add(&uc->ident, ident, ident_len); strbuf_add(&uc->ident, ident, ident_len);
load_sha1_stat(&uc->ss_info_exclude, load_oid_stat(&uc->ss_info_exclude,
next + ouc_offset(info_exclude_stat), next + ouc_offset(info_exclude_stat),
next + ouc_offset(info_exclude_sha1)); next + ouc_offset(info_exclude_sha1));
load_sha1_stat(&uc->ss_excludes_file, load_oid_stat(&uc->ss_excludes_file,
next + ouc_offset(excludes_file_stat), next + ouc_offset(excludes_file_stat),
next + ouc_offset(excludes_file_sha1)); next + ouc_offset(excludes_file_sha1));
uc->dir_flags = get_be32(next + ouc_offset(dir_flags)); uc->dir_flags = get_be32(next + ouc_offset(dir_flags));
exclude_per_dir = (const char *)next + ouc_offset(exclude_per_dir); exclude_per_dir = (const char *)next + ouc_offset(exclude_per_dir);
uc->exclude_per_dir = xstrdup(exclude_per_dir); uc->exclude_per_dir = xstrdup(exclude_per_dir);

12
dir.h
View File

@ -74,9 +74,9 @@ struct exclude_list_group {
struct exclude_list *el; struct exclude_list *el;
}; };


struct sha1_stat { struct oid_stat {
struct stat_data stat; struct stat_data stat;
unsigned char sha1[20]; struct object_id oid;
int valid; int valid;
}; };


@ -124,8 +124,8 @@ struct untracked_cache_dir {
}; };


struct untracked_cache { struct untracked_cache {
struct sha1_stat ss_info_exclude; struct oid_stat ss_info_exclude;
struct sha1_stat ss_excludes_file; struct oid_stat ss_excludes_file;
const char *exclude_per_dir; const char *exclude_per_dir;
struct strbuf ident; struct strbuf ident;
/* /*
@ -195,8 +195,8 @@ struct dir_struct {


/* Enable untracked file cache if set */ /* Enable untracked file cache if set */
struct untracked_cache *untracked; struct untracked_cache *untracked;
struct sha1_stat ss_info_exclude; struct oid_stat ss_info_exclude;
struct sha1_stat ss_excludes_file; struct oid_stat ss_excludes_file;
unsigned unmanaged_exclude_files; unsigned unmanaged_exclude_files;
}; };



View File

@ -54,8 +54,8 @@ int cmd_main(int ac, const char **av)
printf("no untracked cache\n"); printf("no untracked cache\n");
return 0; return 0;
} }
printf("info/exclude %s\n", sha1_to_hex(uc->ss_info_exclude.sha1)); printf("info/exclude %s\n", oid_to_hex(&uc->ss_info_exclude.oid));
printf("core.excludesfile %s\n", sha1_to_hex(uc->ss_excludes_file.sha1)); printf("core.excludesfile %s\n", oid_to_hex(&uc->ss_excludes_file.oid));
printf("exclude_per_dir %s\n", uc->exclude_per_dir); printf("exclude_per_dir %s\n", uc->exclude_per_dir);
printf("flags %08x\n", uc->dir_flags); printf("flags %08x\n", uc->dir_flags);
if (uc->root) if (uc->root)