2020-07-11 17:54:06 +00:00
|
|
|
Compiling and installing LyX with autotools
|
|
|
|
===========================================
|
|
|
|
|
|
|
|
This document is about compiling LyX with the autotools suite. If you
|
|
|
|
want to compile using using CMake (in particular on windows), please
|
|
|
|
refer to the INSTALL.cmake file.
|
|
|
|
|
1999-09-27 18:44:28 +00:00
|
|
|
|
|
|
|
Quick compilation guide
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
These four steps will compile, test and install LyX:
|
|
|
|
|
2018-02-21 13:47:03 +00:00
|
|
|
0) Linux users beware: You need qt5 and qt5-devel packages
|
2010-08-05 15:18:18 +00:00
|
|
|
of the same version to compile LyX.
|
2003-02-27 15:55:55 +00:00
|
|
|
|
2011-06-06 10:32:16 +00:00
|
|
|
In general, it is also recommended to have pkg-config
|
2013-03-19 15:17:40 +00:00
|
|
|
installed (the name might vary depending on your
|
2011-06-06 10:32:16 +00:00
|
|
|
distribution).
|
|
|
|
|
|
|
|
1) ./configure configures LyX according to your system. You
|
2014-07-19 01:34:28 +00:00
|
|
|
may have to set --with-qt-dir=<path-to-your-qt-installation>
|
2018-02-21 13:47:03 +00:00
|
|
|
(for example, "--with-qt-dir=/usr/share/qt5/") if the
|
2011-06-06 10:32:16 +00:00
|
|
|
environment variable QTDIR is not set and pkg-config is not
|
|
|
|
available.
|
2013-01-30 03:36:48 +00:00
|
|
|
|
2008-07-07 14:18:44 +00:00
|
|
|
See Note below if ./configure script is not present.
|
1999-09-27 18:44:28 +00:00
|
|
|
|
|
|
|
2) make
|
|
|
|
compiles the program.
|
|
|
|
|
|
|
|
3) src/lyx
|
|
|
|
runs the program so you can check it out.
|
|
|
|
|
|
|
|
4) make install
|
2000-06-08 13:55:33 +00:00
|
|
|
will install it. You can use "make install-strip" instead
|
2003-02-06 10:54:14 +00:00
|
|
|
if you want a smaller binary.
|
1999-09-27 18:44:28 +00:00
|
|
|
|
|
|
|
|
2012-06-21 09:14:18 +00:00
|
|
|
Note for Git checkouts
|
2006-02-24 11:14:04 +00:00
|
|
|
-----------------------------
|
2002-03-26 10:13:36 +00:00
|
|
|
|
2012-06-21 09:14:18 +00:00
|
|
|
If you have checked this out from Git, you need to have:
|
2018-03-18 23:43:25 +00:00
|
|
|
* automake (supported versions are 1.14--1.16)
|
2017-04-06 11:48:32 +00:00
|
|
|
* autoconf (supported versions are 2.65--2.69)
|
2005-02-23 14:54:20 +00:00
|
|
|
Then type "./autogen.sh" to build the needed configuration
|
2012-11-01 17:06:26 +00:00
|
|
|
files and proceed as stated above/below.
|
2002-03-26 10:13:36 +00:00
|
|
|
|
|
|
|
You will also probably need GNU m4 (perhaps installed as gm4).
|
2003-02-06 10:54:14 +00:00
|
|
|
|
2010-08-05 15:18:18 +00:00
|
|
|
|
1999-09-27 18:44:28 +00:00
|
|
|
Requirements
|
|
|
|
------------
|
|
|
|
|
2024-10-22 15:03:18 +00:00
|
|
|
First of all, you will need a C++17 standard conforming compiler, like
|
2024-10-22 19:05:39 +00:00
|
|
|
g++ (we suggest at least version 8.0) or clang++.
|
2005-02-23 14:54:20 +00:00
|
|
|
|
2024-04-19 15:16:00 +00:00
|
|
|
LyX makes great use of the C++ Standard Library. This means that gcc
|
|
|
|
users will have to install the relevant libstdc++ library to be able
|
|
|
|
to compile this version of LyX.
|
2002-03-26 10:13:36 +00:00
|
|
|
|
2024-10-23 08:48:45 +00:00
|
|
|
LyX requires Qt 5.12 and higher. It is also possible to compile
|
|
|
|
against Qt 6. The only special point to make is that you must ensure
|
|
|
|
that both LyX and the Qt libraries are compiled with the same C++
|
|
|
|
compiler.
|
2005-07-18 09:42:42 +00:00
|
|
|
|
2010-11-13 12:09:23 +00:00
|
|
|
To build LyX with spell checking capabilities included you have to
|
|
|
|
install at least one of the development packages of the spell checker
|
|
|
|
libraries. See the RELEASE-NOTES for details.
|
|
|
|
|
2020-04-16 16:57:31 +00:00
|
|
|
Users of debian-based distributions are well advised to run
|
|
|
|
'apt-get build-dep lyx' before compiling to install proper dependencies.
|
|
|
|
|
2024-06-13 09:44:56 +00:00
|
|
|
Python 3.8 (or newer) must be installed. Python is used for many simple
|
|
|
|
tasks that are executed by external scripts, such as the automatic
|
|
|
|
configuration step and the import of older LyX documents with the
|
|
|
|
lyx2lyx script (this script is called automatically when opening a file).
|
2010-11-13 12:09:23 +00:00
|
|
|
|
2003-02-06 10:54:14 +00:00
|
|
|
* Other things to note
|
2003-01-26 16:57:47 +00:00
|
|
|
|
2014-04-13 14:10:57 +00:00
|
|
|
If you make modifications to the source that affect any of the
|
|
|
|
translations or you change the translation files themselves (po/*.po)
|
2015-08-31 16:17:35 +00:00
|
|
|
files, you will need to have the GNU gettext package installed to
|
2014-04-13 14:10:57 +00:00
|
|
|
compile LyX with up-to-date translations (at least gettext version
|
|
|
|
0.16.1 is needed). You can get the latest version from:
|
2024-06-24 20:54:21 +00:00
|
|
|
https://ftp.gnu.org/gnu/gettext/
|
2014-04-12 12:01:11 +00:00
|
|
|
|
1999-09-27 18:44:28 +00:00
|
|
|
|
|
|
|
Creating the Makefile
|
|
|
|
---------------------
|
|
|
|
|
2003-02-06 10:54:14 +00:00
|
|
|
LyX can be configured using GNU autoconf utility which attempts to guess
|
|
|
|
the configuration needed to suit your system. The standard way to use it
|
|
|
|
is described in the file INSTALL.autoconf. In most cases you will be able
|
1999-09-27 18:44:28 +00:00
|
|
|
to create the Makefile by typing
|
|
|
|
|
|
|
|
./configure
|
|
|
|
|
2011-01-25 11:22:47 +00:00
|
|
|
For more complicated cases, LyX configure honors the following specific
|
1999-09-27 18:44:28 +00:00
|
|
|
flags:
|
|
|
|
|
2011-01-25 13:49:49 +00:00
|
|
|
o --enable-build-type=[rel(ease), pre(release), dev(elopment), prof(iling), gprof]
|
2008-02-12 10:10:54 +00:00
|
|
|
allows to tweak the compiled code. The following table describes
|
|
|
|
the settings in terms of various options that are described later
|
|
|
|
|
2011-01-25 13:49:49 +00:00
|
|
|
release prerelease development profiling gprof
|
2024-04-25 10:30:48 +00:00
|
|
|
optimization -O2 -O2 -Og -O2 -O2
|
2008-02-12 10:10:54 +00:00
|
|
|
assertions X X
|
2022-12-04 18:22:38 +00:00
|
|
|
stdlib-assertions X
|
|
|
|
stdlib-debug
|
2008-02-12 10:10:54 +00:00
|
|
|
warnings X X
|
2011-01-25 13:49:49 +00:00
|
|
|
debug X X X X
|
2020-07-11 17:54:06 +00:00
|
|
|
maintainer-mode X
|
2008-02-12 10:10:54 +00:00
|
|
|
|
2022-12-04 18:22:38 +00:00
|
|
|
The defaults are as follows in terms of version number:
|
2015-08-31 16:17:35 +00:00
|
|
|
release: stable release (2.x.y)
|
2020-07-11 17:54:06 +00:00
|
|
|
prerelease: version number contains `alpha', `beta', `rc' or `pre'.
|
|
|
|
development: version number contains `dev'.
|
2008-02-11 15:11:15 +00:00
|
|
|
|
2013-03-19 15:17:40 +00:00
|
|
|
The `profiling' build type uses the -fno-omit-frame-pointer option with gcc
|
|
|
|
|
|
|
|
The `gprof' build type compiles and links with -pg option with gcc.
|
|
|
|
|
2022-11-19 18:28:07 +00:00
|
|
|
o --enable-qt6 that checks configuration with Qt 6.x, and then Qt
|
|
|
|
5.x. By default, only Qt5 is tried.
|
2018-08-29 15:53:06 +00:00
|
|
|
|
2020-07-11 17:54:06 +00:00
|
|
|
o --with-extra-lib=DIRECTORY that specifies the path where LyX will
|
2018-08-29 15:53:06 +00:00
|
|
|
find extra libraries (like Qt) it needs. Defaults to NONE
|
2003-02-18 17:23:55 +00:00
|
|
|
(i.e. search in standard places). You can specify several
|
|
|
|
directories, separated by colons.
|
1999-09-27 18:44:28 +00:00
|
|
|
|
|
|
|
o --with-extra-inc=DIRECTORY that gives the place where LyX will find
|
2006-01-19 12:23:00 +00:00
|
|
|
extra headers. Defaults to NONE (i.e. search in standard places).
|
1999-09-27 18:44:28 +00:00
|
|
|
You can specify several directories, separated by colons.
|
|
|
|
|
|
|
|
o --with-extra-prefix[=DIRECTORY] that is equivalent to
|
|
|
|
--with-extra-lib=DIRECTORY/lib --with-extra-inc=DIRECTORY/include
|
2000-01-10 16:28:29 +00:00
|
|
|
If DIRECTORY is not specified, the current prefix is used.
|
|
|
|
|
2008-09-29 08:58:24 +00:00
|
|
|
o --with-version-suffix[=SUFFIX] will install LyX as lyxSUFFIX. The
|
|
|
|
LyX data directory will be something like <whatever>/lyxSUFFIX/.
|
|
|
|
Additionally your user configuration files will be found in e.g.
|
|
|
|
$HOME/.lyxSUFFIX. The default for SUFFIX is "-<currentversion>",
|
|
|
|
e.g. lyx-1.6.1.
|
2001-03-01 15:03:52 +00:00
|
|
|
|
2003-02-18 17:23:55 +00:00
|
|
|
You can use this feature to install more than one version of LyX
|
|
|
|
on the same system. You can optionally specify a "version" of your
|
2004-10-26 21:16:44 +00:00
|
|
|
own, by doing something like :
|
2012-11-01 17:06:26 +00:00
|
|
|
./configure --with-version-suffix=-latestdev
|
2001-07-25 15:05:10 +00:00
|
|
|
|
2003-02-18 17:23:55 +00:00
|
|
|
Note that the standard configure options --program-prefix,
|
|
|
|
--program-suffix and the others will not affect the shared LyX
|
|
|
|
directory etc. so it is recommended that you use --with-version-suffix
|
|
|
|
(or --prefix) instead.
|
2002-05-29 15:10:11 +00:00
|
|
|
|
1999-09-27 18:44:28 +00:00
|
|
|
There are also flags to control the internationalization support in
|
|
|
|
LyX:
|
|
|
|
|
|
|
|
o --disable-nls suppresses all internationalization support,
|
2013-01-30 03:36:48 +00:00
|
|
|
yielding somewhat smaller code.
|
1999-09-27 18:44:28 +00:00
|
|
|
|
|
|
|
o You can also set the environment variable LINGUAS to a list of
|
2013-01-30 03:36:48 +00:00
|
|
|
languages in case you do not want to install all the translation
|
1999-09-27 18:44:28 +00:00
|
|
|
files. For example, if you are only interested in German and
|
|
|
|
Finnish, you can type (with sh or bash)
|
|
|
|
export LINGUAS='de fi'
|
|
|
|
before running configure.
|
|
|
|
|
|
|
|
Moreover, the following generic configure flags may be useful:
|
|
|
|
|
|
|
|
o --prefix=DIRECTORY specifies the root directory to use for
|
2001-11-12 14:29:14 +00:00
|
|
|
installation. [defaults to /usr/local]
|
1999-09-27 18:44:28 +00:00
|
|
|
|
2003-02-06 10:54:14 +00:00
|
|
|
o --datadir=DIRECTORY gives the directory where all extra LyX
|
2006-11-09 17:40:44 +00:00
|
|
|
files (documentation, templates and layout definitions)
|
|
|
|
will be installed.
|
1999-09-27 18:44:28 +00:00
|
|
|
[defaults to ${prefix}/share/lyx${program_suffix}]
|
|
|
|
|
|
|
|
o --bindir=DIRECTORY gives the directory where the lyx binary
|
|
|
|
will be installed. [defaults to ${prefix}/bin]
|
|
|
|
|
|
|
|
o --mandir=DIRECTORY gives the directory where the man pages will go.
|
|
|
|
[defaults to ${prefix}/man]
|
|
|
|
|
2004-04-06 13:48:13 +00:00
|
|
|
o --enable-maintainer-mode enables some code that automatically
|
2003-03-28 17:35:32 +00:00
|
|
|
rebuilds the configure script, makefiles templates and other useful
|
2004-10-08 12:12:22 +00:00
|
|
|
files when needed. This is off by default on releases, to avoid
|
|
|
|
surprises.
|
2003-03-28 17:35:32 +00:00
|
|
|
|
1999-09-27 18:44:28 +00:00
|
|
|
Note that the --with-extra-* commands are not really robust when it
|
2013-01-30 03:36:48 +00:00
|
|
|
comes to using relative paths. If you really want to use a relative path
|
2003-02-06 10:54:14 +00:00
|
|
|
here, you can prepend it with "`pwd`/".
|
1999-09-27 18:44:28 +00:00
|
|
|
|
2003-02-06 10:54:14 +00:00
|
|
|
If you do not like the default compile flags used (-g -O2 on gcc), you can
|
1999-09-27 18:44:28 +00:00
|
|
|
set CXXFLAGS variable to other values as follows:
|
|
|
|
|
|
|
|
o CXXFLAGS='-O2' (sh, bash)
|
|
|
|
o setenv CXXFLAGS '-O2' (csh, tcsh)
|
|
|
|
|
2013-01-30 03:36:48 +00:00
|
|
|
Similarly, if you want to force the use of a specific compiler, you can
|
1999-09-27 18:44:28 +00:00
|
|
|
give a value to the CXX variable.
|
|
|
|
|
2019-06-12 13:14:11 +00:00
|
|
|
The following options allow you to tweak the generated code more
|
|
|
|
precisely (see the description of --enable-build-type for the default
|
|
|
|
values):
|
1999-09-27 18:44:28 +00:00
|
|
|
|
2020-11-02 16:40:29 +00:00
|
|
|
o --enable-cxx-mode=VALUE can be used to select a C++ standard, for
|
2024-03-21 21:50:38 +00:00
|
|
|
example --enable-cxx-mode=11. The default is to try C++17, C++14, and
|
|
|
|
C++11, in this order.
|
2020-11-02 16:40:29 +00:00
|
|
|
|
2008-02-11 15:11:15 +00:00
|
|
|
o --enable-optimization=VALUE enables you to set optimization to a
|
2013-03-19 15:17:40 +00:00
|
|
|
higher level than the default, for example --enable-optimization=-O3.
|
2024-04-25 10:30:48 +00:00
|
|
|
Default is -Og when debugging is enabled, -O2 otherwise.
|
2008-02-11 15:11:15 +00:00
|
|
|
|
|
|
|
o --disable-optimization - you can use this to disable compiler
|
|
|
|
optimization of LyX. The compile may be much quicker with some
|
2024-04-25 10:30:48 +00:00
|
|
|
compilers, but LyX will be slower.
|
2008-02-11 15:11:15 +00:00
|
|
|
|
2006-01-19 12:23:00 +00:00
|
|
|
o --enable-debug will add debug information to your binary. This
|
2013-03-19 15:17:40 +00:00
|
|
|
requires a lot more disk space, but is a must if you want to try
|
|
|
|
to debug problems in LyX. There is no run-time penalty.
|
2006-01-19 12:23:00 +00:00
|
|
|
|
2001-07-25 15:05:10 +00:00
|
|
|
o --enable-warnings that make the compiler output more warnings during
|
2013-03-19 15:17:40 +00:00
|
|
|
the compilation of LyX. Opposite is --disable-warnings.
|
1999-09-27 18:44:28 +00:00
|
|
|
|
2002-03-26 10:13:36 +00:00
|
|
|
o --enable-assertions that make the compiler generate run-time
|
2000-04-19 16:32:36 +00:00
|
|
|
code which checks that some variables have sane values. Opposite
|
2013-03-19 15:17:40 +00:00
|
|
|
is --disable-assertions.
|
1999-12-16 14:16:42 +00:00
|
|
|
|
2022-12-04 18:22:38 +00:00
|
|
|
o --enable-stdlib-assertions adds some bound checking code in the
|
|
|
|
libstdc++ standard library; this slows down the code, but has been
|
|
|
|
helpful in the past to find bugs. This has no effect when using
|
|
|
|
llvm's libc++ library.
|
|
|
|
|
|
|
|
o --enable-stdlib-debug encompasses stdlib-assertions and adds
|
|
|
|
additional checks in libstdc++. Note that this changes the ABI and
|
|
|
|
is in general incompatible with the system hunspell library (as of
|
|
|
|
version 1.5). You may have to use --disable-stdlib-debug when
|
|
|
|
linking development versions against your system's hunspell
|
|
|
|
library. This has no effect when using llvm's libc++ library.
|
2006-01-19 12:23:00 +00:00
|
|
|
|
2008-02-13 20:30:31 +00:00
|
|
|
|
1999-09-27 18:44:28 +00:00
|
|
|
|
|
|
|
Compiling and installing LyX
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
Once you've got the Makefile created, you just have to type:
|
|
|
|
|
|
|
|
make all
|
|
|
|
make install
|
|
|
|
|
|
|
|
All should be OK ;)
|
|
|
|
|
2000-06-08 13:55:33 +00:00
|
|
|
Since the binaries with debug information tend to be huge (although
|
2002-03-26 10:13:36 +00:00
|
|
|
this does not affect the run-time memory footprint), you might want
|
2000-06-08 13:55:33 +00:00
|
|
|
to strip the lyx binary. In this case replace "make install" with
|
|
|
|
|
|
|
|
make install-strip
|
|
|
|
|
2015-08-31 16:17:35 +00:00
|
|
|
BTW: in the lib/images subdirectory there is also small icons
|
|
|
|
`lyx.png' and `lyx.svg', that can be used to display LyX documents in
|
|
|
|
filemanagers.
|
1999-09-27 18:44:28 +00:00
|
|
|
|
|
|
|
If configure fails for some strange reason
|
|
|
|
------------------------------------------
|
|
|
|
|
2013-01-30 03:36:48 +00:00
|
|
|
Even when configure fails, it creates a Makefile. You can always check
|
1999-09-27 18:44:28 +00:00
|
|
|
the contents of this file, modify it and run 'make'.
|
|
|
|
|
|
|
|
Compiling For Multiple Architectures
|
|
|
|
------------------------------------
|
|
|
|
|
|
|
|
You can compile LyX for more than one kind of computer at the same
|
|
|
|
time, by placing the object files for each architecture in their own
|
|
|
|
directory. To do this, you must use a version of `make' that supports
|
|
|
|
the `VPATH' variable, such as GNU `make'. `cd' to the directory where
|
|
|
|
you want the object files and executables to go and run the
|
|
|
|
`configure' script. `configure' automatically checks for the source
|
|
|
|
code in the directory that `configure' is in and in `..'.
|
|
|
|
|
2015-01-21 03:08:00 +00:00
|
|
|
If you have to use a `make' that does not support the `VPATH'
|
1999-09-27 18:44:28 +00:00
|
|
|
variable, you have to compile LyX for one architecture at a time in
|
|
|
|
the source code directory. After you have installed LyX for one
|
|
|
|
architecture, use `make distclean' before reconfiguring for another
|
|
|
|
architecture.
|