passenger 5.1.4 → 5.1.5
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of passenger might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/.editorconfig +9 -0
- data/CHANGELOG +9 -0
- data/build/cxx_tests.rb +11 -1
- data/build/documentation.rb +0 -32
- data/build/support/cxx_dependency_map.rb +602 -2
- data/build/test_basics.rb +3 -3
- data/dev/boost-patches/0001-Patch-boost-thread-so-that-oxt-thread-can-use-it.patch +48 -0
- data/dev/boost-patches/0002-Make-boost-thread_interrupted-derive-from-oxt-tracab.patch +33 -0
- data/dev/boost-patches/0003-Disable-a-Clang-pragma-to-prevent-warnings-on-OS-X.patch +25 -0
- data/dev/ci/README.md +121 -0
- data/dev/ci/lib/functions.sh +129 -0
- data/dev/ci/lib/set-container-envvars.sh +46 -0
- data/dev/ci/lib/setup-container.sh +43 -0
- data/dev/ci/run-tests-natively +24 -0
- data/dev/ci/run-tests-with-docker +42 -0
- data/dev/ci/scripts/debug-console-wrapper.sh +27 -0
- data/dev/ci/scripts/docker-entrypoint-stage2.sh +17 -0
- data/dev/ci/scripts/docker-entrypoint.sh +17 -0
- data/dev/ci/scripts/inituidgid +17 -0
- data/dev/ci/scripts/run-tests-natively-stage2.sh +17 -0
- data/dev/ci/scripts/setup-host-natively.sh +11 -0
- data/dev/ci/setup-host +50 -0
- data/dev/ci/tests/apache2/run +6 -0
- data/dev/ci/tests/apache2/setup +4 -0
- data/dev/ci/tests/cxx/run +9 -0
- data/dev/ci/tests/cxx/setup +4 -0
- data/dev/ci/tests/nginx-dynamic/run +20 -0
- data/dev/ci/tests/nginx-dynamic/setup +4 -0
- data/dev/ci/tests/nginx/run +5 -0
- data/dev/ci/tests/nginx/setup +4 -0
- data/dev/ci/tests/nodejs/run +4 -0
- data/dev/ci/tests/nodejs/setup +4 -0
- data/dev/ci/tests/ruby/run +4 -0
- data/dev/ci/tests/ruby/setup +4 -0
- data/dev/ci/tests/source-packaging/run +4 -0
- data/dev/ci/tests/source-packaging/setup +4 -0
- data/dev/ci/tests/standalone/run +4 -0
- data/dev/ci/tests/standalone/setup +4 -0
- data/dev/copy_boost_headers +8 -2
- data/src/agent/Core/ApiServer.h +11 -5
- data/src/agent/Core/Controller.h +12 -46
- data/src/agent/Core/Controller/CheckoutSession.cpp +1 -1
- data/src/agent/Core/Controller/Config.h +369 -0
- data/src/agent/Core/Controller/ForwardResponse.cpp +4 -4
- data/src/agent/Core/Controller/Hooks.cpp +15 -3
- data/src/agent/Core/Controller/Implementation.cpp +1 -1
- data/src/agent/Core/Controller/InitRequest.cpp +28 -39
- data/src/agent/Core/Controller/InitializationAndShutdown.cpp +25 -60
- data/src/agent/Core/Controller/InternalUtils.cpp +0 -16
- data/src/agent/Core/Controller/Miscellaneous.cpp +0 -17
- data/src/agent/Core/Controller/Request.h +2 -0
- data/src/agent/Core/Controller/SendRequest.cpp +4 -4
- data/src/agent/Core/Controller/{StateInspectionAndConfiguration.cpp → StateInspection.cpp} +0 -22
- data/src/agent/Core/Controller/TurboCaching.h +11 -10
- data/src/agent/Core/CoreMain.cpp +16 -6
- data/src/agent/Core/ResponseCache.h +3 -3
- data/src/agent/Core/SpawningKit/SmartSpawner.h +9 -3
- data/src/agent/Core/SpawningKit/Spawner.h +7 -3
- data/src/agent/UstRouter/ApiServer.h +3 -2
- data/src/agent/UstRouter/Controller.h +66 -32
- data/src/agent/UstRouter/UstRouterMain.cpp +10 -2
- data/src/agent/Watchdog/ApiServer.h +3 -2
- data/src/agent/Watchdog/WatchdogMain.cpp +3 -1
- data/src/apache2_module/ConfigurationCommands.cpp +1 -1
- data/src/cxx_supportlib/ConfigKit/Common.h +125 -0
- data/src/cxx_supportlib/ConfigKit/ConfigKit.h +34 -0
- data/src/cxx_supportlib/ConfigKit/README.md +895 -0
- data/src/cxx_supportlib/ConfigKit/Schema.h +331 -0
- data/src/cxx_supportlib/ConfigKit/Store.h +385 -0
- data/src/cxx_supportlib/ConfigKit/TableTranslator.h +185 -0
- data/src/cxx_supportlib/ConfigKit/Utils.h +141 -0
- data/src/cxx_supportlib/ConfigKit/VariantMapUtils.h +81 -0
- data/src/cxx_supportlib/Constants.h +1 -1
- data/src/cxx_supportlib/Crypto.cpp +2 -2
- data/src/cxx_supportlib/Logging.h +0 -35
- data/src/cxx_supportlib/ServerKit/HttpServer.h +35 -16
- data/src/cxx_supportlib/ServerKit/Server.h +65 -25
- data/src/cxx_supportlib/oxt/macros.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/algorithm/string/replace.hpp +0 -2
- data/src/cxx_supportlib/vendor-modified/boost/array.hpp +53 -42
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/atomic_template.hpp +11 -5
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/bitwise_cast.hpp +13 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/caps_gcc_x86.hpp +23 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/caps_msvc_x86.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/config.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/interlocked.hpp +8 -1
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_emulated.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_alpha.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_arm.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_atomic.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_ppc.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_sparc.hpp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_sync.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_x86.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_x86_dcas.hpp +28 -17
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_linux_arm.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_msvc_arm.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_msvc_x86.hpp +9 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/platform.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/bind/arg.hpp +10 -3
- data/src/cxx_supportlib/vendor-modified/boost/bind/bind.hpp +90 -18
- data/src/cxx_supportlib/vendor-modified/boost/cerrno.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/chrono/duration.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/auto_link.hpp +8 -3
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/borland.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/clang.hpp +35 -6
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/codegear.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/comeau.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/common_edg.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/compaq_cxx.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/cray.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/digitalmars.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/gcc.hpp +19 -4
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/gcc_xml.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/greenhills.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/hp_acc.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/intel.hpp +29 -7
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/kai.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/metrowerks.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/mpw.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/nvcc.hpp +16 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/pathscale.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/pgi.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/sgi_mipspro.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/sunpro_cc.hpp +10 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/vacpp.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/visualc.hpp +44 -16
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/xlcpp.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/platform/cygwin.hpp +1 -2
- data/src/cxx_supportlib/vendor-modified/boost/config/platform/linux.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/select_compiler_config.hpp +21 -21
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/dinkumware.hpp +42 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libcomo.hpp +7 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libcpp.hpp +40 -7
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libstdcpp3.hpp +39 -6
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/modena.hpp +7 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/msl.hpp +7 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/roguewave.hpp +7 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/sgi.hpp +8 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/stlport.hpp +7 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/vacpp.hpp +7 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/suffix.hpp +33 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/adaptive_pool.hpp +0 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator.hpp +0 -3
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator_traits.hpp +34 -27
- data/src/cxx_supportlib/vendor-modified/boost/container/deque.hpp +62 -26
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/addressof.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/advanced_insert_int.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/compare_functors.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/config_begin.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/construct_in_place.hpp +39 -5
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/copy_move_algo.hpp +49 -32
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/dispatch_uses_allocator.hpp +175 -7
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/flat_tree.hpp +223 -98
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/is_sorted.hpp +57 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/iterators.hpp +88 -41
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/mpl.hpp +7 -8
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/mutex.hpp +4 -9
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/node_alloc_holder.hpp +45 -18
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/pair.hpp +205 -26
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/tree.hpp +290 -181
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/value_init.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/variadic_templates_tools.hpp +24 -19
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/workaround.hpp +38 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/flat_map.hpp +320 -46
- data/src/cxx_supportlib/vendor-modified/boost/container/flat_set.hpp +91 -18
- data/src/cxx_supportlib/vendor-modified/boost/container/list.hpp +23 -19
- data/src/cxx_supportlib/vendor-modified/boost/container/map.hpp +491 -120
- data/src/cxx_supportlib/vendor-modified/boost/container/new_allocator.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/node_allocator.hpp +0 -3
- data/src/cxx_supportlib/vendor-modified/boost/container/node_handle.hpp +399 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/deque.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/flat_map.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/flat_set.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/list.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/map.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/set.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/slist.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/small_vector.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/stable_vector.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/string.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/vector.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/set.hpp +101 -20
- data/src/cxx_supportlib/vendor-modified/boost/container/slist.hpp +19 -14
- data/src/cxx_supportlib/vendor-modified/boost/container/small_vector.hpp +117 -59
- data/src/cxx_supportlib/vendor-modified/boost/container/stable_vector.hpp +8 -6
- data/src/cxx_supportlib/vendor-modified/boost/container/static_vector.hpp +33 -28
- data/src/cxx_supportlib/vendor-modified/boost/container/string.hpp +414 -70
- data/src/cxx_supportlib/vendor-modified/boost/container/throw_exception.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/uses_allocator_fwd.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/vector.hpp +134 -117
- data/src/cxx_supportlib/vendor-modified/boost/core/addressof.hpp +202 -99
- data/src/cxx_supportlib/vendor-modified/boost/core/demangle.hpp +8 -10
- data/src/cxx_supportlib/vendor-modified/boost/core/lightweight_test.hpp +217 -1
- data/src/cxx_supportlib/vendor-modified/boost/core/scoped_enum.hpp +29 -27
- data/src/cxx_supportlib/vendor-modified/boost/current_function.hpp +5 -1
- data/src/cxx_supportlib/vendor-modified/boost/date_time/c_time.hpp +13 -13
- data/src/cxx_supportlib/vendor-modified/boost/date_time/constrained_value.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/date_time/date.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/date_time/date_duration.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/date_time/date_duration_types.hpp +6 -5
- data/src/cxx_supportlib/vendor-modified/boost/date_time/date_facet.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/date_time/date_names_put.hpp +8 -7
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_calendar.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_date.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_day.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_day_of_year.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_duration.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_duration_types.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_facet.hpp +27 -7
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_month.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_serialize.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_weekday.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian/greg_year.hpp +4 -5
- data/src/cxx_supportlib/vendor-modified/boost/date_time/gregorian_calendar.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/date_time/local_time/local_date_time.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/date_time/local_time/posix_time_zone.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/date_time/period.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/date_duration_operators.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/posix_time_config.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/posix_time_duration.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/ptime.hpp +6 -5
- data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/time_parsers.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/date_time/time_duration.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/date_time/time_facet.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/date_time/time_zone_base.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/date_time/year_month_day.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/detail/iterator.hpp +13 -0
- data/src/cxx_supportlib/vendor-modified/boost/detail/lcast_precision.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/detail/workaround.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/exception/detail/error_info_impl.hpp +11 -0
- data/src/cxx_supportlib/vendor-modified/boost/exception/detail/shared_ptr.hpp +17 -0
- data/src/cxx_supportlib/vendor-modified/boost/exception/exception.hpp +25 -3
- data/src/cxx_supportlib/vendor-modified/boost/exception/get_error_info.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/exception/info.hpp +114 -1
- data/src/cxx_supportlib/vendor-modified/boost/function/function_base.hpp +116 -142
- data/src/cxx_supportlib/vendor-modified/boost/function/function_template.hpp +57 -69
- data/src/cxx_supportlib/vendor-modified/boost/functional/hash/detail/hash_float.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/functional/hash/extensions.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/functional/hash/hash.hpp +27 -13
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/any_hook.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/avl_set.hpp +99 -12
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/avl_set_hook.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree.hpp +35 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree_algorithms.hpp +37 -6
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/bs_set.hpp +95 -8
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/bs_set_hook.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree.hpp +209 -72
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree_algorithms.hpp +86 -20
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_list_algorithms.hpp +11 -11
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_slist_algorithms.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/algo_type.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/any_node_and_algorithms.hpp +58 -45
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/avltree_node.hpp +27 -26
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/bstree_algorithms_base.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/common_slist_algorithms.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/config_begin.hpp +8 -3
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/default_header_holder.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/ebo_functor_holder.hpp +27 -26
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/equal_to_value.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/exception_disposer.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/generic_hook.hpp +9 -7
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/has_member_function_callable_with.hpp +83 -57
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hashtable_node.hpp +30 -30
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hook_traits.hpp +9 -8
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/iiterator.hpp +8 -7
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/iterator.hpp +16 -15
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/key_nodeptr_comp.hpp +70 -44
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/list_iterator.hpp +22 -21
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/list_node.hpp +7 -6
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/parent_from_member.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/rbtree_node.hpp +29 -28
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/reverse_iterator.hpp +33 -12
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/size_holder.hpp +19 -12
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/slist_iterator.hpp +21 -20
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/slist_node.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/to_raw_pointer.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/transform_iterator.hpp +23 -22
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/tree_iterator.hpp +23 -22
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/tree_node.hpp +10 -9
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/tree_value_compare.hpp +103 -29
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/workaround.hpp +15 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/hashtable.hpp +295 -211
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/linear_slist_algorithms.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/list.hpp +20 -7
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/list_hook.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/member_value_traits.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/options.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/parent_from_member.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_plus_bits.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_traits.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/priority_compare.hpp +22 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree.hpp +36 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree_algorithms.hpp +43 -13
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/set.hpp +95 -8
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/set_hook.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/sg_set.hpp +96 -12
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree.hpp +102 -5
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree_algorithms.hpp +48 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist.hpp +20 -11
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist_hook.hpp +9 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/splay_set.hpp +95 -8
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree.hpp +36 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree_algorithms.hpp +27 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap.hpp +167 -23
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_algorithms.hpp +28 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_set.hpp +100 -46
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/trivial_value_traits.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set.hpp +37 -27
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set_hook.hpp +30 -14
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_lexical_streams.hpp +35 -36
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_numeric.hpp +6 -28
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/try_lexical_convert.hpp +20 -5
- data/src/cxx_supportlib/vendor-modified/boost/libs/regex/src/posix_api.cpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/libs/regex/src/regex.cpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/libs/thread/src/pthread/once.cpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/libs/thread/src/pthread/thread.cpp +11 -7
- data/src/cxx_supportlib/vendor-modified/boost/math/policies/policy.hpp +1 -3
- data/src/cxx_supportlib/vendor-modified/boost/math/special_functions/fpclassify.hpp +5 -1
- data/src/cxx_supportlib/vendor-modified/boost/math/special_functions/math_fwd.hpp +11 -0
- data/src/cxx_supportlib/vendor-modified/boost/math/tools/config.hpp +10 -2
- data/src/cxx_supportlib/vendor-modified/boost/move/adl_move_swap.hpp +40 -7
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/adaptive_merge.hpp +67 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/adaptive_sort.hpp +63 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/detail/adaptive_sort_merge.hpp +2437 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/detail/basic_op.hpp +121 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/detail/insertion_sort.hpp +127 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/detail/merge.hpp +637 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/detail/merge_sort.hpp +139 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/algo/move.hpp +155 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/algorithm.hpp +1 -116
- data/src/cxx_supportlib/vendor-modified/boost/move/core.hpp +14 -13
- data/src/cxx_supportlib/vendor-modified/boost/move/default_delete.hpp +17 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/config_begin.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/destruct_n.hpp +67 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/fwd_macros.hpp +227 -32
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/iterator_traits.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/meta_utils.hpp +30 -9
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/meta_utils_core.hpp +12 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/move_helpers.hpp +84 -80
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/placement_new.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/reverse_iterator.hpp +171 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/type_traits.hpp +14 -20
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/unique_ptr_meta_utils.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/workaround.hpp +14 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/iterator.hpp +32 -33
- data/src/cxx_supportlib/vendor-modified/boost/move/make_unique.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/unique_ptr.hpp +49 -49
- data/src/cxx_supportlib/vendor-modified/boost/move/utility.hpp +8 -7
- data/src/cxx_supportlib/vendor-modified/boost/move/utility_core.hpp +17 -16
- data/src/cxx_supportlib/vendor-modified/boost/mpl/print.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/none.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/none_t.hpp +2 -3
- data/src/cxx_supportlib/vendor-modified/boost/operators.hpp +197 -255
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/old_optional_implementation.hpp +1059 -0
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/optional_aligned_storage.hpp +75 -0
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/optional_config.hpp +116 -0
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/optional_factory_support.hpp +36 -0
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/optional_reference_spec.hpp +253 -0
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/optional_relops.hpp +196 -0
- data/src/cxx_supportlib/vendor-modified/boost/optional/detail/optional_swap.hpp +117 -0
- data/src/cxx_supportlib/vendor-modified/boost/optional/optional.hpp +372 -554
- data/src/cxx_supportlib/vendor-modified/boost/optional/optional_fwd.hpp +12 -1
- data/src/cxx_supportlib/vendor-modified/boost/pool/detail/mutex.hpp +15 -7
- data/src/cxx_supportlib/vendor-modified/boost/pool/pool_alloc.hpp +24 -0
- data/src/cxx_supportlib/vendor-modified/boost/predef/compiler/intel.h +9 -2
- data/src/cxx_supportlib/vendor-modified/boost/predef/compiler/visualc.h +15 -1
- data/src/cxx_supportlib/vendor-modified/boost/predef/hardware/simd.h +16 -4
- data/src/cxx_supportlib/vendor-modified/boost/predef/hardware/simd/x86.h +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/predef/hardware/simd/x86_amd.h +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/predef/hardware/simd/x86_amd/versions.h +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/predef/os/cygwin.h +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/predef/version.h +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/predef/version_number.h +20 -1
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/cat.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/config/config.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/seq/detail/binary_transform.hpp +5 -6
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/seq/detail/to_list_msvc.hpp +55 -0
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/seq/to_list.hpp +12 -0
- data/src/cxx_supportlib/vendor-modified/boost/range/const_iterator.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/range/size_type.hpp +0 -5
- data/src/cxx_supportlib/vendor-modified/boost/regex/concepts.hpp +16 -16
- data/src/cxx_supportlib/vendor-modified/boost/regex/config.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/pending/unicode_iterator.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_creator.hpp +102 -87
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_parser.hpp +45 -21
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/cpp_regex_traits.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/fileiter.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/instances.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/match_flags.hpp +14 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/mem_block_cache.hpp +46 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher.hpp +5 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher_common.hpp +5 -14
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher_non_recursive.hpp +116 -13
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher_recursive.hpp +34 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_format.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_traits.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_traits_defaults.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_workaround.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/w32_regex_traits.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/allocate_shared_array.hpp +1004 -159
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/bad_weak_ptr.hpp +9 -0
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/atomic_count.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/shared_count.hpp +4 -58
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base.hpp +5 -2
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_clang.hpp +9 -0
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_impl.hpp +0 -8
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_has_sync.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_noexcept.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/spinlock.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/enable_shared_from_this.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/intrusive_ptr.hpp +28 -3
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/intrusive_ref_counter.hpp +187 -0
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/make_shared_array.hpp +52 -144
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/make_shared_object.hpp +120 -450
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/scoped_array.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/scoped_ptr.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/shared_array.hpp +7 -6
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/shared_ptr.hpp +70 -8
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/weak_ptr.hpp +6 -5
- data/src/cxx_supportlib/vendor-modified/boost/system/error_code.hpp +9 -8
- data/src/cxx_supportlib/vendor-modified/boost/system/system_error.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/thread/barrier.hpp +5 -4
- data/src/cxx_supportlib/vendor-modified/boost/thread/completion_latch.hpp +0 -1
- data/src/cxx_supportlib/vendor-modified/boost/thread/concurrent_queues/queue_views.hpp +0 -11
- data/src/cxx_supportlib/vendor-modified/boost/thread/concurrent_queues/sync_timed_queue.hpp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/thread/detail/config.hpp +11 -2
- data/src/cxx_supportlib/vendor-modified/boost/thread/detail/thread.hpp +11 -4
- data/src/cxx_supportlib/vendor-modified/boost/thread/exceptions.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/thread/executors/executor.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/thread/executors/generic_executor_ref.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/thread/executors/loop_executor.hpp +22 -18
- data/src/cxx_supportlib/vendor-modified/boost/thread/future.hpp +163 -55
- data/src/cxx_supportlib/vendor-modified/boost/thread/futures/launch.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/thread/futures/wait_for_all.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/thread/lock_types.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/thread/locks.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/condition_variable.hpp +6 -7
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/condition_variable_fwd.hpp +17 -2
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/shared_mutex.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/thread_data.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/thread/pthread/timespec.hpp +29 -0
- data/src/cxx_supportlib/vendor-modified/boost/thread/scoped_thread.hpp +23 -18
- data/src/cxx_supportlib/vendor-modified/boost/thread/synchronized_value.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/thread/thread_functors.hpp +19 -4
- data/src/cxx_supportlib/vendor-modified/boost/thread/thread_guard.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/thread/user_scheduler.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_index.hpp +265 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_index/stl_type_index.hpp +272 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_index/type_index_facade.hpp +300 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/add_reference.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/aligned_storage.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/common_type.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/common_arithmetic_type.hpp +9 -3
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/detail/mp_defer.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/extent.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_nothrow_assign.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_nothrow_constructor.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_nothrow_destructor.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_trivial_assign.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_trivial_copy.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_trivial_destructor.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_trivial_move_assign.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/has_trivial_move_constructor.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_abstract.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_array.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_assignable.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_const.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_default_constructible.hpp +21 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_destructible.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_nothrow_move_assignable.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_nothrow_move_constructible.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_pod.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_rvalue_reference.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_virtual_base_of.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_volatile.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/make_void.hpp +52 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/rank.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/remove_all_extents.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/remove_const.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/remove_cv.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/remove_extent.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/remove_pointer.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/remove_volatile.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/type_with_alignment.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/fwd.hpp +40 -6
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/implementation.hpp +4986 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/map.hpp +107 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/set.hpp +105 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_map.hpp +1814 -1255
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_map_fwd.hpp +41 -45
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_set.hpp +1498 -1161
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_set_fwd.hpp +40 -44
- data/src/cxx_supportlib/vendor-modified/boost/utility.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/utility/base_from_member.hpp +7 -6
- data/src/cxx_supportlib/vendor-modified/boost/utility/compare_pointees.hpp +10 -2
- data/src/cxx_supportlib/vendor-modified/boost/utility/string_ref.hpp +39 -22
- data/src/cxx_supportlib/vendor-modified/boost/utility/string_view.hpp +690 -0
- data/src/cxx_supportlib/vendor-modified/boost/utility/string_view_fwd.hpp +39 -0
- data/src/cxx_supportlib/vendor-modified/boost/version.hpp +2 -2
- data/src/helper-scripts/crash-watch.rb +3 -0
- data/src/ruby_supportlib/phusion_passenger.rb +1 -1
- data/src/ruby_supportlib/phusion_passenger/apache2/config_options.rb +1 -0
- data/src/ruby_supportlib/phusion_passenger/packaging.rb +2 -12
- metadata +77 -38
- data/dev/ci/inituidgid +0 -24
- data/dev/ci/run_jenkins.sh +0 -70
- data/dev/ci/run_travis.sh +0 -314
- data/doc/Design and Architecture.html +0 -2421
- data/doc/Design and Architecture.txt +0 -511
- data/doc/Security of user switching support.html +0 -1833
- data/doc/Users guide Apache.html +0 -3101
- data/doc/Users guide Apache.idmap.txt +0 -451
- data/doc/Users guide Apache.txt +0 -534
- data/doc/Users guide Nginx.html +0 -3026
- data/doc/Users guide Nginx.idmap.txt +0 -431
- data/doc/Users guide Nginx.txt +0 -451
- data/doc/Users guide Standalone.html +0 -2092
- data/doc/Users guide Standalone.idmap.txt +0 -137
- data/doc/Users guide Standalone.txt +0 -81
- data/doc/Users guide.html +0 -1606
- data/doc/Users guide.txt +0 -8
- data/src/cxx_supportlib/vendor-modified/boost/align/align.hpp +0 -20
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/address.hpp +0 -29
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/align.hpp +0 -40
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/align_cxx11.hpp +0 -22
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/is_alignment.hpp +0 -29
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/hash_table.hpp +0 -383
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/array_allocator.hpp +0 -318
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/array_count_impl.hpp +0 -67
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/array_traits.hpp +0 -60
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/array_utility.hpp +0 -214
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_if_array.hpp +0 -34
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/allocate.hpp +0 -1128
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/buckets.hpp +0 -928
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/equivalent.hpp +0 -686
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/extract_key.hpp +0 -188
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/table.hpp +0 -873
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/unique.hpp +0 -628
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/util.hpp +0 -266
@@ -34,5 +34,5 @@
|
|
34
34
|
#include <Core/Controller/InitializationAndShutdown.cpp>
|
35
35
|
#include <Core/Controller/InternalUtils.cpp>
|
36
36
|
#include <Core/Controller/Miscellaneous.cpp>
|
37
|
-
#include <Core/Controller/
|
37
|
+
#include <Core/Controller/StateInspection.cpp>
|
38
38
|
|
@@ -136,7 +136,7 @@ void
|
|
136
136
|
Controller::initializePoolOptions(Client *client, Request *req, RequestAnalysis &analysis) {
|
137
137
|
boost::shared_ptr<Options> *options;
|
138
138
|
|
139
|
-
if (singleAppMode) {
|
139
|
+
if (req->configCache->singleAppMode) {
|
140
140
|
P_ASSERT_EQ(poolOptionsCache.size(), 1);
|
141
141
|
poolOptionsCache.lookupRandom(NULL, &options);
|
142
142
|
req->options = **options;
|
@@ -177,42 +177,31 @@ Controller::initializePoolOptions(Client *client, Request *req, RequestAnalysis
|
|
177
177
|
}
|
178
178
|
|
179
179
|
void
|
180
|
-
Controller::
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
if (agentsOptions->has("meteor_app_settings")) {
|
189
|
-
options.meteorAppSettings = agentsOptions->get("meteor_app_settings");
|
190
|
-
}
|
191
|
-
if (agentsOptions->has("app_file_descriptor_ulimit")) {
|
192
|
-
options.fileDescriptorUlimit = agentsOptions->getUint("app_file_descriptor_ulimit");
|
193
|
-
}
|
180
|
+
Controller::fillPoolOptionsFromConfigCaches(Options &options,
|
181
|
+
const ControllerRequestConfigCachePtr &requestConfigCache)
|
182
|
+
{
|
183
|
+
options.ruby = requestConfigCache->defaultRuby;
|
184
|
+
options.nodejs = requestConfigCache->defaultNodejs;
|
185
|
+
options.python = requestConfigCache->defaultPython;
|
186
|
+
options.meteorAppSettings = requestConfigCache->meteorAppSettings;
|
187
|
+
options.fileDescriptorUlimit = requestConfigCache->fileDescriptorUlimit;
|
194
188
|
|
195
189
|
options.logLevel = getLogLevel();
|
196
|
-
options.integrationMode =
|
197
|
-
|
198
|
-
options.ustRouterAddress = ustRouterAddress;
|
190
|
+
options.integrationMode = mainConfigCache.integrationMode;
|
191
|
+
options.ustRouterAddress = requestConfigCache->ustRouterAddress;
|
199
192
|
options.ustRouterUsername = P_STATIC_STRING("logging");
|
200
|
-
options.ustRouterPassword = ustRouterPassword;
|
201
|
-
options.userSwitching =
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
|
206
|
-
|
207
|
-
|
208
|
-
options.
|
209
|
-
options.
|
210
|
-
options.
|
211
|
-
options.
|
212
|
-
options.forceMaxConcurrentRequestsPerProcess = agentsOptions->getInt("force_max_concurrent_requests_per_process");
|
213
|
-
options.spawnMethod = agentsOptions->get("spawn_method");
|
214
|
-
options.loadShellEnvvars = agentsOptions->getBool("load_shell_envvars");
|
215
|
-
options.statThrottleRate = statThrottleRate;
|
193
|
+
options.ustRouterPassword = requestConfigCache->ustRouterPassword;
|
194
|
+
options.userSwitching = mainConfigCache.userSwitching;
|
195
|
+
options.defaultUser = requestConfigCache->defaultUser;
|
196
|
+
options.defaultGroup = requestConfigCache->defaultGroup;
|
197
|
+
options.minProcesses = requestConfigCache->minInstances;
|
198
|
+
options.maxPreloaderIdleTime = requestConfigCache->maxPreloaderIdleTime;
|
199
|
+
options.maxRequestQueueSize = requestConfigCache->maxRequestQueueSize;
|
200
|
+
options.abortWebsocketsOnProcessShutdown = requestConfigCache->abortWebsocketsOnProcessShutdown;
|
201
|
+
options.forceMaxConcurrentRequestsPerProcess = requestConfigCache->forceMaxConcurrentRequestsPerProcess;
|
202
|
+
options.spawnMethod = requestConfigCache->spawnMethod;
|
203
|
+
options.loadShellEnvvars = requestConfigCache->loadShellEnvvars;
|
204
|
+
options.statThrottleRate = mainConfigCache.statThrottleRate;
|
216
205
|
|
217
206
|
/******************************/
|
218
207
|
}
|
@@ -344,7 +333,7 @@ Controller::createNewPoolOptions(Client *client, Request *req,
|
|
344
333
|
options.baseURI = StaticString(scriptName->start->data, scriptName->size);
|
345
334
|
}
|
346
335
|
|
347
|
-
|
336
|
+
fillPoolOptionsFromConfigCaches(options, req->configCache);
|
348
337
|
|
349
338
|
const LString *appType = secureHeaders.lookup("!~PASSENGER_APP_TYPE");
|
350
339
|
if (appType == NULL || appType->size == 0) {
|
@@ -457,7 +446,7 @@ Controller::getStickySessionCookieName(Request *req) {
|
|
457
446
|
const LString *value = req->headers.lookup(PASSENGER_STICKY_SESSIONS_COOKIE_NAME);
|
458
447
|
if (value == NULL || value->size == 0) {
|
459
448
|
return psg_lstr_create(req->pool,
|
460
|
-
defaultStickySessionsCookieName);
|
449
|
+
req->configCache->defaultStickySessionsCookieName);
|
461
450
|
} else {
|
462
451
|
return value;
|
463
452
|
}
|
@@ -482,15 +471,15 @@ Controller::onRequestBegin(Client *client, Request *req) {
|
|
482
471
|
// and localize them as much as possible, for better CPU caching.
|
483
472
|
RequestAnalysis analysis;
|
484
473
|
analysis.flags = req->secureHeaders.lookup(FLAGS);
|
485
|
-
analysis.appGroupNameCell = singleAppMode
|
474
|
+
analysis.appGroupNameCell = req->configCache->singleAppMode
|
486
475
|
? NULL
|
487
476
|
: req->secureHeaders.lookupCell(PASSENGER_APP_GROUP_NAME);
|
488
477
|
analysis.unionStationSupport = unionStationContext != NULL
|
489
478
|
&& getBoolOption(req, UNION_STATION_SUPPORT, false);
|
490
479
|
req->stickySession = getBoolOption(req, PASSENGER_STICKY_SESSIONS,
|
491
|
-
|
480
|
+
mainConfigCache.stickySessions);
|
492
481
|
req->showVersionInHeader = getBoolOption(req, PASSENGER_SHOW_VERSION_IN_HEADER,
|
493
|
-
|
482
|
+
req->configCache->showVersionInHeader);
|
494
483
|
req->host = req->headers.lookup(HTTP_HOST);
|
495
484
|
|
496
485
|
/***************/
|
@@ -45,20 +45,12 @@ using namespace boost;
|
|
45
45
|
****************************/
|
46
46
|
|
47
47
|
|
48
|
-
Controller::Controller(ServerKit::Context *context, const
|
49
|
-
|
50
|
-
: ParentClass(context),
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
benchmarkMode(parseBenchmarkMode(_agentsOptions->get("benchmark_mode", false))),
|
55
|
-
singleAppMode(false),
|
56
|
-
showVersionInHeader(_agentsOptions->getBool("show_version_in_header")),
|
57
|
-
stickySessions(_agentsOptions->getBool("sticky_sessions")),
|
58
|
-
gracefulExit(_agentsOptions->getBool("core_graceful_exit")),
|
59
|
-
|
60
|
-
agentsOptions(_agentsOptions),
|
61
|
-
stringPool(psg_create_pool(1024 * 4)),
|
48
|
+
Controller::Controller(ServerKit::Context *context, const ControllerSchema &schema,
|
49
|
+
const Json::Value &initialConfig)
|
50
|
+
: ParentClass(context, schema, initialConfig),
|
51
|
+
|
52
|
+
mainConfigCache(config),
|
53
|
+
requestConfigCache(new ControllerRequestConfigCache(config)),
|
62
54
|
poolOptionsCache(4),
|
63
55
|
|
64
56
|
PASSENGER_APP_GROUP_NAME("!~PASSENGER_APP_GROUP_NAME"),
|
@@ -83,52 +75,10 @@ Controller::Controller(ServerKit::Context *context, const VariantMap *_agentsOpt
|
|
83
75
|
HTTP_STATUS("status"),
|
84
76
|
HTTP_TRANSFER_ENCODING("transfer-encoding"),
|
85
77
|
|
86
|
-
|
87
|
-
|
78
|
+
turboCaching(),
|
79
|
+
resourceLocator(NULL)
|
80
|
+
/**************************/
|
88
81
|
{
|
89
|
-
defaultRuby = psg_pstrdup(stringPool,
|
90
|
-
agentsOptions->get("default_ruby"));
|
91
|
-
ustRouterAddress = psg_pstrdup(stringPool,
|
92
|
-
agentsOptions->get("ust_router_address", false));
|
93
|
-
ustRouterPassword = psg_pstrdup(stringPool,
|
94
|
-
agentsOptions->get("ust_router_password", false));
|
95
|
-
defaultUser = psg_pstrdup(stringPool,
|
96
|
-
agentsOptions->get("default_user", false));
|
97
|
-
defaultGroup = psg_pstrdup(stringPool,
|
98
|
-
agentsOptions->get("default_group", false));
|
99
|
-
defaultServerName = psg_pstrdup(stringPool,
|
100
|
-
agentsOptions->get("default_server_name"));
|
101
|
-
defaultServerPort = psg_pstrdup(stringPool,
|
102
|
-
agentsOptions->get("default_server_port"));
|
103
|
-
serverSoftware = psg_pstrdup(stringPool,
|
104
|
-
agentsOptions->get("server_software"));
|
105
|
-
defaultStickySessionsCookieName = psg_pstrdup(stringPool,
|
106
|
-
agentsOptions->get("sticky_sessions_cookie_name"));
|
107
|
-
|
108
|
-
if (agentsOptions->has("vary_turbocache_by_cookie")) {
|
109
|
-
defaultVaryTurbocacheByCookie = psg_pstrdup(stringPool,
|
110
|
-
agentsOptions->get("vary_turbocache_by_cookie"));
|
111
|
-
}
|
112
|
-
|
113
|
-
generateServerLogName(_threadNumber);
|
114
|
-
|
115
|
-
if (!agentsOptions->getBool("multi_app")) {
|
116
|
-
boost::shared_ptr<Options> options = boost::make_shared<Options>();
|
117
|
-
|
118
|
-
singleAppMode = true;
|
119
|
-
fillPoolOptionsFromAgentsOptions(*options);
|
120
|
-
|
121
|
-
options->appRoot = psg_pstrdup(stringPool,
|
122
|
-
agentsOptions->get("app_root"));
|
123
|
-
options->environment = psg_pstrdup(stringPool,
|
124
|
-
agentsOptions->get("environment"));
|
125
|
-
options->appType = psg_pstrdup(stringPool,
|
126
|
-
agentsOptions->get("app_type"));
|
127
|
-
options->startupFile = psg_pstrdup(stringPool,
|
128
|
-
agentsOptions->get("startup_file"));
|
129
|
-
poolOptionsCache.insert(options->getAppGroupName(), options);
|
130
|
-
}
|
131
|
-
|
132
82
|
ev_check_init(&checkWatcher, onEventLoopCheck);
|
133
83
|
ev_set_priority(&checkWatcher, EV_MAXPRI);
|
134
84
|
ev_check_start(getLoop(), &checkWatcher);
|
@@ -145,7 +95,6 @@ Controller::Controller(ServerKit::Context *context, const VariantMap *_agentsOpt
|
|
145
95
|
|
146
96
|
Controller::~Controller() {
|
147
97
|
ev_check_stop(getLoop(), &checkWatcher);
|
148
|
-
psg_destroy_pool(stringPool);
|
149
98
|
}
|
150
99
|
|
151
100
|
void
|
@@ -160,6 +109,22 @@ Controller::initialize() {
|
|
160
109
|
if (unionStationContext == NULL) {
|
161
110
|
unionStationContext = appPool->getUnionStationContext();
|
162
111
|
}
|
112
|
+
|
113
|
+
ParentClass::initialize();
|
114
|
+
turboCaching.initialize(config["turbocaching"].asBool());
|
115
|
+
getContext()->defaultFileBufferedChannelConfig.bufferDir =
|
116
|
+
config["data_buffer_dir"].asString();
|
117
|
+
|
118
|
+
if (requestConfigCache->singleAppMode) {
|
119
|
+
boost::shared_ptr<Options> options = boost::make_shared<Options>();
|
120
|
+
fillPoolOptionsFromConfigCaches(*options, requestConfigCache);
|
121
|
+
options->appRoot = config["app_root"].asString();
|
122
|
+
options->environment = config["environment"].asString();
|
123
|
+
options->appType = config["app_type"].asString();
|
124
|
+
options->startupFile = config["startup_file"].asString();
|
125
|
+
*options = options->copyAndPersist();
|
126
|
+
poolOptionsCache.insert(options->getAppGroupName(), options);
|
127
|
+
}
|
163
128
|
}
|
164
129
|
|
165
130
|
|
@@ -45,22 +45,6 @@ using namespace boost;
|
|
45
45
|
****************************/
|
46
46
|
|
47
47
|
|
48
|
-
TurboCaching<Request>::State
|
49
|
-
Controller::getTurboCachingInitialState(const VariantMap *agentsOptions) {
|
50
|
-
bool enabled = agentsOptions->getBool("turbocaching", false, true);
|
51
|
-
if (enabled) {
|
52
|
-
return TurboCaching<Request>::ENABLED;
|
53
|
-
} else {
|
54
|
-
return TurboCaching<Request>::DISABLED;
|
55
|
-
}
|
56
|
-
}
|
57
|
-
|
58
|
-
void
|
59
|
-
Controller::generateServerLogName(unsigned int number) {
|
60
|
-
string name = "ServerThr." + toString(number);
|
61
|
-
serverLogName = psg_pstrdup(stringPool, name);
|
62
|
-
}
|
63
|
-
|
64
48
|
void
|
65
49
|
Controller::disconnectWithClientSocketWriteError(Client **client, int e) {
|
66
50
|
stringstream message;
|
@@ -94,23 +94,6 @@ Controller::disconnectLongRunningConnections(const StaticString &gupid) {
|
|
94
94
|
}
|
95
95
|
}
|
96
96
|
|
97
|
-
Controller::BenchmarkMode
|
98
|
-
Controller::parseBenchmarkMode(const StaticString mode) {
|
99
|
-
if (mode.empty()) {
|
100
|
-
return BM_NONE;
|
101
|
-
} else if (mode == "after_accept") {
|
102
|
-
return BM_AFTER_ACCEPT;
|
103
|
-
} else if (mode == "before_checkout") {
|
104
|
-
return BM_BEFORE_CHECKOUT;
|
105
|
-
} else if (mode == "after_checkout") {
|
106
|
-
return BM_AFTER_CHECKOUT;
|
107
|
-
} else if (mode == "response_begin") {
|
108
|
-
return BM_RESPONSE_BEGIN;
|
109
|
-
} else {
|
110
|
-
return BM_UNKNOWN;
|
111
|
-
}
|
112
|
-
}
|
113
|
-
|
114
97
|
|
115
98
|
} // namespace Core
|
116
99
|
} // namespace Passenger
|
@@ -38,6 +38,7 @@
|
|
38
38
|
#include <Core/UnionStation/Context.h>
|
39
39
|
#include <Core/UnionStation/Transaction.h>
|
40
40
|
#include <Core/UnionStation/StopwatchLog.h>
|
41
|
+
#include <Core/Controller/Config.h>
|
41
42
|
#include <Core/Controller/AppResponse.h>
|
42
43
|
|
43
44
|
namespace Passenger {
|
@@ -85,6 +86,7 @@ public:
|
|
85
86
|
Options options;
|
86
87
|
AbstractSessionPtr session;
|
87
88
|
const LString *host;
|
89
|
+
ControllerRequestConfigCachePtr configCache;
|
88
90
|
|
89
91
|
ServerKit::FdSinkChannel appSink;
|
90
92
|
ServerKit::FdSourceChannel appSource;
|
@@ -393,8 +393,8 @@ Controller::determineHeaderSizeForSessionProtocol(Request *req,
|
|
393
393
|
}
|
394
394
|
}
|
395
395
|
} else {
|
396
|
-
state.serverName = defaultServerName;
|
397
|
-
state.serverPort = defaultServerPort;
|
396
|
+
state.serverName = req->configCache->defaultServerName;
|
397
|
+
state.serverPort = req->configCache->defaultServerPort;
|
398
398
|
}
|
399
399
|
|
400
400
|
dataSize += sizeof("SERVER_NAME");
|
@@ -404,7 +404,7 @@ Controller::determineHeaderSizeForSessionProtocol(Request *req,
|
|
404
404
|
dataSize += state.serverPort.size() + 1;
|
405
405
|
|
406
406
|
dataSize += sizeof("SERVER_SOFTWARE");
|
407
|
-
dataSize += serverSoftware.size() + 1;
|
407
|
+
dataSize += req->configCache->serverSoftware.size() + 1;
|
408
408
|
|
409
409
|
dataSize += sizeof("SERVER_PROTOCOL");
|
410
410
|
dataSize += sizeof("HTTP/1.1");
|
@@ -515,7 +515,7 @@ Controller::constructHeaderForSessionProtocol(Request *req, char * restrict buff
|
|
515
515
|
pos = appendData(pos, end, "", 1);
|
516
516
|
|
517
517
|
pos = appendData(pos, end, P_STATIC_STRING_WITH_NULL("SERVER_SOFTWARE"));
|
518
|
-
pos = appendData(pos, end, serverSoftware);
|
518
|
+
pos = appendData(pos, end, req->configCache->serverSoftware);
|
519
519
|
pos = appendData(pos, end, "", 1);
|
520
520
|
|
521
521
|
pos = appendData(pos, end, P_STATIC_STRING_WITH_NULL("SERVER_PROTOCOL"));
|
@@ -46,28 +46,6 @@ using namespace boost;
|
|
46
46
|
****************************/
|
47
47
|
|
48
48
|
|
49
|
-
Json::Value
|
50
|
-
Controller::getConfigAsJson() const {
|
51
|
-
Json::Value doc = ParentClass::getConfigAsJson();
|
52
|
-
doc["single_app_mode"] = singleAppMode;
|
53
|
-
doc["stat_throttle_rate"] = statThrottleRate;
|
54
|
-
doc["show_version_in_header"] = showVersionInHeader;
|
55
|
-
doc["data_buffer_dir"] = getContext()->defaultFileBufferedChannelConfig.bufferDir;
|
56
|
-
return doc;
|
57
|
-
}
|
58
|
-
|
59
|
-
void
|
60
|
-
Controller::configure(const Json::Value &doc) {
|
61
|
-
ParentClass::configure(doc);
|
62
|
-
if (doc.isMember("show_version_in_header")) {
|
63
|
-
showVersionInHeader = doc["show_version_in_header"].asBool();
|
64
|
-
}
|
65
|
-
if (doc.isMember("data_buffer_dir")) {
|
66
|
-
getContext()->defaultFileBufferedChannelConfig.bufferDir =
|
67
|
-
doc["data_buffer_dir"].asString();
|
68
|
-
}
|
69
|
-
}
|
70
|
-
|
71
49
|
Json::Value
|
72
50
|
Controller::inspectStateAsJson() const {
|
73
51
|
Json::Value doc = ParentClass::inspectStateAsJson();
|
@@ -113,7 +113,7 @@ private:
|
|
113
113
|
|
114
114
|
prep.ageValueSize = integerSizeInOtherBase<time_t, 10>(prep.age);
|
115
115
|
prep.contentLengthStrSize = uintSizeAsString(entry.body->httpBodySize);
|
116
|
-
prep.showVersionInHeader =
|
116
|
+
prep.showVersionInHeader = req->configCache->showVersionInHeader;
|
117
117
|
}
|
118
118
|
|
119
119
|
template<typename Server>
|
@@ -192,15 +192,16 @@ private:
|
|
192
192
|
public:
|
193
193
|
ResponseCache<Request> responseCache;
|
194
194
|
|
195
|
-
TurboCaching(
|
196
|
-
: state(
|
197
|
-
lastTimeout(
|
198
|
-
nextTimeout(
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
195
|
+
TurboCaching()
|
196
|
+
: state(ENABLED),
|
197
|
+
lastTimeout(0),
|
198
|
+
nextTimeout(0)
|
199
|
+
{ }
|
200
|
+
|
201
|
+
void initialize(bool initiallyEnabled) {
|
202
|
+
state = initiallyEnabled ? ENABLED : DISABLED;
|
203
|
+
lastTimeout = (ev_tstamp) time(NULL);
|
204
|
+
nextTimeout = (ev_tstamp) time(NULL) + ENABLED_TIMEOUT;
|
204
205
|
}
|
205
206
|
|
206
207
|
bool isEnabled() const {
|
data/src/agent/Core/CoreMain.cpp
CHANGED
@@ -76,6 +76,7 @@
|
|
76
76
|
#include <Constants.h>
|
77
77
|
#include <ServerKit/Server.h>
|
78
78
|
#include <ServerKit/AcceptLoadBalancer.h>
|
79
|
+
#include <ConfigKit/VariantMapUtils.h>
|
79
80
|
#include <MessageReadersWriters.h>
|
80
81
|
#include <FileDescriptor.h>
|
81
82
|
#include <ResourceLocator.h>
|
@@ -118,6 +119,7 @@ namespace Core {
|
|
118
119
|
struct ApiWorkingObjects {
|
119
120
|
BackgroundEventLoop *bgloop;
|
120
121
|
ServerKit::Context *serverKitContext;
|
122
|
+
ServerKit::HttpServerSchema apiServerSchema;
|
121
123
|
ApiServer::ApiServer *apiServer;
|
122
124
|
|
123
125
|
ApiWorkingObjects()
|
@@ -141,6 +143,7 @@ namespace Core {
|
|
141
143
|
PoolPtr appPool;
|
142
144
|
|
143
145
|
ServerKit::AcceptLoadBalancer<Controller> loadBalancer;
|
146
|
+
ControllerSchema controllerSchema;
|
144
147
|
vector<ThreadWorkingObjects> threadWorkingObjects;
|
145
148
|
struct ev_signal sigintWatcher;
|
146
149
|
struct ev_signal sigtermWatcher;
|
@@ -461,7 +464,7 @@ inspectControllerStateAsJson(Controller *controller, string *result) {
|
|
461
464
|
|
462
465
|
static void
|
463
466
|
inspectControllerConfigAsJson(Controller *controller, string *result) {
|
464
|
-
*result = controller->
|
467
|
+
*result = controller->inspectConfig().toStyledString();
|
465
468
|
}
|
466
469
|
|
467
470
|
static void
|
@@ -541,7 +544,7 @@ dumpDiagnosticsOnCrash(void *userData) {
|
|
541
544
|
for (i = 0; i < wo->threadWorkingObjects.size(); i++) {
|
542
545
|
ThreadWorkingObjects *two = &wo->threadWorkingObjects[i];
|
543
546
|
cerr << "### Request handler config (thread " << (i + 1) << ")\n";
|
544
|
-
cerr << two->controller->
|
547
|
+
cerr << two->controller->inspectConfig();
|
545
548
|
cerr << "\n";
|
546
549
|
cerr.flush();
|
547
550
|
}
|
@@ -672,6 +675,10 @@ initializeNonPrivilegedWorkingObjects() {
|
|
672
675
|
UPDATE_TRACE_POINT();
|
673
676
|
ThreadWorkingObjects two;
|
674
677
|
|
678
|
+
Json::Value config = ConfigKit::variantMapToJson(wo->controllerSchema,
|
679
|
+
*agentsOptions);
|
680
|
+
config["thread_number"] = i + 1;
|
681
|
+
|
675
682
|
if (i == 0) {
|
676
683
|
two.bgloop = firstLoop = new BackgroundEventLoop(true, true);
|
677
684
|
} else {
|
@@ -688,7 +695,8 @@ initializeNonPrivilegedWorkingObjects() {
|
|
688
695
|
options.getUint("file_buffer_threshold");
|
689
696
|
|
690
697
|
UPDATE_TRACE_POINT();
|
691
|
-
two.controller = new Core::Controller(two.serverKitContext,
|
698
|
+
two.controller = new Core::Controller(two.serverKitContext,
|
699
|
+
wo->controllerSchema, config);
|
692
700
|
two.controller->minSpareClients = 128;
|
693
701
|
two.controller->clientFreelistLimit = 1024;
|
694
702
|
two.controller->resourceLocator = &wo->resourceLocator;
|
@@ -724,7 +732,8 @@ initializeNonPrivilegedWorkingObjects() {
|
|
724
732
|
options.getUint("file_buffer_threshold");
|
725
733
|
|
726
734
|
UPDATE_TRACE_POINT();
|
727
|
-
awo->apiServer = new Core::ApiServer::ApiServer(awo->serverKitContext
|
735
|
+
awo->apiServer = new Core::ApiServer::ApiServer(awo->serverKitContext,
|
736
|
+
awo->apiServerSchema);
|
728
737
|
awo->apiServer->controllers.reserve(wo->threadWorkingObjects.size());
|
729
738
|
for (unsigned int i = 0; i < wo->threadWorkingObjects.size(); i++) {
|
730
739
|
awo->apiServer->controllers.push_back(
|
@@ -736,6 +745,7 @@ initializeNonPrivilegedWorkingObjects() {
|
|
736
745
|
awo->apiServer->fdPassingPassword = options.get("watchdog_fd_passing_password", false);
|
737
746
|
awo->apiServer->exitEvent = &wo->exitEvent;
|
738
747
|
awo->apiServer->shutdownFinishCallback = apiServerShutdownFinished;
|
748
|
+
awo->apiServer->initialize();
|
739
749
|
|
740
750
|
wo->shutdownCounter.fetch_add(1, boost::memory_order_relaxed);
|
741
751
|
}
|
@@ -1305,8 +1315,8 @@ sanityCheckOptions() {
|
|
1305
1315
|
ok = false;
|
1306
1316
|
#endif
|
1307
1317
|
}
|
1308
|
-
if (Core::
|
1309
|
-
== Core::
|
1318
|
+
if (Core::parseControllerBenchmarkMode(options.get("benchmark_mode", false))
|
1319
|
+
== Core::BM_UNKNOWN)
|
1310
1320
|
{
|
1311
1321
|
fprintf(stderr, "ERROR: '%s' is not a valid mode for --benchmark.\n",
|
1312
1322
|
options.get("benchmark_mode", false).c_str());
|