summaryrefslogtreecommitdiff
path: root/installperl
diff options
context:
space:
mode:
authorJarkko Hietaniemi <jhi@iki.fi>2001-06-16 19:46:38 +0000
committerJarkko Hietaniemi <jhi@iki.fi>2001-06-16 19:46:38 +0000
commit2986a63f7e513cf37f46db9f211b77071260031f (patch)
tree9a6e62602396938ea5a612420f53ebf267e8d941 /installperl
parent87b11a197a59fac210fc9265bde0ef1ffe36de89 (diff)
downloadperl-2986a63f7e513cf37f46db9f211b77071260031f.tar.gz
NetWare port from Guruprasad S <SGURUPRASAD@novell.com>.
p4raw-id: //depot/perl@10643
Diffstat (limited to 'installperl')
-rwxr-xr-xinstallperl88
1 files changed, 67 insertions, 21 deletions
diff --git a/installperl b/installperl
index 9f49c131cd..a58f8e5a53 100755
--- a/installperl
+++ b/installperl
@@ -9,7 +9,7 @@ BEGIN {
use strict;
my ($Is_VMS, $Is_W32, $Is_OS2, $Is_Cygwin, $nonono, $dostrip,
- $versiononly, $silent, $verbose, $otherperls, $archname);
+ $versiononly, $silent, $verbose, $otherperls, $archname,$Is_NetWare, $nwinstall);
use vars qw /$depth/;
BEGIN {
@@ -30,6 +30,12 @@ use ExtUtils::Packlist;
use Config;
use subs qw(unlink link chmod);
+$Is_NetWare = $Config{osname} eq 'NetWare';
+if ($Is_NetWare) {
+ $Is_W32 = 0;
+ $scr_ext = '.pl';
+}
+
# override the ones in the rest of the script
sub mkpath {
File::Path::mkpath(@_) unless $nonono;
@@ -59,6 +65,7 @@ while (@ARGV) {
$otherperls = 0 if $ARGV[0] eq '-o';
$verbose = 1 if $ARGV[0] eq '-V' || $ARGV [0] eq '-n';
$archname = 1 if $ARGV[0] eq '-A';
+ $nwinstall = 1 if $ARGV[0] eq '-netware';
shift;
}
@@ -157,6 +164,14 @@ if ($^O eq 'os390') {
}
}
+if ($nwinstall) {
+ # This is required only if we are installing on a NetWare server
+ $installscript = $Config{installnwscripts};
+ $installprivlib = $Config{installnwlib};
+ $installarchlib = $Config{installnwlib};
+ $installsitelib = $Config{installnwlib};
+}
+
my $d_dosuid = $Config{d_dosuid};
my $binexp = $Config{binexp};
@@ -178,14 +193,16 @@ if ($d_dosuid && $>) { die "You must run as root to install suidperl\n"; }
-w $installbin || $nonono || die "$installbin is not writable by you\n"
unless $installbin =~ m#^/afs/# || $nonono;
+if (!$Is_NetWare) {
-x 'perl' . $exe_ext || die "perl isn't executable!\n";
-x 'suidperl' . $exe_ext|| die "suidperl isn't executable!\n" if $d_dosuid;
-f 't/rantests' || $Is_W32
|| warn "WARNING: You've never run 'make test' or",
" some tests failed! (Installing anyway.)\n";
+} #if (!$Is_NetWare)
-if ($Is_W32 or $Is_Cygwin) {
+if (($Is_W32 and ! $Is_NetWare) or $Is_Cygwin) {
my $perldll;
if ($Is_Cygwin) {
@@ -212,7 +229,7 @@ if ($Is_W32 or $Is_Cygwin) {
copy("$perldll", "$installbin/$perldll");
chmod(0755, "$installbin/$perldll");
-} # if ($Is_W32 or $Is_Cygwin)
+} # if (($Is_W32 and ! $Is_NetWare) or $Is_Cygwin)
# This will be used to store the packlist
my $packlist = ExtUtils::Packlist->new("$installarchlib/.packlist");
@@ -238,10 +255,26 @@ elsif ($^O eq 'mpeix') {
link($Config{perlpath}, "$installbin/perl$ver$exe_ext");
}
elsif ($^O ne 'dos') {
- safe_unlink("$installbin/$perl_verbase$ver$exe_ext");
- copy("perl$exe_ext", "$installbin/$perl_verbase$ver$exe_ext");
- strip("$installbin/$perl_verbase$ver$exe_ext");
- chmod(0755, "$installbin/$perl_verbase$ver$exe_ext");
+ if (!$Is_NetWare) {
+ safe_unlink("$installbin/$perl_verbase$ver$exe_ext");
+ copy("perl$exe_ext", "$installbin/$perl_verbase$ver$exe_ext");
+ strip("$installbin/$perl_verbase$ver$exe_ext");
+ chmod(0755, "$installbin/$perl_verbase$ver$exe_ext");
+ }
+ else {
+ # If installing onto a NetWare server
+ if ($nwinstall) {
+ # Copy perl.nlm, echo.nlm, type.nlm, a2p.nlm & cgi2perl.nlm
+ mkpath($Config{installnwsystem}, 1, 0777);
+ copy("netware\\".$ENV{'MAKE_TYPE'}."\\perl.nlm", $Config{installnwsystem});
+ copy("netware\\testnlm\\echo\\echo.nlm", $Config{installnwsystem});
+ copy("netware\\testnlm\\type\\type.nlm", $Config{installnwsystem});
+ copy("x2p\\a2p.nlm", $Config{installnwsystem});
+ chmod(0755, "$Config{installnwsystem}\\perl.nlm");
+ mkpath($Config{installnwlcgi}, 1, 0777);
+ copy("lib\\auto\\cgi2perl\\cgi2perl.nlm", $Config{installnwlcgi});
+ }
+ } #if (!$Is_NetWare)
}
else {
safe_unlink("$installbin/$perl.exe");
@@ -315,7 +348,7 @@ foreach my $file (@corefiles) {
# Install main perl executables
# Make links to ordinary names if installbin directory isn't current directory.
-if (! $versiononly && ! samepath($installbin, '.') && ($^O ne 'dos') && ! $Is_VMS) {
+if (! $versiononly && ! samepath($installbin, '.') && ($^O ne 'dos') && ! $Is_VMS && ! $Is_NetWare) {
safe_unlink("$installbin/$perl$exe_ext", "$installbin/suid$perl$exe_ext");
if ($^O eq 'mpeix') {
# MPE doesn't support hard links, so use a symlink.
@@ -350,7 +383,7 @@ if ($archname && ! samepath($installbin, '.') && ($^O ne 'dos') && ! $Is_VMS) {
my $mainperl_is_instperl = 0;
if ($Config{installusrbinperl} && $Config{installusrbinperl} eq 'define' &&
- !$versiononly && !$nonono && !$Is_W32 && !$Is_VMS && -t STDIN && -t STDERR
+ !$versiononly && !$nonono && !$Is_W32 && !$Is_NetWare && !$Is_VMS && -t STDIN && -t STDERR
&& -w $mainperldir && ! samepath($mainperldir, $installbin)) {
my($usrbinperl) = "$mainperldir/$perl$exe_ext";
my($instperl) = "$installbin/$perl$exe_ext";
@@ -384,11 +417,12 @@ if ($Config{installusrbinperl} && $Config{installusrbinperl} eq 'define' &&
}
# Make links to ordinary names if installbin directory isn't current directory.
-
-if (!$versiononly && ! samepath($installbin, 'x2p')) {
- safe_unlink("$installbin/a2p$exe_ext");
- copy("x2p/a2p$exe_ext", "$installbin/a2p$exe_ext");
- chmod(0755, "$installbin/a2p$exe_ext");
+if (!$Is_NetWare) {
+ if (!$versiononly && ! samepath($installbin, 'x2p')) {
+ safe_unlink("$installbin/a2p$exe_ext");
+ copy("x2p/a2p$exe_ext", "$installbin/a2p$exe_ext");
+ chmod(0755, "$installbin/a2p$exe_ext");
+ }
}
# cppstdin is just a script, but it is architecture-dependent, so
@@ -483,7 +517,7 @@ if ( !$versiononly || ($installprivlib =~ m/\Q$ver/)) {
if (!$versiononly && $otherperls) {
my ($path, @path);
- my $dirsep = ($Is_OS2 || $Is_W32) ? ';' : ':' ;
+ my $dirsep = ($Is_OS2 || $Is_W32 || $Is_NetWare) ? ';' : ':' ;
($path = $ENV{"PATH"}) =~ s:\\:/:g ;
@path = split(/$dirsep/, $path);
if ($Is_VMS) {
@@ -542,7 +576,7 @@ sub unlink {
foreach my $name (@names) {
next unless -e $name;
- chmod 0777, $name if ($Is_OS2 || $Is_W32 || $Is_Cygwin);
+ chmod 0777, $name if ($Is_OS2 || $Is_W32 || $Is_Cygwin || $Is_NetWare);
print " unlink $name\n" if $verbose;
( CORE::unlink($name) and ++$cnt
or warn "Couldn't unlink $name: $!\n" ) unless $nonono;
@@ -555,7 +589,7 @@ sub safe_unlink {
my @names = @_;
foreach my $name (@names) {
next unless -e $name;
- chmod 0777, $name if ($Is_OS2 || $Is_W32);
+ chmod 0777, $name if ($Is_OS2 || $Is_W32 || $Is_NetWare);
print " unlink $name\n" if $verbose;
next if CORE::unlink($name);
warn "Couldn't unlink $name: $!\n";
@@ -633,7 +667,7 @@ sub copy {
sub samepath {
my($p1, $p2) = @_;
- return (lc($p1) eq lc($p2)) if $Is_W32;
+ return (lc($p1) eq lc($p2)) if ($Is_W32 || $Is_NetWare);
if ($p1 ne $p2) {
my($dev1, $ino1, $dev2, $ino2);
@@ -668,7 +702,7 @@ sub installlib {
my $installlib = $installprivlib;
if ($dir =~ /^auto/ ||
($name =~ /^(.*)\.(?:pm|pod)$/ && $archpms{$1}) ||
- ($name =~ /^(.*)\.(?:h|lib)$/i && $Is_W32)
+ ($name =~ /^(.*)\.(?:h|lib)$/i && ($Is_W32 || $Is_NetWare))
) {
$installlib = $installarchlib;
return unless $do_installarchlib;
@@ -691,9 +725,21 @@ sub installlib {
mkpath("$installlib/$dir", $verbose, 0777);
# HP-UX (at least) needs to maintain execute permissions
# on dynamically-loaded libraries.
- copy_if_diff($_, "$installlib/$name")
- and chmod($name =~ /\.(so|$dlext)$/o ? 0555 : 0444,
+ if ($Is_NetWare && !$nwinstall) {
+ # Don't copy .nlp,.nlm files, doesn't make sense on Windows and also
+ # if copied will give problems when building new extensions.
+ # Has to be copied if we are installing on a NetWare server and hence
+ # the check !$nwinstall
+ if (!(/\.(?:nlp|nlm|bs)$/)) {
+ copy_if_diff($_, "$installlib/$name")
+ and chmod($name =~ /\.(so|$dlext)$/o ? 0555 : 0444,
+ "$installlib/$name");
+ }
+ } else {
+ copy_if_diff($_, "$installlib/$name")
+ and chmod($name =~ /\.(so|$dlext)$/o ? 0555 : 0444,
"$installlib/$name");
+ } #if ($Is_NetWare)
}
}
}