diff options
Diffstat (limited to 'src/boost/libs/log/build')
-rw-r--r-- | src/boost/libs/log/build/Jamfile.v2 | 534 | ||||
-rw-r--r-- | src/boost/libs/log/build/log-architecture.jam | 112 | ||||
-rw-r--r-- | src/boost/libs/log/build/log-platform-config.jam | 59 |
3 files changed, 705 insertions, 0 deletions
diff --git a/src/boost/libs/log/build/Jamfile.v2 b/src/boost/libs/log/build/Jamfile.v2 new file mode 100644 index 00000000..a172767a --- /dev/null +++ b/src/boost/libs/log/build/Jamfile.v2 @@ -0,0 +1,534 @@ +# +# Copyright Andrey Semashev 2007 - 2016. +# Distributed under the Boost Software License, Version 1.0. +# (See accompanying file LICENSE_1_0.txt or copy at +# http://www.boost.org/LICENSE_1_0.txt) +# + +import common ; +import modules ; +import os ; +import path ; +import project ; +import feature ; +import configure ; +import log-architecture ; +import log-platform-config ; +using mc ; + +local here = [ modules.binding $(__name__) ] ; + +project.push-current [ project.current ] ; +project.load [ path.join [ path.make $(here:D) ] ../config/message-compiler ] ; +project.load [ path.join [ path.make $(here:D) ] ../config/x86-ext ] ; +project.load [ path.join [ path.make $(here:D) ] ../config/pthread-mutex-robust ] ; +project.load [ path.join [ path.make $(here:D) ] ../config/native-syslog ] ; +project.load [ path.join [ path.make $(here:D) ] ../config/atomic-int32 ] ; +project.pop-current ; + +# Windows libs +lib psapi ; +lib advapi32 ; +lib secur32 ; +lib ws2_32 ; +lib mswsock ; + +# UNIX libs +lib rt ; +lib socket ; +lib nsl ; +lib ipv6 ; + +rule has-config-flag ( flag : properties * ) +{ + if ( "<define>$(flag)" in $(properties) || "<define>$(flag)=1" in $(properties) ) + { + return 1 ; + } + else + { + return ; + } +} + +rule check-instruction-set ( properties * ) +{ + local result ; + local instruction_set = [ feature.get-values "log-instruction-set" : [ log-architecture.deduce-instruction-set $(properties) ] ] ; + + if $(instruction_set) = i386 || $(instruction_set) = i486 + { + if ! $(.annouced-failure) + { + ECHO Boost.Log is not supported on the specified target CPU and will not be built. At least i586 class CPU is required. ; + .annouced-failure = 1 ; + } + result = <build>no ; + } + + return $(result) ; +} + +rule select-regex-backend ( properties * ) +{ + local result = ; + + # Use Boost.Regex backend by default. It produces smaller executables and also has the best performance for small string matching. + if ! ( + [ has-config-flag BOOST_LOG_WITHOUT_SETTINGS_PARSERS : $(properties) ] || + [ has-config-flag BOOST_LOG_WITHOUT_DEFAULT_FACTORIES : $(properties) ] || + [ has-config-flag BOOST_LOG_USE_STD_REGEX : $(properties) ] || + [ has-config-flag BOOST_LOG_USE_BOOST_XPRESSIVE : $(properties) ] ) + { + result = <library>/boost/regex//boost_regex ; + } + + return $(result) ; +} + +rule check-pthread-mutex-robust ( properties * ) +{ + local result = ; + + local has_pthread_mutex_robust = [ configure.builds /boost/log/pthread-mutex-robust//pthread_mutex_robust : $(properties) : pthread-supports-robust-mutexes ] ; + if $(has_pthread_mutex_robust) + { + result = <define>BOOST_LOG_HAS_PTHREAD_MUTEX_ROBUST ; + } + + return $(result) ; +} + +rule check-atomic-int32 ( properties * ) +{ + local result = ; + + local has_atomic_int32 = [ configure.builds /boost/log/atomic-int32//atomic_int32 : $(properties) : native-atomic-int32-supported ] ; + if ! $(has_atomic_int32) + { + result = <define>BOOST_LOG_WITHOUT_IPC ; + } + + return $(result) ; +} + +rule check-native-syslog ( properties * ) +{ + local result = ; + + if ! [ has-config-flag BOOST_LOG_WITHOUT_SYSLOG : $(properties) ] + { + local has_native_syslog = [ configure.builds /boost/log/native-syslog//native_syslog : $(properties) : native-syslog-supported ] ; + if $(has_native_syslog) + { + result = <define>BOOST_LOG_USE_NATIVE_SYSLOG ; + } + } + + return $(result) ; +} + +rule check-message-compiler ( properties * ) +{ + local result ; + + if <target-os>windows in $(properties) + { + if ! [ has-config-flag BOOST_LOG_WITHOUT_EVENT_LOG : $(properties) ] + { + local has_mc = [ configure.builds /boost/log/message-compiler//test-availability : $(properties) : message-compiler ] ; + if ! $(has_mc) + { + result = <define>BOOST_LOG_WITHOUT_EVENT_LOG ; + } + } + else + { + # This branch is needed to fix building with MinGW + result = <define>BOOST_LOG_WITHOUT_EVENT_LOG ; + } + } + else + { + result = <define>BOOST_LOG_WITHOUT_EVENT_LOG ; + } + + return $(result) ; +} + +project boost/log + : source-location ../src + : requirements + <conditional>@check-instruction-set + <conditional>@check-atomic-int32 + <conditional>@select-regex-backend + <conditional>@check-pthread-mutex-robust + <conditional>@check-native-syslog + <conditional>@check-message-compiler + <conditional>@log-platform-config.set-platform-defines + + <include>../src + + <define>__STDC_CONSTANT_MACROS # Use system-defined macros for integer constants, if possible + <define>BOOST_SPIRIT_USE_PHOENIX_V3=1 + <define>BOOST_THREAD_DONT_USE_CHRONO=1 # Don't introduce false dependency on Boost.Chrono + + # Disable warnings about using 'insecure' standard C functions + <toolset>msvc:<define>_SCL_SECURE_NO_WARNINGS + <toolset>msvc:<define>_SCL_SECURE_NO_DEPRECATE + <toolset>msvc:<define>_CRT_SECURE_NO_WARNINGS + <toolset>msvc:<define>_CRT_SECURE_NO_DEPRECATE + <toolset>intel-win:<define>_SCL_SECURE_NO_WARNINGS + <toolset>intel-win:<define>_SCL_SECURE_NO_DEPRECATE + <toolset>intel-win:<define>_CRT_SECURE_NO_WARNINGS + <toolset>intel-win:<define>_CRT_SECURE_NO_DEPRECATE + + <toolset>msvc:<cxxflags>/bigobj + <toolset>msvc:<cxxflags>/wd4503 # decorated name length exceeded, name was truncated + <toolset>msvc:<cxxflags>/wd4456 # declaration of 'A' hides previous local declaration + <toolset>msvc:<cxxflags>/wd4459 # declaration of 'A' hides global declaration + <toolset>msvc:<cxxflags>/wd4003 # not enough actual parameters for macro 'X' - caused by BOOST_PP_IS_EMPTY and BOOST_PP_IS_BEGIN_PARENS which are used by Fusion + + # Disable Intel warnings: + # warning #177: function "X" was declared but never referenced + # warning #780: using-declaration ignored -- it refers to the current namespace + # warning #2196: routine is both "inline" and "noinline" + # remark #1782: #pragma once is obsolete. Use #ifndef guard instead. + # remark #193: zero used for undefined preprocessing identifier "X" + # remark #304: access control not specified ("public" by default) + # remark #981: operands are evaluated in unspecified order + # remark #1418: external function definition with no prior declaration + # Mostly comes from Boost.Phoenix: warning #411: class "X" defines no constructor to initialize the following: reference member "Y"... + # warning #734: "X" (declared at line N of "file.hpp"), required for copy that was eliminated, is inaccessible + # warning #279: controlling expression is constant + <toolset>intel-win:<cxxflags>"/Qwd177,780,2196,1782,193,304,981,1418,411,734,279" + <toolset>intel-linux:<cxxflags>"-wd177,780,2196,1782,193,304,981,1418,411,734,279" + <toolset>intel-darwin:<cxxflags>"-wd177,780,2196,1782,193,304,981,1418,411,734,279" + + <toolset>darwin:<cxxflags>-ftemplate-depth-1024 + <toolset>clang:<cxxflags>-ftemplate-depth-1024 + <toolset>gcc:<cxxflags>-ftemplate-depth-1024 + + <toolset>gcc:<cxxflags>-fno-strict-aliasing # avoids strict aliasing violations in other Boost components + <toolset>gcc,<target-os>windows:<linkflags>-Wl,--enable-auto-import + <toolset>gcc,<target-os>cygwin:<linkflags>-Wl,--enable-auto-import + + <library>/boost/date_time//boost_date_time + <library>/boost/filesystem//boost_filesystem + <threading>single:<define>BOOST_LOG_NO_THREADS + <threading>multi:<library>/boost/atomic//boost_atomic + <threading>multi:<library>/boost/thread//boost_thread + + <target-os>windows:<library>ws2_32 + <target-os>windows:<library>mswsock + <target-os>windows:<library>advapi32 + + <target-os>cygwin:<library>ws2_32 + <target-os>cygwin:<library>mswsock + <target-os>cygwin:<library>advapi32 + # Boost.Interprocess does not compile on Cygwin: https://github.com/boostorg/interprocess/issues/76 + <target-os>cygwin:<define>BOOST_LOG_WITHOUT_IPC + + <target-os>linux:<library>rt + + <target-os>solaris:<library>socket + <target-os>solaris:<library>nsl + + <target-os>hpux:<library>ipv6 + + <target-os>freebsd:<library>rt + <target-os>qnxnto:<library>socket + <toolset>pgi:<library>rt + : usage-requirements + <toolset>clang:<cxxflags>-Wno-bind-to-temporary-copy + <toolset>clang:<cxxflags>-Wno-unused-function + ; + +local BOOST_LOG_COMMON_SRC = + attribute_name.cpp + attribute_set.cpp + attribute_value_set.cpp + code_conversion.cpp + core.cpp + record_ostream.cpp + severity_level.cpp + global_logger_storage.cpp + named_scope.cpp + process_name.cpp + process_id.cpp + thread_id.cpp + timer.cpp + exceptions.cpp + default_attribute_names.cpp + default_sink.cpp + text_ostream_backend.cpp + text_file_backend.cpp + text_multifile_backend.cpp + thread_specific.cpp + once_block.cpp + timestamp.cpp + threadsafe_queue.cpp + event.cpp + trivial.cpp + spirit_encoding.cpp + format_parser.cpp + date_time_format_parser.cpp + named_scope_format_parser.cpp + permissions.cpp + dump.cpp + ; + +BOOST_LOG_COMMON_SSSE3_SRC = + dump_ssse3 + ; + +BOOST_LOG_COMMON_AVX2_SRC = + dump_avx2 + ; + +rule ssse3-targets-cond ( properties * ) +{ + local result = <build>no ; + + if <log-architecture>x86 in [ log-architecture.deduce-architecture $(properties) ] + { + local has_ssse3 = [ configure.builds /boost/log/x86-extensions//ssse3 : $(properties) : compiler-supports-ssse3 ] ; + if $(has_ssse3) + { + result = ; + if <toolset>gcc in $(properties) || <toolset>clang in $(properties) + { + result = <cxxflags>"-msse -msse2 -msse3 -mssse3" ; + } + else if <toolset>intel in $(properties) + { + if <toolset-intel:platform>win in $(properties) + { + result = <cxxflags>"/QxSSSE3" ; + } + else + { + result = <cxxflags>"-xSSSE3" ; + } + } + else if <toolset>msvc in $(properties) + { + # MSVC doesn't really care about these switches, all SSE intrinsics are always available, but still... + # Also 64 bit MSVC doesn't have the /arch:SSE2 switch as it is the default. + if <log-address-model>32 in [ log-architecture.deduce-address-model $(properties) ] + { + result = <cxxflags>"/arch:SSE2" ; + } + } + } + } + +# if ! <build>no in $(result) +# { +# ECHO Boost.Log: Using SSSE3 optimized implementation ; +# } +# ECHO $(result) ; + + return $(result) ; +} + +for local src in $(BOOST_LOG_COMMON_SSSE3_SRC) +{ + obj $(src) + : ## sources ## + $(src).cpp + : ## requirements ## + <conditional>@ssse3-targets-cond + <link>shared:<define>BOOST_LOG_DLL + <define>BOOST_LOG_BUILDING_THE_LIB=1 + : ## default-build ## + : ## usage-requirements ## + <define>BOOST_LOG_USE_SSSE3 + ; + + explicit $(src) ; +} + +rule avx2-targets-cond ( properties * ) +{ + local result = <build>no ; + + if <log-architecture>x86 in [ log-architecture.deduce-architecture $(properties) ] + { + local has_avx2 = [ configure.builds /boost/log/x86-extensions//avx2 : $(properties) : compiler-supports-avx2 ] ; + if $(has_avx2) + { + result = ; + if <toolset>gcc in $(properties) + { + result = <cxxflags>"-mavx -mavx2 -fabi-version=0" ; + } + else if <toolset>clang in $(properties) + { + result = <cxxflags>"-mavx -mavx2" ; + } + else if <toolset>intel in $(properties) + { + if <toolset-intel:platform>win in $(properties) + { + result = <cxxflags>"/arch:CORE-AVX2" ; + } + else + { + result = <cxxflags>"-xCORE-AVX2 -fabi-version=0" ; + } + } + else if <toolset>msvc in $(properties) + { + result = <cxxflags>"/arch:AVX" ; + } + } + } + +# if ! <build>no in $(result) +# { +# ECHO Boost.Log: Using AVX2 optimized implementation ; +# } +# ECHO $(result) ; + + return $(result) ; +} + +for local src in $(BOOST_LOG_COMMON_AVX2_SRC) +{ + obj $(src) + : ## sources ## + $(src).cpp + : ## requirements ## + <conditional>@avx2-targets-cond + <link>shared:<define>BOOST_LOG_DLL + <define>BOOST_LOG_BUILDING_THE_LIB=1 + : ## default-build ## + : ## usage-requirements ## + <define>BOOST_LOG_USE_AVX2 + ; + + explicit $(src) ; +} + +rule select-arch-specific-sources ( properties * ) +{ + local result ; + + if <log-architecture>x86 in [ log-architecture.deduce-architecture $(properties) ] + { + local has_ssse3 = [ configure.builds /boost/log/x86-extensions//ssse3 : $(properties) : compiler-supports-ssse3 ] ; + if $(has_ssse3) + { + result += <define>BOOST_LOG_USE_SSSE3 ; + result += <source>$(BOOST_LOG_COMMON_SSSE3_SRC) ; + } + + local has_avx2 = [ configure.builds /boost/log/x86-extensions//avx2 : $(properties) : compiler-supports-avx2 ] ; + if $(has_avx2) + { + result += <define>BOOST_LOG_USE_AVX2 ; + result += <source>$(BOOST_LOG_COMMON_AVX2_SRC) ; + } + } + +# ECHO Arch sources: $(result) ; + + return $(result) ; +} + +rule select-platform-specific-sources ( properties * ) +{ + local result ; + + if <target-os>windows in $(properties) + { + result += <source>windows/light_rw_mutex.cpp ; + + if ! [ has-config-flag BOOST_LOG_WITHOUT_IPC : $(properties) ] + { + result += <source>windows/object_name.cpp ; + result += <source>windows/mapped_shared_memory.cpp ; + result += <source>windows/ipc_sync_wrappers.cpp ; + result += <source>windows/ipc_reliable_message_queue.cpp ; + result += <library>secur32 ; + } + + if ! [ has-config-flag BOOST_LOG_WITHOUT_DEBUG_OUTPUT : $(properties) ] + { + result += <source>windows/debug_output_backend.cpp ; + } + + if ! [ has-config-flag BOOST_LOG_WITHOUT_EVENT_LOG : $(properties) ] + { + result += <source>windows/simple_event_log.mc ; + result += <source>windows/event_log_backend.cpp ; + result += <library>psapi ; + + DEPENDS windows/event_log_backend.cpp : windows/simple_event_log.mc ; + } + } + else + { + result += <define>BOOST_LOG_WITHOUT_EVENT_LOG ; + result += <define>BOOST_LOG_WITHOUT_DEBUG_OUTPUT ; + + if ! [ has-config-flag BOOST_LOG_WITHOUT_IPC : $(properties) ] + { + result += <source>posix/object_name.cpp ; + result += <source>posix/ipc_reliable_message_queue.cpp ; + } + } + + if ! [ has-config-flag BOOST_LOG_WITHOUT_SYSLOG : $(properties) ] + { + result += <source>syslog_backend.cpp ; + } + +# ECHO Platform sources: $(result) ; + + return $(result) ; +} + +lib boost_log + : ## sources ## + $(BOOST_LOG_COMMON_SRC) + : ## requirements ## + <conditional>@select-arch-specific-sources + <conditional>@select-platform-specific-sources + <link>shared:<define>BOOST_LOG_DLL + <define>BOOST_LOG_BUILDING_THE_LIB=1 + : ## default-build ## + : ## usage-requirements ## + <link>shared:<define>BOOST_LOG_DYN_LINK=1 + <threading>single:<define>BOOST_LOG_NO_THREADS + ; + + +local BOOST_LOG_SETUP_COMMON_SRC = + parser_utils.cpp + init_from_stream.cpp + init_from_settings.cpp + settings_parser.cpp + filter_parser.cpp + formatter_parser.cpp + default_filter_factory.cpp + matches_relation_factory.cpp + default_formatter_factory.cpp + ; + +lib boost_log_setup + : ## sources ## + setup/$(BOOST_LOG_SETUP_COMMON_SRC) + : ## requirements ## + <link>shared:<define>BOOST_LOG_DYN_LINK=1 + <link>shared:<define>BOOST_LOG_SETUP_DLL + <define>BOOST_LOG_SETUP_BUILDING_THE_LIB=1 + <library>boost_log + : ## default-build ## + : ## usage-requirements ## + <link>shared:<define>BOOST_LOG_SETUP_DYN_LINK=1 + <threading>single:<define>BOOST_LOG_NO_THREADS + ; + +boost-install boost_log boost_log_setup ; diff --git a/src/boost/libs/log/build/log-architecture.jam b/src/boost/libs/log/build/log-architecture.jam new file mode 100644 index 00000000..785dda0f --- /dev/null +++ b/src/boost/libs/log/build/log-architecture.jam @@ -0,0 +1,112 @@ +# log-architecture.jam +# +# Copyright 2012 Steven Watanabe +# Copyright 2013 Andrey Semashev +# +# Distributed under the Boost Software License Version 1.0. (See +# accompanying file LICENSE_1_0.txt or copy at +# http://www.boost.org/LICENSE_1_0.txt) + +import configure ; +import project ; +import path ; +import property ; +import feature ; + +local here = [ modules.binding $(__name__) ] ; + +feature.feature log-architecture : : free ; +feature.feature log-address-model : : free ; +feature.feature log-instruction-set : : free ; + +project.push-current [ project.current ] ; +project.load [ path.join [ path.make $(here:D) ] ../../config/checks/architecture ] ; +project.pop-current ; + +rule deduce-address-model ( properties * ) +{ + local address_model = [ feature.get-values "address-model" : $(properties) ] ; + if $(address_model) + { + return <log-address-model>$(address_model) ; + } + else + { + if [ configure.builds /boost/architecture//32 : $(properties) : 32-bit ] + { + return <log-address-model>32 ; + } + else if [ configure.builds /boost/architecture//64 : $(properties) : 64-bit ] + { + return <log-address-model>64 ; + } + } +} + +rule address-model ( ) +{ + return <conditional>@log-architecture.deduce-address-model ; +} + +rule deduce-architecture ( properties * ) +{ + local architecture = [ feature.get-values "architecture" : $(properties) ] ; + if $(architecture) + { + return <log-architecture>$(architecture) ; + } + else + { + if [ configure.builds /boost/architecture//x86 : $(properties) : x86 ] + { + return <log-architecture>x86 ; + } + else if [ configure.builds /boost/architecture//arm : $(properties) : arm ] + { + return <log-architecture>arm ; + } + else if [ configure.builds /boost/architecture//mips1 : $(properties) : mips1 ] + { + return <log-architecture>mips1 ; + } + else if [ configure.builds /boost/architecture//power : $(properties) : power ] + { + return <log-architecture>power ; + } + else if [ configure.builds /boost/architecture//sparc : $(properties) : sparc ] + { + return <log-architecture>sparc ; + } + } +} + +rule architecture ( ) +{ + return <conditional>@log-architecture.deduce-architecture ; +} + +rule deduce-instruction-set ( properties * ) +{ + local result ; + local instruction_set = [ feature.get-values "instruction-set" : $(properties) ] ; + + if $(instruction_set) + { + result = <log-instruction-set>$(instruction_set) ; + } + else + { + if <log-architecture>x86 in $(properties) && <log-address-model>32 in $(properties) + { + # We build for Pentium Pro and later CPUs by default. This is used as the target in many Linux distributions, and Windows and OS X also seem to not support older CPUs. + result = <log-instruction-set>i686 ; + } + } + + return $(result) ; +} + +rule instruction-set ( ) +{ + return <conditional>@log-architecture.deduce-instruction-set ; +} diff --git a/src/boost/libs/log/build/log-platform-config.jam b/src/boost/libs/log/build/log-platform-config.jam new file mode 100644 index 00000000..cee01cc1 --- /dev/null +++ b/src/boost/libs/log/build/log-platform-config.jam @@ -0,0 +1,59 @@ +# log-platform-config.jam +# +# Copyright 2017 Andrey Semashev +# +# Distributed under the Boost Software License Version 1.0. (See +# accompanying file LICENSE_1_0.txt or copy at +# http://www.boost.org/LICENSE_1_0.txt) + +import configure ; +import project ; +import path ; +import property ; +import feature ; + +local here = [ modules.binding $(__name__) ] ; + +project.push-current [ project.current ] ; +project.load [ path.join [ path.make $(here:D) ] ../config/xopen-source-600 ] ; +project.pop-current ; + +rule set-platform-defines ( properties * ) +{ + local result = ; + + if ( <target-os>windows in $(properties) ) || ( <target-os>cygwin in $(properties) ) + { + result += <define>NOMINMAX ; + result += <define>WIN32_LEAN_AND_MEAN ; + result += <define>SECURITY_WIN32 ; + result += <define>BOOST_USE_WINDOWS_H ; + + if <target-os>cygwin in $(properties) + { + result += <define>__USE_W32_SOCKETS ; + result += <define>_XOPEN_SOURCE=600 ; + } + } + else if <target-os>solaris in $(properties) + { + # Solaris headers are broken and cannot be included in C++03 when _XOPEN_SOURCE=600. At the same time, they cannot be included with _XOPEN_SOURCE=500 in C++11 and later. + # This is because the system headers check the C language version and error out if the version does not match. We have to test if we can request _XOPEN_SOURCE=600. + if [ configure.builds /boost/log/xopen-source-600//xopen_source_600 : $(properties) : xopen-source-600-supported ] + { + result += <define>_XOPEN_SOURCE=600 ; + } + else + { + result += <define>_XOPEN_SOURCE=500 ; + } + + result += <define>__EXTENSIONS__ ; + } + else if ( <target-os>linux in $(properties) ) || ( <target-os>hpux in $(properties) ) + { + result += <define>_XOPEN_SOURCE=600 ; + } + + return $(result) ; +} |