diff options
| author | Shawn O. Pearce <spearce@spearce.org> | 2007-10-16 00:15:25 -0400 | 
|---|---|---|
| committer | Shawn O. Pearce <spearce@spearce.org> | 2007-10-16 00:15:25 -0400 | 
| commit | 2e13e5d89252ceef606a0a7be32dbf5bea7e5aca (patch) | |
| tree | 91f34e2fa799880e917238a7794b3dde35536c09 /send-pack.c | |
| parent | ccfc02a30057a5fa7376e1fc8e8c3fe5478556f4 (diff) | |
| parent | d55e7c3acf72413563e695a19f7f66efac442064 (diff) | |
| download | git-2e13e5d89252ceef606a0a7be32dbf5bea7e5aca.tar.gz | |
Merge branch 'master' into db/fetch-pack
There's a number of tricky conflicts between master and
this topic right now due to the rewrite of builtin-push.
Junio must have handled these via rerere; I'd rather not
deal with them again so I'm pre-merging master into the
topic.  Besides this topic somehow started to depend on
the strbuf series that was in next, but is now in master.
It no longer compiles on its own without the strbuf API.
* master: (184 commits)
  Whip post 1.5.3.4 maintenance series into shape.
  Minor usage update in setgitperms.perl
  manual: use 'URL' instead of 'url'.
  manual: add some markup.
  manual: Fix example finding commits referencing given content.
  Fix wording in push definition.
  Fix some typos, punctuation, missing words, minor markup.
  manual: Fix or remove em dashes.
  Add a --dry-run option to git-push.
  Add a --dry-run option to git-send-pack.
  Fix in-place editing functions in convert.c
  instaweb: support for Ruby's WEBrick server
  instaweb: allow for use of auto-generated scripts
  Add 'git-p4 commit' as an alias for 'git-p4 submit'
  hg-to-git speedup through selectable repack intervals
  git-svn: respect Subversion's [auth] section configuration values
  gtksourceview2 support for gitview
  fix contrib/hooks/post-receive-email hooks.recipients error message
  Support cvs via git-shell
  rebase -i: use diff plumbing instead of porcelain
  ...
Conflicts:
	Makefile
	builtin-push.c
	rsh.c
Diffstat (limited to 'send-pack.c')
| -rw-r--r-- | send-pack.c | 31 | 
1 files changed, 19 insertions, 12 deletions
| diff --git a/send-pack.c b/send-pack.c index 4533d1bf8e..7b776243e6 100644 --- a/send-pack.c +++ b/send-pack.c @@ -7,13 +7,14 @@  #include "remote.h"  static const char send_pack_usage[] = -"git-send-pack [--all] [--force] [--receive-pack=<git-receive-pack>] [--verbose] [--thin] [<host>:]<directory> [<ref>...]\n" +"git-send-pack [--all] [--dry-run] [--force] [--receive-pack=<git-receive-pack>] [--verbose] [--thin] [<host>:]<directory> [<ref>...]\n"  "  --all and explicit <ref> specification are mutually exclusive.";  static const char *receivepack = "git-receive-pack";  static int verbose;  static int send_all;  static int force_update;  static int use_thin_pack; +static int dry_run;  /*   * Make a pack stream and spit it out into file descriptor fd @@ -282,16 +283,18 @@ static int send_pack(int in, int out, struct remote *remote, int nr_refspec, cha  		strcpy(old_hex, sha1_to_hex(ref->old_sha1));  		new_hex = sha1_to_hex(ref->new_sha1); -		if (ask_for_status_report) { -			packet_write(out, "%s %s %s%c%s", -				     old_hex, new_hex, ref->name, 0, -				     "report-status"); -			ask_for_status_report = 0; -			expect_status_report = 1; +		if (!dry_run) { +			if (ask_for_status_report) { +				packet_write(out, "%s %s %s%c%s", +					old_hex, new_hex, ref->name, 0, +					"report-status"); +				ask_for_status_report = 0; +				expect_status_report = 1; +			} +			else +				packet_write(out, "%s %s %s", +					old_hex, new_hex, ref->name);  		} -		else -			packet_write(out, "%s %s %s", -				     old_hex, new_hex, ref->name);  		if (will_delete_ref)  			fprintf(stderr, "deleting '%s'\n", ref->name);  		else { @@ -302,7 +305,7 @@ static int send_pack(int in, int out, struct remote *remote, int nr_refspec, cha  			fprintf(stderr, "\n  from %s\n  to   %s\n",  				old_hex, new_hex);  		} -		if (remote) { +		if (remote && !dry_run) {  			struct refspec rs;  			rs.src = ref->name;  			rs.dst = NULL; @@ -321,7 +324,7 @@ static int send_pack(int in, int out, struct remote *remote, int nr_refspec, cha  	}  	packet_flush(out); -	if (new_refs) +	if (new_refs && !dry_run)  		ret = pack_objects(out, remote_refs);  	close(out); @@ -390,6 +393,10 @@ int main(int argc, char **argv)  				send_all = 1;  				continue;  			} +			if (!strcmp(arg, "--dry-run")) { +				dry_run = 1; +				continue; +			}  			if (!strcmp(arg, "--force")) {  				force_update = 1;  				continue; | 
