This is a live mirror of the Perl 5 development currently hosted at
https://github.com/perl/perl5
https://perl5.git.perl.org
/
perl5.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add option to omit Changes file, from Abigail <abigail@delanet.com>;
[perl5.git]
/
installman
diff --git
a/installman
b/installman
index
600a681
..
04ef578
100755
(executable)
--- a/
installman
+++ b/
installman
@@
-3,8
+3,11
@@
BEGIN { @INC = ('lib') }
use Config;
use Getopt::Long;
use File::Find;
use Config;
use Getopt::Long;
use File::Find;
+use File::Copy;
use File::Path qw(mkpath);
use File::Path qw(mkpath);
+use ExtUtils::Packlist;
use subs qw(unlink chmod rename link);
use subs qw(unlink chmod rename link);
+use vars qw($packlist);
require Cwd;
umask 022;
require Cwd;
umask 022;
@@
-14,8
+17,8
@@
$ver = $];
$release = substr($ver,0,3); # Not used presently.
$patchlevel = substr($ver,3,2);
die "Patchlevel of perl ($patchlevel)",
$release = substr($ver,0,3); # Not used presently.
$patchlevel = substr($ver,3,2);
die "Patchlevel of perl ($patchlevel)",
- "and patchlevel of config.sh ($Config{'P
ATCHLEVEL
'}) don't match\n"
- if $patchlevel != $Config{'P
ATCHLEVEL
'};
+ "and patchlevel of config.sh ($Config{'P
ERL_VERSION
'}) don't match\n"
+ if $patchlevel != $Config{'P
ERL_VERSION
'};
$usage =
"Usage: installman --man1dir=/usr/wherever --man1ext=1
$usage =
"Usage: installman --man1dir=/usr/wherever --man1ext=1
@@
-50,6
+53,8
@@
$notify = $opt_notify || $opt_n;
-x "t/perl$Config{exe_ext}" || warn "WARNING: You've never run 'make test'!!!",
" (Installing anyway.)\n";
-x "t/perl$Config{exe_ext}" || warn "WARNING: You've never run 'make test'!!!",
" (Installing anyway.)\n";
+$packlist = ExtUtils::Packlist->new("$Config{installarchlib}/.packlist");
+
# Install the main pod pages.
runpod2man('pod', $man1dir, $man1ext);
# Install the main pod pages.
runpod2man('pod', $man1dir, $man1ext);
@@
-60,12
+65,19
@@
runpod2man('lib', $man3dir, $man3ext);
runpod2man('utils', $man1dir, $man1ext, 'c2ph');
runpod2man('utils', $man1dir, $man1ext, 'h2ph');
runpod2man('utils', $man1dir, $man1ext, 'h2xs');
runpod2man('utils', $man1dir, $man1ext, 'c2ph');
runpod2man('utils', $man1dir, $man1ext, 'h2ph');
runpod2man('utils', $man1dir, $man1ext, 'h2xs');
+runpod2man('utils', $man1dir, $man1ext, 'perlcc');
runpod2man('utils', $man1dir, $man1ext, 'perldoc');
runpod2man('utils', $man1dir, $man1ext, 'perlbug');
runpod2man('utils', $man1dir, $man1ext, 'pl2pm');
runpod2man('utils', $man1dir, $man1ext, 'perldoc');
runpod2man('utils', $man1dir, $man1ext, 'perlbug');
runpod2man('utils', $man1dir, $man1ext, 'pl2pm');
+runpod2man('utils', $man1dir, $man1ext, 'splain');
+runpod2man('utils', $man1dir, $man1ext, 'dprofpp');
runpod2man('x2p', $man1dir, $man1ext, 's2p');
runpod2man('x2p', $man1dir, $man1ext, 'a2p.pod');
runpod2man('pod', $man1dir, $man1ext, 'pod2man');
runpod2man('x2p', $man1dir, $man1ext, 's2p');
runpod2man('x2p', $man1dir, $man1ext, 'a2p.pod');
runpod2man('pod', $man1dir, $man1ext, 'pod2man');
+runpod2man('pod', $man1dir, $man1ext, 'pod2html');
+runpod2man('pod', $man1dir, $man1ext, 'pod2usage');
+runpod2man('pod', $man1dir, $man1ext, 'podchecker');
+runpod2man('pod', $man1dir, $man1ext, 'podselect');
# It would probably be better to have this page linked
# to the c2ph man page. Or, this one could say ".so man1/c2ph.1",
# It would probably be better to have this page linked
# to the c2ph man page. Or, this one could say ".so man1/c2ph.1",
@@
-127,7
+139,7
@@
sub runpod2man {
# Convert name from File/Basename.pm to File::Basename.3 format,
# if necessary.
$manpage =~ s#\.p(m|od)$##;
# Convert name from File/Basename.pm to File::Basename.3 format,
# if necessary.
$manpage =~ s#\.p(m|od)$##;
- if ($^O eq 'os2' || $^O eq 'amigaos') {
+ if ($^O eq 'os2' || $^O eq 'amigaos'
|| $^O eq 'uwin' || $^O =~ /cygwin/
) {
$manpage =~ s#/#.#g;
} else {
$manpage =~ s#/#::#g;
$manpage =~ s#/#.#g;
} else {
$manpage =~ s#/#::#g;
@@
-154,6
+166,7
@@
sub lsmodpods {
}
}
}
}
+$packlist->write() unless $notify;
print STDERR " Installation complete\n";
exit 0;
print STDERR " Installation complete\n";
exit 0;
@@
-186,18
+199,33
@@
next unless -e $name;
chmod 0777, $name if $^O eq 'os2';
print STDERR " unlink $name\n";
( CORE::unlink($name) and ++$cnt
chmod 0777, $name if $^O eq 'os2';
print STDERR " unlink $name\n";
( CORE::unlink($name) and ++$cnt
- or warn "Couldn't unlink $name: $!\n" ) unless $no
nono
;
+ or warn "Couldn't unlink $name: $!\n" ) unless $no
tify
;
}
return $cnt;
}
sub link {
}
return $cnt;
}
sub link {
- local($from,$to) = @_;
+ my($from,$to) = @_;
+ my($success) = 0;
print STDERR " ln $from $to\n";
print STDERR " ln $from $to\n";
- eval { CORE::link($from,$to) }
-|| system('cp', $from, $to) == 0
-|| warn "Couldn't link $from to $to: $!\n" unless $notify;
+ eval {
+ CORE::link($from, $to)
+ ? $success++
+ : ($from =~ m#^/afs/# || $to =~ m#^/afs/#)
+ ? die "AFS" # okay inside eval {}
+ : warn "Couldn't link $from to $to: $!\n"
+ unless $notify;
+ $packlist->{$to} = { type => 'file' };
+ };
+ if ($@) {
+ File::Copy::copy($from, $to)
+ ? $success++
+ : warn "Couldn't copy $from to $to: $!\n"
+ unless $notify;
+ $packlist->{$to} = { type => 'file' };
+ }
+ $success;
}
sub rename {
}
sub rename {
@@
-212,6
+240,7
@@
warn("Cannot rename to `$to.$i': $!"), return 0
}
link($from,$to) || return 0;
unlink($from);
}
link($from,$to) || return 0;
unlink($from);
+ $packlist->{$to} = { type => 'file' };
}
sub chmod {
}
sub chmod {