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
@@ -0,0 +1,24 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -eo pipefail
|
3
|
+
|
4
|
+
SELFDIR=$(dirname "$0")
|
5
|
+
SELFDIR=$(cd "$SELFDIR" && pwd)
|
6
|
+
PASSENGER_ROOT=$(cd "$SELFDIR/../.." && pwd)
|
7
|
+
# shellcheck source=lib/functions.sh
|
8
|
+
source "$SELFDIR/lib/functions.sh"
|
9
|
+
cd "$PASSENGER_ROOT"
|
10
|
+
|
11
|
+
autodetect_environment
|
12
|
+
sanity_check_environment
|
13
|
+
echo
|
14
|
+
|
15
|
+
if [[ "$OS" != macos ]]; then
|
16
|
+
echo "ERROR: this script can only be run on macOS." >&2
|
17
|
+
exit 1
|
18
|
+
fi
|
19
|
+
|
20
|
+
security unlock-keychain -p `cat ~/.password` ~/Library/Keychains/login.keychain
|
21
|
+
|
22
|
+
export CI_COMMAND="./dev/ci/run-tests-natively $*"
|
23
|
+
exec "$PASSENGER_ROOT/dev/ci/scripts/debug-console-wrapper.sh" \
|
24
|
+
"$PASSENGER_ROOT/dev/ci/scripts/run-tests-natively-stage2.sh" "$@"
|
@@ -0,0 +1,42 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -eo pipefail
|
3
|
+
|
4
|
+
SELFDIR=$(dirname "$0")
|
5
|
+
SELFDIR=$(cd "$SELFDIR" && pwd)
|
6
|
+
PASSENGER_ROOT=$(cd "$SELFDIR/../.." && pwd)
|
7
|
+
# shellcheck source=lib/functions.sh
|
8
|
+
source "$SELFDIR/lib/functions.sh"
|
9
|
+
cd "$PASSENGER_ROOT"
|
10
|
+
|
11
|
+
autodetect_environment
|
12
|
+
sanity_check_environment
|
13
|
+
echo
|
14
|
+
|
15
|
+
if [[ "$OS" != linux ]]; then
|
16
|
+
echo "ERROR: this script can only be run on Linux." >&2
|
17
|
+
exit 1
|
18
|
+
fi
|
19
|
+
|
20
|
+
if tty -s; then
|
21
|
+
TTY_ARGS='-t -i'
|
22
|
+
else
|
23
|
+
TTY_ARGS=
|
24
|
+
fi
|
25
|
+
|
26
|
+
run_exec docker run --rm $TTY_ARGS \
|
27
|
+
-v "$PASSENGER_ROOT:/passenger" \
|
28
|
+
-v "$CACHE_DIR:/passenger/.ci_cache" \
|
29
|
+
-e "APP_UID=$(id -u)" \
|
30
|
+
-e "APP_GID=$(id -g)" \
|
31
|
+
-e "TRAP_DEBUG_CONSOLE=$TRAP_DEBUG_CONSOLE" \
|
32
|
+
-e "TEST_RUBY_VERSION=$TEST_RUBY_VERSION" \
|
33
|
+
-e "COMPILE_CONCURRENCY=$COMPILE_CONCURRENCY" \
|
34
|
+
-e "SUDO=$SUDO" \
|
35
|
+
phusion/passenger-ci-docker-env:1.0.0 \
|
36
|
+
/sbin/my_init --skip-runit --skip-startup-files --quiet -- \
|
37
|
+
/passenger/dev/ci/scripts/inituidgid \
|
38
|
+
/sbin/setuser app \
|
39
|
+
/bin/bash -lc 'cd /passenger && exec "$@"' \
|
40
|
+
./dev/ci/scripts/docker-entrypoint.sh \
|
41
|
+
./dev/ci/scripts/docker-entrypoint.sh \
|
42
|
+
"$@"
|
@@ -0,0 +1,27 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -eo pipefail
|
3
|
+
|
4
|
+
SELFDIR=$(dirname "$0")
|
5
|
+
SELFDIR=$(cd "$SELFDIR" && pwd)
|
6
|
+
PASSENGER_ROOT=$(cd "$SELFDIR/../../.." && pwd)
|
7
|
+
# shellcheck source=lib/functions.sh
|
8
|
+
source "$SELFDIR/../lib/functions.sh"
|
9
|
+
|
10
|
+
if ! "$@"; then
|
11
|
+
echo
|
12
|
+
echo "-----------------------------"
|
13
|
+
echo
|
14
|
+
echo "*** An error occurred ***"
|
15
|
+
if [[ "$DEBUG_CONSOLE" == 1 ]]; then
|
16
|
+
echo "DEBUG_CONSOLE set to 1, so launching a debugging console..."
|
17
|
+
echo
|
18
|
+
# shellcheck source=../lib/set-container-envvars.sh
|
19
|
+
set +e
|
20
|
+
source "$PASSENGER_ROOT/dev/ci/lib/set-container-envvars.sh"
|
21
|
+
header2 "Launching bash"
|
22
|
+
bash -l
|
23
|
+
else
|
24
|
+
echo "If you want to debug this, run '$CI_COMMAND' with the environment variable DEBUG_CONSOLE=1."
|
25
|
+
fi
|
26
|
+
exit 1
|
27
|
+
fi
|
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -eo pipefail
|
3
|
+
|
4
|
+
SELFDIR=/passenger/dev/ci/scripts
|
5
|
+
PASSENGER_ROOT=/passenger
|
6
|
+
# shellcheck source=../lib/functions.sh
|
7
|
+
source "$SELFDIR/../lib/functions.sh"
|
8
|
+
|
9
|
+
# shellcheck source=../lib/setup-container.sh
|
10
|
+
source "$PASSENGER_ROOT/dev/ci/lib/setup-container.sh"
|
11
|
+
add_bundler_path_to_gem_path
|
12
|
+
echo
|
13
|
+
echo
|
14
|
+
|
15
|
+
header "Running test suite: $1"
|
16
|
+
# shellcheck source=/dev/null
|
17
|
+
source "$PASSENGER_ROOT/dev/ci/tests/$1/run"
|
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -eo pipefail
|
3
|
+
|
4
|
+
SELFDIR=/passenger/dev/ci/scripts
|
5
|
+
PASSENGER_ROOT=/passenger
|
6
|
+
# shellcheck source=../lib/functions.sh
|
7
|
+
source "$SELFDIR/../lib/functions.sh"
|
8
|
+
cd "$PASSENGER_ROOT"
|
9
|
+
|
10
|
+
header "Inside Docker container"
|
11
|
+
|
12
|
+
autodetect_environment
|
13
|
+
echo
|
14
|
+
|
15
|
+
export CI_COMMAND="./dev/ci/run-tests-with-docker $*"
|
16
|
+
exec "$PASSENGER_ROOT/dev/ci/scripts/debug-console-wrapper.sh" \
|
17
|
+
"$PASSENGER_ROOT/dev/ci/scripts/docker-entrypoint-stage2.sh" "$@"
|
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -e
|
3
|
+
|
4
|
+
chown -R "$APP_UID:$APP_GID" /home/app
|
5
|
+
groupmod -g "$APP_GID" app
|
6
|
+
usermod -u "$APP_UID" -g "$APP_GID" app
|
7
|
+
|
8
|
+
# There's something strange with either Docker or the kernel, so that
|
9
|
+
# the 'app' user cannot access its home directory even after a proper
|
10
|
+
# chown/chmod. We work around it like this.
|
11
|
+
mv /home/app /home/app2
|
12
|
+
cp -dpR /home/app2 /home/app
|
13
|
+
rm -rf /home/app2
|
14
|
+
|
15
|
+
if [[ $# -gt 0 ]]; then
|
16
|
+
exec "$@"
|
17
|
+
fi
|
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -eo pipefail
|
3
|
+
|
4
|
+
SELFDIR=$(dirname "$0")
|
5
|
+
SELFDIR=$(cd "$SELFDIR" && pwd)
|
6
|
+
PASSENGER_ROOT=$(cd "$SELFDIR/../../.." && pwd)
|
7
|
+
# shellcheck source=lib/functions.sh
|
8
|
+
source "$SELFDIR/../lib/functions.sh"
|
9
|
+
|
10
|
+
# shellcheck source=lib/set-container-envvars.sh
|
11
|
+
source "$SELFDIR/../lib/set-container-envvars.sh"
|
12
|
+
add_bundler_path_to_gem_path
|
13
|
+
echo
|
14
|
+
|
15
|
+
header "Running test suite: $1"
|
16
|
+
# shellcheck source=/dev/null
|
17
|
+
source "$PASSENGER_ROOT/dev/ci/tests/$1/run"
|
@@ -0,0 +1,11 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -eo pipefail
|
3
|
+
|
4
|
+
SELFDIR=$(dirname "$0")
|
5
|
+
SELFDIR=$(cd "$SELFDIR" && pwd)
|
6
|
+
PASSENGER_ROOT=$(cd "$SELFDIR/../../.." && pwd)
|
7
|
+
# shellcheck source=../lib/functions.sh
|
8
|
+
source "$SELFDIR/../lib/functions.sh"
|
9
|
+
|
10
|
+
# shellcheck source=../lib/setup-container.sh
|
11
|
+
source "$PASSENGER_ROOT/dev/ci/lib/setup-container.sh"
|
data/dev/ci/setup-host
ADDED
@@ -0,0 +1,50 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -eo pipefail
|
3
|
+
|
4
|
+
SELFDIR=$(dirname "$0")
|
5
|
+
SELFDIR=$(cd "$SELFDIR" && pwd)
|
6
|
+
PASSENGER_ROOT=$(cd "$SELFDIR/../.." && pwd)
|
7
|
+
# shellcheck source=lib/functions.sh
|
8
|
+
source "$SELFDIR/lib/functions.sh"
|
9
|
+
cd "$PASSENGER_ROOT"
|
10
|
+
|
11
|
+
header "Setting up stuff on the host"
|
12
|
+
|
13
|
+
autodetect_environment
|
14
|
+
sanity_check_environment
|
15
|
+
echo
|
16
|
+
|
17
|
+
if [[ "$OS" = macos && "$1" = "" ]]; then
|
18
|
+
echo "Usage: ./dev/ci/setup-host <TEST NAME>" >&2
|
19
|
+
exit 1
|
20
|
+
fi
|
21
|
+
|
22
|
+
if $IN_JENKINS; then
|
23
|
+
# Relax permissions. Necessary for unit tests which test permissions.
|
24
|
+
header2 "Relaxing file permissions"
|
25
|
+
echo "+ Setting umask"
|
26
|
+
umask u=rwx,g=rx,o=rx
|
27
|
+
run chmod g+rx,o+rx .
|
28
|
+
echo "+ chmodding files"
|
29
|
+
find ./* -type f -print0 | xargs -0 -n 512 chmod g+r,o+r
|
30
|
+
echo "+ chmodding directories"
|
31
|
+
find ./* -type d -print0 | xargs -0 -n 512 chmod g+rx,o+rx
|
32
|
+
|
33
|
+
# Create this file now because otherwise it would be owned by root,
|
34
|
+
# which Jenkins cannot remove.
|
35
|
+
run touch test/test.log
|
36
|
+
|
37
|
+
echo
|
38
|
+
fi
|
39
|
+
|
40
|
+
header2 "Creating cache directories"
|
41
|
+
run mkdir -p "$CACHE_DIR"
|
42
|
+
run mkdir -p "$CACHE_DIR/bundle"
|
43
|
+
run mkdir -p "$CACHE_DIR/ccache"
|
44
|
+
echo
|
45
|
+
|
46
|
+
if [[ "$OS" = macos ]]; then
|
47
|
+
export CI_COMMAND="./dev/ci/setup-host $*"
|
48
|
+
exec "$PASSENGER_ROOT/dev/ci/scripts/debug-console-wrapper.sh" \
|
49
|
+
"$PASSENGER_ROOT/dev/ci/scripts/setup-host-natively.sh" "$@"
|
50
|
+
fi
|
@@ -0,0 +1,20 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
set -e
|
3
|
+
|
4
|
+
TEST_DYNAMIC_WITH_NGINX_VERSION=1.9.15
|
5
|
+
NGINX_ADDON_DIR=$(./bin/passenger-config --nginx-addon-dir)
|
6
|
+
echo "+ Nginx addon dir: $NGINX_ADDON_DIR"
|
7
|
+
echo
|
8
|
+
|
9
|
+
header2 "Compliing Passenger"
|
10
|
+
run drake "-j$COMPILE_CONCURRENCY" nginx:as_dynamic_module
|
11
|
+
echo
|
12
|
+
|
13
|
+
header2 "Downloading and compiling Nginx"
|
14
|
+
cd buildout
|
15
|
+
run curl -sSLO https://www.nginx.org/download/nginx-$TEST_DYNAMIC_WITH_NGINX_VERSION.tar.gz
|
16
|
+
run tar -xzf nginx-$TEST_DYNAMIC_WITH_NGINX_VERSION.tar.gz
|
17
|
+
echo "+ Entering nginx-$TEST_DYNAMIC_WITH_NGINX_VERSION"
|
18
|
+
cd "nginx-$TEST_DYNAMIC_WITH_NGINX_VERSION"
|
19
|
+
run ./configure --with-cc='ccache cc' --add-dynamic-module="$NGINX_ADDON_DIR"
|
20
|
+
run make "-j$COMPILE_CONCURRENCY"
|
data/dev/copy_boost_headers
CHANGED
@@ -83,6 +83,7 @@ PROGRAM_SOURCE = %q{
|
|
83
83
|
#include <boost/make_shared.hpp>
|
84
84
|
#include <boost/enable_shared_from_this.hpp>
|
85
85
|
#include <boost/intrusive_ptr.hpp>
|
86
|
+
#include <boost/smart_ptr/intrusive_ref_counter.hpp>
|
86
87
|
#include <boost/thread.hpp>
|
87
88
|
#include <boost/noncopyable.hpp>
|
88
89
|
#include <boost/function.hpp>
|
@@ -203,8 +204,13 @@ def copy_dependencies(cflags)
|
|
203
204
|
end
|
204
205
|
|
205
206
|
def start
|
206
|
-
if BOOST_DIR.nil? || BOOST_DIR.empty?
|
207
|
-
puts "Usage:
|
207
|
+
if BOOST_DIR.nil? || BOOST_DIR.empty? || BOOST_DIR == "--help"
|
208
|
+
puts "Usage:"
|
209
|
+
puts "Remove the src/cxx_supportlib/vendor-modified/boost directory,"
|
210
|
+
puts "then call: copy_boost_headers <boost source directory>"
|
211
|
+
puts "then reapply patches to boost source files,"
|
212
|
+
puts "they are kept in dev/boost-patches and can be applied by:"
|
213
|
+
puts "patch -p1 < dev/boost-patches/000*-Patch-Name.patch"
|
208
214
|
exit 1
|
209
215
|
end
|
210
216
|
begin
|
data/src/agent/Core/ApiServer.h
CHANGED
@@ -460,7 +460,7 @@ private:
|
|
460
460
|
void processConfig_getControllerConfig(Client *client, Request *req,
|
461
461
|
Controller *controller)
|
462
462
|
{
|
463
|
-
Json::Value config = controller->
|
463
|
+
Json::Value config = controller->inspectConfig();
|
464
464
|
getContext()->libev->runLater(boost::bind(
|
465
465
|
&ApiServer::processConfig_controllerConfigGathered, this,
|
466
466
|
client, req, controller, config));
|
@@ -497,8 +497,13 @@ private:
|
|
497
497
|
unrefRequest(req, __FILE__, __LINE__);
|
498
498
|
}
|
499
499
|
|
500
|
-
static void configureController(Controller *controller, Json::Value
|
501
|
-
|
500
|
+
static void configureController(Controller *controller, Json::Value updates) {
|
501
|
+
vector<ConfigKit::Error> errors;
|
502
|
+
if (!controller->configure(updates, errors)) {
|
503
|
+
P_ERROR("Unable to apply configuration change to Core controller.\n"
|
504
|
+
"Configuration: " << updates.toStyledString() << "\n"
|
505
|
+
"Errors: " << toString(errors));
|
506
|
+
}
|
502
507
|
}
|
503
508
|
|
504
509
|
void processConfigBody(Client *client, Request *req) {
|
@@ -646,8 +651,9 @@ public:
|
|
646
651
|
EventFd *exitEvent;
|
647
652
|
vector<Authorization> authorizations;
|
648
653
|
|
649
|
-
ApiServer(ServerKit::Context *context
|
650
|
-
|
654
|
+
ApiServer(ServerKit::Context *context, const ServerKit::HttpServerSchema &schema,
|
655
|
+
const Json::Value &initialConfig = Json::Value())
|
656
|
+
: ParentClass(context, schema, initialConfig),
|
651
657
|
serverConnectionPath("^/server/(.+)\\.json$"),
|
652
658
|
apiAccountDatabase(NULL),
|
653
659
|
exitEvent(NULL)
|
data/src/agent/Core/Controller.h
CHANGED
@@ -32,7 +32,7 @@
|
|
32
32
|
|
33
33
|
#define CC_BENCHMARK_POINT(client, req, value) \
|
34
34
|
do { \
|
35
|
-
if (OXT_UNLIKELY(benchmarkMode == value)) { \
|
35
|
+
if (OXT_UNLIKELY(mainConfigCache.benchmarkMode == value)) { \
|
36
36
|
writeBenchmarkResponse(&client, &req); \
|
37
37
|
return; \
|
38
38
|
} \
|
@@ -64,6 +64,7 @@
|
|
64
64
|
#include <Logging.h>
|
65
65
|
#include <MessageReadersWriters.h>
|
66
66
|
#include <Constants.h>
|
67
|
+
#include <ConfigKit/ConfigKit.h>
|
67
68
|
#include <ServerKit/Errors.h>
|
68
69
|
#include <ServerKit/HttpServer.h>
|
69
70
|
#include <ServerKit/HttpHeaderParser.h>
|
@@ -76,9 +77,9 @@
|
|
76
77
|
#include <Utils/IOUtils.h>
|
77
78
|
#include <Utils/JsonUtils.h>
|
78
79
|
#include <Utils/HttpConstants.h>
|
79
|
-
#include <Utils/VariantMap.h>
|
80
80
|
#include <Utils/Timer.h>
|
81
81
|
#include <Core/ApplicationPool/ErrorRenderer.h>
|
82
|
+
#include <Core/Controller/Config.h>
|
82
83
|
#include <Core/Controller/Client.h>
|
83
84
|
#include <Core/Controller/AppResponse.h>
|
84
85
|
#include <Core/Controller/TurboCaching.h>
|
@@ -101,16 +102,6 @@ namespace Core {
|
|
101
102
|
|
102
103
|
|
103
104
|
class Controller: public ServerKit::HttpServer<Controller, Client> {
|
104
|
-
public:
|
105
|
-
enum BenchmarkMode {
|
106
|
-
BM_NONE,
|
107
|
-
BM_AFTER_ACCEPT,
|
108
|
-
BM_BEFORE_CHECKOUT,
|
109
|
-
BM_AFTER_CHECKOUT,
|
110
|
-
BM_RESPONSE_BEGIN,
|
111
|
-
BM_UNKNOWN
|
112
|
-
};
|
113
|
-
|
114
105
|
private:
|
115
106
|
typedef ServerKit::HttpServer<Controller, Client> ParentClass;
|
116
107
|
typedef ServerKit::Channel Channel;
|
@@ -123,29 +114,10 @@ private:
|
|
123
114
|
// has enough bits.
|
124
115
|
static const unsigned int MAX_SESSION_CHECKOUT_TRY = 10;
|
125
116
|
|
126
|
-
|
127
|
-
|
128
|
-
BenchmarkMode benchmarkMode: 3;
|
129
|
-
bool singleAppMode: 1;
|
130
|
-
bool showVersionInHeader: 1;
|
131
|
-
bool stickySessions: 1;
|
132
|
-
bool gracefulExit: 1;
|
133
|
-
|
134
|
-
const VariantMap *agentsOptions;
|
135
|
-
psg_pool_t *stringPool;
|
117
|
+
ControllerMainConfigCache mainConfigCache;
|
118
|
+
ControllerRequestConfigCachePtr requestConfigCache;
|
136
119
|
StringKeyTable< boost::shared_ptr<Options> > poolOptionsCache;
|
137
120
|
|
138
|
-
StaticString defaultRuby;
|
139
|
-
StaticString ustRouterAddress;
|
140
|
-
StaticString ustRouterPassword;
|
141
|
-
StaticString defaultUser;
|
142
|
-
StaticString defaultGroup;
|
143
|
-
StaticString defaultServerName;
|
144
|
-
StaticString defaultServerPort;
|
145
|
-
StaticString serverSoftware;
|
146
|
-
StaticString defaultStickySessionsCookieName;
|
147
|
-
StaticString defaultVaryTurbocacheByCookie;
|
148
|
-
|
149
121
|
HashedStaticString PASSENGER_APP_GROUP_NAME;
|
150
122
|
HashedStaticString PASSENGER_ENV_VARS;
|
151
123
|
HashedStaticString PASSENGER_MAX_REQUESTS;
|
@@ -168,9 +140,6 @@ private:
|
|
168
140
|
HashedStaticString HTTP_STATUS;
|
169
141
|
HashedStaticString HTTP_TRANSFER_ENCODING;
|
170
142
|
|
171
|
-
unsigned int threadNumber;
|
172
|
-
StaticString serverLogName;
|
173
|
-
|
174
143
|
friend class TurboCaching<Request>;
|
175
144
|
friend class ResponseCache<Request>;
|
176
145
|
struct ev_check checkWatcher;
|
@@ -189,7 +158,8 @@ private:
|
|
189
158
|
void initializeFlags(Client *client, Request *req, RequestAnalysis &analysis);
|
190
159
|
bool respondFromTurboCache(Client *client, Request *req);
|
191
160
|
void initializePoolOptions(Client *client, Request *req, RequestAnalysis &analysis);
|
192
|
-
void
|
161
|
+
void fillPoolOptionsFromConfigCaches(Options &options,
|
162
|
+
const ControllerRequestConfigCachePtr &requestConfigCache);
|
193
163
|
static void fillPoolOption(Request *req, StaticString &field,
|
194
164
|
const HashedStaticString &name);
|
195
165
|
static void fillPoolOption(Request *req, int &field,
|
@@ -332,9 +302,6 @@ private:
|
|
332
302
|
|
333
303
|
/****** Internal utility functions ******/
|
334
304
|
|
335
|
-
static TurboCaching<Request>::State getTurboCachingInitialState(
|
336
|
-
const VariantMap *agentsOptions);
|
337
|
-
void generateServerLogName(unsigned int number);
|
338
305
|
void disconnectWithClientSocketWriteError(Client **client, int e);
|
339
306
|
void disconnectWithAppSocketIncompleteResponseError(Client **client);
|
340
307
|
void disconnectWithAppSocketReadError(Client **client, int e);
|
@@ -383,6 +350,7 @@ protected:
|
|
383
350
|
virtual void onNextRequestEarlyReadError(Client *client, Request *req, int errcode);
|
384
351
|
virtual bool shouldDisconnectClientOnShutdown(Client *client);
|
385
352
|
virtual bool supportsUpgrade(Client *client, Request *req);
|
353
|
+
virtual void onConfigChange(const ConfigKit::Store *oldConfig);
|
386
354
|
|
387
355
|
|
388
356
|
/****** Marked virtual so that unit tests can mock these ******/
|
@@ -392,6 +360,7 @@ protected:
|
|
392
360
|
|
393
361
|
|
394
362
|
public:
|
363
|
+
// Dependencies
|
395
364
|
ResourceLocator *resourceLocator;
|
396
365
|
PoolPtr appPool;
|
397
366
|
UnionStation::ContextPtr unionStationContext;
|
@@ -399,10 +368,10 @@ public:
|
|
399
368
|
|
400
369
|
/****** Initialization and shutdown ******/
|
401
370
|
|
402
|
-
Controller(ServerKit::Context *context, const
|
403
|
-
|
371
|
+
Controller(ServerKit::Context *context, const ControllerSchema &schema,
|
372
|
+
const Json::Value &initialConfig);
|
404
373
|
virtual ~Controller();
|
405
|
-
void initialize();
|
374
|
+
virtual void initialize();
|
406
375
|
|
407
376
|
|
408
377
|
/****** Hooks ******/
|
@@ -413,8 +382,6 @@ public:
|
|
413
382
|
|
414
383
|
/****** State inspection and configuration ******/
|
415
384
|
|
416
|
-
virtual Json::Value getConfigAsJson() const;
|
417
|
-
virtual void configure(const Json::Value &doc);
|
418
385
|
virtual Json::Value inspectStateAsJson() const;
|
419
386
|
virtual Json::Value inspectClientStateAsJson(const Client *client) const;
|
420
387
|
virtual Json::Value inspectRequestStateAsJson(const Request *req) const;
|
@@ -422,7 +389,6 @@ public:
|
|
422
389
|
|
423
390
|
/****** Miscellaneous *******/
|
424
391
|
|
425
|
-
static BenchmarkMode parseBenchmarkMode(const StaticString mode);
|
426
392
|
void disconnectLongRunningConnections(const StaticString &gupid);
|
427
393
|
};
|
428
394
|
|