diff options
| author | Daniel Barkalow <barkalow@iabervon.org> | 2008-03-25 19:35:28 -0400 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-03-26 00:50:51 -0700 | 
| commit | 472fa4cd33c690dd9b338c02af3ed135666aea43 (patch) | |
| tree | 5d26a3bdc95ae0b66d85ba55cfbebb6486b335ec /remote.c | |
| parent | c091b3d415f95d3e4e62acddb084e211af46acbf (diff) | |
| download | git-472fa4cd33c690dd9b338c02af3ed135666aea43.tar.gz | |
Fix branches file configuration
Fetched remote branch from .git/branches/foo should fetch into
refs/heads/foo.  Also when partial URL is given, the fetched head should
always be remote HEAD, and the result should not be stored anywhere.
Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'remote.c')
| -rw-r--r-- | remote.c | 28 | 
1 files changed, 22 insertions, 6 deletions
| @@ -171,7 +171,7 @@ static void read_branches_file(struct remote *remote)  {  	const char *slash = strchr(remote->name, '/');  	char *frag; -	char *branch; +	struct strbuf branch;  	int n = slash ? slash - remote->name : 1000;  	FILE *f = fopen(git_path("branches/%.*s", n, remote->name), "r");  	char *s, *p; @@ -197,17 +197,33 @@ static void read_branches_file(struct remote *remote)  	strcpy(p, s);  	if (slash)  		strcat(p, slash); + +	/* +	 * With "slash", e.g. "git fetch jgarzik/netdev-2.6" when +	 * reading from $GIT_DIR/branches/jgarzik fetches "HEAD" from +	 * the partial URL obtained from the branches file plus +	 * "/netdev-2.6" and does not store it in any tracking ref. +	 * #branch specifier in the file is ignored. +	 * +	 * Otherwise, the branches file would have URL and optionally +	 * #branch specified.  The "master" (or specified) branch is +	 * fetched and stored in the local branch of the same name. +	 */ +	strbuf_init(&branch, 0);  	frag = strchr(p, '#');  	if (frag) {  		*(frag++) = '\0'; -		branch = xmalloc(strlen(frag) + 12); -		strcpy(branch, "refs/heads/"); -		strcat(branch, frag); +		strbuf_addf(&branch, "refs/heads/%s", frag); +	} else +		strbuf_addstr(&branch, "refs/heads/master"); +	if (!slash) { +		strbuf_addf(&branch, ":refs/heads/%s", remote->name);  	} else { -		branch = "refs/heads/master"; +		strbuf_reset(&branch); +		strbuf_addstr(&branch, "HEAD:");  	}  	add_url(remote, p); -	add_fetch_refspec(remote, branch); +	add_fetch_refspec(remote, strbuf_detach(&branch, 0));  	remote->fetch_tags = 1; /* always auto-follow */  } | 
