Jamfile cleanup:

- Don't set the global link settings (`<link>`) to avoid dependency
ordering issues in the future.
- Allow the user to decide on the link settings for dependencies
(filesystem/coroutine).
- Make dependencies in examples explicit.
- Remove dependency of examples on Boost.Filesystem (was not used there).
- Deduplicate build settings.
- Speed up test compilation by avoiding rebuilding of main test file.

Signed-off-by: Damian Jarek <damian.jarek93@gmail.com>
This commit is contained in:
Damian Jarek
2019-03-20 19:07:09 +01:00
parent 1f560692ac
commit 222dcf7b18
51 changed files with 114 additions and 122 deletions

75
Jamfile
View File

@ -51,67 +51,18 @@ variant beast_ubasan
path-constant TEST_MAIN : include/boost/beast/_experimental/unit_test/main.cpp ; path-constant TEST_MAIN : include/boost/beast/_experimental/unit_test/main.cpp ;
lib static_beast
: test/lib_beast.cpp
: requirements
[ requires
cxx11_constexpr
cxx11_decltype
cxx11_hdr_tuple
cxx11_template_aliases
cxx11_variadic_templates
]
<define>BOOST_BEAST_SPLIT_COMPILATION
<define>BOOST_ASIO_SEPARATE_COMPILATION
<define>BOOST_ASIO_NO_DEPRECATED=1
<define>BOOST_ASIO_DISABLE_BOOST_ARRAY=1
<define>BOOST_ASIO_DISABLE_BOOST_BIND=1
<define>BOOST_ASIO_DISABLE_BOOST_DATE_TIME=1
<define>BOOST_ASIO_DISABLE_BOOST_REGEX=1
<define>BOOST_COROUTINES_NO_DEPRECATION_WARNING=1
<toolset>msvc-14.1:<cxxflags>"/permissive-"
<toolset>msvc:<define>_SCL_SECURE_NO_WARNINGS=1
<toolset>msvc:<define>_CRT_SECURE_NO_WARNINGS=1
<toolset>msvc:<define>_SILENCE_CXX17_ALLOCATOR_VOID_DEPRECATION_WARNING
<toolset>msvc:<define>_SILENCE_CXX17_ADAPTOR_TYPEDEFS_DEPRECATION_WARNING
<target-os>windows:<define>_WIN32_WINNT=0x0601
<link>static
: usage-requirements
<define>BOOST_BEAST_SPLIT_COMPILATION
<define>BOOST_ASIO_SEPARATE_COMPILATION
<define>BOOST_ASIO_NO_DEPRECATED=1
<define>BOOST_ASIO_DISABLE_BOOST_ARRAY=1
<define>BOOST_ASIO_DISABLE_BOOST_BIND=1
<define>BOOST_ASIO_DISABLE_BOOST_DATE_TIME=1
<define>BOOST_ASIO_DISABLE_BOOST_REGEX=1
<define>BOOST_COROUTINES_NO_DEPRECATION_WARNING=1
<toolset>msvc-14.1:<cxxflags>"/permissive-"
<toolset>msvc:<define>_SCL_SECURE_NO_WARNINGS=1
<toolset>msvc:<define>_CRT_SECURE_NO_WARNINGS=1
<toolset>msvc:<define>_SILENCE_CXX17_ALLOCATOR_VOID_DEPRECATION_WARNING
<toolset>msvc:<define>_SILENCE_CXX17_ADAPTOR_TYPEDEFS_DEPRECATION_WARNING
<target-os>windows:<define>_WIN32_WINNT=0x0601
;
lib static_ssl_asio
: test/lib_ssl.cpp
: requirements
<link>static
<library>static_beast
[ ac.check-library /boost/beast//ssl : <library>/boost/beast//ssl/<link>shared : <build>no ]
[ ac.check-library /boost/beast//crypto : <library>/boost/beast//crypto/<link>shared : <build>no ]
;
project /boost/beast project /boost/beast
: requirements : requirements
[ requires
cxx11_constexpr
cxx11_decltype
cxx11_hdr_tuple
cxx11_template_aliases
cxx11_variadic_templates
]
<include>. <include>.
<include>./test/extras/include <include>./test/extras/include
<library>/boost/coroutine//boost_coroutine
<library>/boost/filesystem//boost_filesystem
<library>static_beast
<implicit-dependency>/boost//headers <implicit-dependency>/boost//headers
<threading>multi
<debug-symbols>on
<runtime-link>shared
<define>BOOST_ALL_NO_LIB=1 <define>BOOST_ALL_NO_LIB=1
<define>BOOST_BEAST_SPLIT_COMPILATION <define>BOOST_BEAST_SPLIT_COMPILATION
<define>BOOST_ASIO_SEPARATE_COMPILATION <define>BOOST_ASIO_SEPARATE_COMPILATION
@ -145,7 +96,17 @@ project /boost/beast
<target-os>hpux:<library>ipv6 <target-os>hpux:<library>ipv6
<target-os>qnxnto:<library>socket <target-os>qnxnto:<library>socket
<target-os>haiku:<library>network <target-os>haiku:<library>network
: usage-requirements : usage-requirements
; ;
lib static_beast
: test/lib_beast.cpp
;
lib static_ssl_asio
: test/lib_ssl.cpp
: requirements
<library>/boost/beast//static_beast/<link>static
[ ac.check-library /boost/beast//ssl : <library>/boost/beast//ssl/<link>shared : <build>no ]
[ ac.check-library /boost/beast//crypto : <library>/boost/beast//crypto/<link>shared : <build>no ]
;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe advanced-server-flex : exe advanced-server-flex :

View File

@ -12,4 +12,5 @@ exe advanced-server :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -12,4 +12,5 @@ exe echo-op :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe http-client-async-ssl : exe http-client-async-ssl :

View File

@ -12,4 +12,5 @@ exe http-client-async :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe http-client-coro-ssl : exe http-client-coro-ssl :
@ -19,4 +19,5 @@ exe http-client-coro-ssl :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -12,4 +12,6 @@ exe http-client-coro :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -13,4 +13,5 @@ exe http-crawl :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe http-client-sync-ssl : exe http-client-sync-ssl :

View File

@ -12,4 +12,5 @@ exe http-client-sync :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe http-server-async-ssl : exe http-server-async-ssl :

View File

@ -12,4 +12,5 @@ exe http-server-async :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe http-server-coro-ssl : exe http-server-coro-ssl :
@ -19,4 +19,5 @@ exe http-server-coro-ssl :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -12,4 +12,6 @@ exe http-server-coro :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -16,4 +16,6 @@ exe http-server-fast :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe http-server-flex : exe http-server-flex :

View File

@ -12,4 +12,5 @@ exe http-server-small :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe http-server-stackless-ssl : exe http-server-stackless-ssl :

View File

@ -12,4 +12,5 @@ exe http-server-stackless :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe http-server-sync-ssl : exe http-server-sync-ssl :

View File

@ -12,4 +12,5 @@ exe http-server-sync :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe websocket-client-async-ssl : exe websocket-client-async-ssl :

View File

@ -12,4 +12,5 @@ exe websocket-client-async :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe websocket-client-coro-ssl : exe websocket-client-coro-ssl :
@ -19,4 +19,5 @@ exe websocket-client-coro-ssl :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -12,4 +12,6 @@ exe websocket-client-coro :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe websocket-client-sync-ssl : exe websocket-client-sync-ssl :

View File

@ -12,4 +12,5 @@ exe websocket-client-sync :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe websocket-server-async-ssl : exe websocket-server-async-ssl :

View File

@ -12,4 +12,5 @@ exe websocket-server-async :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -16,4 +16,5 @@ exe websocket-chat-multi :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe websocket-server-coro-ssl : exe websocket-server-coro-ssl :
@ -19,4 +19,5 @@ exe websocket-server-coro-ssl :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -12,4 +12,6 @@ exe websocket-server-coro :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -12,4 +12,6 @@ exe websocket-server-fast :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
<library>/boost/coroutine//boost_coroutine
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe websocket-server-stackless-ssl : exe websocket-server-stackless-ssl :

View File

@ -12,4 +12,5 @@ exe websocket-server-stackless :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -11,7 +11,7 @@ import ac ;
project project
: requirements : requirements
[ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio : <build>no ] [ ac.check-library /boost/beast//static_ssl_asio : <library>/boost/beast//static_ssl_asio/<link>static : <build>no ]
; ;
exe websocket-server-sync-ssl : exe websocket-server-sync-ssl :

View File

@ -12,4 +12,5 @@ exe websocket-server-sync :
: :
<variant>coverage:<build>no <variant>coverage:<build>no
<variant>ubasan:<build>no <variant>ubasan:<build>no
<library>/boost/beast//static_beast/<link>static
; ;

View File

@ -10,6 +10,12 @@
import testing ; import testing ;
import ../../config/checks/config : requires ; import ../../config/checks/config : requires ;
lib test_main
: $(TEST_MAIN)
: requirements
;
project /boost/beast/test project /boost/beast/test
: requirements : requirements
[ requires [ requires
@ -23,8 +29,10 @@ project /boost/beast/test
<include>./extern <include>./extern
<define>BOOST_BEAST_ALLOW_DEPRECATED <define>BOOST_BEAST_ALLOW_DEPRECATED
<define>BOOST_BEAST_TESTS <define>BOOST_BEAST_TESTS
<define>BOOST_ASIO_SEPARATE_COMPILATION <library>/boost/beast//static_ssl_asio/<link>static
<library>/boost/beast//static_ssl_asio <library>/boost/beast/test//test_main/<link>static
<library>/boost/filesystem//boost_filesystem
<library>/boost/coroutine//boost_coroutine
; ;
path-constant ZLIB_SOURCES : path-constant ZLIB_SOURCES :

View File

@ -17,15 +17,15 @@ local RUN_TESTS ;
for local f in $(SOURCES) for local f in $(SOURCES)
{ {
RUN_TESTS += [ run $(f) $(TEST_MAIN) ] ; RUN_TESTS += [ run $(f) ] ;
} }
alias run-tests : $(RUN_TESTS) ; alias run-tests : $(RUN_TESTS) ;
exe fat-tests : $(TEST_MAIN) $(SOURCES) ; exe fat-tests : $(SOURCES) ;
explicit fat-tests ; explicit fat-tests ;
run $(TEST_MAIN) $(SOURCES) : : : : run-fat-tests ; run $(SOURCES) : : : : run-fat-tests ;
explicit run-fat-tests ; explicit run-fat-tests ;

View File

@ -61,15 +61,15 @@ local RUN_TESTS ;
for local f in $(SOURCES) for local f in $(SOURCES)
{ {
RUN_TESTS += [ run $(f) $(TEST_MAIN) ] ; RUN_TESTS += [ run $(f) ] ;
} }
alias run-tests : $(RUN_TESTS) ; alias run-tests : $(RUN_TESTS) ;
exe fat-tests : $(TEST_MAIN) $(SOURCES) ; exe fat-tests : $(SOURCES) ;
explicit fat-tests ; explicit fat-tests ;
run $(TEST_MAIN) $(SOURCES) : : : : run-fat-tests ; run $(SOURCES) : : : : run-fat-tests ;
explicit run-fat-tests ; explicit run-fat-tests ;

View File

@ -36,15 +36,15 @@ local RUN_TESTS ;
for local f in $(SOURCES) for local f in $(SOURCES)
{ {
RUN_TESTS += [ run $(f) $(TEST_MAIN) ] ; RUN_TESTS += [ run $(f) ] ;
} }
alias run-tests : $(RUN_TESTS) ; alias run-tests : $(RUN_TESTS) ;
exe fat-tests : $(TEST_MAIN) $(SOURCES) ; exe fat-tests : $(SOURCES) ;
explicit fat-tests ; explicit fat-tests ;
run $(TEST_MAIN) $(SOURCES) : : : : run-fat-tests ; run $(SOURCES) : : : : run-fat-tests ;
explicit run-fat-tests ; explicit run-fat-tests ;

View File

@ -15,15 +15,15 @@ local RUN_TESTS ;
for local f in $(SOURCES) for local f in $(SOURCES)
{ {
RUN_TESTS += [ run $(f) $(TEST_MAIN) ] ; RUN_TESTS += [ run $(f) ] ;
} }
alias run-tests : $(RUN_TESTS) ; alias run-tests : $(RUN_TESTS) ;
exe fat-tests : $(TEST_MAIN) $(SOURCES) ; exe fat-tests : $(SOURCES) ;
explicit fat-tests ; explicit fat-tests ;
run $(TEST_MAIN) $(SOURCES) : : : : run-fat-tests ; run $(SOURCES) : : : : run-fat-tests ;
explicit run-fat-tests ; explicit run-fat-tests ;

View File

@ -37,15 +37,15 @@ local RUN_TESTS ;
for local f in $(SOURCES) for local f in $(SOURCES)
{ {
RUN_TESTS += [ run $(f) $(TEST_MAIN) ] ; RUN_TESTS += [ run $(f) ] ;
} }
alias run-tests : $(RUN_TESTS) ; alias run-tests : $(RUN_TESTS) ;
exe fat-tests : $(TEST_MAIN) $(SOURCES) ; exe fat-tests : $(SOURCES) ;
explicit fat-tests ; explicit fat-tests ;
run $(TEST_MAIN) $(SOURCES) : : : : run-fat-tests ; run $(SOURCES) : : : : run-fat-tests ;
explicit run-fat-tests ; explicit run-fat-tests ;

View File

@ -18,15 +18,15 @@ local RUN_TESTS ;
for local f in $(SOURCES) for local f in $(SOURCES)
{ {
RUN_TESTS += [ run $(f) $(TEST_MAIN) $(ZLIB_SOURCES) ] ; RUN_TESTS += [ run $(f) $(ZLIB_SOURCES) ] ;
} }
alias run-tests : $(RUN_TESTS) ; alias run-tests : $(RUN_TESTS) ;
exe fat-tests : $(TEST_MAIN) $(ZLIB_SOURCES) $(SOURCES) ; exe fat-tests : $(ZLIB_SOURCES) $(SOURCES) ;
explicit fat-tests ; explicit fat-tests ;
run $(TEST_MAIN) $(ZLIB_SOURCES) $(SOURCES) : : : : run-fat-tests ; run $(ZLIB_SOURCES) $(SOURCES) : : : : run-fat-tests ;
explicit run-fat-tests ; explicit run-fat-tests ;

View File

@ -8,7 +8,7 @@
# #
exe bench-buffers : exe bench-buffers :
$(TEST_MAIN)
bench_buffers.cpp bench_buffers.cpp
; ;

View File

@ -7,7 +7,7 @@
# Official repository: https://github.com/boostorg/beast # Official repository: https://github.com/boostorg/beast
# #
run $(TEST_MAIN) nodejs_parser.cpp bench_parser.cpp : : : : bench-parser ; run nodejs_parser.cpp bench_parser.cpp : : : : bench-parser ;
explicit bench-parser ; explicit bench-parser ;

View File

@ -8,7 +8,7 @@
# #
exe bench-utf8-checker : exe bench-utf8-checker :
$(TEST_MAIN)
bench_utf8_checker.cpp bench_utf8_checker.cpp
; ;

View File

@ -9,7 +9,7 @@
exe bench-zlib : exe bench-zlib :
$(ZLIB_SOURCES) $(ZLIB_SOURCES)
$(TEST_MAIN)
deflate_stream.cpp deflate_stream.cpp
inflate_stream.cpp inflate_stream.cpp
; ;

View File

@ -7,35 +7,27 @@
# Official repository: https://github.com/boostorg/beast # Official repository: https://github.com/boostorg/beast
# #
import ac ;
project
: requirements
[ ac.check-library /boost/beast//ssl : <library>/boost/beast//ssl : <build>no ]
<library>/boost/beast//crypto
;
alias run-tests : alias run-tests :
[ compile core_snippets.cpp ] [ compile core_snippets.cpp ]
[ compile http_snippets.cpp ] [ compile http_snippets.cpp ]
[ run core_1_refresher.cpp $(TEST_MAIN) ] [ run core_1_refresher.cpp ]
[ run core_3_timeouts.cpp $(TEST_MAIN) ] [ run core_3_timeouts.cpp ]
[ run core_4_layers.cpp $(TEST_MAIN) ] [ run core_4_layers.cpp ]
[ run http_10_custom_parser.cpp $(TEST_MAIN) ] [ run http_10_custom_parser.cpp ]
[ run http_examples.cpp $(TEST_MAIN) ] [ run http_examples.cpp ]
[ run websocket.cpp $(TEST_MAIN) ] [ run websocket.cpp ]
[ run websocket_1_connecting.cpp $(TEST_MAIN) ] [ run websocket_1_connecting.cpp ]
[ run websocket_2_handshaking.cpp $(TEST_MAIN) ] [ run websocket_2_handshaking.cpp ]
[ run websocket_3_decorator.cpp $(TEST_MAIN) ] [ run websocket_3_decorator.cpp ]
[ run websocket_4_messages.cpp $(TEST_MAIN) ] [ run websocket_4_messages.cpp ]
[ run websocket_5_control_frames.cpp $(TEST_MAIN) ] [ run websocket_5_control_frames.cpp ]
[ run websocket_6_timeouts.cpp $(TEST_MAIN) ] [ run websocket_6_timeouts.cpp ]
[ run websocket_7_teardown.cpp $(TEST_MAIN) ] [ run websocket_7_teardown.cpp ]
[ run websocket_8_notes.cpp $(TEST_MAIN) ] [ run websocket_8_notes.cpp ]
; ;
exe fat-tests : exe fat-tests :
$(TEST_MAIN)
core_1_refresher.cpp core_1_refresher.cpp
core_3_timeouts.cpp core_3_timeouts.cpp
core_4_layers.cpp core_4_layers.cpp
@ -54,6 +46,6 @@ exe fat-tests :
explicit fat-tests ; explicit fat-tests ;
run $(TEST_MAIN) $(SOURCES) : : : : run-fat-tests ; run fat-tests : : : : run-fat-tests ;
explicit run-fat-tests ; explicit run-fat-tests ;

View File

@ -15,6 +15,6 @@ alias fat-tests ;
explicit fat-tests ; explicit fat-tests ;
run $(TEST_MAIN) $(SOURCES) : : : : run-fat-tests ; alias run-fat-tests : common//run-tests ;
explicit run-fat-tests ; explicit run-fat-tests ;