diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-30 02:50:01 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-30 02:50:01 +0000 |
commit | 91275eb478ceb58083426099b6da3f4c7e189f19 (patch) | |
tree | 260f7d2fa77408b38c5cea96b320b9b0b6713ff2 /debian/vendor-h2o/share/h2o/kill-on-close | |
parent | Merging upstream version 1.9.4. (diff) | |
download | dnsdist-91275eb478ceb58083426099b6da3f4c7e189f19.tar.xz dnsdist-91275eb478ceb58083426099b6da3f4c7e189f19.zip |
Merging debian version 1.9.4-1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'debian/vendor-h2o/share/h2o/kill-on-close')
-rwxr-xr-x | debian/vendor-h2o/share/h2o/kill-on-close | 63 |
1 files changed, 0 insertions, 63 deletions
diff --git a/debian/vendor-h2o/share/h2o/kill-on-close b/debian/vendor-h2o/share/h2o/kill-on-close deleted file mode 100755 index 4890abd..0000000 --- a/debian/vendor-h2o/share/h2o/kill-on-close +++ /dev/null @@ -1,63 +0,0 @@ -#! /bin/sh -exec ${H2O_PERL:-perl} -x $0 "$@" -#! perl - -use strict; -use warnings; -use Errno qw(EINTR); -use POSIX qw(WNOHANG); - -my $rmpath; - -while (@ARGV) { - if ($ARGV[0] eq '--') { - shift @ARGV; - last; - } elsif ($ARGV[0] !~ /^--/) { - last; - } elsif ($ARGV[0] =~ /^--rm(?:=(.*)|)$/) { - shift @ARGV; - if (defined $1) { - $rmpath = $1; - } else { - die "option `--rm` requires an argument\n" - unless @ARGV; - $rmpath = shift @ARGV; - } - } else { - die "unknown argument: $ARGV[0]"; - } -} - -shift @ARGV - if @ARGV && $ARGV[0] eq '--'; - -die "Usage: $0 [--rm=path] -- cmd args...\n" - unless @ARGV; - -open my $wait_fh, '<&', 5 - or die "failed to open wait file descriptor (fd=5):$!"; - -my $pid = fork; -die "fork failed:$!" - if $pid == -1; -if ($pid == 0) { - exec @ARGV; - die "failed to exec $ARGV[0]:$!"; -} - -$SIG{INT} = sub {}; - -while (1) { - my $r = sysread $wait_fh, my $buf, 1; - last if !defined($r) || $r == 0 || ($r == -1 && $! != EINTR); -} - -kill 'TERM', $pid; -while (waitpid($pid, 0) != $pid) { -} - -if (defined $rmpath) { - exec '/bin/rm', '-rf', $rmpath; - die "failed to exec /bin/rm:$!"; -} |