]> git.ipfire.org Git - thirdparty/public-inbox.git/commitdiff
git_credential: use autodie where appropriate
authorEric Wong <e@80x24.org>
Thu, 2 Nov 2023 09:35:32 +0000 (09:35 +0000)
committerEric Wong <e@80x24.org>
Fri, 3 Nov 2023 06:39:29 +0000 (06:39 +0000)
We can also rely on `say' in Perl 5.10+ to save us the trouble
of printing a newline.

lib/PublicInbox/GitCredential.pm

index a4444e2c5847195259df677f0d26246f985831f2..bb225ff320585385eb989f95fd1a6e181f14ff4b 100644 (file)
@@ -5,19 +5,20 @@
 package PublicInbox::GitCredential;
 use v5.12;
 use PublicInbox::Spawn qw(popen_rd);
+use autodie qw(close pipe);
 
 sub run ($$;$) {
        my ($self, $op, $lei) = @_;
        my ($in_r, $in_w, $out_r);
        my $cmd = [ qw(git credential), $op ];
-       pipe($in_r, $in_w) or die "pipe: $!";
+       pipe($in_r, $in_w);
        if ($lei) { # we'll die if disconnected:
-               pipe($out_r, my $out_w) or die "pipe: $!";
+               pipe($out_r, my $out_w);
                $lei->send_exec_cmd([ $in_r, $out_w ], $cmd, {});
        } else {
                $out_r = popen_rd($cmd, undef, { 0 => $in_r });
        }
-       close $in_r or die "close in_r: $!";
+       close $in_r;
 
        my $out = '';
        for my $k (qw(url protocol host username password)) {
@@ -25,9 +26,8 @@ sub run ($$;$) {
                die "`$k' contains `\\n' or `\\0'\n" if $v =~ /[\n\0]/;
                $out .= "$k=$v\n";
        }
-       $out .= "\n";
-       print $in_w $out or die "print (git credential $op): $!";
-       close $in_w or die "close (git credential $op): $!";
+       say $in_w $out;
+       close $in_w;
        return $out_r if $op eq 'fill';
        <$out_r> and die "unexpected output from `git credential $op'\n";
        $out_r->close or die "`git credential $op' failed: \$!=$! \$?=$?\n";