File: check-cpan

package info (click to toggle)
horae 063-3
  • links: PTS
  • area: contrib
  • in suites: etch, etch-m68k
  • size: 23,964 kB
  • ctags: 4,939
  • sloc: perl: 101,791; ansic: 6,700; xml: 2,019; lisp: 744; sh: 81; makefile: 76
file content (246 lines) | stat: -rwxr-xr-x 8,261 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
#! /usr/bin/perl -w
######################################################################
## check-cpan.pl (-h for help)         copyright (c) 1998 Bruce Ravel
##                                          ravel@phys.washington.edu
##                            http://feff.phys.washington.edu/~ravel/
##
##	  The latest version of Atoms can always be found at
##      http://feff.phys.washington.edu/~ravel/software/atoms/
##
## -------------------------------------------------------------------
##     All rights reserved. This program is free software; you can
##     redistribute it and/or modify it under the same terms as Perl
##     itself.
##
##     This program is distributed in the hope that it will be useful,
##     but WITHOUT ANY WARRANTY; without even the implied warranty of
##     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
##     Artistic License for more details.
## -------------------------------------------------------------------
######################################################################
## $Id: check-cpan,v 1.8 1999/07/02 00:44:48 bruce Exp $
######################################################################
##  This script scan the state of the machines perl installation,
##  searching for required modules and performing a few other check.
##  It will generate a list of modules that must be installed.  If the
##  user is privileged on a machine which can use CPAN, it goes ahead
##  and downloads the modules.
##
##  Here is a list of all the check it performs:
##    1. Check for platform and privilege of user
##    2. Perl version number (looking for 5.004 or greater)
##    3. Check to be sure version 3.0 of Text::ParseWords is not
##       installed
##    4. Check for each of the modules in %modules (but skip checks
##       for Tk modules if the system is MacOS or VMS)
######################################################################
## Code:

use Getopt::Std;
use vars qw($opt_h);
getopts('h');

use Pod::Text;
($opt_h) && do {
  $^W=0;
  pod2text($0, *STDOUT);
  exit;
};

use strict;
##                                          required  sort  needed
##                                          version   order   by
my %modules = ("Statistics::Descriptive" => ["2.2",      1, "all"],
	       "Chemistry::Elements"	 => ["97.1102",  2, "all"],
	       "File::Spec"		 => ["0.6",      3, "all"],
	       "Storable"		 => ["0.603",    4, "all"],
	       "Data::Dumper"		 => ["2.08",     5, "all"],
	       ##"DB_File"		 => ["1.15"   ,],
	       ##"MLDBM"		 => ["2.00"   ,],
	       "Tk"			 => ["400.004",  6, "tkatoms"],
	       "Tk::FileDialog"		 => ["1.3",      7, "tkatoms"],
	       "Text::English"		 => ["0.01",     8, "Tk::Pod"],
	       "Tk::Pod"		 => ["3.15",     9, "tkatoms"],
	       "Math::Spline"            => ["0",       10, "Elam Tables"],
	       "Math::Derivative"        => ["0",       11, "Elam Tables"],
	       ##"foo::bar"                => ["0",       12, "nothing"],
	      );

my %found = ();
my @need = ();
my ($yes, $no) = ("installed", "not installed");

## check for who and what is running this script
print "$/Perl configuration checker for Atoms 3.0beta9.$/$/";
print "This is a $^O computer";
if (($^O eq 'VMS') or ($^O eq 'os2') or ($^O eq 'MacOS')
    or ($^O eq 'MSWin32')) {
  print ".", $/, $/;
} else {
  if ($>) {
    print " and you are a normal user.$/$/";
  } else {
    print " and you are the privileged user.$/$/";
  };
};

## check perl version number
my $required = 5.004;
print "Checking perl version number ... found $], require $required ... ";
if ($] >= $required) {
  print "ok", $/, $/;
} else {
  print "not ok$/";
  die $/, "Atoms requires perl $required or later.  Quitting now.", $/, $/;
};


## check for the evil version 3.0 of Text::ParseWords
require Text::ParseWords;
if ($Text::ParseWords::VERSION == 3.0) {
  print "Uh-oh!  I found version 3.0 of Text::ParseWords, which is buggy.
I will add that to the list of things to install.$/$/";
  push @need, "Text::ParseWords";
};

