passenger 6.0.11 → 6.0.12
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG +24 -1
- data/CONTRIBUTORS +3 -0
- data/src/agent/Core/Config.h +1 -1
- data/src/agent/Core/Controller/CheckoutSession.cpp +24 -13
- data/src/agent/Core/Controller/Config.h +1 -1
- data/src/agent/Core/Controller/InternalUtils.cpp +32 -6
- data/src/agent/Core/Controller.h +4 -1
- data/src/agent/Watchdog/Config.h +1 -1
- data/src/cxx_supportlib/Constants.h +1 -1
- data/src/cxx_supportlib/IOTools/IOUtils.cpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/align/aligned_alloc.hpp +47 -0
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/aligned_alloc_posix.hpp +41 -0
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/is_alignment.hpp +28 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/associated_allocator.hpp +53 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/associated_cancellation_slot.hpp +179 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/associated_executor.hpp +57 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/associator.hpp +37 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/async_result.hpp +789 -106
- data/src/cxx_supportlib/vendor-modified/boost/asio/awaitable.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_datagram_socket.hpp +80 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_deadline_timer.hpp +10 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_raw_socket.hpp +80 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_seq_packet_socket.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket.hpp +20 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket_acceptor.hpp +90 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_stream_socket.hpp +60 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_waitable_timer.hpp +10 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/bind_cancellation_slot.hpp +723 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/bind_executor.hpp +191 -12
- data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_signal.hpp +361 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_state.hpp +237 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_type.hpp +176 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/co_spawn.hpp +30 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/connect.hpp +60 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/base_from_cancellation_state.hpp +165 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/bind_handler.hpp +209 -76
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/config.hpp +149 -60
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/deadline_timer_service.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/dev_poll_reactor.hpp +8 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/epoll_reactor.hpp +14 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/functional.hpp +6 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_alloc_helpers.hpp +14 -10
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_type_requirements.hpp +21 -18
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_work.hpp +30 -19
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.hpp +8 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.ipp +14 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/epoll_reactor.hpp +20 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/epoll_reactor.ipp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/kqueue_reactor.hpp +20 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/kqueue_reactor.ipp +29 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/select_reactor.hpp +24 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/select_reactor.ipp +19 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/strand_executor_service.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/timer_queue_ptime.ipp +6 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/kqueue_reactor.hpp +15 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/memory.hpp +60 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/pop_options.hpp +8 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/push_options.hpp +27 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_descriptor_service.hpp +93 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service.hpp +77 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service_base.hpp +111 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_op.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_op_queue.hpp +44 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/recycling_allocator.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolve_endpoint_op.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/select_reactor.hpp +14 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/thread_info_base.hpp +90 -24
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue.hpp +30 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue_ptime.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/wait_op.hpp +5 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/work_dispatcher.hpp +5 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/any_executor.hpp +12 -12
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/bulk_execute.hpp +10 -8
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/connect.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/execute.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/schedule.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_done.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_error.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_value.hpp +13 -13
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/start.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/submit.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/append.hpp +73 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/as_tuple.hpp +133 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/awaitable_operators.hpp +538 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/cancellation_condition.hpp +157 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/coro.hpp +1057 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/deferred.hpp +607 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/completion_handler_erasure.hpp +160 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/coro_promise_allocator.hpp +120 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/coro_traits.hpp +185 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/partial_promise.hpp +181 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/append.hpp +219 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/as_single.hpp +14 -28
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/as_tuple.hpp +248 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/deferred.hpp +106 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/parallel_group.hpp +434 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/prepend.hpp +219 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/promise.hpp +100 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/parallel_group.hpp +217 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/prepend.hpp +73 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/promise.hpp +608 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/use_coro.hpp +284 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/awaitable.hpp +344 -20
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/buffered_read_stream.hpp +23 -54
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/buffered_write_stream.hpp +23 -54
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/co_spawn.hpp +66 -18
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/compose.hpp +55 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/connect.hpp +68 -80
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/defer.hpp +8 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/dispatch.hpp +8 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/handler_alloc_hook.ipp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/post.hpp +8 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read.hpp +98 -113
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_at.hpp +71 -82
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_until.hpp +210 -266
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/redirect_error.hpp +248 -30
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/spawn.hpp +11 -21
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/use_awaitable.hpp +15 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write.hpp +71 -87
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write_at.hpp +46 -68
- data/src/cxx_supportlib/vendor-modified/boost/asio/io_context.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/local/detail/impl/endpoint.ipp +2 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_descriptor.hpp +10 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_stream_descriptor.hpp +23 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/prefer.hpp +21 -21
- data/src/cxx_supportlib/vendor-modified/boost/asio/query.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/asio/read.hpp +88 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/read_at.hpp +44 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/read_until.hpp +132 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/require.hpp +21 -21
- data/src/cxx_supportlib/vendor-modified/boost/asio/require_concept.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/buffered_handshake_op.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/engine.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/handshake_op.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/impl/engine.ipp +14 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/io.hpp +36 -27
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/read_op.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/shutdown_op.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/stream_core.hpp +37 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/write_op.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/context.ipp +14 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/stream.hpp +73 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/system_executor.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/this_coro.hpp +235 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/thread_pool.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/use_awaitable.hpp +7 -10
- data/src/cxx_supportlib/vendor-modified/boost/asio/version.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_random_access_handle.hpp +20 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_stream_handle.hpp +20 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/write.hpp +88 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/write_at.hpp +44 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio.hpp +6 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/atomic_ref.hpp +14 -1
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/config.hpp +17 -13
- data/src/cxx_supportlib/vendor-modified/boost/atomic/ipc_atomic_ref.hpp +14 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx03.hpp +2 -5
- data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx11.hpp +2 -5
- data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx14.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx17.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx20.hpp +56 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/auto_link.hpp +1 -5
- data/src/cxx_supportlib/vendor-modified/boost/config/compiler/common_edg.hpp +31 -11
- data/src/cxx_supportlib/vendor-modified/boost/config/detail/cxx_composite.hpp +20 -4
- data/src/cxx_supportlib/vendor-modified/boost/config/detail/select_platform_config.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/detail/suffix.hpp +81 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/platform/bsd.hpp +5 -8
- data/src/cxx_supportlib/vendor-modified/boost/config/platform/wasm.hpp +17 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/dinkumware.hpp +26 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libcpp.hpp +49 -0
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libstdcpp3.hpp +46 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/adaptive_pool.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/adaptive_node_pool.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/node_pool.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/std_fwd.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/devector.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/new_allocator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/node_allocator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/polymorphic_allocator.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/container/static_vector.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/throw_exception.hpp +45 -38
- data/src/cxx_supportlib/vendor-modified/boost/container/vector.hpp +24 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/ignore_unused.hpp +32 -2
- data/src/cxx_supportlib/vendor-modified/boost/core/uncaught_exceptions.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/date_time/compiler_config.hpp +0 -24
- data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/time_parsers.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/any_hook.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/avl_set.hpp +83 -83
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree.hpp +43 -43
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree_algorithms.hpp +31 -31
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/bs_set.hpp +85 -85
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree.hpp +68 -68
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree_algorithms.hpp +72 -62
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_list_algorithms.hpp +19 -20
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_slist_algorithms.hpp +19 -19
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/derivation_value_traits.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/any_node_and_algorithms.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/bstree_algorithms_base.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/common_slist_algorithms.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/config_begin.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/generic_hook.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hash_combine.hpp +2 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hashtable_node.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/math.hpp +2 -50
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/node_cloner_disposer.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/hashtable.hpp +71 -70
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/linear_slist_algorithms.hpp +15 -14
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/list.hpp +84 -82
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/list_hook.hpp +10 -10
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/member_value_traits.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/parent_from_member.hpp +2 -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 +18 -18
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree.hpp +43 -43
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree_algorithms.hpp +26 -26
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/set.hpp +85 -85
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/set_hook.hpp +12 -12
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/sg_set.hpp +93 -93
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree.hpp +51 -51
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree_algorithms.hpp +24 -24
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist.hpp +104 -104
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist_hook.hpp +8 -6
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/splay_set.hpp +91 -91
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree.hpp +46 -46
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree_algorithms.hpp +31 -31
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap.hpp +51 -51
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_algorithms.hpp +18 -18
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_set.hpp +97 -97
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/trivial_value_traits.hpp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set.hpp +63 -63
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set_hook.hpp +15 -15
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_numeric.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/config_begin.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/iterator_traits.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/nsec_clock.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/operators.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/concepts.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_parser.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/unicode_iterator.hpp +112 -31
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/basic_regex_parser.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/mem_block_cache.hpp +4 -8
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/unicode_iterator.hpp +0 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/w32_regex_traits.hpp +6 -2
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/shared_count.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_impl.hpp +22 -2
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/shared_ptr.hpp +59 -1
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/config.hpp +9 -11
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_category.hpp +27 -21
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_category_impl.hpp +34 -3
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_code.hpp +378 -36
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_condition.hpp +97 -21
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/interop_category.hpp +107 -0
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/is_same.hpp +33 -0
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/snprintf.hpp +70 -0
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/{to_std_category.hpp → std_category.hpp} +5 -55
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/system_category_impl.hpp +2 -12
- data/src/cxx_supportlib/vendor-modified/boost/system/error_code.hpp +0 -33
- data/src/cxx_supportlib/vendor-modified/boost/utility/detail/result_of_variadic.hpp +190 -0
- data/src/cxx_supportlib/vendor-modified/boost/utility/result_of.hpp +20 -9
- data/src/cxx_supportlib/vendor-modified/boost/utility/string_view.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/version.hpp +2 -2
- data/src/nginx_module/ConfigGeneral/AutoGeneratedDefinitions.c +8 -0
- data/src/nginx_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.c +6 -0
- data/src/nginx_module/ConfigGeneral/AutoGeneratedSetterFuncs.c +12 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedCreateFunction.c +5 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedHeaderSerialization.c +21 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedManifestGeneration.c +13 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedMergeFunction.c +3 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedStruct.h +4 -0
- data/src/ruby_supportlib/phusion_passenger/admin_tools/instance_registry.rb +3 -2
- data/src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb +8 -1
- data/src/ruby_supportlib/phusion_passenger/nginx/config_options.rb +6 -0
- data/src/ruby_supportlib/phusion_passenger/packaging.rb +1 -0
- data/src/ruby_supportlib/phusion_passenger/platform_info/openssl.rb +1 -1
- data/src/ruby_supportlib/phusion_passenger/platform_info/operating_system.rb +8 -0
- data/src/ruby_supportlib/phusion_passenger/request_handler.rb +4 -1
- data/src/ruby_supportlib/phusion_passenger.rb +1 -1
- metadata +39 -4
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/is_generic_value.hpp +0 -125
@@ -20,7 +20,9 @@
|
|
20
20
|
#if !defined(BOOST_ASIO_HAS_IOCP) \
|
21
21
|
&& !defined(BOOST_ASIO_WINDOWS_RUNTIME)
|
22
22
|
|
23
|
+
#include <boost/asio/associated_cancellation_slot.hpp>
|
23
24
|
#include <boost/asio/buffer.hpp>
|
25
|
+
#include <boost/asio/cancellation_type.hpp>
|
24
26
|
#include <boost/asio/error.hpp>
|
25
27
|
#include <boost/asio/execution_context.hpp>
|
26
28
|
#include <boost/asio/socket_base.hpp>
|
@@ -200,6 +202,9 @@ public:
|
|
200
202
|
bool is_continuation =
|
201
203
|
boost_asio_handler_cont_helpers::is_continuation(handler);
|
202
204
|
|
205
|
+
typename associated_cancellation_slot<Handler>::type slot
|
206
|
+
= boost::asio::get_associated_cancellation_slot(handler);
|
207
|
+
|
203
208
|
// Allocate and construct an operation to wrap the handler.
|
204
209
|
typedef reactive_wait_op<Handler, IoExecutor> op;
|
205
210
|
typename op::ptr p = { boost::asio::detail::addressof(handler),
|
@@ -228,6 +233,14 @@ public:
|
|
228
233
|
return;
|
229
234
|
}
|
230
235
|
|
236
|
+
// Optionally register for per-operation cancellation.
|
237
|
+
if (slot.is_connected())
|
238
|
+
{
|
239
|
+
p.p->cancellation_key_ =
|
240
|
+
&slot.template emplace<reactor_op_cancellation>(
|
241
|
+
&reactor_, &impl.reactor_data_, impl.socket_, op_type);
|
242
|
+
}
|
243
|
+
|
231
244
|
start_op(impl, op_type, p.p, is_continuation, false, false);
|
232
245
|
p.v = p.p = 0;
|
233
246
|
}
|
@@ -275,6 +288,9 @@ public:
|
|
275
288
|
bool is_continuation =
|
276
289
|
boost_asio_handler_cont_helpers::is_continuation(handler);
|
277
290
|
|
291
|
+
typename associated_cancellation_slot<Handler>::type slot
|
292
|
+
= boost::asio::get_associated_cancellation_slot(handler);
|
293
|
+
|
278
294
|
// Allocate and construct an operation to wrap the handler.
|
279
295
|
typedef reactive_socket_send_op<
|
280
296
|
ConstBufferSequence, Handler, IoExecutor> op;
|
@@ -283,6 +299,14 @@ public:
|
|
283
299
|
p.p = new (p.v) op(success_ec_, impl.socket_,
|
284
300
|
impl.state_, buffers, flags, handler, io_ex);
|
285
301
|
|
302
|
+
// Optionally register for per-operation cancellation.
|
303
|
+
if (slot.is_connected())
|
304
|
+
{
|
305
|
+
p.p->cancellation_key_ =
|
306
|
+
&slot.template emplace<reactor_op_cancellation>(
|
307
|
+
&reactor_, &impl.reactor_data_, impl.socket_, reactor::write_op);
|
308
|
+
}
|
309
|
+
|
286
310
|
BOOST_ASIO_HANDLER_CREATION((reactor_.context(), *p.p, "socket",
|
287
311
|
&impl, impl.socket_, "async_send"));
|
288
312
|
|
@@ -301,12 +325,23 @@ public:
|
|
301
325
|
bool is_continuation =
|
302
326
|
boost_asio_handler_cont_helpers::is_continuation(handler);
|
303
327
|
|
328
|
+
typename associated_cancellation_slot<Handler>::type slot
|
329
|
+
= boost::asio::get_associated_cancellation_slot(handler);
|
330
|
+
|
304
331
|
// Allocate and construct an operation to wrap the handler.
|
305
332
|
typedef reactive_null_buffers_op<Handler, IoExecutor> op;
|
306
333
|
typename op::ptr p = { boost::asio::detail::addressof(handler),
|
307
334
|
op::ptr::allocate(handler), 0 };
|
308
335
|
p.p = new (p.v) op(success_ec_, handler, io_ex);
|
309
336
|
|
337
|
+
// Optionally register for per-operation cancellation.
|
338
|
+
if (slot.is_connected())
|
339
|
+
{
|
340
|
+
p.p->cancellation_key_ =
|
341
|
+
&slot.template emplace<reactor_op_cancellation>(
|
342
|
+
&reactor_, &impl.reactor_data_, impl.socket_, reactor::write_op);
|
343
|
+
}
|
344
|
+
|
310
345
|
BOOST_ASIO_HANDLER_CREATION((reactor_.context(), *p.p, "socket",
|
311
346
|
&impl, impl.socket_, "async_send(null_buffers)"));
|
312
347
|
|
@@ -358,6 +393,9 @@ public:
|
|
358
393
|
bool is_continuation =
|
359
394
|
boost_asio_handler_cont_helpers::is_continuation(handler);
|
360
395
|
|
396
|
+
typename associated_cancellation_slot<Handler>::type slot
|
397
|
+
= boost::asio::get_associated_cancellation_slot(handler);
|
398
|
+
|
361
399
|
// Allocate and construct an operation to wrap the handler.
|
362
400
|
typedef reactive_socket_recv_op<
|
363
401
|
MutableBufferSequence, Handler, IoExecutor> op;
|
@@ -366,6 +404,14 @@ public:
|
|
366
404
|
p.p = new (p.v) op(success_ec_, impl.socket_,
|
367
405
|
impl.state_, buffers, flags, handler, io_ex);
|
368
406
|
|
407
|
+
// Optionally register for per-operation cancellation.
|
408
|
+
if (slot.is_connected())
|
409
|
+
{
|
410
|
+
p.p->cancellation_key_ =
|
411
|
+
&slot.template emplace<reactor_op_cancellation>(
|
412
|
+
&reactor_, &impl.reactor_data_, impl.socket_, reactor::read_op);
|
413
|
+
}
|
414
|
+
|
369
415
|
BOOST_ASIO_HANDLER_CREATION((reactor_.context(), *p.p, "socket",
|
370
416
|
&impl, impl.socket_, "async_receive"));
|
371
417
|
|
@@ -389,12 +435,23 @@ public:
|
|
389
435
|
bool is_continuation =
|
390
436
|
boost_asio_handler_cont_helpers::is_continuation(handler);
|
391
437
|
|
438
|
+
typename associated_cancellation_slot<Handler>::type slot
|
439
|
+
= boost::asio::get_associated_cancellation_slot(handler);
|
440
|
+
|
392
441
|
// Allocate and construct an operation to wrap the handler.
|
393
442
|
typedef reactive_null_buffers_op<Handler, IoExecutor> op;
|
394
443
|
typename op::ptr p = { boost::asio::detail::addressof(handler),
|
395
444
|
op::ptr::allocate(handler), 0 };
|
396
445
|
p.p = new (p.v) op(success_ec_, handler, io_ex);
|
397
446
|
|
447
|
+
// Optionally register for per-operation cancellation.
|
448
|
+
if (slot.is_connected())
|
449
|
+
{
|
450
|
+
p.p->cancellation_key_ =
|
451
|
+
&slot.template emplace<reactor_op_cancellation>(
|
452
|
+
&reactor_, &impl.reactor_data_, impl.socket_, reactor::read_op);
|
453
|
+
}
|
454
|
+
|
398
455
|
BOOST_ASIO_HANDLER_CREATION((reactor_.context(), *p.p, "socket",
|
399
456
|
&impl, impl.socket_, "async_receive(null_buffers)"));
|
400
457
|
|
@@ -447,6 +504,9 @@ public:
|
|
447
504
|
bool is_continuation =
|
448
505
|
boost_asio_handler_cont_helpers::is_continuation(handler);
|
449
506
|
|
507
|
+
typename associated_cancellation_slot<Handler>::type slot
|
508
|
+
= boost::asio::get_associated_cancellation_slot(handler);
|
509
|
+
|
450
510
|
// Allocate and construct an operation to wrap the handler.
|
451
511
|
typedef reactive_socket_recvmsg_op<
|
452
512
|
MutableBufferSequence, Handler, IoExecutor> op;
|
@@ -455,6 +515,14 @@ public:
|
|
455
515
|
p.p = new (p.v) op(success_ec_, impl.socket_,
|
456
516
|
buffers, in_flags, out_flags, handler, io_ex);
|
457
517
|
|
518
|
+
// Optionally register for per-operation cancellation.
|
519
|
+
if (slot.is_connected())
|
520
|
+
{
|
521
|
+
p.p->cancellation_key_ =
|
522
|
+
&slot.template emplace<reactor_op_cancellation>(
|
523
|
+
&reactor_, &impl.reactor_data_, impl.socket_, reactor::read_op);
|
524
|
+
}
|
525
|
+
|
458
526
|
BOOST_ASIO_HANDLER_CREATION((reactor_.context(), *p.p, "socket",
|
459
527
|
&impl, impl.socket_, "async_receive_with_flags"));
|
460
528
|
|
@@ -476,12 +544,23 @@ public:
|
|
476
544
|
bool is_continuation =
|
477
545
|
boost_asio_handler_cont_helpers::is_continuation(handler);
|
478
546
|
|
547
|
+
typename associated_cancellation_slot<Handler>::type slot
|
548
|
+
= boost::asio::get_associated_cancellation_slot(handler);
|
549
|
+
|
479
550
|
// Allocate and construct an operation to wrap the handler.
|
480
551
|
typedef reactive_null_buffers_op<Handler, IoExecutor> op;
|
481
552
|
typename op::ptr p = { boost::asio::detail::addressof(handler),
|
482
553
|
op::ptr::allocate(handler), 0 };
|
483
554
|
p.p = new (p.v) op(success_ec_, handler, io_ex);
|
484
555
|
|
556
|
+
// Optionally register for per-operation cancellation.
|
557
|
+
if (slot.is_connected())
|
558
|
+
{
|
559
|
+
p.p->cancellation_key_ =
|
560
|
+
&slot.template emplace<reactor_op_cancellation>(
|
561
|
+
&reactor_, &impl.reactor_data_, impl.socket_, reactor::read_op);
|
562
|
+
}
|
563
|
+
|
485
564
|
BOOST_ASIO_HANDLER_CREATION((reactor_.context(), *p.p, "socket",
|
486
565
|
&impl, impl.socket_, "async_receive_with_flags(null_buffers)"));
|
487
566
|
|
@@ -520,6 +599,38 @@ protected:
|
|
520
599
|
reactor_op* op, bool is_continuation,
|
521
600
|
const socket_addr_type* addr, size_t addrlen);
|
522
601
|
|
602
|
+
// Helper class used to implement per-operation cancellation
|
603
|
+
class reactor_op_cancellation
|
604
|
+
{
|
605
|
+
public:
|
606
|
+
reactor_op_cancellation(reactor* r,
|
607
|
+
reactor::per_descriptor_data* p, int d, int o)
|
608
|
+
: reactor_(r),
|
609
|
+
reactor_data_(p),
|
610
|
+
descriptor_(d),
|
611
|
+
op_type_(o)
|
612
|
+
{
|
613
|
+
}
|
614
|
+
|
615
|
+
void operator()(cancellation_type_t type)
|
616
|
+
{
|
617
|
+
if (!!(type &
|
618
|
+
(cancellation_type::terminal
|
619
|
+
| cancellation_type::partial
|
620
|
+
| cancellation_type::total)))
|
621
|
+
{
|
622
|
+
reactor_->cancel_ops_by_key(descriptor_,
|
623
|
+
*reactor_data_, op_type_, this);
|
624
|
+
}
|
625
|
+
}
|
626
|
+
|
627
|
+
private:
|
628
|
+
reactor* reactor_;
|
629
|
+
reactor::per_descriptor_data* reactor_data_;
|
630
|
+
int descriptor_;
|
631
|
+
int op_type_;
|
632
|
+
};
|
633
|
+
|
523
634
|
// The selector that performs event demultiplexing for the service.
|
524
635
|
reactor& reactor_;
|
525
636
|
|
@@ -31,6 +31,9 @@ public:
|
|
31
31
|
// The error code to be passed to the completion handler.
|
32
32
|
boost::system::error_code ec_;
|
33
33
|
|
34
|
+
// The operation key used for targeted cancellation.
|
35
|
+
void* cancellation_key_;
|
36
|
+
|
34
37
|
// The number of bytes transferred, to be passed to the completion handler.
|
35
38
|
std::size_t bytes_transferred_;
|
36
39
|
|
@@ -51,6 +54,7 @@ protected:
|
|
51
54
|
perform_func_type perform_func, func_type complete_func)
|
52
55
|
: operation(complete_func),
|
53
56
|
ec_(success_ec),
|
57
|
+
cancellation_key_(0),
|
54
58
|
bytes_transferred_(0),
|
55
59
|
perform_func_(perform_func)
|
56
60
|
{
|
@@ -101,6 +101,50 @@ public:
|
|
101
101
|
return this->cancel_operations(operations_.find(descriptor), ops, ec);
|
102
102
|
}
|
103
103
|
|
104
|
+
// Cancel operations associated with the descriptor identified by the
|
105
|
+
// supplied iterator, and the specified cancellation key. Any operations
|
106
|
+
// pending for the descriptor with the key will be cancelled. Returns true if
|
107
|
+
// any operations were cancelled, in which case the reactor's event
|
108
|
+
// demultiplexing function may need to be interrupted and restarted.
|
109
|
+
bool cancel_operations_by_key(iterator i, op_queue<operation>& ops,
|
110
|
+
void* cancellation_key, const boost::system::error_code& ec =
|
111
|
+
boost::asio::error::operation_aborted)
|
112
|
+
{
|
113
|
+
bool result = false;
|
114
|
+
if (i != operations_.end())
|
115
|
+
{
|
116
|
+
op_queue<reactor_op> other_ops;
|
117
|
+
while (reactor_op* op = i->second.front())
|
118
|
+
{
|
119
|
+
i->second.pop();
|
120
|
+
if (op->cancellation_key_ == cancellation_key)
|
121
|
+
{
|
122
|
+
op->ec_ = ec;
|
123
|
+
ops.push(op);
|
124
|
+
result = true;
|
125
|
+
}
|
126
|
+
else
|
127
|
+
other_ops.push(op);
|
128
|
+
}
|
129
|
+
i->second.push(other_ops);
|
130
|
+
if (i->second.empty())
|
131
|
+
operations_.erase(i);
|
132
|
+
}
|
133
|
+
return result;
|
134
|
+
}
|
135
|
+
|
136
|
+
// Cancel all operations associated with the descriptor. Any operations
|
137
|
+
// pending for the descriptor will be cancelled. Returns true if any
|
138
|
+
// operations were cancelled, in which case the reactor's event
|
139
|
+
// demultiplexing function may need to be interrupted and restarted.
|
140
|
+
bool cancel_operations_by_key(Descriptor descriptor, op_queue<operation>& ops,
|
141
|
+
void* cancellation_key, const boost::system::error_code& ec =
|
142
|
+
boost::asio::error::operation_aborted)
|
143
|
+
{
|
144
|
+
return this->cancel_operations_by_key(
|
145
|
+
operations_.find(descriptor), ops, cancellation_key, ec);
|
146
|
+
}
|
147
|
+
|
104
148
|
// Whether there are no operations in the queue.
|
105
149
|
bool empty() const
|
106
150
|
{
|
@@ -50,7 +50,8 @@ public:
|
|
50
50
|
T* allocate(std::size_t n)
|
51
51
|
{
|
52
52
|
void* p = thread_info_base::allocate(Purpose(),
|
53
|
-
thread_context::top_of_thread_call_stack(),
|
53
|
+
thread_context::top_of_thread_call_stack(),
|
54
|
+
sizeof(T) * n, BOOST_ASIO_ALIGNOF(T));
|
54
55
|
return static_cast<T*>(p);
|
55
56
|
}
|
56
57
|
|
@@ -80,8 +80,8 @@ public:
|
|
80
80
|
// the resolver operation.
|
81
81
|
|
82
82
|
// Perform the blocking endpoint resolution operation.
|
83
|
-
char host_name[NI_MAXHOST];
|
84
|
-
char service_name[NI_MAXSERV];
|
83
|
+
char host_name[NI_MAXHOST] = "";
|
84
|
+
char service_name[NI_MAXSERV] = "";
|
85
85
|
socket_ops::background_getnameinfo(o->cancel_token_, o->endpoint_.data(),
|
86
86
|
o->endpoint_.size(), host_name, NI_MAXHOST, service_name, NI_MAXSERV,
|
87
87
|
o->endpoint_.protocol().type(), o->ec_);
|
@@ -91,10 +91,7 @@ public:
|
|
91
91
|
per_descriptor_data& descriptor_data, reactor_op* op);
|
92
92
|
|
93
93
|
// Post a reactor operation for immediate completion.
|
94
|
-
void post_immediate_completion(reactor_op* op, bool is_continuation)
|
95
|
-
{
|
96
|
-
scheduler_.post_immediate_completion(op, is_continuation);
|
97
|
-
}
|
94
|
+
void post_immediate_completion(reactor_op* op, bool is_continuation);
|
98
95
|
|
99
96
|
// Start a new operation. The reactor operation will be performed when the
|
100
97
|
// given descriptor is flagged as ready, or an error has occurred.
|
@@ -106,6 +103,13 @@ public:
|
|
106
103
|
// operation_aborted error.
|
107
104
|
BOOST_ASIO_DECL void cancel_ops(socket_type descriptor, per_descriptor_data&);
|
108
105
|
|
106
|
+
// Cancel all operations associated with the given descriptor and key. The
|
107
|
+
// handlers associated with the descriptor will be invoked with the
|
108
|
+
// operation_aborted error.
|
109
|
+
BOOST_ASIO_DECL void cancel_ops_by_key(socket_type descriptor,
|
110
|
+
per_descriptor_data& descriptor_data,
|
111
|
+
int op_type, void* cancellation_key);
|
112
|
+
|
109
113
|
// Cancel any operations that are running against the descriptor and remove
|
110
114
|
// its registration from the reactor. The reactor resources associated with
|
111
115
|
// the descriptor must be released by calling cleanup_descriptor_data.
|
@@ -149,6 +153,12 @@ public:
|
|
149
153
|
typename timer_queue<Time_Traits>::per_timer_data& timer,
|
150
154
|
std::size_t max_cancelled = (std::numeric_limits<std::size_t>::max)());
|
151
155
|
|
156
|
+
// Cancel the timer operations associated with the given key.
|
157
|
+
template <typename Time_Traits>
|
158
|
+
void cancel_timer_by_key(timer_queue<Time_Traits>& queue,
|
159
|
+
typename timer_queue<Time_Traits>::per_timer_data* timer,
|
160
|
+
void* cancellation_key);
|
161
|
+
|
152
162
|
// Move the timer operations associated with the given timer.
|
153
163
|
template <typename Time_Traits>
|
154
164
|
void move_timer(timer_queue<Time_Traits>& queue,
|
@@ -18,6 +18,7 @@
|
|
18
18
|
#include <boost/asio/detail/config.hpp>
|
19
19
|
#include <climits>
|
20
20
|
#include <cstddef>
|
21
|
+
#include <boost/asio/detail/memory.hpp>
|
21
22
|
#include <boost/asio/detail/noncopyable.hpp>
|
22
23
|
|
23
24
|
#if defined(BOOST_ASIO_HAS_STD_EXCEPTION_PTR) \
|
@@ -33,25 +34,66 @@ namespace boost {
|
|
33
34
|
namespace asio {
|
34
35
|
namespace detail {
|
35
36
|
|
37
|
+
#ifndef BOOST_ASIO_RECYCLING_ALLOCATOR_CACHE_SIZE
|
38
|
+
# define BOOST_ASIO_RECYCLING_ALLOCATOR_CACHE_SIZE 2
|
39
|
+
#endif // BOOST_ASIO_RECYCLING_ALLOCATOR_CACHE_SIZE
|
40
|
+
|
36
41
|
class thread_info_base
|
37
42
|
: private noncopyable
|
38
43
|
{
|
39
44
|
public:
|
40
45
|
struct default_tag
|
41
46
|
{
|
42
|
-
enum
|
47
|
+
enum
|
48
|
+
{
|
49
|
+
cache_size = BOOST_ASIO_RECYCLING_ALLOCATOR_CACHE_SIZE,
|
50
|
+
begin_mem_index = 0,
|
51
|
+
end_mem_index = cache_size
|
52
|
+
};
|
43
53
|
};
|
44
54
|
|
45
55
|
struct awaitable_frame_tag
|
46
56
|
{
|
47
|
-
enum
|
57
|
+
enum
|
58
|
+
{
|
59
|
+
cache_size = BOOST_ASIO_RECYCLING_ALLOCATOR_CACHE_SIZE,
|
60
|
+
begin_mem_index = default_tag::end_mem_index,
|
61
|
+
end_mem_index = begin_mem_index + cache_size
|
62
|
+
};
|
48
63
|
};
|
49
64
|
|
50
65
|
struct executor_function_tag
|
51
66
|
{
|
52
|
-
enum
|
67
|
+
enum
|
68
|
+
{
|
69
|
+
cache_size = BOOST_ASIO_RECYCLING_ALLOCATOR_CACHE_SIZE,
|
70
|
+
begin_mem_index = awaitable_frame_tag::end_mem_index,
|
71
|
+
end_mem_index = begin_mem_index + cache_size
|
72
|
+
};
|
73
|
+
};
|
74
|
+
|
75
|
+
struct cancellation_signal_tag
|
76
|
+
{
|
77
|
+
enum
|
78
|
+
{
|
79
|
+
cache_size = BOOST_ASIO_RECYCLING_ALLOCATOR_CACHE_SIZE,
|
80
|
+
begin_mem_index = executor_function_tag::end_mem_index,
|
81
|
+
end_mem_index = begin_mem_index + cache_size
|
82
|
+
};
|
83
|
+
};
|
84
|
+
|
85
|
+
struct parallel_group_tag
|
86
|
+
{
|
87
|
+
enum
|
88
|
+
{
|
89
|
+
cache_size = BOOST_ASIO_RECYCLING_ALLOCATOR_CACHE_SIZE,
|
90
|
+
begin_mem_index = cancellation_signal_tag::end_mem_index,
|
91
|
+
end_mem_index = begin_mem_index + cache_size
|
92
|
+
};
|
53
93
|
};
|
54
94
|
|
95
|
+
enum { max_mem_index = parallel_group_tag::end_mem_index };
|
96
|
+
|
55
97
|
thread_info_base()
|
56
98
|
#if defined(BOOST_ASIO_HAS_STD_EXCEPTION_PTR) \
|
57
99
|
&& !defined(BOOST_ASIO_NO_EXCEPTIONS)
|
@@ -71,13 +113,14 @@ public:
|
|
71
113
|
// it is significantly faster when using a tight io_context::poll() loop
|
72
114
|
// in latency sensitive applications.
|
73
115
|
if (reusable_memory_[i])
|
74
|
-
|
116
|
+
aligned_delete(reusable_memory_[i]);
|
75
117
|
}
|
76
118
|
}
|
77
119
|
|
78
|
-
static void* allocate(thread_info_base* this_thread,
|
120
|
+
static void* allocate(thread_info_base* this_thread,
|
121
|
+
std::size_t size, std::size_t align = BOOST_ASIO_DEFAULT_ALIGN)
|
79
122
|
{
|
80
|
-
return allocate(default_tag(), this_thread, size);
|
123
|
+
return allocate(default_tag(), this_thread, size, align);
|
81
124
|
}
|
82
125
|
|
83
126
|
static void deallocate(thread_info_base* this_thread,
|
@@ -88,26 +131,43 @@ public:
|
|
88
131
|
|
89
132
|
template <typename Purpose>
|
90
133
|
static void* allocate(Purpose, thread_info_base* this_thread,
|
91
|
-
std::size_t size)
|
134
|
+
std::size_t size, std::size_t align = BOOST_ASIO_DEFAULT_ALIGN)
|
92
135
|
{
|
93
136
|
std::size_t chunks = (size + chunk_size - 1) / chunk_size;
|
94
137
|
|
95
|
-
if (this_thread
|
138
|
+
if (this_thread)
|
96
139
|
{
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
unsigned char* const mem = static_cast<unsigned char*>(pointer);
|
101
|
-
if (static_cast<std::size_t>(mem[0]) >= chunks)
|
140
|
+
for (int mem_index = Purpose::begin_mem_index;
|
141
|
+
mem_index < Purpose::end_mem_index; ++mem_index)
|
102
142
|
{
|
103
|
-
|
104
|
-
|
143
|
+
if (this_thread->reusable_memory_[mem_index])
|
144
|
+
{
|
145
|
+
void* const pointer = this_thread->reusable_memory_[mem_index];
|
146
|
+
unsigned char* const mem = static_cast<unsigned char*>(pointer);
|
147
|
+
if (static_cast<std::size_t>(mem[0]) >= chunks
|
148
|
+
&& reinterpret_cast<std::size_t>(pointer) % align == 0)
|
149
|
+
{
|
150
|
+
this_thread->reusable_memory_[mem_index] = 0;
|
151
|
+
mem[size] = mem[0];
|
152
|
+
return pointer;
|
153
|
+
}
|
154
|
+
}
|
105
155
|
}
|
106
156
|
|
107
|
-
|
157
|
+
for (int mem_index = Purpose::begin_mem_index;
|
158
|
+
mem_index < Purpose::end_mem_index; ++mem_index)
|
159
|
+
{
|
160
|
+
if (this_thread->reusable_memory_[mem_index])
|
161
|
+
{
|
162
|
+
void* const pointer = this_thread->reusable_memory_[mem_index];
|
163
|
+
this_thread->reusable_memory_[mem_index] = 0;
|
164
|
+
aligned_delete(pointer);
|
165
|
+
break;
|
166
|
+
}
|
167
|
+
}
|
108
168
|
}
|
109
169
|
|
110
|
-
void* const pointer =
|
170
|
+
void* const pointer = aligned_new(align, chunks * chunk_size + 1);
|
111
171
|
unsigned char* const mem = static_cast<unsigned char*>(pointer);
|
112
172
|
mem[size] = (chunks <= UCHAR_MAX) ? static_cast<unsigned char>(chunks) : 0;
|
113
173
|
return pointer;
|
@@ -119,16 +179,23 @@ public:
|
|
119
179
|
{
|
120
180
|
if (size <= chunk_size * UCHAR_MAX)
|
121
181
|
{
|
122
|
-
if (this_thread
|
182
|
+
if (this_thread)
|
123
183
|
{
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
184
|
+
for (int mem_index = Purpose::begin_mem_index;
|
185
|
+
mem_index < Purpose::end_mem_index; ++mem_index)
|
186
|
+
{
|
187
|
+
if (this_thread->reusable_memory_[mem_index] == 0)
|
188
|
+
{
|
189
|
+
unsigned char* const mem = static_cast<unsigned char*>(pointer);
|
190
|
+
mem[0] = mem[size];
|
191
|
+
this_thread->reusable_memory_[mem_index] = pointer;
|
192
|
+
return;
|
193
|
+
}
|
194
|
+
}
|
128
195
|
}
|
129
196
|
}
|
130
197
|
|
131
|
-
|
198
|
+
aligned_delete(pointer);
|
132
199
|
}
|
133
200
|
|
134
201
|
void capture_current_exception()
|
@@ -172,7 +239,6 @@ public:
|
|
172
239
|
|
173
240
|
private:
|
174
241
|
enum { chunk_size = 4 };
|
175
|
-
enum { max_mem_index = 3 };
|
176
242
|
void* reusable_memory_[max_mem_index];
|
177
243
|
|
178
244
|
#if defined(BOOST_ASIO_HAS_STD_EXCEPTION_PTR) \
|
@@ -151,7 +151,12 @@ public:
|
|
151
151
|
while (!heap_.empty() && !Time_Traits::less_than(now, heap_[0].time_))
|
152
152
|
{
|
153
153
|
per_timer_data* timer = heap_[0].timer_;
|
154
|
-
|
154
|
+
while (wait_op* op = timer->op_queue_.front())
|
155
|
+
{
|
156
|
+
timer->op_queue_.pop();
|
157
|
+
op->ec_ = boost::system::error_code();
|
158
|
+
ops.push(op);
|
159
|
+
}
|
155
160
|
remove_timer(*timer);
|
156
161
|
}
|
157
162
|
}
|
@@ -193,6 +198,30 @@ public:
|
|
193
198
|
return num_cancelled;
|
194
199
|
}
|
195
200
|
|
201
|
+
// Cancel and dequeue a specific operation for the given timer.
|
202
|
+
void cancel_timer_by_key(per_timer_data* timer,
|
203
|
+
op_queue<operation>& ops, void* cancellation_key)
|
204
|
+
{
|
205
|
+
if (timer->prev_ != 0 || timer == timers_)
|
206
|
+
{
|
207
|
+
op_queue<wait_op> other_ops;
|
208
|
+
while (wait_op* op = timer->op_queue_.front())
|
209
|
+
{
|
210
|
+
timer->op_queue_.pop();
|
211
|
+
if (op->cancellation_key_ == cancellation_key)
|
212
|
+
{
|
213
|
+
op->ec_ = boost::asio::error::operation_aborted;
|
214
|
+
ops.push(op);
|
215
|
+
}
|
216
|
+
else
|
217
|
+
other_ops.push(op);
|
218
|
+
}
|
219
|
+
timer->op_queue_.push(other_ops);
|
220
|
+
if (timer->op_queue_.empty())
|
221
|
+
remove_timer(*timer);
|
222
|
+
}
|
223
|
+
}
|
224
|
+
|
196
225
|
// Move operations from one timer to another, empty timer.
|
197
226
|
void move_timer(per_timer_data& target, per_timer_data& source)
|
198
227
|
{
|
@@ -78,6 +78,10 @@ public:
|
|
78
78
|
per_timer_data& timer, op_queue<operation>& ops,
|
79
79
|
std::size_t max_cancelled = (std::numeric_limits<std::size_t>::max)());
|
80
80
|
|
81
|
+
// Cancel and dequeue operations for the given timer and key.
|
82
|
+
BOOST_ASIO_DECL void cancel_timer_by_key(per_timer_data* timer,
|
83
|
+
op_queue<operation>& ops, void* cancellation_key);
|
84
|
+
|
81
85
|
// Move operations from one timer to another, empty timer.
|
82
86
|
BOOST_ASIO_DECL void move_timer(per_timer_data& target,
|
83
87
|
per_timer_data& source);
|
@@ -31,9 +31,13 @@ public:
|
|
31
31
|
// The error code to be passed to the completion handler.
|
32
32
|
boost::system::error_code ec_;
|
33
33
|
|
34
|
+
// The operation key used for targeted cancellation.
|
35
|
+
void* cancellation_key_;
|
36
|
+
|
34
37
|
protected:
|
35
38
|
wait_op(func_type func)
|
36
|
-
: operation(func)
|
39
|
+
: operation(func),
|
40
|
+
cancellation_key_(0)
|
37
41
|
{
|
38
42
|
}
|
39
43
|
};
|
@@ -16,6 +16,7 @@
|
|
16
16
|
#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
|
17
17
|
|
18
18
|
#include <boost/asio/detail/config.hpp>
|
19
|
+
#include <boost/asio/detail/bind_handler.hpp>
|
19
20
|
#include <boost/asio/detail/type_traits.hpp>
|
20
21
|
#include <boost/asio/associated_executor.hpp>
|
21
22
|
#include <boost/asio/associated_allocator.hpp>
|
@@ -82,7 +83,8 @@ public:
|
|
82
83
|
boost::asio::prefer(executor_,
|
83
84
|
execution::blocking.possibly,
|
84
85
|
execution::allocator((get_associated_allocator)(handler_))),
|
85
|
-
|
86
|
+
boost::asio::detail::bind_handler(
|
87
|
+
BOOST_ASIO_MOVE_CAST(Handler)(handler_)));
|
86
88
|
}
|
87
89
|
|
88
90
|
private:
|
@@ -130,7 +132,8 @@ public:
|
|
130
132
|
typename associated_allocator<Handler>::type alloc(
|
131
133
|
(get_associated_allocator)(handler_));
|
132
134
|
work_.get_executor().dispatch(
|
133
|
-
|
135
|
+
boost::asio::detail::bind_handler(
|
136
|
+
BOOST_ASIO_MOVE_CAST(Handler)(handler_)), alloc);
|
134
137
|
work_.reset();
|
135
138
|
}
|
136
139
|
|