From: Ian Jackson Date: Sun, 31 May 2015 10:47:18 +0000 (+0100) Subject: Dgit.pm: git_for_each_ref: Provide optional $git_dir argument X-Git-Tag: debian/0.30~124 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=dgit.git;a=commitdiff_plain;h=33757ceaca394c2af95930775ee8ca1fd55108cf;ds=sidebyside Dgit.pm: git_for_each_ref: Provide optional $git_dir argument --- diff --git a/Debian/Dgit.pm b/Debian/Dgit.pm index 32c2bc56..48aae188 100644 --- a/Debian/Dgit.pm +++ b/Debian/Dgit.pm @@ -188,12 +188,15 @@ sub git_rev_parse ($) { return cmdoutput qw(git rev-parse), "$_[0]~0"; } -sub git_for_each_ref ($$) { - my ($pattern,$func) = @_; +sub git_for_each_ref ($$;$) { + my ($pattern,$func,$gitdir) = @_; # calls $func->($objid,$objtype,$fullrefname,$reftail); # $reftail is RHS of ref after refs/[^/]+/ # breaks if $pattern matches any ref `refs/blah' where blah has no `/' my @cmd = (qw(git for-each-ref), $pattern); + if (defined $gitdir) { + @cmd = ('sh','-ec','cd "$1"; shift; exec "$@"','x', $gitdir, @cmd); + } open GFER, "-|", @cmd or die $!; debugcmd "|", @cmd; while () {