diff options
| author | Junio C Hamano <junkio@cox.net> | 2006-07-30 23:42:10 -0700 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-07-30 23:42:10 -0700 | 
| commit | c1a788aceecb0a8e95d6442938ade9ca43df033e (patch) | |
| tree | 30d99ae60a57281f75586d64f9853429fa3d26e7 /http-fetch.c | |
| parent | f59aac47f3839367d0da04019b0fc2bd61345225 (diff) | |
| parent | 076b0adcf9dac7bd9d18624087f679cc811aeb77 (diff) | |
| download | git-c1a788aceecb0a8e95d6442938ade9ca43df033e.tar.gz | |
Merge branch 'js/read-tree' into js/c-merge-recursive
* js/read-tree: (107 commits)
  read-tree: move merge functions to the library
  read-trees: refactor the unpack_trees() part
  tar-tree: illustrate an obscure feature better
  git.c: allow alias expansion without a git directory
  setup_git_directory_gently: do not barf when GIT_DIR is given.
  Build on Debian GNU/kFreeBSD
  Call setup_git_directory() much earlier
  Call setup_git_directory() early
  Display an error from update-ref if target ref name is invalid.
  Fix http-fetch
  t4103: fix binary patch application test.
  git-apply -R: binary patches are irreversible for now.
  Teach git-apply about '-R'
  Makefile: ssh-pull.o depends on ssh-fetch.c
  log and diff family: honor config even from subdirectories
  git-reset: detect update-ref error and report it.
  lost-found: use fsck-objects --full
  Teach git-http-fetch the --stdin switch
  Teach git-local-fetch the --stdin switch
  Make pull() support fetching multiple targets at once
  ...
Diffstat (limited to 'http-fetch.c')
| -rw-r--r-- | http-fetch.c | 45 | 
1 files changed, 29 insertions, 16 deletions
| diff --git a/http-fetch.c b/http-fetch.c index 12493fbed2..1aad39b4d8 100644 --- a/http-fetch.c +++ b/http-fetch.c @@ -36,6 +36,8 @@ enum XML_Status {  #define PREV_BUF_SIZE 4096  #define RANGE_HEADER_SIZE 30 +static int commits_on_stdin = 0; +  static int got_alternates = -1;  static int corrupt_object_found = 0; @@ -43,7 +45,7 @@ static struct curl_slist *no_pragma_header;  struct alt_base  { -	char *base; +	const char *base;  	int path_len;  	int got_indices;  	struct packed_git *packs; @@ -81,7 +83,7 @@ struct object_request  };  struct alternates_request { -	char *base; +	const char *base;  	char *url;  	struct buffer *buffer;  	struct active_request_slot *slot; @@ -142,7 +144,7 @@ static size_t fwrite_sha1_file(void *ptr, size_t eltsize, size_t nmemb,  	return size;  } -static void fetch_alternates(char *base); +static void fetch_alternates(const char *base);  static void process_object_response(void *callback_data); @@ -507,7 +509,7 @@ static void process_alternates_response(void *callback_data)  		(struct alternates_request *)callback_data;  	struct active_request_slot *slot = alt_req->slot;  	struct alt_base *tail = alt; -	char *base = alt_req->base; +	const char *base = alt_req->base;  	static const char null_byte = '\0';  	char *data;  	int i = 0; @@ -612,7 +614,7 @@ static void process_alternates_response(void *callback_data)  	got_alternates = 1;  } -static void fetch_alternates(char *base) +static void fetch_alternates(const char *base)  {  	struct buffer buffer;  	char *url; @@ -1185,7 +1187,7 @@ int fetch_ref(char *ref, unsigned char *sha1)          char *url;          char hex[42];          struct buffer buffer; -	char *base = alt->base; +	const char *base = alt->base;  	struct active_request_slot *slot;  	struct slot_results results;          buffer.size = 41; @@ -1214,10 +1216,12 @@ int fetch_ref(char *ref, unsigned char *sha1)          return 0;  } -int main(int argc, char **argv) +int main(int argc, const char **argv)  { -	char *commit_id; -	char *url; +	int commits; +	const char **write_ref = NULL; +	char **commit_id; +	const char *url;  	char *path;  	int arg = 1;  	int rc = 0; @@ -1237,20 +1241,26 @@ int main(int argc, char **argv)  		} else if (argv[arg][1] == 'v') {  			get_verbosely = 1;  		} else if (argv[arg][1] == 'w') { -			write_ref = argv[arg + 1]; +			write_ref = &argv[arg + 1];  			arg++;  		} else if (!strcmp(argv[arg], "--recover")) {  			get_recover = 1; +		} else if (!strcmp(argv[arg], "--stdin")) { +			commits_on_stdin = 1;  		}  		arg++;  	} -	if (argc < arg + 2) { -		usage("git-http-fetch [-c] [-t] [-a] [-d] [-v] [--recover] [-w ref] commit-id url"); +	if (argc < arg + 2 - commits_on_stdin) { +		usage("git-http-fetch [-c] [-t] [-a] [-v] [--recover] [-w ref] [--stdin] commit-id url");  		return 1;  	} -	commit_id = argv[arg]; -	url = argv[arg + 1]; -	write_ref_log_details = url; +	if (commits_on_stdin) { +		commits = pull_targets_stdin(&commit_id, &write_ref); +	} else { +		commit_id = (char **) &argv[arg++]; +		commits = 1; +	} +	url = argv[arg];  	http_init(); @@ -1268,13 +1278,16 @@ int main(int argc, char **argv)  			alt->path_len = strlen(path);  	} -	if (pull(commit_id)) +	if (pull(commits, commit_id, write_ref, url))  		rc = 1;  	http_cleanup();  	curl_slist_free_all(no_pragma_header); +	if (commits_on_stdin) +		pull_targets_free(commits, commit_id, write_ref); +  	if (corrupt_object_found) {  		fprintf(stderr,  "Some loose object were found to be corrupt, but they might be just\n" | 
