diff options
author | Mystery Man <unknown@mandriva.org> | 2001-08-07 17:40:36 +0000 |
---|---|---|
committer | Mystery Man <unknown@mandriva.org> | 2001-08-07 17:40:36 +0000 |
commit | 068d599562888a36a50e5bbdeb8b70f83fa7c287 (patch) | |
tree | 18f5eed8353b3af647412875d438b55ef8c07670 /perl-install/run_program.pm | |
parent | be838931607e1ab14c8c699e20dd807b55579f7b (diff) | |
download | drakx-068d599562888a36a50e5bbdeb8b70f83fa7c287.tar drakx-068d599562888a36a50e5bbdeb8b70f83fa7c287.tar.gz drakx-068d599562888a36a50e5bbdeb8b70f83fa7c287.tar.bz2 drakx-068d599562888a36a50e5bbdeb8b70f83fa7c287.tar.xz drakx-068d599562888a36a50e5bbdeb8b70f83fa7c287.zip |
This commit was manufactured by cvs2svn to create branchtopic/v_webmin_0_87
'v_webmin_0_87'.
Diffstat (limited to 'perl-install/run_program.pm')
-rw-r--r-- | perl-install/run_program.pm | 70 |
1 files changed, 0 insertions, 70 deletions
diff --git a/perl-install/run_program.pm b/perl-install/run_program.pm deleted file mode 100644 index f56c59f4d..000000000 --- a/perl-install/run_program.pm +++ /dev/null @@ -1,70 +0,0 @@ -package run_program; # $Id$ - -use diagnostics; -use strict; - -use log; - -1; - -sub run_or_die { - my ($name, @args) = @_; - run($name, @args) or die "$name failed\n"; -} -sub rooted_or_die { - my ($root, $name, @args) = @_; - rooted($root, $name, @args) or die "$name failed\n"; -} -sub run { rooted('', @_) } - -sub rooted { - my ($root, $name, @args) = @_; - my $str = ref $name ? $name->[0] : $name; - log::l("running: $str @args" . ($root ? " with root $root" : "")); - - return 1 if $root && $<; - - $root ? $root .= '/' : ($root = ''); - install_any::check_prog (ref $name ? $name->[0] : $name) if !$root && $::isInstall; - - if (my $pid = fork) { - waitpid $pid, 0; - return $? == 0; - } - { - my ($stdout, $stdoutm, $stderr, $stderrm); - ($stdoutm, $stdout, @args) = @args if $args[0] =~ /^>>?$/; - ($stderrm, $stderr, @args) = @args if $args[0] =~ /^2>>?$/; - - open STDIN, "/dev/null" or die "can't open /dev/null as stdin"; - - if ($stderr) { - $stderrm =~ s/2//; - open STDERR, "$stderrm $root$stderr" or die "run_program can't output in $root$stderr (mode `$stderrm')"; - } elsif ($::isInstall) { - open STDERR, ">> /tmp/ddebug.log" or open STDOUT, ">> /dev/tty7" or die "run_program can't log, give me access to /tmp/ddebug.log"; - } - if ($stdout) { - open STDOUT, "$stdoutm $root$stdout" or die "run_program can't output in $root$stdout (mode `$stdoutm')"; - } elsif ($::isInstall) { - open STDOUT, ">> /tmp/ddebug.log" or open STDOUT, ">> /dev/tty7" or die "run_program can't log, give me access to /tmp/ddebug.log"; - } - - $root and chroot $root; - chdir "/"; - - if (ref $name) { - unless (exec { $name->[0] } $name->[1], @args) { - log::l("exec of $name->[0] failed: $!"); - c::_exit(128); - } - } else { - unless (exec $name, @args) { - log::l("exec of $name failed: $!"); - c::_exit(128); - } - - } - } - -} |