2 # @(#)dotsh.pl 03/19/94
4 # This library is no longer being maintained, and is included for backward
5 # compatibility with Perl 4 programs which may require it.
6 # This legacy library is deprecated and will be removed in a future
9 # In particular, this should not be used as an example of modern Perl
10 # programming techniques.
12 # Author: Charles Collins
15 # This routine takes a shell script and 'dots' it into the current perl
16 # environment. This makes it possible to use existing system scripts
17 # to alter environment variables on the fly.
20 # &dotsh ('ShellScript', 'DependentVariable(s)');
24 # 'ShellScript' is the full name of the shell script to be dotted
26 # 'DependentVariable(s)' is an optional list of shell variables in the
27 # form VARIABLE=VALUE,VARIABLE=VALUE,... that 'ShellScript' is
28 # dependent upon. These variables MUST be defined using shell syntax.
31 # &dotsh ('/foo/bar', 'arg1');
32 # &dotsh ('/foo/bar');
33 # &dotsh ('/foo/bar arg1 ... argN');
36 warn( "The 'dotsh.pl' legacy library is deprecated and will be"
37 . " removed in the next major release of perl. Please use "
38 . " one of the related modules from CPAN instead."
39 . " (Shell::Source, Shell::GetEnv, ...)" );
43 local($tmp,$key,$shell,$command,$args,$vars) = '';
47 @dotsh = split (/\s/, $dotsh);
48 $command = shift (@dotsh);
49 $args = join (" ", @dotsh);
50 $vars = join ("\n", @sh);
51 open (_SH_ENV, "$command") || die "Could not open $dotsh!\n";
53 $shell = "$1 -c" if ($_ =~ /^\#\!\s*(\S+(\/sh|\/ksh|\/zsh|\/csh))\s*$/);
56 if ($ENV{'SHELL'} =~ /\/sh$|\/ksh$|\/zsh$|\/bash$|\/csh$/) {
57 $shell = "$ENV{'SHELL'} -c";
59 print "SHELL not recognized!\nUsing /bin/sh...\n";
60 $shell = "/bin/sh -c";
63 if (length($vars) > 0) {
64 open (_SH_ENV, "$shell \"$vars && . $command $args && set \" |") || die;
66 open (_SH_ENV, "$shell \". $command $args && set \" |") || die;
76 foreach $key (keys(%ENV)) {
77 $tmp .= "\$$key = \$ENV{'$key'};" if $key =~ /^[A-Za-z]\w*$/;