diff options
| author | Junio C Hamano <gitster@pobox.com> | 2008-05-25 13:38:44 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-05-25 13:41:37 -0700 | 
| commit | b84c343c885b8168047b2773b5c597d04337d9bd (patch) | |
| tree | a4ef0ee1fd0939d2a465d794ba0d88fc54234d28 /refs.c | |
| parent | 0dbaa5bd514b9d234c07fd6b857888566abcf836 (diff) | |
| parent | b50c8469cc9a336b22ef37b23711d4547a48bc2b (diff) | |
| download | git-b84c343c885b8168047b2773b5c597d04337d9bd.tar.gz | |
Merge branch 'db/clone-in-c'
* db/clone-in-c:
  Add test for cloning with "--reference" repo being a subset of source repo
  Add a test for another combination of --reference
  Test that --reference actually suppresses fetching referenced objects
  clone: fall back to copying if hardlinking fails
  builtin-clone.c: Need to closedir() in copy_or_link_directory()
  builtin-clone: fix initial checkout
  Build in clone
  Provide API access to init_db()
  Add a function to set a non-default work tree
  Allow for having for_each_ref() list extra refs
  Have a constant extern refspec for "--tags"
  Add a library function to add an alternate to the alternates file
  Add a lockfile function to append to a file
  Mark the list of refs to fetch as const
Conflicts:
	cache.h
	t/t5700-clone-reference.sh
Diffstat (limited to 'refs.c')
| -rw-r--r-- | refs.c | 18 | 
1 files changed, 18 insertions, 0 deletions
| @@ -159,6 +159,8 @@ static struct cached_refs {  } cached_refs;  static struct ref_list *current_ref; +static struct ref_list *extra_refs; +  static void free_ref_list(struct ref_list *list)  {  	struct ref_list *next; @@ -215,6 +217,17 @@ static void read_packed_refs(FILE *f, struct cached_refs *cached_refs)  	cached_refs->packed = sort_ref_list(list);  } +void add_extra_ref(const char *name, const unsigned char *sha1, int flag) +{ +	extra_refs = add_ref(name, sha1, flag, extra_refs, NULL); +} + +void clear_extra_refs(void) +{ +	free_ref_list(extra_refs); +	extra_refs = NULL; +} +  static struct ref_list *get_packed_refs(void)  {  	if (!cached_refs.did_packed) { @@ -547,6 +560,11 @@ static int do_for_each_ref(const char *base, each_ref_fn fn, int trim,  	struct ref_list *packed = get_packed_refs();  	struct ref_list *loose = get_loose_refs(); +	struct ref_list *extra; + +	for (extra = extra_refs; extra; extra = extra->next) +		retval = do_one_ref(base, fn, trim, cb_data, extra); +  	while (packed && loose) {  		struct ref_list *entry;  		int cmp = strcmp(packed->name, loose->name); | 
