 f4781068fa
			
		
	
	f4781068fa
	
	
	
		
			
			Occasionally, it may be useful for callers to know the number of object IDs in an oidset. Right now, the only way to compute this is to call 'kh_size' on the internal 'kh_set_oid_t'. Similar to how we wrap other 'kh_*' functions over the 'oidset' type, let's allow callers to compute this value by introducing 'oidset_size'. We will add its first caller in the subsequent commit. Signed-off-by: Taylor Blau <me@ttaylorr.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			78 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #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);
 | |
| }
 | |
| 
 | |
| int oidset_size(struct oidset *set)
 | |
| {
 | |
| 	return kh_size(&set->set);
 | |
| }
 | |
| 
 | |
| 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);
 | |
| }
 |