diff options
author | Vincent Ambo <Vincent Ambo> | 2020-01-11T23·36+0000 |
---|---|---|
committer | Vincent Ambo <Vincent Ambo> | 2020-01-11T23·36+0000 |
commit | 1b593e1ea4d2af0f6444d9a7788d5d99abd6fde5 (patch) | |
tree | e3accb9beed5c4c1b5a05c99db71ab2841f0ed04 /oidset.c |
Squashed 'third_party/git/' content from commit cb71568594
git-subtree-dir: third_party/git git-subtree-split: cb715685942260375e1eb8153b0768a376e4ece7
Diffstat (limited to 'oidset.c')
-rw-r--r-- | oidset.c | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/oidset.c b/oidset.c new file mode 100644 index 000000000000..f63ce818f677 --- /dev/null +++ b/oidset.c @@ -0,0 +1,72 @@ +#include "cache.h" +#include "oidset.h" + +void oidset_init(struct oidset *set, size_t initial_size) +{ + memset(&set->set, 0, sizeof(set->set)); + if (initial_size) + kh_resize_oid_set(&set->set, initial_size); +} + +int oidset_contains(const struct oidset *set, const struct object_id *oid) +{ + khiter_t pos = kh_get_oid_set(&set->set, *oid); + return pos != kh_end(&set->set); +} + +int oidset_insert(struct oidset *set, const struct object_id *oid) +{ + int added; + kh_put_oid_set(&set->set, *oid, &added); + return !added; +} + +int oidset_remove(struct oidset *set, const struct object_id *oid) +{ + khiter_t pos = kh_get_oid_set(&set->set, *oid); + if (pos == kh_end(&set->set)) + return 0; + kh_del_oid_set(&set->set, pos); + return 1; +} + +void oidset_clear(struct oidset *set) +{ + kh_release_oid_set(&set->set); + oidset_init(set, 0); +} + +void oidset_parse_file(struct oidset *set, const char *path) +{ + FILE *fp; + struct strbuf sb = STRBUF_INIT; + struct object_id oid; + + fp = fopen(path, "r"); + if (!fp) + die("could not open object name list: %s", path); + while (!strbuf_getline(&sb, fp)) { + const char *p; + const char *name; + + /* + * Allow trailing comments, leading whitespace + * (including before commits), and empty or whitespace + * only lines. + */ + name = strchr(sb.buf, '#'); + if (name) + strbuf_setlen(&sb, name - sb.buf); + strbuf_trim(&sb); + if (!sb.len) + continue; + + if (parse_oid_hex(sb.buf, &oid, &p) || *p != '\0') + die("invalid object name: %s", sb.buf); + oidset_insert(set, &oid); + } + if (ferror(fp)) + die_errno("Could not read '%s'", path); + fclose(fp); + strbuf_release(&sb); +} |