X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=Debian%2FDgit.pm;h=3f2988e4b3599f08b4b9e54fa5b2170c53d96723;hb=7684f83e49bdc4d883e682abd922a7722cf996c4;hp=2b9479db58d9b4e5f07c0301033657d449475c75;hpb=835d5026fd4c39a5012d1a0d64c85a2481a2c686;p=dgit.git diff --git a/Debian/Dgit.pm b/Debian/Dgit.pm index 2b9479db..3f2988e4 100644 --- a/Debian/Dgit.pm +++ b/Debian/Dgit.pm @@ -16,9 +16,12 @@ BEGIN { @ISA = qw(Exporter); @EXPORT = qw(debiantag server_branch server_ref stat_exists git_for_each_ref - $package_re $component_re $branchprefix - initdebug enabledebug printdebug debugcmd - $debugprefix $debug + git_for_each_tag_referring + $package_re $component_re $deliberately_re + $branchprefix + initdebug enabledebug enabledebuglevel + printdebug debugcmd + $debugprefix *debuglevel *DEBUG shellquote printcmd); %EXPORT_TAGS = ( policyflags => [qw(NOFFCHECK FRESHREPO)] ); @EXPORT_OK = @{ $EXPORT_TAGS{policyflags} }; @@ -28,6 +31,7 @@ our @EXPORT_OK; our $package_re = '[0-9a-z][-+.0-9a-z]*'; our $component_re = '[0-9a-zA-Z][-+.0-9a-zA-Z]*'; +our $deliberately_re = "(?:TEST-)?$package_re"; our $branchprefix = 'dgit'; # policy hook exit status bits @@ -58,12 +62,12 @@ sub git_for_each_ref ($$) { # calls $func->($objid,$objtype,$fullrefname,$reftail); # $reftail is RHS of ref after refs/\w+/ # breaks if $pattern matches any ref `refs/blah' where blah has no `/' - my $fh = new IO::File "-|", qw(git for-each-ref), $pattern or die $!; - while (<$fh>) { + open GFER, "-|", qw(git for-each-ref), $pattern or die $!; + while () { m#^(\w+)\s+(\w+)\s+(refs/\w+/(\S+))\s# or die "$_ ?"; $func->($1,$2,$3,$4); } - $!=0; $?=0; close $fh or die "$pattern $? $!"; + $!=0; $?=0; close GFER or die "$pattern $? $!"; } sub git_for_each_tag_referring ($$) { @@ -78,21 +82,31 @@ sub git_for_each_tag_referring ($$) { } our $debugprefix; -our $debug = 0; +our $debuglevel = 0; sub initdebug ($) { ($debugprefix) = @_; - open ::DEBUG, ">/dev/null" or die $!; + open DEBUG, ">/dev/null" or die $!; } sub enabledebug () { - open ::DEBUG, ">&STDERR" or die $!; - ::DEBUG->autoflush(1); - $debug ||= 1; + open DEBUG, ">&STDERR" or die $!; + DEBUG->autoflush(1); + $debuglevel ||= 1; +} + +sub enabledebuglevel ($) { + my ($newlevel) = @_; # may be undef (eg from env var) + die if $debuglevel; + $newlevel //= 0; + $newlevel += 0; + return unless $newlevel; + $debuglevel = $newlevel; + enabledebug(); } sub printdebug { - print ::DEBUG $debugprefix, @_ or die $!; + print DEBUG $debugprefix, @_ or die $! if $debuglevel>0; } sub shellquote { @@ -100,7 +114,7 @@ sub shellquote { local $_; foreach my $a (@_) { $_ = $a; - if (m{[^-=_./0-9a-z]}i) { + if (!length || m{[^-=_./0-9a-z]}i) { s{['\\]}{'\\$&'}g; push @out, "'$_'"; } else { @@ -120,7 +134,7 @@ sub printcmd { sub debugcmd { my $extraprefix = shift @_; - printcmd(\*::DEBUG,$debugprefix.$extraprefix,@_) if $debug>0; + printcmd(\*DEBUG,$debugprefix.$extraprefix,@_) if $debuglevel>0; } 1;