## check for CPAN modules
print "Checking whether the modules required by Atoms can be found on$/",
  "this computer...$/$/";

my $format = "* %-25s\t%-7s\t\t%s\t   %s$/";

printf $format, "   module", "found", "require", "needed by";
print  "=" x 72, $/;
foreach my $mod
  (sort {$modules{$a}->[1] <=> $modules{$b}->[1]} (keys %modules)) {

    ## skip Tk modules on systems that don't support it
    next if ((($^O eq 'MacOS') or ($^O eq 'VMS')) and
	     (($mod =~ /^Tk/)  or ($mod =~ /English/)));

    my $vnum = join("", "\$", $mod, "::VERSION");
    $found{$mod} = eval "require $mod;";
    $vnum = eval "$vnum" || 0;
				# the version number in Stats::Descr
				# v. 2.2 was in the wrong place
    if (($mod =~ /descriptive/i) and not $vnum) {
      $vnum = join("", "\$", $mod, "::Sparse::VERSION");
      $found{$mod} = eval "require $mod;";
      $vnum = eval "$vnum" || 0;
    };
    if ($found{$mod}) {
      printf $format, $mod, $vnum, $modules{$mod}->[0], $modules{$mod}->[2];
    } else {
      printf $format, $mod, "missing", $modules{$mod}->[0], $modules{$mod}->[2];
    };
    ((not $found{$mod}) || ($modules{$mod}->[0] > $vnum))
      && push @need, $mod;
  };

(@need) || do {
  print
    "$/Looks like you have them all and they are all up to date.  Cool!$/$/";
  exit;
};

use Text::Wrap qw($columns &wrap);
$columns=66;
print "$/You need to install the following modules$/";
print wrap("\t", "\t", join(", ", @need)), $/;
print <<EOH

  Some modules are integral parts of Atoms and others are used only
  by parts of the package.  This is indicated in the last column of
  the table above.  If you are *certain* you will not be using those
  parts of the package, then you are not obliged to install those
  modules.
EOH
;

## bail because this is not Unix and I don't know if the CPAN module
## will work
($^O =~ /^(macos|mswin32|os2|vms)$/i) && do {
  print <<EOH

  You are not on a Unix computer and so must install the missing
  modules by hand.  If you are on a Macintosh or VMS computer, Don\'t
  worry about the missing Tk modules, because TkAtoms won\'t run on
  your computer in any case.

  Mac Users:
    You should download those modules from http://www.perl.com/CPAN/.
    You might find precompiled Mac versions of some of these at
    http://pudge.net/macperl/.  After unpacking the archives, move the
    pm files and perform any autosplitting chores as described in
    Chapter 11 of the MacPerl book.

EOH
; #  '
  exit;
};

## bail because this is a normal user
$> && do {
  print <<EOH

  You are not installing as root, thus this script cannot continue
  with the installation using the CPAN module.  You will have to
  install the missing modules by hand.  Don't fret, it's not hard.

  You should download those modules from http://www.perl.com/CPAN/
  After unpacking the archives and cd-ing to the new subdirectory,
  type \`perl Makefile.PL\' then \`make\'.  After that, run the script
  \"private-install\" for each new module.  That script can be found
  in this directory.

EOH
;
  exit;
};

## continue because this is the superuser on a unix machine
print <<EOH;

It is possible to download and install these using the CPAN module.
This requires that your computer be connected to the internet.

EOH
;

print "Do you want to proceed with the network installation? [y/n] > ";
$_ = <STDIN>;
($_ =~ /^y/i) || exit;

require CPAN;
# install stuff (lines taken from CPAN pod)
for my $mod (@need) {
  my $obj = CPAN::Shell->expand('Module',$mod);
  $obj->install;		# will this work for Text::ParseWords?
}

__END__


=head1 NAME

  check-cpan.pl - check system for CPAN modules required by Atoms

=head1 DESCRIPTION

  This program checks your current perl installation to see which of
  the CPAN modules required by Atoms are alreay installed.  At the
  very least, this script will tell you which ones you should install
  and will give you some hints about how to do so.  If you are running
  this script as the privileged user on a system for which the CPAN
  module works, it will fetch and install the needed modules for you.

=head1 AUTHOR

  Bruce Ravel <ravel@phys.washington.edu>
  (http://feff.phys.washington.edu/~ravel/)

=cut

## Local Variables:
## mode: cperl
## End: