![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /proc/self/root/usr/share/boost-build/src/tools/ |
Upload File : |
# Copyright (c) 2005 Vladimir Prus. # Copyright 2006 Rene Rivera. # # Use, modification and distribution is subject to the Boost Software # License Version 1.0. (See accompanying file LICENSE_1_0.txt or # http://www.boost.org/LICENSE_1_0.txt) # Provides mechanism for installing whole packages into a specific directory # structure. This is opposed to the 'install' rule, that installs a number of # targets to a single directory, and does not care about directory structure at # all. # Example usage: # # package.install boost : <properties> # : <binaries> # : <libraries> # : <headers> # ; # # This will install binaries, libraries and headers to the 'proper' location, # given by command line options --prefix, --exec-prefix, --bindir, --libdir and # --includedir. # # The rule is just a convenient wrapper, avoiding the need to define several # 'install' targets. # # The only install-related feature is <install-source-root>. It will apply to # headers only and if present, paths of headers relatively to source root will # be retained after installing. If it is not specified, then "." is assumed, so # relative paths in headers are always preserved. import "class" : new ; import option ; import project ; import feature ; import path ; import property ; import stage ; import targets ; import modules ; import os ; feature.feature install-default-prefix : : free incidental ; class package-paths { import feature ; import modules ; import option ; import os ; import path ; rule __init__ ( default-prefix ) { local explicit-options = [ MATCH --(prefix|bindir|libdir|includedir|datarootdir)=.* : [ modules.peek : ARGV ] ] ; self.has-$(explicit-options) = true ; if prefix in $(explicit-options) { # If --prefix is explicitly specified on the command line, # then we need wipe away any settings of libdir/includir that # is specified via options in config files. option.set bindir : ; option.set libdir : ; option.set includedir : ; option.set datarootdir : ; } handle-path prefix : $(default-prefix) ; handle-path libdir : $(self.prefix)/lib ; handle-path bindir : $(self.prefix)/bin ; handle-path includedir : $(self.prefix)/include ; handle-path datarootdir : $(self.prefix)/share ; } local rule handle-path ( option : default-value ) { local opt = [ option.get $(option) ] ; if $(opt) { opt = [ path.root [ path.make $(opt) ] [ path.pwd ] ] ; } else { opt = $(default-value) ; } self.$(option) = $(opt) ; } rule prefix ( ) { return $(self.prefix) ; } rule libdir ( ) { return $(self.libdir) ; } rule bindir ( ) { return $(self.bindir) ; } rule includedir ( ) { return $(self.includedir) ; } rule datarootdir ( ) { return $(self.datarootdir) ; } rule get ( option ) { if ! $(self.$(option)) { local info = [ modules.peek package : .options.$(option) ] ; local default-value = $(info[1]) ; local relative-to = $(info[2]) ; if $(self.has-$(relative-to)) { option.set $(option) ; self.has-$(option) = true ; } if [ MATCH --$(option)=(.*) : [ modules.peek : ARGV ] ] { self.has-$(option) = true ; } local adjusted-default = [ path.join [ get $(relative-to) ] $(default-value) ] ; handle-path $(option) : $(adjusted-default) ; } return $(self.$(option)) ; } } # Registers an additional path option. The option name # can then be used with a package-paths object. # # default-path is the default path that will be used if # the option is not set explicitly. It will be interpreted # relative to another option. This allows options to be # defined hierarchically with --prefix as the root. # # relative-to should be the name of another option. It defaults # to prefix. # # Example:: # # package.add-path-option cmakedir : cmake : libdir ; # cmakedir = [ $(mypaths).get cmakedir ] ; # defaults to /usr/local/lib/cmake # rule add-path-option ( name : default-path : relative-to ? ) { local value = $(default-path) $(relative-to:E=prefix) ; if $(.options.$(name)) && $(.options.$(name)) != $(value) { import errors ; errors.error Duplicate definition of $(name) ; } .options.$(name) = $(value) ; } # Returns a package-paths object that can be used # to find the various install paths. If requirements # contains <install-default-prefix> then that will be used # as the default prefix, otherwise a platform specific # default prefix will be used. All other properties # in requirements are ignored. # rule paths ( package-name : requirements * ) { local default-prefix = [ feature.get-values <install-default-prefix> : $(requirements) ] ; # Or some likely defaults if neither is given. if ! $(default-prefix) { if [ os.name ] = NT { default-prefix = C:\\$(package-name) ; } else { default-prefix = /usr/local ; } } default-prefix = [ path.make $(default-prefix) ] ; if ! $(.package-paths.$(default-prefix)) { .package-paths.$(default-prefix) = [ new package-paths $(default-prefix) ] ; } return $(.package-paths.$(default-prefix)) ; } rule install ( name package-name ? : requirements * : binaries * : libraries * : headers * ) { package-name ?= $(name) ; # If <install-source-root> is not specified, all headers are installed to # prefix/include, no matter what their relative path is. Sometimes that is # what is needed. local install-source-root = [ property.select <install-source-root> : $(requirements) ] ; install-source-root = $(install-source-root:G=) ; requirements = [ property.change $(requirements) : <install-source-root> ] ; local install-header-subdir = [ property.select <install-header-subdir> : $(requirements) ] ; install-header-subdir = /$(install-header-subdir:G=) ; install-header-subdir ?= "" ; requirements = [ property.change $(requirements) : <install-header-subdir> ] ; # First, figure out all locations. Use the default if no prefix option # given. local paths = [ paths $(package-name) : $(requirements) ] ; # Binaries. local bin-locate = [ $(paths).bindir ] ; # Object code libraries. local lib-locate = [ $(paths).libdir ] ; # Source header files. local include-locate = [ $(paths).includedir ] ; stage.install $(name)-bin : $(binaries) : $(requirements) <location>$(bin-locate) ; alias $(name)-lib : $(name)-lib-shared $(name)-lib-static ; # Since the install location of shared libraries differs on universe # and cygwin, use target alternatives to make different targets. # We should have used indirection conditioanl requirements, but it's # awkward to pass bin-locate and lib-locate from there to another rule. alias $(name)-lib-shared : $(name)-lib-shared-universe ; alias $(name)-lib-shared : $(name)-lib-shared-cygwin : <target-os>cygwin ; # For shared libraries, we install both explicitly specified one and the # shared libraries that the installed executables depend on. stage.install $(name)-lib-shared-universe : $(binaries) $(libraries) : $(requirements) <location>$(lib-locate) <install-dependencies>on <install-type>SHARED_LIB ; stage.install $(name)-lib-shared-cygwin : $(binaries) $(libraries) : $(requirements) <location>$(bin-locate) <install-dependencies>on <install-type>SHARED_LIB ; # For static libraries, we do not care about executable dependencies, since # static libraries are already incorporated into them. stage.install $(name)-lib-static : $(libraries) : $(requirements) <location>$(lib-locate) <install-dependencies>on <install-type>STATIC_LIB ; stage.install $(name)-headers : $(headers) : $(requirements) <location>$(include-locate)$(install-header-subdir) <install-source-root>$(install-source-root) ; alias $(name) : $(name)-bin $(name)-lib $(name)-headers ; local c = [ project.current ] ; local project-module = [ $(c).project-module ] ; module $(project-module) { explicit $(1)-bin $(1)-lib $(1)-headers $(1) $(1)-lib-shared $(1)-lib-static $(1)-lib-shared-universe $(1)-lib-shared-cygwin ; } } rule install-data ( target-name : package-name : data * : requirements * ) { package-name ?= target-name ; local paths = [ paths $(package-name) : $(requirements) ] ; local datadir = [ $(paths).datarootdir ] ; stage.install $(target-name) : $(data) : $(requirements) <location>$(datadir)/$(package-name) ; local c = [ project.current ] ; local project-module = [ $(c).project-module ] ; module $(project-module) { explicit $(1) ; } }