Boost-1.64.0

Introduction à Boost

Boost offre un ensemble de bibliothèques sources libres, revues par les pairs et portables en C++. Il inclut des bibliothèques d'algèbre linéaire, de génération de nombres pseudo-aléatoires, de multithreading, de traitement d'images, d'expressions régulières et de tests d'unités.

Ce paquet est connu pour se construire correctement sur une plateforme LFS-8.1.

Informations sur le paquet

  • Téléchargement (HTTP) : https://dl.bintray.com/boostorg/release/1.64.0/source/boost_1_64_0.tar.bz2

  • Téléchargement (FTP) :

  • Somme de contrôle MD5 du téléchargement : 93eecce2abed9d2442c9676914709349

  • Taille du téléchargement : 77 Mo

  • Estimation de l'espace disque requis : 980 Mo (avec les tests de régression)

  • Estimation du temps de construction : 1.6 SBU (avec -j4, plus 2.1 SBU avec les tests de régression)

Dépendances de Boost

Recommandées

Facultatives

ICU-59.1, Python-2.7.13 ou Python-3.6.2 et Open MPI

Notes utilisateur : http://wiki.linuxfromscratch.org/blfs/wiki/boost

Installation de Boost

Tout d'abord, corrigez un bogue avec le chemin des en-têtes lorsque Python3 est utilisé :

sed -e '/using python/ s@;@: /usr/include/python${PYTHON_VERSION/3*/${PYTHON_VERSION}m} ;@' \
    -i bootstrap.sh

Installez Boost en lançant les commandes suivantes :

./bootstrap.sh --prefix=/usr &&
./b2 stage threading=multi link=shared

Pour lancer les tests de regression de Boost.Build (Python-2.7.13 requis), tapez pushd tools/build/test; python test_all.py; popd. Les 131 tests devraient tous réussir.

Pour lancer tous les tests de régression de chaque bibliothèque, tapez pushd status; ../b2; popd. Quelques tests peuvent échouer. Ils prennent beaucoup de temps (plus de 120 SBU avec -j1, 50 SBU avec -j4) et utilisent un espace disque volumineux (jusqu'à 40Go). Vous pouvez utiliser le paramètre -jN pour les accélérer.

Maintenant, en tant qu'utilisateur root :

./b2 install threading=multi link=shared

Explication des commandes

threading=multi : ce paramètre assure que Boost soit bien construit avec le support du multithreading.

link=shared : Ce paramètre fait que seules les bibliothèques partagées sont créées, excepté pour libboost_exception et libboost_test_exec_monitor qui sont créés statiquement. La plupart des gens n'auront pas besoin des bibliothèques statiques. En effet la plupart des programmes utilisant Boost se servent uniquement des en-têtes. Vous pouvez omettre ce paramètre si vous avez besoin des bibliothèques statiques.

-jN : Ce paramètre peut être utilisé dans la ligne de commande b2, pour lancer N processus en parallèle.

--with-python=python3 : Ajoutez cette option à la commande bootstrap si vous souhaitez que Boost utilise Python3 à la place de Python2.

Contenu

Programmes installés: Aucun
Bibliothèques installées: libboost_atomic.so, libboost_chrono.a, libboost_chrono.so, libboost_container.so, libboost_context.so, libboost_coroutine.so, libboost_date_time.so, libboost_exception.a, libboost-fiber.so, libboost_filesystem.so, libboost_graph.so, libboost_iostreams.so, libboost_locale.so, libboost_log_setup.so, libboost_log.so, libboost_math_c99.so, libboost_math_c99f.so, libboost_math_c99l.so, libboost_math_tr1.so, libboost_math_tr1f.so, libboost_math_tr1l.so, libboost_prg_exec_monitor.so, libboost_program_options.so, libboost_python.so ou libboost_python3.so, libboost_random.so, libboost_regex.so, libboost_serialization.so, libboost_signals.so, libboost_system.a, libboost_system.so, libboost_test_exec_monitor.a, libboost_thread.so, libboost_timer.a, libboost_timer.so, libboost_type_erasure.so, libboost_unit_test_framework.so, libboost_wave.so et libboost_wserialization.so
Répertoire installé: /usr/include/boost

Last updated on 2017-08-20 00:43:35 +0200