mirror of
https://github.com/mirror/wget.git
synced 2025-01-06 10:20:56 +08:00
[svn] Expanded and updated with the current options.
This commit is contained in:
parent
db31c2f437
commit
68f8b83d63
130
INSTALL
130
INSTALL
@ -1,20 +1,34 @@
|
|||||||
-*- text -*-
|
-*- text -*-
|
||||||
Installation Procedure
|
GNU Wget Installation Procedure
|
||||||
|
===============================
|
||||||
|
|
||||||
0) Preparation
|
0. Preparation
|
||||||
|
--------------
|
||||||
|
|
||||||
To build and install GNU Wget, you need to unpack the archive (which
|
To build and install GNU Wget, you need to unpack the archive (which
|
||||||
you have presumably done, since you are reading this), and read on.
|
you have presumably done, since you are reading this), and read on.
|
||||||
Like most GNU utilities, Wget uses the GNU Autoconf mechanism for
|
Like most GNU utilities, Wget uses the GNU Autoconf mechanism for
|
||||||
build and installation; those of you familiar with compiling GNU
|
build and installation; users familiar with compiling GNU software
|
||||||
software will feel at home.
|
should feel at home.
|
||||||
|
|
||||||
1) Configuration
|
Note that instructions in this file do not pertain to installation on
|
||||||
|
Windows, for which see windows/README.
|
||||||
|
|
||||||
To configure Wget, run the configure script provided with the
|
1. Configuration
|
||||||
distribution. It will create the Makefiles needed to start the
|
----------------
|
||||||
compilation. You may use the standard arguments Autoconf-created
|
|
||||||
configure scripts take, the most important ones being:
|
Before compiling Wget, you need to "configure" it using the provided
|
||||||
|
`configure' script. Configuration serves two purposes: it enables the
|
||||||
|
compilation system to inspect certain features of your operating
|
||||||
|
system for more robust compilation, and it enables you to choose which
|
||||||
|
features you want the resulting Wget to have.
|
||||||
|
|
||||||
|
The simplest way to configure Wget is by running the configure script
|
||||||
|
provided with the distribution without additional arguments. After
|
||||||
|
running some programming-related tests, it will create the Makefiles
|
||||||
|
needed to compile Wget. If you have experience with Autoconf-based
|
||||||
|
build systems, you may use the standard arguments such configure
|
||||||
|
scripts take, the most important ones being:
|
||||||
|
|
||||||
--help display a help message and exit
|
--help display a help message and exit
|
||||||
|
|
||||||
@ -24,12 +38,20 @@ configure scripts take, the most important ones being:
|
|||||||
--infodir=DIR info documentation in DIR [PREFIX/info]
|
--infodir=DIR info documentation in DIR [PREFIX/info]
|
||||||
--mandir=DIR man documentation in DIR [PREFIX/man]
|
--mandir=DIR man documentation in DIR [PREFIX/man]
|
||||||
|
|
||||||
--build=BUILD configure for building on BUILD [BUILD=HOST]
|
For example, if you are not root and want to install Wget in your home
|
||||||
--host=HOST configure for HOST [guessed]
|
directory, you can use:
|
||||||
--target=TARGET configure for TARGET [TARGET=HOST]
|
|
||||||
|
|
||||||
--enable and --with options recognized (mostly Wget-specific):
|
./configure --prefix=$HOME
|
||||||
--with-ssl[=SSL_ROOT] link with libssl [in SSL_ROOT/lib] for https: support
|
|
||||||
|
Options beginning with "--disable", such as `--disable-opie' or
|
||||||
|
`--disable-ntlm', allow you to turn off certain built-in functionality
|
||||||
|
you don't need in order to reduce the size of the executable. Options
|
||||||
|
beginning with "--with" turning off autodetection and use of external
|
||||||
|
software Wget can link with, such as the SSL libraries. Recognized
|
||||||
|
"--enable" and "--with" options include:
|
||||||
|
|
||||||
|
--without-ssl disable SSL autodetection (used for https support)
|
||||||
|
--with-libssl-prefix=DIR search for libssl in DIR/lib
|
||||||
--disable-opie disable support for opie or s/key FTP login
|
--disable-opie disable support for opie or s/key FTP login
|
||||||
--disable-digest disable support for HTTP digest authorization
|
--disable-digest disable support for HTTP digest authorization
|
||||||
--disable-ntlm disable support for HTTP NTLM authorization
|
--disable-ntlm disable support for HTTP NTLM authorization
|
||||||
@ -37,62 +59,70 @@ configure scripts take, the most important ones being:
|
|||||||
--disable-nls do not use Native Language Support
|
--disable-nls do not use Native Language Support
|
||||||
--disable-largefile omit support for large files
|
--disable-largefile omit support for large files
|
||||||
--disable-ipv6 disable IPv6 support
|
--disable-ipv6 disable IPv6 support
|
||||||
|
--disable-rpath do not hardcode runtime library paths
|
||||||
|
|
||||||
If you want to configure Wget for installation in your home directory,
|
You can inspect the decisions made by configure by editing the
|
||||||
you can type:
|
generated Makefiles and the `src/config.h' include file. The defaults
|
||||||
|
should work without intervention, but if you know what you are doing,
|
||||||
./configure --prefix=$HOME
|
editing the generated files before compilation is fine -- they will
|
||||||
|
not be regenerated until you run configure again.
|
||||||
You can customize many settings simply by editing the Makefiles and
|
|
||||||
`src/config.h'. The defaults should work without intervention, but it
|
|
||||||
is useful to have a look at things you can change there.
|
|
||||||
|
|
||||||
configure will try to find a compiler in your PATH, defaulting to
|
configure will try to find a compiler in your PATH, defaulting to
|
||||||
`gcc', but falling back to `cc' if the former is unavailable. This is
|
`gcc', but falling back to `cc' if the former is unavailable. This is
|
||||||
a reasonable default on most Unix-like systems, but sometimes you
|
a reasonable default on most Unix-like systems, but sometimes you
|
||||||
might want to override it. The compiler choice is overridden with the
|
might want to override it. The compiler choice is overridden by
|
||||||
value of the `CC' environment variable. For example, to force
|
setting the `CC' environment variable to the desired compiler file
|
||||||
compilation with the Unix `cc' compiler, invoke configure like this:
|
name. For example, to force compilation with the Unix `cc' compiler,
|
||||||
|
invoke configure like this:
|
||||||
|
|
||||||
./configure CC=cc
|
./configure CC=cc
|
||||||
|
|
||||||
This assumes that `cc' is in your path -- if it is not, simply replace
|
This assumes that `cc' is in your path -- if it is not, simply use
|
||||||
"cc" with "/path/to/cc". Note that environment variables that affect
|
CC=/path/to/cc instead. Note that environment variables that affect
|
||||||
configure can be set with the usual shell syntax `var=value
|
configure can be set with the usual shell syntax `VAR=value
|
||||||
./configure' (assuming an sh-compatible shell). In addition to that,
|
./configure' (assuming sh syntax), but can also be specified as
|
||||||
configure allows environment variables to be specified as arguments in
|
arguments to configure, as shown above. The latter method, while
|
||||||
the form "var=value", which are shell-independent.
|
being specific to configure, works unmodified in all shells.
|
||||||
|
|
||||||
Environment variables that affect `configure' include: CFLAGS for
|
Environment variables that affect `configure' include: CFLAGS for C
|
||||||
compilation flags, LDFLAGS for linker flags, and CPPFLAGS for
|
compiler flags, CPPFLAGS for C preprocessor flags, LDFLAGS for linker
|
||||||
preprocessor flags.
|
flags, and LIBS for libraries.
|
||||||
|
|
||||||
If you have OpenSSL libraries installed at one of the default
|
Barring a the use of --without-* flags, configure will try to
|
||||||
locations, such as the system library directories or /usr/local/lib or
|
autodetect certain external libraries needed by Wget, currently only
|
||||||
/usr/local/ssl/lib, configure will autodetect them. If they are
|
the OpenSSL libraries. If they are installed in the system library
|
||||||
installed elsewhere, you need to specify the OpenSSL root directory.
|
directories or in the same prefix where you plan to install Wget,
|
||||||
For instance, if libcrypto.* and libssl.* are in /opt/openssl/lib, you
|
configure should be able to autodetect them. If they are installed
|
||||||
need to `configure --with-ssl=/opt/openssl'.
|
elsewhere, use the `--with-libNAME' option to specify the root
|
||||||
|
directory under which libraries reside in the `lib/' subdirectory and
|
||||||
|
the corresponding header files reside in the `include/' subdirectory.
|
||||||
|
For example, if the OpenSSL libraries are installed under the
|
||||||
|
/usr/local/ssl prefix, use `--with-libssl=/usr/local/ssl'.
|
||||||
|
|
||||||
To configure Wget on Windows, read the instructions in
|
Sometimes external libraries will be installed on the system, but the
|
||||||
`windows/README'. If this doesn't work for any reason, talk to the
|
header files will be missing, which happens on Linux if you forget to
|
||||||
Windows developers listed there; I do not maintain the port. Those
|
install the "-devel" or "-dev" package that corresponds to the library
|
||||||
instructions do not apply to the "Cygwin" environment, where Wget
|
and that is typically *not* installed by default. In that case
|
||||||
should build out of the box as described here.
|
configure will not find the library and you will not be able to use
|
||||||
|
the features provided by the library until you install the devel
|
||||||
|
package and rerun configure. If you have all the necessary headers,
|
||||||
|
but configure still fails to detect the library, report a bug.
|
||||||
|
|
||||||
2) Compilation
|
2. Compilation
|
||||||
|
--------------
|
||||||
|
|
||||||
To compile GNU Wget after it has been configured, simply type make.
|
To compile GNU Wget after it has been configured, simply type make.
|
||||||
If you do not have an ISO C (C89) compiler, Wget will try to K&R-ize
|
Wget requires a compiler and standard library compliant with the 1990
|
||||||
its sources on the fly. This should make GNU Wget compilable on
|
ISO C standard, which includes the vast majority of compilation
|
||||||
almost any Unix-like system you are likely to encounter.
|
environments present on systems in use today.
|
||||||
|
|
||||||
After the compilation a ready-to-use `wget' executable should reside
|
After the compilation a ready-to-use `wget' executable should reside
|
||||||
in the src directory. At this point there is no formal test suite for
|
in the src directory. At this point there is no formal test suite for
|
||||||
testing the binary, but it should be easy enough to test whether the
|
testing the binary, but it should be easy enough to test whether the
|
||||||
basic functionality works.
|
basic functionality works.
|
||||||
|
|
||||||
3) Installation
|
3. Installation
|
||||||
|
---------------
|
||||||
|
|
||||||
Use `make install' to install GNU Wget to directories specified to
|
Use `make install' to install GNU Wget to directories specified to
|
||||||
configure. To install it in a system directory (which is the
|
configure. To install it in a system directory (which is the
|
||||||
|
Loading…
Reference in New Issue
Block a user