X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=infra%2Fdgit-repos-policy-debian;h=b25a560109f96b719b1f3b951da1589edcda6706;hb=ba923623a80877a6ba06e7fe528b480763ab9ddb;hp=2e0bcc79af7034e9a253a3f532ad5d3003cb1bba;hpb=ffcf3ccafd44190803adffa74730034fbba0b5ac;p=dgit.git diff --git a/infra/dgit-repos-policy-debian b/infra/dgit-repos-policy-debian index 2e0bcc79..b25a5601 100755 --- a/infra/dgit-repos-policy-debian +++ b/infra/dgit-repos-policy-debian @@ -88,10 +88,10 @@ sub apiquery ($) { $cmd .= " archive-api-query $subpath"; printdebug "apiquery $cmd\n"; $!=0; $?=0; my $json = `$cmd`; - defined $json or die "$subpath $! $?"; + defined $json && !$? or die "$subpath $! $?"; my $r = decode_json $json; my $d = new Data::Dumper([$r], [qw(r)]); - printdebug "apiquery $subpath | ", $d->Dump(), "\n" if $debuglevel>=2; + printdebug "apiquery $subpath | ", $d->Dump() if $debuglevel>=2; return $r; } @@ -150,21 +150,28 @@ sub getpackage () { } sub add_taint ($$) { - my ($refobj, $reason); + my ($refobj, $reason) = @_; + + printdebug "TAINTING $refobj\n", + (map { "\%| $_" } split "\n", $reason), + "\n"; my $tf = new File::Temp or die $!; print $tf "$refobj^0\n" or die $!; + flush $tf or die $!; + seek $tf,0,0 or die $!; my $gcfpid = open GCF, "-|"; defined $gcfpid or die $!; if (!$gcfpid) { open STDIN, "<&", $tf or die $!; - exec 'git', 'cat-file'; + exec 'git', 'cat-file', '--batch'; die $!; } close $tf or die $!; $_ = ; + defined $_ or die; m/^(\w+) (\w+) (\d+)\n/ or die "$_ ?"; my $gitobjid = $1; my $gitobjtype = $2; @@ -178,7 +185,7 @@ sub add_taint ($$) { close GCF; $poldbh->do("INSERT INTO taints". - " (package, gitobjid, gitobjtype, gitobjdata, time, comment)", + " (package, gitobjid, gitobjtype, gitobjdata, time, comment)". " VALUES (?,?,?,?,?,?)", {}, $pkg, $gitobjid, $gitobjtype, $gitobjdata, time, $reason); @@ -186,7 +193,7 @@ sub add_taint ($$) { die unless defined $taint_id; $poldbh->do("INSERT INTO taintoverrides". - " (taint_id, deliberately)", + " (taint_id, deliberately)". " VALUES (?, 'include-questionable-history')", {}, $taint_id); } @@ -376,7 +383,10 @@ END my $oldmode = ((stat _)[2]); my $oldwrites = $oldmode & 0222; # remove r and x bits which have corresponding w bits clear - my $newmode = $oldmode & ($oldwrites << 1) & ($oldwrites > 1); + my $newmode = $oldmode & + (~0555 | ($oldwrites << 1) | ($oldwrites >> 1)); + printdebug sprintf "chmod %#o (was %#o) %s\n", + $newmode, $oldmode, $freshrepo; chmod $newmode, $freshrepo or die $!; } } @@ -392,7 +402,7 @@ sub action_check_list () { statpackage(); next unless $pkg_exists; next unless $pkg_secret; - printdebug "$pkg\n" or die $!; + print "$pkg\n" or die $!; } closedir L or die $!; close STDOUT or die $!;