diff options
author | Andy Dougherty <doughera@lafayette.edu> | 2002-07-18 08:40:05 -0400 |
---|---|---|
committer | Jarkko Hietaniemi <jhi@iki.fi> | 2002-07-18 16:01:38 +0000 |
commit | cc65bb4961e551c0b5a3921471c9232b097b937e (patch) | |
tree | fb53db3c418eaa8a59d164e44a31169a0c9035a1 /INSTALL | |
parent | e655887db8bcf3e620d45a662a43d964226eb3f1 (diff) | |
download | perl-cc65bb4961e551c0b5a3921471c9232b097b937e.tar.gz |
Re: [PATCH] AUTHORS and INSTALL
Message-ID: <Pine.SOL.4.10.10207181236030.15097-100000@maxwell.phys.lafayette.edu>
p4raw-id: //depot/perl@17624
Diffstat (limited to 'INSTALL')
-rw-r--r-- | INSTALL | 130 |
1 files changed, 53 insertions, 77 deletions
@@ -24,7 +24,7 @@ with all the defaults are: Each of these is explained in further detail below. -B<NOTE>: starting from the release 5.6.0, Perl will use a version +B<NOTE>: starting from the release 5.6.0, Perl uses a version scheme where even-numbered subreleases (like 5.6 and 5.8) are stable maintenance releases and odd-numbered subreleases (like 5.7) are unstable development releases. Development releases should not be @@ -33,8 +33,9 @@ carefully tested in development releases and only if they prove themselves to be worthy will they be migrated to the maintenance releases. -The above commands will install Perl to /usr/local or /opt, depending -on the platform. If that's not okay with you, use +The above commands will install Perl to /usr/local (or some other +platform-specific directory -- see the appropriate file in hints/.) +If that's not okay with you, use rm -f config.sh Policy.sh sh Configure @@ -46,8 +47,8 @@ For information on non-Unix systems, see the section on L<"Porting information"> below. If "make install" just says "`install' is up to date" or something -similar, you may be on case-preserving filesystems such as Mac's HFS+ -and you should say "make install-all". (This confusion brought to you +similar, you may be on a case-insensitive filesystems such as Mac's HFS+, +and you should say "make install-all". (This confusion is brought to you by the Perl distribution having a file called INSTALL.) If you have problems, corrections, or questions, please see @@ -81,9 +82,8 @@ also read the README file specific to that system. If there is a hint file for your system (in the hints/ directory) you should also read that hint file for specific information for your -system. (Unixware users should use the svr4.sh hint file.) If -there is a README file for your platform, then you should read -that too. Additional information is in the Porting/ directory. +system. (Unixware users should use the svr4.sh hint file.) +Additional information is in the Porting/ directory. =head1 WARNING: This version requires an extra step to build old extensions. @@ -104,7 +104,7 @@ pod/perl56delta.pod contains more details about this. =head1 WARNING: This version is not binary compatible with releases of Perl prior to 5.8.0. -If you have built extensions (ie modules that include C code) +If you have built extensions (i.e. modules that include C code) using an earlier version of Perl, you will need to rebuild and reinstall those extensions. @@ -137,8 +137,8 @@ know that an ANSI-capable compiler is installed on your system, you can tell F<Configure> to use the correct compiler by means of the C<-Dcc=> command-line option -- see L<"gcc">. -If do not have an ANSI-capable compiler there are several avenues open -to you: +If do not have an ANSI-capable compiler there are a couple of avenues +open to you: =over 4 @@ -159,21 +159,6 @@ access it.) If there is a README file for your system in the Perl distribution (for example, F<README.hpux>), it may contain advice on suitable compilers. -=item * - -Another alternative may be to use a tool like ansi2knr to convert the -sources back to K&R style, but there is no guarantee this route will get -you anywhere, since the prototypes are not the only ANSI features used -in the Perl sources. ansi2knr is usually found as part of the freely -available Ghostscript distribution. Another similar tool is -unprotoize, distributed with GCC. Since unprotoize requires GCC to -run, you may have to run it on a platform where GCC is available, and move -the sources back to the platform without GCC. - -If you succeed in automatically converting the sources to a K&R compatible -form, be sure to email perlbug@perl.org to let us know the steps you -followed. This will enable us to officially support this option. - =back Although Perl can be compiled using a C++ compiler, the Configure script @@ -255,7 +240,7 @@ After it runs, Configure will perform variable substitution on all the =head2 Altering config.sh variables for C compiler switches etc. For most users, all of the Configure defaults are fine. Configure -also has several convenient options which are all described below. +also has several convenient options which are described below. However, if Configure doesn't have an option to do what you want, you can change Configure variables after the platform hints have been run, by using Configure's -A switch. For example, here's how to add @@ -272,10 +257,8 @@ For more help on Configure switches, run: Sometimes it is desirable to build Perl in a directory different from where the sources are, for example if you want to keep your sources read-only, or if you want to share the sources between different binary -architectures. - -Starting from Perl 5.6.1 you can do this (if your file system supports -symbolic links) by +architectures. You can do this (if your file system supports symbolic +links) by mkdir /tmp/perl/build/directory cd /tmp/perl/build/directory @@ -362,7 +345,7 @@ output, you can run sh Configure -des -Note: for development releases (odd subreleases, like 5.7, as opposed +Note: for development releases (odd subreleases, like 5.9, as opposed to maintenance releases which have even subreleases, like 5.6 and 5.8) if you want to use Configure -d, you will also need to supply -Dusedevel to Configure, because the default answer to the question "do you really @@ -387,25 +370,26 @@ options. Try for a listing. -Cross compiling and compiling in a different directory are not supported. - (The file is called configure.gnu to avoid problems on systems that would not distinguish the files "Configure" and "configure".) +See L<Cross-compilation> below for information on cross-compiling. + =head2 Installation Directories The installation directories can all be changed by answering the appropriate questions in Configure. For convenience, all the installation questions are near the beginning of Configure. -Further, there are a number of additions to the installation -directories since 5.005, so reusing your old config.sh may not -be sufficient to put everything where you want it. Do not include -trailing slashes on directory names. +Do not include trailing slashes on directory names. I highly recommend running Configure interactively to be sure it puts everything where you want it. At any point during the Configure process, you can answer a question with &-d and Configure will use -the defaults from then on. +the defaults from then on. Alternatively, you can + + grep '^install' config.sh + +after Configure has run to verify the installation paths. The defaults are intended to be reasonable and sensible for most people building from sources. Those who build and distribute binary @@ -580,13 +564,12 @@ Configure. =item HTML pages -As of perl5.005_57, the standard perl installation does not do -anything with HTML documentation, but that may change in the future. -Further, some add-on modules may wish to install HTML documents. The -html Configure variables listed above are provided if you wish to -specify where such documents should be placed. The default is "none", -but will likely eventually change to something useful based on user -feedback. +Currently, the standard perl installation does not do anything with +HTML documentation, but that may change in the future. Further, some +add-on modules may wish to install HTML documents. The html Configure +variables listed above are provided if you wish to specify where such +documents should be placed. The default is "none", but will likely +eventually change to something useful based on user feedback. =back @@ -689,11 +672,6 @@ If the generated Policy.sh file is unsuitable, you may freely edit it to contain any valid shell commands. It will be run just after the platform-specific hints files. -Note: Since the directory hierarchy since 5.6.0 contains a number of -new vendor* and site* entries, your Policy.sh file will probably not -set them to your desired values. I encourage you to run Configure -interactively to be sure it puts things where you want them. - =head2 Configure-time Options There are several different ways to Configure and build perl for your @@ -703,9 +681,8 @@ some of the main things you can change. =head2 Threads -On some platforms, perl5.005 and later can be compiled with -experimental support for threads. To enable this, read the file -ext/threads/threads.pm, and then try: +On some platforms, perl can be compiled with +support for threads. To enable this, run sh Configure -Dusethreads @@ -724,10 +701,10 @@ unmaintained. By default, Configure selects ithreads if -Dusethreads is specified. -(You need to use also the PerlIO layer, explained later, if you decide +(You need to also use the PerlIO layer, explained later, if you decide to use ithreads, to guarantee the good interworking of threads and I/O.) -However, you can select the old 5005threads behavior +However, if you wish, you can select the unsupported old 5005threads behavior sh Configure -Dusethreads -Duse5005threads @@ -944,11 +921,11 @@ for example: There is also an potential problem with the shared perl library if you want to have more than one "flavor" of the same version of perl (e.g. with and without -DDEBUGGING). For example, suppose you build and -install a standard Perl 5.004 with a shared library. Then, suppose you -try to build Perl 5.004 with -DDEBUGGING enabled, but everything else +install a standard Perl 5.8.0 with a shared library. Then, suppose you +try to build Perl 5.8.0 with -DDEBUGGING enabled, but everything else the same, including all the installation directories. How can you ensure that your newly built perl will link with your newly built -libperl.so.4 rather with the installed libperl.so.4? The answer is +libperl.so.8 rather with the installed libperl.so.8? The answer is that you might not be able to. The installation directory is encoded in the perl binary with the LD_RUN_PATH environment variable (or equivalent ld command-line option). On Solaris, you can override that @@ -2081,7 +2058,7 @@ approach. =head1 Coexistence with earlier versions of perl5 Perl 5.8 is not binary compatible with earlier versions of Perl. -In other words, you have to recompile your XS modules. +In other words, you will have to recompile your XS modules. In general, you can usually safely upgrade from one version of Perl (e.g. 5.004_04) to another similar version (e.g. 5.004_05) without re-compiling @@ -2130,9 +2107,8 @@ but will not interfere with the 5.005_03 version. The last entry, /usr/local/lib/perl5/site_perl/, is there so that 5.6.0 and above will look for 5.004-era pure perl modules. -Lastly, suppose you later installed 5.6.1, and finally install version -5.8.0, which we'll assume is backwards binary compatible with 5.6.0 -and 5.005. The directories searched by 5.8.0 (if you don't change the +Lastly, suppose you now install 5.8.0, which is not binary compatible +with 5.6.0. The directories searched by 5.8.0 (if you don't change the Configure defaults) will be: /usr/local/lib/perl5/5.8.0/$archname @@ -2140,26 +2116,26 @@ Configure defaults) will be: /usr/local/lib/perl5/site_perl/5.8.0/$archname /usr/local/lib/perl5/site_perl/5.8.0 - /usr/local/lib/perl5/site_perl/5.6.1/$archname - /usr/local/lib/perl5/site_perl/5.6.1 - - /usr/local/lib/perl5/site_perl/5.6.0/$archname /usr/local/lib/perl5/site_perl/5.6.0 - /usr/local/lib/perl5/site_perl/5.005/$archname /usr/local/lib/perl5/site_perl/5.005 /usr/local/lib/perl5/site_perl/ +Note that the earlier $archname entries are now gone, but pure perl +modules from earlier versions will still be found. + Assuming the users in your site are still actively using perl 5.6.0 and 5.005 after you installed 5.8.0, you can continue to install add-on -extensions using any of perl 5.8.0, 5.6.1, 5.6.0, or 5.005. The installations -of these different versions remain distinct, but remember that the newer -versions of perl are automatically set up to search the site libraries of -the older ones. This means that installing a new extension with 5.005 -will make it visible to all three versions. Later, if you install the -same extension using, say, perl 5.6.1, it will override the 5.005-installed -version, but only for perl 5.6.1. +extensions using any of perl 5.8.0, 5.6.0, or 5.005. The installations +of these different versions remain distinct, but remember that the +newer versions of perl are automatically set up to search the +compatible site libraries of the older ones. This means that +installing a new XS extension with 5.005 will make it visible to both +5.005 and 5.6.0, but not to 5.8.0. Installing a pure perl module with +5.005 will make it visible to all three versions. Later, if you +install the same extension using, say, perl 5.8.0, it will override the +5.005-installed version, but only for perl 5.8.0. This way, you can choose to share compatible extensions, but also upgrade to a newer version of an extension that may be incompatible with earlier @@ -2180,7 +2156,7 @@ may also wish to add a symbolic link /usr/local/bin/perl so that scripts can still start with #!/usr/local/bin/perl. Others might share a common directory for maintenance sub-versions -(e.g. 5.004 for all 5.004_0x versions), but change directory with +(e.g. 5.8 for all 5.8.x versions), but change directory with each major version. If you are installing a development subversion, you probably ought to @@ -2200,7 +2176,7 @@ above.) See your installed copy of the perllocal.pod file for a (possibly incomplete) list of locally installed modules. Note that you want -perllocal.pod not perllocale.pod for installed module information. +perllocal.pod, not perllocale.pod, for installed module information. =head1 Coexistence with perl4 |