Here is the procedure for installing Octave from scratch on a Unix system.
Here is a summary of the configure options that are most frequently used when building Octave:
--prefix=
prefix--srcdir=
dir--with-f2c
f2c
even if a Fortran compiler is available.
--with-f77
f77
to compile Fortran code. You may also specify the name
of the compiler to use as an optional argument. For example,
--with-f77=g77
sets the name of the Fortran compiler to
g77
.
--enable-shared
--enable-lite-kernel
or the dynamic loading features, you will
probably want to use this option. It will make your .oct files
much smaller and on some systems it may be necessary to build shared
libraries in order to use dynamically linked functions.
You may also want to build a shared version of libstdc++
, if your
system doesn't already have one. Note that a patch is needed to build
shared versions of version 2.7.2 of libstdc++
on the HP-PA
architecture. You can find the patch at
ftp://ftp.cygnus.com/pub/g++/libg++-2.7.2-hppa-gcc-fix.
--enable-dl
dlopen
and friends to make Octave capable of dynamically
linking externally compiled functions. This only works on systems that
actually have these functions. If you plan on using this feature, you
should probably also use --enable-shared
to reduce the size of
your .oct files.
--enable-shl
shl_load
and friends to make Octave capable of dynamically
linking externally compiled functions. This only works on systems that
actually have these functions (only HP-UX systems). If you plan on
using this feature, you should probably also use --enable-shared
to reduce the size of your .oct files.
--enable-lite-kernel
dlopen
or shl_load
and friends so that Octave
can load functions at run time that are not loaded at compile time.
--without-blas
--with-blas=lib
to specify a particular BLAS library
-llib
that configure doesn't check for automatically.
--help
See the file INSTALL for more information about the command line options used by configure. That file also contains instructions for compiling in a directory other than where the source is located.
You will need a recent version of GNU Make. Modifying Octave's makefiles to work with other make programs is probably not worth your time. We recommend you get and compile GNU Make instead.
For plotting, you will need to have gnuplot installed on your system. Gnuplot is a command-driven interactive function plotting program. Gnuplot is copyrighted, but freely distributable. The `gnu' in gnuplot is a coincidence—it is not related to the GNU project or the FSF in any but the most peripheral sense.
To compile Octave, you will need a recent version of GNU Make. You
will also need g++
2.7.2 or later. Version 2.8.0 or egcs
1.0.x should work. Later versions may work, but C++ is still evolving,
so don't be too surprised if you run into some trouble.
It is no longer necessary to have libg++
, but you do need to have
the GNU implementation of libstdc++
. If you are using g++
2.7.2, libstdc++
is distributed along with libg++
, but for
later versions, libstdc++
is distributed separately. For
egcs
, libstdc++
is included with the compiler
distribution.
If you plan to modify the parser you will also need GNU bison
and
flex
. If you modify the documentation, you will need GNU
Texinfo, along with the patch for the makeinfo
program that is
distributed with Octave.
GNU Make, gcc
, and libstdc++
, gnuplot
,
bison
, flex
, and Texinfo are all available from many
anonymous ftp archives. The primary site is ftp.gnu.org, but it
is often very busy. A list of sites that mirror the software on
ftp.gnu.org is available by anonymous ftp from
ftp://ftp.gnu.org/pub/gnu/GNUinfo/FTP.
If you don't have a Fortran compiler, or if your Fortran compiler
doesn't work like the traditional Unix f77, you will need to have the
Fortran to C translator f2c
. You can get f2c
from any
number of anonymous ftp archives. The most recent version of f2c
is always available from netlib.att.com.
On an otherwise idle Pentium 133 running Linux, it will take somewhere between 1-1/2 to 3 hours to compile everything, depending on whether you are building shared libraries. You will need about 100 megabytes of disk storage to work with (considerably less if you don't compile with debugging symbols). To do that, use the command
make CFLAGS=-O CXXFLAGS=-O LDFLAGS=
instead of just `make'.
This will install a copy of octave, its libraries, and its documentation in the destination directory. As distributed, Octave is installed in the following directories. In the table below, prefix defaults to /usr/local, version stands for the current version number of the interpreter, and arch is the type of computer on which Octave is installed (for example, `i586-unknown-gnu').