diff options
| author | Johannes Sixt <johannes.sixt@telecom.at> | 2007-03-18 21:34:46 +0100 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2007-03-20 01:54:49 -0700 | 
| commit | 8bf0e3d15d3d327ae16d8eaa56374492d03a7b88 (patch) | |
| tree | fbf8facb5523b6952e04eb2e05dcd90622717031 /git-remote.perl | |
| parent | 08727ea8bba8c81678e5cf15124ada23ad097bc3 (diff) | |
| download | git-8bf0e3d15d3d327ae16d8eaa56374492d03a7b88.tar.gz | |
Teach git-remote to list pushed branches.
The configured refspecs are printed almost verbatim, i.e. both the local
and the remote branch name separated by a colon are printed; only the
prefix 'refs/heads/' is removed, like this:
  Local branch(es) pushed with 'git push'
    master refs/tags/*:refs/tags/* next:next
Signed-off-by: Johannes Sixt <johannes.sixt@telecom.at>
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'git-remote.perl')
| -rwxr-xr-x | git-remote.perl | 16 | 
1 files changed, 15 insertions, 1 deletions
| diff --git a/git-remote.perl b/git-remote.perl index bd70bf1ddd..52013fe76d 100755 --- a/git-remote.perl +++ b/git-remote.perl @@ -15,6 +15,10 @@ sub add_remote_config {  		$hash->{$name}{'FETCH'} ||= [];  		push @{$hash->{$name}{'FETCH'}}, $value;  	} +	elsif ($what eq 'push') { +		$hash->{$name}{'PUSH'} ||= []; +		push @{$hash->{$name}{'PUSH'}}, $value; +	}  	if (!exists $hash->{$name}{'SOURCE'}) {  		$hash->{$name}{'SOURCE'} = 'config';  	} @@ -44,7 +48,8 @@ sub add_remote_remotes {  			}  		}  		elsif (/^Push:\s*(.*)$/) { -			; # later +			$it->{'PUSH'} ||= []; +			push @{$it->{'PUSH'}}, $1;  		}  		elsif (/^Pull:\s*(.*)$/) {  			$it->{'FETCH'} ||= []; @@ -250,6 +255,15 @@ sub show_remote {  	if ($info->{'LS_REMOTE'}) {  		show_mapping($name, $info);  	} +	if ($info->{'PUSH'}) { +		my @pushed = map { +			s|^refs/heads/||; +			s|:refs/heads/|:|; +			$_; +		} @{$info->{'PUSH'}}; +		print "  Local branch(es) pushed with 'git push'\n"; +		print "    @pushed\n"; +	}  }  sub add_remote { | 
