Boost主页:http://www.boost.org/
环境:Ubuntu LTS 10.04, 64bit
GCC版本:
#gcc --version
gcc (Ubuntu 4.4.3-4ubuntu5) 4.4.3
Copyright (C) 2009 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
#
适用版本(适用版本只用于记录本次编译测试所使用的版本,不代表只能适用此版本):boost_1_49_0.tar.gz
说明:Boost的编译系统是使用其自带的bjam工具,所以和一般的编译的过程不太一样。
编译过程:
1. 解压、创建prefix目录
tar zxvf boost_1_49_0.tar.gz mv boost_1_49_0 gcc_boost_1_49_0 cd gcc_boost_1_49_0 mkdir prefix2. 关于boost
Boost文件夹,这里面是Boost的源码。其余的libs、doc、tools、more等等里面都主要是文档,当然,tools里面可能还有b2(bjam,boost的编译工具)的源码。
主目录下的index.html就可以打开boost的文档,里面可以链接到上面各个文档中。
PS:这里的boost文档,并非编译后的boost库的API文档什么的,由于Boost项目比较大,所以提供了很多文档,包括介绍如何编译等等的。总之,这点很好。
bootstrap.sh,这个脚本用于进行一些配置,事实上,它还会先编译bjam。总之,这个脚本用于编译bjam工具以及进行一些编译前的配置。
3. 配置
./bootstrap.sh其输出:
Building Boost.Build engine with toolset gcc... tools/build/v2/engine/bin.linuxx86_64/b2 Detecting Python version... 2.6 Detecting Python root... /usr Unicode/ICU support for Boost.Regex?... not found. Generating Boost.Build configuration in project-config.jam... Bootstrapping is done. To build, run: ./b2 To adjust configuration, edit 'project-config.jam'. Further information: - Command line help: ./b2 --help - Getting started guide: http://www.boost.org/more/getting_started/unix-variants.html - Boost.Build documentation: http://www.boost.org/boost-build2/doc/html/index.html可以看到,其编译了boost的编译引擎(bjam/b2)。
会生成一个project-config.jam文件,这个文件可以用于对bjam进行一些配置。当然,还有一些其它可以配置的地方。另外,通过命令行配置也是可以的(PS:个人喜欢用命令行去配置)。
4. 编译
./bjam --prefix=./prefix/ install
bjam的使用:
关于bjam的文档,可以参考:boost_1_49_0/doc/html/bbv2/overview.html,由于bjam可以有几种配置的地方,下面的内容只说明如何在命令行对bjam编译进行配置。
1. bjam的调用(boost_1_49_0/doc/html/bbv2/overview.html#bbv2.overview.invocation)
要调用Boost.build来编译,只需要使用bjam命令即可。bjam可以接受三种类型的tokens,而且顺序不限。分别是:选项(options)、属性(properties)、目标(target)。
PS:由于对于一般的命令行,可执行程序后面的部分,有时候我们都称之为“选项”。这里,将其分为了三个类型,那么下面的内容,提到选项,就是表示bjam的options的概念。
2. 选项(boost_1_49_0/doc/html/bbv2/overview.html#bbv2.overview.invocation.options):
选项一般以破折号(dash)或者双破折号开始。下面是一些标准选项,但是,每个不同的工程可以增加额外的一些选项:
--help
帮助
--clean
清除所有targets。与make中的clean不同的是,可以同时使用--clean和target names来清除指定的目标。
--clean-all
清除
--build-dir
指定编译的临时文件的存放目录
--version
显示版本
-a
使得所有文件重新编译
-n
不执行命令,只是显示之(用于调试自己的设置选项是否被正确使用是比较合适的。)
-q
在遇到第一个错误就停止,而不是继续编译其它不依赖这个错误的targets
-j N
并行执行命令数
--debug-configuration
--debug-building
--debug-generators
--ignore-config
-d0
-d N
-d +N
都和debug(编译的debug)信息有关。用于控制输出哪些信息。
-o file
将更新操作写入指定的文件,而不运行它们。
-s var=value
为jam设置全局变量。
3. 属性(boost_1_49_0/doc/html/bbv2/overview.html#bbv2.overview.invocation.properties):
属性的形式为“feature=value”。
下面是常见的features(完整的features参考相关文档):
toolset配置,可以参考:pl_Boost/boost_1_49_0/doc/html/bbv2/reference.html#bbv2.reference.tools.compilers
4. 目标(boost_1_49_0/doc/html/bbv2/overview.html#bbv2.overview.invocation.targets):
和make中的target的理解应该是类似的,就是指定要编译哪些target了,所以和“输入”配置文件有关。