[29] | 1 | # Copyright Vladimir Prus 2002-2006. |
---|
| 2 | # Copyright Dave Abrahams 2005-2006. |
---|
| 3 | # Copyright Rene Rivera 2005-2006. |
---|
| 4 | # Copyright Douglas Gregor 2005. |
---|
| 5 | # |
---|
| 6 | # Distributed under the Boost Software License, Version 1.0. |
---|
| 7 | # (See accompanying file LICENSE_1_0.txt or copy at |
---|
| 8 | # http://www.boost.org/LICENSE_1_0.txt) |
---|
| 9 | |
---|
| 10 | # Usage: |
---|
| 11 | # |
---|
| 12 | # bjam [options] [install|stage] |
---|
| 13 | # |
---|
| 14 | # Builds and installs Boost. |
---|
| 15 | # |
---|
| 16 | # Targets and Related Options: |
---|
| 17 | # |
---|
| 18 | # install Install headers and compiled library files to the |
---|
| 19 | # ======= configured locations (below). |
---|
| 20 | # |
---|
| 21 | # --prefix=<PREFIX> Install architecture independent files here. |
---|
| 22 | # Default; C:\Boost on Win32 |
---|
| 23 | # Default; /usr/local on Unix. Linux, etc. |
---|
| 24 | # |
---|
| 25 | # --exec-prefix=<EPREFIX> Install architecture dependent files here. |
---|
| 26 | # Default; <PREFIX> |
---|
| 27 | # |
---|
| 28 | # --libdir=<DIR> Install library files here. |
---|
| 29 | # Default; <EPREFIX>/lib |
---|
| 30 | # |
---|
| 31 | # --includedir=<HDRDIR> Install header files here. |
---|
| 32 | # Default; <PREFIX>/include |
---|
| 33 | # |
---|
| 34 | # stage Build and install only compiled library files |
---|
| 35 | # ===== to the stage directory. |
---|
| 36 | # |
---|
| 37 | # --stagedir=<STAGEDIR> Install library files here |
---|
| 38 | # Default; ./stage |
---|
| 39 | # |
---|
| 40 | # Other Options: |
---|
| 41 | # |
---|
| 42 | # --builddir=DIR Build in this location instead of building |
---|
| 43 | # within the distribution tree. Recommended! |
---|
| 44 | # |
---|
| 45 | # --toolset=toolset Indicates the toolset to build with. |
---|
| 46 | # |
---|
| 47 | # --show-libraries Displays the list of Boost libraries that require |
---|
| 48 | # build and installation steps, then exit. |
---|
| 49 | # |
---|
| 50 | # --layout=<layout> Determines whether to choose library names |
---|
| 51 | # and header locations such that multiple |
---|
| 52 | # versions of Boost or multiple compilers can |
---|
| 53 | # be used on the same system. |
---|
| 54 | # |
---|
| 55 | # versioned (default) - Names of boost |
---|
| 56 | # binaries include the Boost version |
---|
| 57 | # number and the name and version of the |
---|
| 58 | # compiler. Boost headers are installed |
---|
| 59 | # in a subdirectory of <HDRDIR> whose |
---|
| 60 | # name contains the Boost version |
---|
| 61 | # number. |
---|
| 62 | # |
---|
| 63 | # system - Binaries names do not include |
---|
| 64 | # the Boost version number or the name |
---|
| 65 | # and version number of the compiler. |
---|
| 66 | # Boost headers are installed directly |
---|
| 67 | # into <HDRDIR>. This option is |
---|
| 68 | # intended for system integrators who |
---|
| 69 | # are building distribution packages. |
---|
| 70 | # |
---|
| 71 | # --buildid=ID Adds the specified ID to the name of built |
---|
| 72 | # libraries. The default is to not add anything. |
---|
| 73 | # |
---|
| 74 | # --help This message. |
---|
| 75 | # |
---|
| 76 | # --with-<library> Build and install the specified <library> |
---|
| 77 | # If this option is used, only libraries |
---|
| 78 | # specified using this option will be built. |
---|
| 79 | # |
---|
| 80 | # --without-<library> Do not build, stage, or install the specified |
---|
| 81 | # <library>. By default, all libraries are built. |
---|
| 82 | |
---|
| 83 | # TODO: |
---|
| 84 | # - handle boost version |
---|
| 85 | # - handle python options such as pydebug |
---|
| 86 | |
---|
| 87 | import modules ; |
---|
| 88 | import set ; |
---|
| 89 | import stage ; |
---|
| 90 | import package ; |
---|
| 91 | import path ; |
---|
| 92 | import common ; |
---|
| 93 | import os ; |
---|
| 94 | import regex ; |
---|
| 95 | import errors ; |
---|
| 96 | import "class" : new ; |
---|
| 97 | import common ; |
---|
| 98 | |
---|
| 99 | constant BOOST_VERSION : 1.34.1 ; |
---|
| 100 | |
---|
| 101 | local version-tag = [ MATCH "^([^.]+)[.]([^.]+)[.]([^.]+)" : $(BOOST_VERSION) ] ; |
---|
| 102 | if $(version-tag[3]) = 0 |
---|
| 103 | { |
---|
| 104 | version-tag = $(version-tag[1-2]) ; |
---|
| 105 | } |
---|
| 106 | |
---|
| 107 | constant BOOST_VERSION_TAG : $(version-tag:J="_") ; |
---|
| 108 | |
---|
| 109 | local default-build ; |
---|
| 110 | if $(__file__:D) = "" |
---|
| 111 | { |
---|
| 112 | default-build = |
---|
| 113 | debug release |
---|
| 114 | <threading>single <threading>multi |
---|
| 115 | <link>shared <link>static |
---|
| 116 | ; |
---|
| 117 | |
---|
| 118 | if [ os.name ] = NT |
---|
| 119 | { |
---|
| 120 | default-build += <runtime-link>shared <runtime-link>static ; |
---|
| 121 | } |
---|
| 122 | } |
---|
| 123 | else |
---|
| 124 | { |
---|
| 125 | default-build = |
---|
| 126 | debug |
---|
| 127 | ; |
---|
| 128 | } |
---|
| 129 | |
---|
| 130 | |
---|
| 131 | rule handle-static-runtime ( properties * ) |
---|
| 132 | { |
---|
| 133 | # This property combination is dangerous. |
---|
| 134 | # Ideally, we'd add constraint to default build, |
---|
| 135 | # so that user can build with property combination |
---|
| 136 | # by hand. But we don't have any 'constraint' mechanism |
---|
| 137 | # for default-build, so disable such builds in requirements. |
---|
| 138 | |
---|
| 139 | # For CW, static runtime is needed so that |
---|
| 140 | # std::locale works. |
---|
| 141 | if <link>shared in $(properties) |
---|
| 142 | && <runtime-link>static in $(properties) |
---|
| 143 | && ! ( <toolset>cw in $(properties) ) |
---|
| 144 | { |
---|
| 145 | return <build>no ; |
---|
| 146 | } |
---|
| 147 | } |
---|
| 148 | |
---|
| 149 | |
---|
| 150 | project boost |
---|
| 151 | : requirements <include>. |
---|
| 152 | # disable auto-linking for all targets here, |
---|
| 153 | # primarily because it caused troubles with V2 |
---|
| 154 | <define>BOOST_ALL_NO_LIB=1 |
---|
| 155 | # Used to encode variant in target name. See the |
---|
| 156 | # 'tag' rule below. |
---|
| 157 | <tag>@$(__name__).tag |
---|
| 158 | <conditional>@handle-static-runtime |
---|
| 159 | |
---|
| 160 | : usage-requirements <include>. |
---|
| 161 | : build-dir bin.v2 |
---|
| 162 | : default-build $(default-build) |
---|
| 163 | ; |
---|
| 164 | |
---|
| 165 | # Setup convenient aliases for all libraries. |
---|
| 166 | |
---|
| 167 | all-libraries = |
---|
| 168 | [ MATCH .*libs/(.*)/build/.* : [ glob libs/*/build/Jamfile.v2 ] ] |
---|
| 169 | ; |
---|
| 170 | |
---|
| 171 | # First, the complicated libraries: where the target name in |
---|
| 172 | # Jamfile is different from directory name. |
---|
| 173 | alias prg_exec_monitor : libs/test/build//boost_prg_exec_monitor ; |
---|
| 174 | alias test_exec_monitor : libs/test/build//boost_test_exec_monitor ; |
---|
| 175 | alias unit_test_framework : libs/test/build//boost_unit_test_framework ; |
---|
| 176 | alias bgl-vis : libs/graps/build//bgl-vis ; |
---|
| 177 | alias serialization : libs/serialization/build//boost_serialization ; |
---|
| 178 | alias wserialization : libs/serialization/build//boost_wserialization ; |
---|
| 179 | |
---|
| 180 | explicit prg_exec_monitor test_exec_monitor unit_test_framework |
---|
| 181 | bgl-vis serialization wserialization ; |
---|
| 182 | |
---|
| 183 | for local l in $(all-libraries) |
---|
| 184 | { |
---|
| 185 | if ! $(l) in test graph serialization |
---|
| 186 | { |
---|
| 187 | alias $(l) : libs/$(l)/build//boost_$(l) ; |
---|
| 188 | explicit $(l) ; |
---|
| 189 | } |
---|
| 190 | } |
---|
| 191 | |
---|
| 192 | alias headers : : : : <include>. ; |
---|
| 193 | |
---|
| 194 | |
---|
| 195 | # Decides which libraries are to be installed by looking at --with-<library> |
---|
| 196 | # --without-<library> arguments. Returns the list of directories under "libs" |
---|
| 197 | # which must be built at installed. |
---|
| 198 | rule libraries-to-install ( existing-libraries * ) |
---|
| 199 | { |
---|
| 200 | local argv = [ modules.peek : ARGV ] ; |
---|
| 201 | local with-parameter = [ MATCH --with-(.*) : $(argv) ] ; |
---|
| 202 | local without-parameter = [ MATCH --without-(.*) : $(argv) ] ; |
---|
| 203 | |
---|
| 204 | # Do some checks |
---|
| 205 | if $(with-parameter) && $(without-parameter) |
---|
| 206 | { |
---|
| 207 | ECHO "error: both --with-<library> and --without-<library> specified" ; |
---|
| 208 | EXIT ; |
---|
| 209 | } |
---|
| 210 | |
---|
| 211 | local wrong = [ set.difference $(with-parameter) : $(existing-libraries) ] ; |
---|
| 212 | if $(wrong) |
---|
| 213 | { |
---|
| 214 | ECHO "error: wrong library name '$(wrong[1])' in the --with-<library> option." ; |
---|
| 215 | EXIT ; |
---|
| 216 | } |
---|
| 217 | local wrong = [ set.difference $(without-parameter) : $(existing-libraries) ] ; |
---|
| 218 | if $(wrong) |
---|
| 219 | { |
---|
| 220 | ECHO "error: wrong library name '$(wrong[1])' in the --without-<library> option." ; |
---|
| 221 | EXIT ; |
---|
| 222 | } |
---|
| 223 | |
---|
| 224 | if $(with-parameter) |
---|
| 225 | { |
---|
| 226 | return [ set.intersection $(existing-libraries) : $(with-parameter) ] ; |
---|
| 227 | } |
---|
| 228 | else |
---|
| 229 | { |
---|
| 230 | return [ set.difference $(existing-libraries) : $(without-parameter) ] ; |
---|
| 231 | } |
---|
| 232 | } |
---|
| 233 | |
---|
| 234 | # what kind of layout are we doing? |
---|
| 235 | layout = [ MATCH "^--layout=(.*)" : [ modules.peek : ARGV ] ] ; |
---|
| 236 | layout ?= versioned ; |
---|
| 237 | layout-$(layout) = true ; |
---|
| 238 | |
---|
| 239 | # possible stage only location |
---|
| 240 | local stage-locate = [ MATCH "^--stagedir=(.*)" : [ modules.peek : ARGV ] ] ; |
---|
| 241 | stage-locate ?= stage ; |
---|
| 242 | |
---|
| 243 | path-constant BOOST_STAGE_LOCATE : $(stage-locate) ; |
---|
| 244 | |
---|
| 245 | |
---|
| 246 | # location of python |
---|
| 247 | local python-root = [ MATCH "^--with-python-root=(.*)" : [ modules.peek : ARGV ] ] ; |
---|
| 248 | PYTHON_ROOT ?= $(python-root) ; |
---|
| 249 | |
---|
| 250 | # Select the libraries to install. |
---|
| 251 | libraries = [ libraries-to-install $(all-libraries) ] ; |
---|
| 252 | |
---|
| 253 | if --show-libraries in [ modules.peek : ARGV ] |
---|
| 254 | { |
---|
| 255 | ECHO "The following libraries require building:" ; |
---|
| 256 | for local l in $(libraries) |
---|
| 257 | { |
---|
| 258 | ECHO " - $(l)" ; |
---|
| 259 | } |
---|
| 260 | EXIT ; |
---|
| 261 | } |
---|
| 262 | |
---|
| 263 | # Custom build ID. |
---|
| 264 | local build-id = [ MATCH "^--buildid=(.*)" : [ modules.peek : ARGV ] ] ; |
---|
| 265 | if $(build-id) |
---|
| 266 | { |
---|
| 267 | constant BUILD_ID : [ regex.replace $(build-id) "[*\\/:.\"\' ]" "_" ] ; |
---|
| 268 | } |
---|
| 269 | |
---|
| 270 | # This rule is called by Boost.Build to determine the name of |
---|
| 271 | # target. We use it to encode build variant, compiler name and |
---|
| 272 | # boost version in the target name |
---|
| 273 | rule tag ( name : type ? : property-set ) |
---|
| 274 | { |
---|
| 275 | if $(type) in STATIC_LIB SHARED_LIB IMPORT_LIB |
---|
| 276 | { |
---|
| 277 | if $(layout) = versioned |
---|
| 278 | { |
---|
| 279 | local result = [ common.format-name |
---|
| 280 | <base> <toolset> <threading> <runtime> -$(BOOST_VERSION_TAG) |
---|
| 281 | -$(BUILD_ID) |
---|
| 282 | : $(name) : $(type) : $(property-set) ] ; |
---|
| 283 | |
---|
| 284 | # Optionally add version suffix. |
---|
| 285 | # On NT, library with version suffix won't be recognized |
---|
| 286 | # by linkers. On CYGWIN, we get strage duplicate symbol |
---|
| 287 | # errors when library is generated with version suffix. |
---|
| 288 | # On OSX, version suffix is not needed -- the linker expets |
---|
| 289 | # libFoo.1.2.3.dylib format. |
---|
| 290 | # AIX linkers don't accept version suffixes either. |
---|
| 291 | if $(type) = SHARED_LIB && |
---|
| 292 | ! ( [ $(property-set).get <target-os> ] in windows cygwin darwin aix ) |
---|
| 293 | { |
---|
| 294 | result = $(result).$(BOOST_VERSION) ; |
---|
| 295 | } |
---|
| 296 | |
---|
| 297 | return $(result) ; |
---|
| 298 | } |
---|
| 299 | else |
---|
| 300 | { |
---|
| 301 | return [ common.format-name |
---|
| 302 | <base> <threading> <runtime> -$(BUILD_ID) |
---|
| 303 | : $(name) : $(type) : $(property-set) ] ; |
---|
| 304 | } |
---|
| 305 | } |
---|
| 306 | } |
---|
| 307 | |
---|
| 308 | # Install to system location. |
---|
| 309 | |
---|
| 310 | local install-requirements = |
---|
| 311 | <install-source-root>boost |
---|
| 312 | ; |
---|
| 313 | if $(layout-versioned) |
---|
| 314 | { |
---|
| 315 | install-requirements += <install-header-subdir>boost-$(BOOST_VERSION_TAG)/boost ; |
---|
| 316 | } |
---|
| 317 | else |
---|
| 318 | { |
---|
| 319 | install-requirements += <install-header-subdir>boost ; |
---|
| 320 | } |
---|
| 321 | if [ modules.peek : NT ] |
---|
| 322 | { |
---|
| 323 | install-requirements += <install-default-prefix>C:/Boost ; |
---|
| 324 | } |
---|
| 325 | else if [ modules.peek : UNIX ] |
---|
| 326 | { |
---|
| 327 | install-requirements += <install-default-prefix>/usr/local ; |
---|
| 328 | } |
---|
| 329 | |
---|
| 330 | local headers = |
---|
| 331 | [ path.glob-tree boost : *.hpp *.ipp *.h *.inc : CVS ] |
---|
| 332 | [ path.glob-tree boost/compatibility/cpp_c_headers : c* : CVS ] |
---|
| 333 | [ path.glob-tree boost/test/utils/runtime : *.cpp : CVS ] |
---|
| 334 | [ path.glob-tree boost/spirit/tree : |
---|
| 335 | parsetree.dtd : CVS ] |
---|
| 336 | [ path.glob-tree boost/tr1/tr1 : |
---|
| 337 | algorithm array bitset complex deque exception fstream functional |
---|
| 338 | iomanip ios iostream istream iterator limits list locale map |
---|
| 339 | memory new numeric ostream queue random regex set sstream stack |
---|
| 340 | stdexcept streambuf string strstream tuple type_traits typeinfo |
---|
| 341 | utility valarray vector *.SUNWCCh : CVS ] |
---|
| 342 | ; |
---|
| 343 | |
---|
| 344 | |
---|
| 345 | # Complete install |
---|
| 346 | package.install install-proper |
---|
| 347 | : $(install-requirements) <install-no-version-symlinks>on |
---|
| 348 | : |
---|
| 349 | : libs/$(libraries)/build |
---|
| 350 | : $(headers) |
---|
| 351 | ; |
---|
| 352 | explicit install-proper ; |
---|
| 353 | |
---|
| 354 | # Install just library. |
---|
| 355 | install stage-proper |
---|
| 356 | : libs/$(libraries)/build |
---|
| 357 | : <location>$(stage-locate)/lib |
---|
| 358 | <install-dependencies>on <install-type>LIB |
---|
| 359 | <install-no-version-symlinks>on |
---|
| 360 | ; |
---|
| 361 | explicit stage-proper ; |
---|
| 362 | |
---|
| 363 | |
---|
| 364 | if $(layout-versioned) |
---|
| 365 | && ( [ modules.peek : NT ] || [ modules.peek : UNIX ] ) |
---|
| 366 | { |
---|
| 367 | rule make-unversioned-links ( project name ? : property-set : sources * ) |
---|
| 368 | { |
---|
| 369 | local result ; |
---|
| 370 | local filtered ; |
---|
| 371 | local pattern ; |
---|
| 372 | local nt = [ modules.peek : NT ] ; |
---|
| 373 | |
---|
| 374 | # Collect the libraries that have the version number in 'filtered'. |
---|
| 375 | for local s in $(sources) |
---|
| 376 | { |
---|
| 377 | local m ; |
---|
| 378 | if $(nt) |
---|
| 379 | { |
---|
| 380 | m = [ MATCH "(.*[.]lib)" : [ $(s).name ] ] ; |
---|
| 381 | } |
---|
| 382 | else |
---|
| 383 | { |
---|
| 384 | m = [ MATCH "(.*[.]so[.0-9]+)" "(.*[.]a)" : [ $(s).name ] ] ; |
---|
| 385 | } |
---|
| 386 | if $(m) |
---|
| 387 | { |
---|
| 388 | filtered += $(s) ; |
---|
| 389 | } |
---|
| 390 | } |
---|
| 391 | |
---|
| 392 | # Create hardlinks without version. |
---|
| 393 | for local s in $(filtered) |
---|
| 394 | { |
---|
| 395 | local name = [ $(s).name ] ; |
---|
| 396 | local ea = [ $(s).action ] ; |
---|
| 397 | local ep = [ $(ea).properties ] ; |
---|
| 398 | local a = [ |
---|
| 399 | new non-scanning-action $(s) : common.hard-link : $(ep) ] ; |
---|
| 400 | |
---|
| 401 | local noversion-file ; |
---|
| 402 | if $(nt) |
---|
| 403 | { |
---|
| 404 | noversion-file = [ MATCH "(.*)-[0-9_]+([.]lib)" : $(name) ] ; |
---|
| 405 | } |
---|
| 406 | else |
---|
| 407 | { |
---|
| 408 | noversion-file = |
---|
| 409 | [ MATCH "(.*)-[0-9_]+([.]so)[.0-9]*" : $(name) ] |
---|
| 410 | [ MATCH "(.*)-[0-9_]+([.]a)" : $(name) ] |
---|
| 411 | [ MATCH "(.*)-[0-9_]+([.]dll[.]a)" : $(name) ] ; |
---|
| 412 | } |
---|
| 413 | |
---|
| 414 | local new-name = |
---|
| 415 | $(noversion-file[1])$(noversion-file[2]) ; |
---|
| 416 | result += [ new file-target $(new-name) exact : [ $(s).type ] : $(project) |
---|
| 417 | : $(a) ] ; |
---|
| 418 | |
---|
| 419 | } |
---|
| 420 | return $(result) ; |
---|
| 421 | } |
---|
| 422 | |
---|
| 423 | generate stage-unversioned : stage-proper : |
---|
| 424 | <generating-rule>@make-unversioned-links ; |
---|
| 425 | explicit stage-unversioned ; |
---|
| 426 | |
---|
| 427 | generate install-unversioned : install-proper : |
---|
| 428 | <generating-rule>@make-unversioned-links ; |
---|
| 429 | explicit install-unversioned ; |
---|
| 430 | } |
---|
| 431 | else |
---|
| 432 | { |
---|
| 433 | # Create do-nothing aliases |
---|
| 434 | alias stage-unversioned ; |
---|
| 435 | alias install-unversioned ; |
---|
| 436 | } |
---|
| 437 | |
---|
| 438 | alias install : install-proper install-unversioned ; |
---|
| 439 | alias stage : stage-proper stage-unversioned ; |
---|
| 440 | explicit install ; |
---|
| 441 | explicit stage ; |
---|
| 442 | |
---|
| 443 | |
---|
| 444 | # Just build the libraries, don't install them anywhere. |
---|
| 445 | # This is what happens with just "bjam --v2". |
---|
| 446 | alias build_all : libs/$(libraries)/build ; |
---|
| 447 | |
---|
| 448 | # This rule should be called from libraries' Jamfiles and will |
---|
| 449 | # create two targets, "install" and "stage", that will install |
---|
| 450 | # or stage that library. The --prefix option is respected, by |
---|
| 451 | # --with and --without options, naturally, are ignored. |
---|
| 452 | # |
---|
| 453 | # - libraries -- list of library targets to install. |
---|
| 454 | rule boost-install ( libraries * ) |
---|
| 455 | { |
---|
| 456 | package.install install |
---|
| 457 | : <dependency>/boost//install-headers $(install-requirements) |
---|
| 458 | : # No binaries |
---|
| 459 | : $(libraries) |
---|
| 460 | : # No headers, it's handled by the dependency |
---|
| 461 | ; |
---|
| 462 | |
---|
| 463 | install stage : $(libraries) : <location>$(BOOST_STAGE_LOCATE) ; |
---|
| 464 | |
---|
| 465 | local c = [ project.current ] ; |
---|
| 466 | local project-module = [ $(c).project-module ] ; |
---|
| 467 | module $(project-module) |
---|
| 468 | { |
---|
| 469 | explicit stage ; |
---|
| 470 | } |
---|
| 471 | } |
---|
| 472 | |
---|
| 473 | # Make project ids of all libraries known. |
---|
| 474 | for local l in $(libraries) |
---|
| 475 | { |
---|
| 476 | use-project /boost/$(l) : libs/$(l)/build ; |
---|
| 477 | } |
---|