update build docs
This commit is contained in:
parent
fbf9f73d43
commit
7608598da8
|
@ -71,12 +71,15 @@ to step 3 (assuming you also have boost build installed).
|
||||||
Step 1: Download boost
|
Step 1: Download boost
|
||||||
~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
If you want to build against boost installed on your system, you can skip this
|
||||||
|
strep. Just make sure to have `BOOST_ROOT` unset for the `b2` invocation.
|
||||||
|
|
||||||
You'll find boost here__.
|
You'll find boost here__.
|
||||||
|
|
||||||
__ https://sourceforge.net/project/showfiles.php?group_id=7586&package_id=8041&release_id=619445
|
__ https://www.boost.org/users/download/#live
|
||||||
|
|
||||||
Extract the archive to some directory where you want it. For the sake of this
|
Extract the archive to some directory where you want it. For the sake of this
|
||||||
guide, let's assume you extract the package to ``c:\boost_1_64_0`` (I'm using
|
guide, let's assume you extract the package to ``c:\boost_1_68_0`` (I'm using
|
||||||
a windows path in this example since if you're on linux/unix you're more likely
|
a windows path in this example since if you're on linux/unix you're more likely
|
||||||
to use the autotools). You'll need at least version 1.49 of the boost library
|
to use the autotools). You'll need at least version 1.49 of the boost library
|
||||||
in order to build libtorrent.
|
in order to build libtorrent.
|
||||||
|
@ -85,39 +88,41 @@ in order to build libtorrent.
|
||||||
Step 2: Setup BBv2
|
Step 2: Setup BBv2
|
||||||
~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
First you need to build ``bjam``. You do this by opening a terminal (In
|
If you have installed ``boost-build`` via a package manager, you can skip this
|
||||||
windows, run ``cmd``). Change directory to
|
step. If not, you need to build boost build from the boost source package.
|
||||||
``c:\boost_1_64_0\tools\jam\src``. Then run the script called
|
|
||||||
``build.bat`` or ``build.sh`` on a unix system. This will build ``bjam`` and
|
|
||||||
place it in a directory starting with ``bin.`` and then have the name of your
|
|
||||||
platform. Copy the ``bjam.exe`` (or ``bjam`` on a unix system) to a place
|
|
||||||
that's in you shell's ``PATH``. On linux systems a place commonly used may be
|
|
||||||
``/usr/local/bin`` or on windows ``c:\windows`` (you can also add directories
|
|
||||||
to the search paths by modifying the environment variable called ``PATH``).
|
|
||||||
|
|
||||||
Now you have ``bjam`` installed. ``bjam`` can be considered an interpreter
|
First you need to build ``b2``. You do this by opening a terminal (In windows,
|
||||||
that the boost-build system is implemented on. So boost-build uses ``bjam``.
|
run ``cmd``). Change directory to ``c:\boost_1_68_0\tools\build``. Then run the
|
||||||
|
script called ``bootstrap.bat`` or ``bootstrap.sh`` on a unix system. This will
|
||||||
|
build ``b2`` and place it in a directory ``src/engine/bin.<os-architecture>``.
|
||||||
|
Copy the ``b2.exe`` (or ``b2`` on a unix system) to a place that's in you
|
||||||
|
shell's ``PATH``. On linux systems a place commonly used may be
|
||||||
|
``/usr/local/bin`` or on windows ``c:\windows`` (you can also add directories to
|
||||||
|
the search paths by modifying the environment variable called ``PATH``).
|
||||||
|
|
||||||
|
Now you have ``b2`` installed. ``b2`` can be considered an interpreter
|
||||||
|
that the boost-build system is implemented on. So boost-build uses ``b2``.
|
||||||
So, to complete the installation you need to make two more things. You need to
|
So, to complete the installation you need to make two more things. You need to
|
||||||
set the environment variable ``BOOST_BUILD_PATH``. This is the path that tells
|
set the environment variable ``BOOST_BUILD_PATH``. This is the path that tells
|
||||||
``bjam`` where it can find boost-build, your configuration file and all the
|
``b2`` where it can find boost-build, your configuration file and all the
|
||||||
toolsets (descriptions used by boost-build to know how to use different
|
toolsets (descriptions used by boost-build to know how to use different
|
||||||
compilers on different platforms). Assuming the boost install path above, set
|
compilers on different platforms). Assuming the boost install path above, set
|
||||||
it to ``c:\boost_1_64_0\tools\build\v2``.
|
it to ``c:\boost_1_68_0\tools\build``.
|
||||||
|
|
||||||
To set an environment variable in windows, type for example::
|
To set an environment variable in windows, type for example::
|
||||||
|
|
||||||
set BOOST_BUILD_PATH=c:\boost_1_64_0\tools\build\v2
|
set BOOST_BUILD_PATH=c:\boost_1_68_0\tools\build\v2
|
||||||
|
|
||||||
In a terminal window.
|
In a terminal window.
|
||||||
|
|
||||||
The last thing to do to complete the setup of BBv2 is to modify your
|
The last thing to do is to configure which compiler(s) to use. Create a file
|
||||||
``user-config.jam`` file. It is located in ``c:\boost_1_64_0\tools\build\v2``.
|
``user-config.jam`` in your home directory. Depending on your platform and which
|
||||||
Depending on your platform and which compiler you're using, you should add a
|
compiler you're using, you should add a line for each compiler and compiler
|
||||||
line for each compiler and compiler version you have installed on your system
|
version you have installed on your system that you want to be able to use with
|
||||||
that you want to be able to use with BBv2. For example, if you're using
|
BBv2. For example, if you're using Microsoft Visual Studio 12 (2013), just add a
|
||||||
Microsoft Visual Studio 12 (2013), just add a line::
|
line::
|
||||||
|
|
||||||
using msvc : 12.0 ;
|
using msvc : 14.0 ;
|
||||||
|
|
||||||
If you use GCC, add the line::
|
If you use GCC, add the line::
|
||||||
|
|
||||||
|
@ -126,8 +131,8 @@ If you use GCC, add the line::
|
||||||
If you have more than one version of GCC installed, you can add the
|
If you have more than one version of GCC installed, you can add the
|
||||||
commandline used to invoke g++ after the version number, like this::
|
commandline used to invoke g++ after the version number, like this::
|
||||||
|
|
||||||
using gcc : 3.3 : g++-3.3 ;
|
using gcc : 6.0 : g++-6 ;
|
||||||
using gcc : 4.0 : g++-4.0 ;
|
using gcc : 7.0 : g++-7 ;
|
||||||
|
|
||||||
Another toolset worth mentioning is the ``darwin`` toolset (For MacOS X).
|
Another toolset worth mentioning is the ``darwin`` toolset (For MacOS X).
|
||||||
From Tiger (10.4) MacOS X comes with both GCC 3.3 and GCC 4.0. Then you can
|
From Tiger (10.4) MacOS X comes with both GCC 3.3 and GCC 4.0. Then you can
|
||||||
|
@ -146,25 +151,26 @@ Also see the `official installation instructions`_.
|
||||||
Step 3: Building libtorrent
|
Step 3: Building libtorrent
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
When building libtorrent, the ``Jamfile`` expects the environment variable
|
When building libtorrent, boost is either picked up from system installed
|
||||||
``BOOST_ROOT`` to be set to the boost installation directory. It uses this to
|
locations or from a boost source package, if the ``BOOST_ROOT`` environment
|
||||||
find the boost libraries it depends on, so they can be built and their headers
|
variable is set pointing to one. If you're building boost from source, set
|
||||||
files found. So, set this to ``c:\boost_1_64_0``. You only need this if you're
|
``BOOST_ROOT`` to your boost directory, e.g. ``c:\boost_1_68_0``.
|
||||||
building against a source distribution of boost.
|
|
||||||
|
|
||||||
Then the only thing left is simply to invoke ``bjam``. If you want to specify
|
Then the only thing left is simply to invoke ``b2``. If you want to specify
|
||||||
a specific toolset to use (compiler) you can just add that to the commandline.
|
a specific toolset to use (compiler) you can just add that to the commandline.
|
||||||
For example::
|
For example::
|
||||||
|
|
||||||
bjam msvc-7.1
|
b2 msvc-14.0
|
||||||
bjam gcc-3.3
|
b2 gcc-7.0
|
||||||
bjam darwin-4.0
|
b2 darwin-4.0
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
If the environment variable ``BOOST_ROOT`` is not set, the jamfile will
|
If the environment variable ``BOOST_ROOT`` is not set, the jamfile will
|
||||||
attempt to link against "installed" boost libraries. i.e. assume the headers
|
attempt to link against "installed" boost libraries. i.e. assume the headers
|
||||||
and libraries are available in default search paths.
|
and libraries are available in default search paths.
|
||||||
|
In this case it's critical that you build your project with the same version
|
||||||
|
of C++ and the same build flags as the system libraries were built with.
|
||||||
|
|
||||||
To build different versions you can also just add the name of the build
|
To build different versions you can also just add the name of the build
|
||||||
variant. Some default build variants in BBv2 are ``release``, ``debug``,
|
variant. Some default build variants in BBv2 are ``release``, ``debug``,
|
||||||
|
@ -178,13 +184,13 @@ can set the ``runtime-link`` feature on the commandline, either to ``shared``
|
||||||
or ``static``. Most operating systems will only allow linking shared against
|
or ``static``. Most operating systems will only allow linking shared against
|
||||||
the runtime, but on windows you can do both. Example::
|
the runtime, but on windows you can do both. Example::
|
||||||
|
|
||||||
bjam msvc-7.1 link=static runtime-link=static
|
b2 msvc-14.0 link=static runtime-link=static
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
When building on windows, the path boost-build puts targets in may be too
|
When building on windows, the path boost-build puts targets in may be too
|
||||||
long. If you get an error message like: "The input line is long", try to
|
long. If you get an error message like: "The input line is long", try to
|
||||||
pass --abbreviate-paths on the bjam command line.
|
pass --hash on the ``b2`` command line.
|
||||||
|
|
||||||
.. warning::
|
.. warning::
|
||||||
|
|
||||||
|
@ -193,40 +199,32 @@ the runtime, but on windows you can do both. Example::
|
||||||
and in the client application. It will result in crashes and possibly link
|
and in the client application. It will result in crashes and possibly link
|
||||||
errors.
|
errors.
|
||||||
|
|
||||||
.. note::
|
|
||||||
|
|
||||||
With boost-build V2 (Milestone 11), the darwin toolset uses the ``-s`` linker
|
|
||||||
option to strip debug symbols. This option is buggy in Apple's GCC, and
|
|
||||||
will make the executable crash on startup. On Mac OS X, instead build
|
|
||||||
your release executables with the ``debug-symbols=on`` option, and
|
|
||||||
later strip your executable with ``strip``.
|
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
Some linux systems requires linking against ``librt`` in order to access
|
Some linux systems requires linking against ``librt`` in order to access
|
||||||
the POSIX clock functions. If you get an error complaining about a missing
|
the POSIX clock functions. If you get an error complaining about a missing
|
||||||
symbol ``clock_gettime``, you have to give ``need-librt=yes`` on the
|
symbol ``clock_gettime``, you have to give ``need-librt=yes`` on the
|
||||||
bjam command line. This will make libtorrent link against ``librt``.
|
b2 command line. This will make libtorrent link against ``librt``.
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
When building on Solaris, you might have to specify ``stdlib=sun-stlport``
|
When building on Solaris, you may have to specify ``stdlib=sun-stlport``
|
||||||
on the bjam command line.
|
on the b2 command line.
|
||||||
|
|
||||||
The build targets are put in a directory called bin, and under it they are
|
The build targets are put in a directory called bin, and under it they are
|
||||||
sorted in directories depending on the toolset and build variant used.
|
sorted in directories depending on the toolset and build variant used.
|
||||||
|
|
||||||
To build the examples, just change directory to the examples directory and
|
To build the examples, just change directory to the examples directory and
|
||||||
invoke ``bjam`` from there. To build and run the tests, go to the test
|
invoke ``b2`` from there. To build and run the tests, go to the test
|
||||||
directory and run ``bjam``.
|
directory and run ``b2``.
|
||||||
|
|
||||||
Note that if you're building on windows using the ``msvc`` toolset, you cannot run it
|
Note that if you're building on windows using the ``msvc`` toolset, you cannot run it
|
||||||
from a cygwin terminal, you'll have to run it from a ``cmd`` terminal. The same goes for
|
from a cygwin terminal, you'll have to run it from a ``cmd`` terminal. The same goes for
|
||||||
cygwin, if you're building with gcc in cygwin you'll have to run it from a cygwin terminal.
|
cygwin, if you're building with gcc in cygwin you'll have to run it from a cygwin terminal.
|
||||||
Also, make sure the paths are correct in the different environments. In cygwin, the paths
|
Also, make sure the paths are correct in the different environments. In cygwin, the paths
|
||||||
(``BOOST_BUILD_PATH`` and ``BOOST_ROOT``) should be in the typical unix-format (e.g.
|
(``BOOST_BUILD_PATH`` and ``BOOST_ROOT``) should be in the typical unix-format (e.g.
|
||||||
``/cygdrive/c/boost_1_64_0``). In the windows environment, they should have the typical
|
``/cygdrive/c/boost_1_68_0``). In the windows environment, they should have the typical
|
||||||
windows format (``c:/boost_1_64_0``).
|
windows format (``c:/boost_1_68_0``).
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
In Jamfiles, spaces are separators. It's typically easiest to avoid spaces
|
In Jamfiles, spaces are separators. It's typically easiest to avoid spaces
|
||||||
|
@ -313,13 +311,11 @@ Build features:
|
||||||
| | * ``pre1.1`` - link against the old windows names |
|
| | * ``pre1.1`` - link against the old windows names |
|
||||||
| | (i.e. ``ssleay32`` and ``libeay32``. |
|
| | (i.e. ``ssleay32`` and ``libeay32``. |
|
||||||
+--------------------------+----------------------------------------------------+
|
+--------------------------+----------------------------------------------------+
|
||||||
| ``allocator`` | * ``pool`` - default, uses pool allocators for |
|
| ``piece-allocator`` | * ``valloc`` - default, uses ``valloc()`` or |
|
||||||
|
| | ``_aligned_malloc()`` for disk cache blocks. |
|
||||||
| | send buffers. |
|
| | send buffers. |
|
||||||
| | * ``system`` - uses ``malloc()`` and ``free()`` |
|
| | * ``memalign`` - uses ``memalign()``. |
|
||||||
| | instead. Might be useful to debug buffer issues |
|
| | * ``posix_memalign`` - uses ``posix_memalign()``. |
|
||||||
| | with tools like electric fence or libgmalloc. |
|
|
||||||
| | * ``debug`` - instruments buffer usage to catch |
|
|
||||||
| | bugs in libtorrent. |
|
|
||||||
+--------------------------+----------------------------------------------------+
|
+--------------------------+----------------------------------------------------+
|
||||||
| ``link`` | * ``static`` - builds libtorrent as a static |
|
| ``link`` | * ``static`` - builds libtorrent as a static |
|
||||||
| | library (.a / .lib) |
|
| | library (.a / .lib) |
|
||||||
|
@ -377,6 +373,26 @@ Build features:
|
||||||
| | is written with stack traces of blocking calls |
|
| | is written with stack traces of blocking calls |
|
||||||
| | ordered by the number of them. |
|
| | ordered by the number of them. |
|
||||||
+--------------------------+----------------------------------------------------+
|
+--------------------------+----------------------------------------------------+
|
||||||
|
| ``utp-log`` | * ``off`` - default. Do not print verbose uTP |
|
||||||
|
| | log. |
|
||||||
|
| | * ``on`` - Print verbose uTP log, used to debug |
|
||||||
|
| | the uTP implementation. |
|
||||||
|
+--------------------------+----------------------------------------------------+
|
||||||
|
| ``picker-debugging`` | * ``off`` - no extra invariant checks in piece |
|
||||||
|
| | picker. |
|
||||||
|
| | * ``on`` - include additional invariant checks in |
|
||||||
|
| | piece picker. Used for testing the piece picker. |
|
||||||
|
+--------------------------+----------------------------------------------------+
|
||||||
|
| ``extensions`` | * ``on`` - enable extensions to the bittorrent |
|
||||||
|
| | protocol. |
|
||||||
|
| | * ``off`` - disable bittorrent extensions. |
|
||||||
|
+--------------------------+----------------------------------------------------+
|
||||||
|
| ``pic`` | * ``off`` - default. Build without specifying |
|
||||||
|
| | ``-fPIC``. |
|
||||||
|
| | * ``on`` - Force build with ``-fPIC`` (useful for |
|
||||||
|
| | building a static library to be linked into a |
|
||||||
|
| | shared library). |
|
||||||
|
+--------------------------+----------------------------------------------------+
|
||||||
|
|
||||||
The ``variant`` feature is *implicit*, which means you don't need to specify
|
The ``variant`` feature is *implicit*, which means you don't need to specify
|
||||||
the name of the feature, just the value.
|
the name of the feature, just the value.
|
||||||
|
@ -391,124 +407,73 @@ boost.program-options symbols.
|
||||||
For more information, see the `Boost build v2 documentation`__, or more
|
For more information, see the `Boost build v2 documentation`__, or more
|
||||||
specifically `the section on builtin features`__.
|
specifically `the section on builtin features`__.
|
||||||
|
|
||||||
__ https://www.boost.org/tools/build/v2/index.html
|
__ https://boostorg.github.io/build/manual/develop/index.html
|
||||||
__ https://www.boost.org/doc/html/bbv2/reference.html#bbv2.advanced.builtins.features
|
__ https://boostorg.github.io/build/manual/develop/index.html#bbv2.overview.builtins.features
|
||||||
|
|
||||||
|
|
||||||
building with autotools
|
building with cmake
|
||||||
-----------------------
|
-------------------
|
||||||
|
|
||||||
First of all, you need to install ``automake`` and ``autoconf``. Many
|
First of all, you need to install ``cmake``. Additionally you need a build
|
||||||
unix/linux systems comes with these preinstalled.
|
system to actually schedule builds, for example ``ninja``.
|
||||||
|
|
||||||
The prerequisites for building libtorrent are boost.system, boost.chrono and
|
|
||||||
boost.random. Those are the *compiled* boost libraries needed. The headers-only
|
|
||||||
libraries needed include (but is not necessarily limited to)
|
|
||||||
boost.multi_index, boost.optional, boost.multiprecision,
|
|
||||||
boost.iterator, boost.preprocessor, boost.static_assert, boost.intrusive.
|
|
||||||
|
|
||||||
Step 1: Generating the build system
|
Step 1: Generating the build system
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
No build system is present if libtorrent is checked out from CVS - it
|
Run ``cmake`` in the libtorrent root directory, like this::
|
||||||
needs to be generated first. If you're building from a released tarball,
|
|
||||||
you may skip directly to `Step 2: Running configure`_.
|
|
||||||
|
|
||||||
Execute the following command to generate the build system::
|
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_CXX_STANDARD=11 -G Ninja .
|
||||||
|
|
||||||
./autotool.sh
|
The ``CMAKE_CXX_STANDARD`` has to be at least 11, but you may want to raise it
|
||||||
|
to ``14`` or ``17`` if your project use a newer version of the C++ standard.
|
||||||
|
|
||||||
Step 2: Running configure
|
.. warning::
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
In your shell, change directory to the libtorrent directory and run
|
The detection of boost sometimes fail in subtle ways. If you have the
|
||||||
``./configure``. This will look for libraries and C++ features that libtorrent
|
``BOOST_ROOT`` environment variable set, it may find the pre-built system
|
||||||
is dependent on. If something is missing or can't be found it will print an
|
libraries, but use the header files from your source package. To avoid this,
|
||||||
error telling you what failed.
|
invoke ``cmake`` with ``BOOST_ROOT`` set to an empty string:
|
||||||
|
``BOOST_ROOT="" cmake ...``.
|
||||||
|
|
||||||
The most likely problem you may encounter is that the configure script won't
|
Other build options are:
|
||||||
find the boost libraries. Make sure you have boost installed on your system.
|
|
||||||
The easiest way to install boost is usually to use the preferred package
|
|
||||||
system on your platform. Usually libraries and headers are installed in
|
|
||||||
standard directories where the compiler will find them, but sometimes that
|
|
||||||
may not be the case. For example when installing boost on darwin using
|
|
||||||
darwinports (the package system based on BSD ports) all libraries are
|
|
||||||
installed to ``/opt/local/lib`` and headers are installed to
|
|
||||||
``/opt/local/include``. By default the compiler will not look in these
|
|
||||||
directories. You have to set the enviornment variables ``LDFLAGS`` and
|
|
||||||
``CXXFLAGS`` in order to make the compiler find those libs. In this example
|
|
||||||
you'd set them like this::
|
|
||||||
|
|
||||||
export LDFLAGS=-L/opt/local/lib
|
+-----------------------+---------------------------------------------------+
|
||||||
export CXXFLAGS=-I/opt/local/include
|
| ``BUILD_SHARED_LIBS`` | Defaults ``ON``. Builds libtorrent as a shared |
|
||||||
|
| | library. |
|
||||||
|
+-----------------------+---------------------------------------------------+
|
||||||
|
| ``static_runtime`` | Defaults ``OFF``. Link libtorrent statically |
|
||||||
|
| | against the runtime libraries. |
|
||||||
|
+-----------------------+---------------------------------------------------+
|
||||||
|
| ``build_tests`` | Defaults ``OFF``. Also build the libtorrent |
|
||||||
|
| | testa. |
|
||||||
|
+-----------------------+---------------------------------------------------+
|
||||||
|
| ``build_examples`` | Defaults ``OFF``. Also build the examples in the |
|
||||||
|
| | examples directory. |
|
||||||
|
+-----------------------+---------------------------------------------------+
|
||||||
|
| ``build_tools`` | Defaults ``OFF``. Also build the tools in the |
|
||||||
|
| | tools directory. |
|
||||||
|
+-----------------------+---------------------------------------------------+
|
||||||
|
| ``python-bindings`` | Defaults ``OFF``. Also build the python bindings |
|
||||||
|
| | in bindings/python directory. |
|
||||||
|
+-----------------------+---------------------------------------------------+
|
||||||
|
| ``encryption`` | Defaults ``ON``. Support trackers and bittorrent |
|
||||||
|
| | over TLS, and obfuscated bittorrent connections. |
|
||||||
|
+-----------------------+---------------------------------------------------+
|
||||||
|
|
||||||
It was observed on FreeBSD (release 6.0) that one needs to add '-lpthread' to
|
Options are set on the ``cmake`` command line with the ``-D`` option.
|
||||||
LDFLAGS, as Boost::Thread detection will fail without it, even if
|
|
||||||
Boost::Thread is installed.
|
|
||||||
|
|
||||||
If you need to set these variables, it may be a good idea to add those lines
|
Step 2: Building libtorrent
|
||||||
to your ``~/.profile`` or ``~/.tcshrc`` depending on your shell.
|
|
||||||
|
|
||||||
If the boost libraries are named with a suffix on your platform, you may use
|
|
||||||
the ``--with-boost-thread=`` option to specify the suffix used for the thread
|
|
||||||
library in this case. For more information about these options, run::
|
|
||||||
|
|
||||||
./configure --help
|
|
||||||
|
|
||||||
On gentoo the boost libraries that are built with multi-threading support have
|
|
||||||
the suffix ``mt``.
|
|
||||||
|
|
||||||
You know that the boost libraries were found if you see the following output
|
|
||||||
from the configure script::
|
|
||||||
|
|
||||||
Checking for boost libraries:
|
|
||||||
checking for boostlib >= 1.53... yes
|
|
||||||
checking whether the Boost::System library is available... yes
|
|
||||||
checking for exit in -lboost_system... yes
|
|
||||||
checking whether the Boost::Chrono library is available... yes
|
|
||||||
checking for exit in -lboost_chrono-mt... yes
|
|
||||||
checking whether the Boost::Random library is available... yes
|
|
||||||
checking for exit in -lboost_random-mt... yes
|
|
||||||
|
|
||||||
Another possible source of problems may be if the path to your libtorrent
|
|
||||||
directory contains spaces. Make sure you either rename the directories with
|
|
||||||
spaces in their names to remove the spaces or move the libtorrent directory.
|
|
||||||
|
|
||||||
Creating a debug build
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
To tell configure to build a debug version (with debug info, asserts
|
|
||||||
and invariant checks enabled), you have to run the configure script
|
|
||||||
with the following option::
|
|
||||||
|
|
||||||
./configure --enable-debug=yes
|
|
||||||
|
|
||||||
Creating a release build
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
To tell the configure to build a release version (without debug info,
|
|
||||||
asserts and invariant checks), you have to run the configure script
|
|
||||||
with the following option::
|
|
||||||
|
|
||||||
./configure --enable-debug=no
|
|
||||||
|
|
||||||
The above option make use of -DNDEBUG, which is used throughout libtorrent.
|
|
||||||
|
|
||||||
Step 3: Building libtorrent
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Once the configure script is run successfully, you just type ``make`` and
|
In the terminal, run::
|
||||||
libtorrent, the examples and the tests will be built.
|
|
||||||
|
|
||||||
When libtorrent is built it may be a good idea to run the tests, you do this
|
ninja -j8
|
||||||
by running ``make check``.
|
|
||||||
|
|
||||||
If you want to build a release version (without debug info, asserts and
|
(the number after 8 specifies the number of parallel jobs to build in).
|
||||||
invariant checks), you have to rerun the configure script and rebuild, like this::
|
|
||||||
|
|
||||||
./configure --disable-debug
|
If you enabled test in the configuration step, to run them, run::
|
||||||
make clean
|
|
||||||
make
|
ctest -j8
|
||||||
|
|
||||||
building with other build systems
|
building with other build systems
|
||||||
---------------------------------
|
---------------------------------
|
||||||
|
|
Loading…
Reference in New Issue