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,9 +20,13 @@
|
|
20
20
|
#include <new>
|
21
21
|
#include <tuple>
|
22
22
|
#include <utility>
|
23
|
+
#include <boost/asio/cancellation_signal.hpp>
|
24
|
+
#include <boost/asio/cancellation_state.hpp>
|
23
25
|
#include <boost/asio/detail/thread_context.hpp>
|
24
26
|
#include <boost/asio/detail/thread_info_base.hpp>
|
27
|
+
#include <boost/asio/detail/throw_error.hpp>
|
25
28
|
#include <boost/asio/detail/type_traits.hpp>
|
29
|
+
#include <boost/asio/error.hpp>
|
26
30
|
#include <boost/asio/post.hpp>
|
27
31
|
#include <boost/system/system_error.hpp>
|
28
32
|
#include <boost/asio/this_coro.hpp>
|
@@ -33,6 +37,8 @@ namespace boost {
|
|
33
37
|
namespace asio {
|
34
38
|
namespace detail {
|
35
39
|
|
40
|
+
struct awaitable_thread_has_context_switched {};
|
41
|
+
|
36
42
|
// An awaitable_thread represents a thread-of-execution that is composed of one
|
37
43
|
// or more "stack frames", with each frame represented by an awaitable_frame.
|
38
44
|
// All execution occurs in the context of the awaitable_thread's executor. An
|
@@ -147,9 +153,17 @@ public:
|
|
147
153
|
}
|
148
154
|
}
|
149
155
|
|
156
|
+
void clear_cancellation_slot()
|
157
|
+
{
|
158
|
+
this->attached_thread_->entry_point()->cancellation_state_.slot().clear();
|
159
|
+
}
|
160
|
+
|
150
161
|
template <typename T>
|
151
162
|
auto await_transform(awaitable<T, Executor> a) const
|
152
163
|
{
|
164
|
+
if (attached_thread_->entry_point()->throw_if_cancelled_)
|
165
|
+
if (!!attached_thread_->get_cancellation_state().cancelled())
|
166
|
+
do_throw_error(boost::asio::error::operation_aborted, "co_await");
|
153
167
|
return a;
|
154
168
|
}
|
155
169
|
|
@@ -179,6 +193,175 @@ public:
|
|
179
193
|
return result{this};
|
180
194
|
}
|
181
195
|
|
196
|
+
// This await transformation obtains the associated cancellation state of the
|
197
|
+
// thread of execution.
|
198
|
+
auto await_transform(this_coro::cancellation_state_t) noexcept
|
199
|
+
{
|
200
|
+
struct result
|
201
|
+
{
|
202
|
+
awaitable_frame_base* this_;
|
203
|
+
|
204
|
+
bool await_ready() const noexcept
|
205
|
+
{
|
206
|
+
return true;
|
207
|
+
}
|
208
|
+
|
209
|
+
void await_suspend(coroutine_handle<void>) noexcept
|
210
|
+
{
|
211
|
+
}
|
212
|
+
|
213
|
+
auto await_resume() const noexcept
|
214
|
+
{
|
215
|
+
return this_->attached_thread_->get_cancellation_state();
|
216
|
+
}
|
217
|
+
};
|
218
|
+
|
219
|
+
return result{this};
|
220
|
+
}
|
221
|
+
|
222
|
+
// This await transformation resets the associated cancellation state.
|
223
|
+
auto await_transform(this_coro::reset_cancellation_state_0_t) noexcept
|
224
|
+
{
|
225
|
+
struct result
|
226
|
+
{
|
227
|
+
awaitable_frame_base* this_;
|
228
|
+
|
229
|
+
bool await_ready() const noexcept
|
230
|
+
{
|
231
|
+
return true;
|
232
|
+
}
|
233
|
+
|
234
|
+
void await_suspend(coroutine_handle<void>) noexcept
|
235
|
+
{
|
236
|
+
}
|
237
|
+
|
238
|
+
auto await_resume() const
|
239
|
+
{
|
240
|
+
return this_->attached_thread_->reset_cancellation_state();
|
241
|
+
}
|
242
|
+
};
|
243
|
+
|
244
|
+
return result{this};
|
245
|
+
}
|
246
|
+
|
247
|
+
// This await transformation resets the associated cancellation state.
|
248
|
+
template <typename Filter>
|
249
|
+
auto await_transform(
|
250
|
+
this_coro::reset_cancellation_state_1_t<Filter> reset) noexcept
|
251
|
+
{
|
252
|
+
struct result
|
253
|
+
{
|
254
|
+
awaitable_frame_base* this_;
|
255
|
+
Filter filter_;
|
256
|
+
|
257
|
+
bool await_ready() const noexcept
|
258
|
+
{
|
259
|
+
return true;
|
260
|
+
}
|
261
|
+
|
262
|
+
void await_suspend(coroutine_handle<void>) noexcept
|
263
|
+
{
|
264
|
+
}
|
265
|
+
|
266
|
+
auto await_resume()
|
267
|
+
{
|
268
|
+
return this_->attached_thread_->reset_cancellation_state(
|
269
|
+
BOOST_ASIO_MOVE_CAST(Filter)(filter_));
|
270
|
+
}
|
271
|
+
};
|
272
|
+
|
273
|
+
return result{this, BOOST_ASIO_MOVE_CAST(Filter)(reset.filter)};
|
274
|
+
}
|
275
|
+
|
276
|
+
// This await transformation resets the associated cancellation state.
|
277
|
+
template <typename InFilter, typename OutFilter>
|
278
|
+
auto await_transform(
|
279
|
+
this_coro::reset_cancellation_state_2_t<InFilter, OutFilter> reset)
|
280
|
+
noexcept
|
281
|
+
{
|
282
|
+
struct result
|
283
|
+
{
|
284
|
+
awaitable_frame_base* this_;
|
285
|
+
InFilter in_filter_;
|
286
|
+
OutFilter out_filter_;
|
287
|
+
|
288
|
+
bool await_ready() const noexcept
|
289
|
+
{
|
290
|
+
return true;
|
291
|
+
}
|
292
|
+
|
293
|
+
void await_suspend(coroutine_handle<void>) noexcept
|
294
|
+
{
|
295
|
+
}
|
296
|
+
|
297
|
+
auto await_resume()
|
298
|
+
{
|
299
|
+
return this_->attached_thread_->reset_cancellation_state(
|
300
|
+
BOOST_ASIO_MOVE_CAST(InFilter)(in_filter_),
|
301
|
+
BOOST_ASIO_MOVE_CAST(OutFilter)(out_filter_));
|
302
|
+
}
|
303
|
+
};
|
304
|
+
|
305
|
+
return result{this,
|
306
|
+
BOOST_ASIO_MOVE_CAST(InFilter)(reset.in_filter),
|
307
|
+
BOOST_ASIO_MOVE_CAST(OutFilter)(reset.out_filter)};
|
308
|
+
}
|
309
|
+
|
310
|
+
// This await transformation determines whether cancellation is propagated as
|
311
|
+
// an exception.
|
312
|
+
auto await_transform(this_coro::throw_if_cancelled_0_t)
|
313
|
+
noexcept
|
314
|
+
{
|
315
|
+
struct result
|
316
|
+
{
|
317
|
+
awaitable_frame_base* this_;
|
318
|
+
|
319
|
+
bool await_ready() const noexcept
|
320
|
+
{
|
321
|
+
return true;
|
322
|
+
}
|
323
|
+
|
324
|
+
void await_suspend(coroutine_handle<void>) noexcept
|
325
|
+
{
|
326
|
+
}
|
327
|
+
|
328
|
+
auto await_resume()
|
329
|
+
{
|
330
|
+
return this_->attached_thread_->throw_if_cancelled();
|
331
|
+
}
|
332
|
+
};
|
333
|
+
|
334
|
+
return result{this};
|
335
|
+
}
|
336
|
+
|
337
|
+
// This await transformation sets whether cancellation is propagated as an
|
338
|
+
// exception.
|
339
|
+
auto await_transform(this_coro::throw_if_cancelled_1_t throw_if_cancelled)
|
340
|
+
noexcept
|
341
|
+
{
|
342
|
+
struct result
|
343
|
+
{
|
344
|
+
awaitable_frame_base* this_;
|
345
|
+
bool value_;
|
346
|
+
|
347
|
+
bool await_ready() const noexcept
|
348
|
+
{
|
349
|
+
return true;
|
350
|
+
}
|
351
|
+
|
352
|
+
void await_suspend(coroutine_handle<void>) noexcept
|
353
|
+
{
|
354
|
+
}
|
355
|
+
|
356
|
+
auto await_resume()
|
357
|
+
{
|
358
|
+
this_->attached_thread_->throw_if_cancelled(value_);
|
359
|
+
}
|
360
|
+
};
|
361
|
+
|
362
|
+
return result{this, throw_if_cancelled.value};
|
363
|
+
}
|
364
|
+
|
182
365
|
// This await transformation is used to run an async operation's initiation
|
183
366
|
// function object after the coroutine has been suspended. This ensures that
|
184
367
|
// immediate resumption of the coroutine in another thread does not cause a
|
@@ -215,6 +398,31 @@ public:
|
|
215
398
|
return result{std::move(f), this};
|
216
399
|
}
|
217
400
|
|
401
|
+
// Access the awaitable thread's has_context_switched_ flag.
|
402
|
+
auto await_transform(detail::awaitable_thread_has_context_switched) noexcept
|
403
|
+
{
|
404
|
+
struct result
|
405
|
+
{
|
406
|
+
awaitable_frame_base* this_;
|
407
|
+
|
408
|
+
bool await_ready() const noexcept
|
409
|
+
{
|
410
|
+
return true;
|
411
|
+
}
|
412
|
+
|
413
|
+
void await_suspend(coroutine_handle<void>) noexcept
|
414
|
+
{
|
415
|
+
}
|
416
|
+
|
417
|
+
bool& await_resume() const noexcept
|
418
|
+
{
|
419
|
+
return this_->attached_thread_->entry_point()->has_context_switched_;
|
420
|
+
}
|
421
|
+
};
|
422
|
+
|
423
|
+
return result{this};
|
424
|
+
}
|
425
|
+
|
218
426
|
void attach_thread(awaitable_thread<Executor>* handler) noexcept
|
219
427
|
{
|
220
428
|
attached_thread_ = handler;
|
@@ -222,6 +430,7 @@ public:
|
|
222
430
|
|
223
431
|
awaitable_thread<Executor>* detach_thread() noexcept
|
224
432
|
{
|
433
|
+
attached_thread_->entry_point()->has_context_switched_ = true;
|
225
434
|
return std::exchange(attached_thread_, nullptr);
|
226
435
|
}
|
227
436
|
|
@@ -229,7 +438,7 @@ public:
|
|
229
438
|
{
|
230
439
|
caller_ = caller;
|
231
440
|
attached_thread_ = caller_->attached_thread_;
|
232
|
-
attached_thread_->top_of_stack_ = this;
|
441
|
+
attached_thread_->entry_point()->top_of_stack_ = this;
|
233
442
|
caller_->attached_thread_ = nullptr;
|
234
443
|
}
|
235
444
|
|
@@ -237,7 +446,7 @@ public:
|
|
237
446
|
{
|
238
447
|
if (caller_)
|
239
448
|
caller_->attached_thread_ = attached_thread_;
|
240
|
-
attached_thread_->top_of_stack_ = caller_;
|
449
|
+
attached_thread_->entry_point()->top_of_stack_ = caller_;
|
241
450
|
attached_thread_ = nullptr;
|
242
451
|
caller_ = nullptr;
|
243
452
|
}
|
@@ -332,25 +541,87 @@ public:
|
|
332
541
|
}
|
333
542
|
};
|
334
543
|
|
544
|
+
struct awaitable_thread_entry_point {};
|
545
|
+
|
546
|
+
template <typename Executor>
|
547
|
+
class awaitable_frame<awaitable_thread_entry_point, Executor>
|
548
|
+
: public awaitable_frame_base<Executor>
|
549
|
+
{
|
550
|
+
public:
|
551
|
+
awaitable_frame()
|
552
|
+
: top_of_stack_(0),
|
553
|
+
has_executor_(false),
|
554
|
+
has_context_switched_(false),
|
555
|
+
throw_if_cancelled_(true)
|
556
|
+
{
|
557
|
+
}
|
558
|
+
|
559
|
+
~awaitable_frame()
|
560
|
+
{
|
561
|
+
if (has_executor_)
|
562
|
+
u_.executor_.~Executor();
|
563
|
+
}
|
564
|
+
|
565
|
+
awaitable<awaitable_thread_entry_point, Executor> get_return_object()
|
566
|
+
{
|
567
|
+
this->coro_ = coroutine_handle<awaitable_frame>::from_promise(*this);
|
568
|
+
return awaitable<awaitable_thread_entry_point, Executor>(this);
|
569
|
+
};
|
570
|
+
|
571
|
+
void return_void()
|
572
|
+
{
|
573
|
+
}
|
574
|
+
|
575
|
+
void get()
|
576
|
+
{
|
577
|
+
this->caller_ = nullptr;
|
578
|
+
this->rethrow_exception();
|
579
|
+
}
|
580
|
+
|
581
|
+
private:
|
582
|
+
template <typename> friend class awaitable_frame_base;
|
583
|
+
template <typename, typename> friend class awaitable_handler_base;
|
584
|
+
template <typename> friend class awaitable_thread;
|
585
|
+
|
586
|
+
union u
|
587
|
+
{
|
588
|
+
u() {}
|
589
|
+
~u() {}
|
590
|
+
char c_;
|
591
|
+
Executor executor_;
|
592
|
+
} u_;
|
593
|
+
|
594
|
+
awaitable_frame_base<Executor>* top_of_stack_;
|
595
|
+
boost::asio::cancellation_slot parent_cancellation_slot_;
|
596
|
+
boost::asio::cancellation_state cancellation_state_;
|
597
|
+
bool has_executor_;
|
598
|
+
bool has_context_switched_;
|
599
|
+
bool throw_if_cancelled_;
|
600
|
+
};
|
601
|
+
|
335
602
|
template <typename Executor>
|
336
603
|
class awaitable_thread
|
337
604
|
{
|
338
605
|
public:
|
339
606
|
typedef Executor executor_type;
|
607
|
+
typedef cancellation_slot cancellation_slot_type;
|
340
608
|
|
341
609
|
// Construct from the entry point of a new thread of execution.
|
342
|
-
awaitable_thread(awaitable<
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
{
|
610
|
+
awaitable_thread(awaitable<awaitable_thread_entry_point, Executor> p,
|
611
|
+
const Executor& ex, cancellation_slot parent_cancel_slot,
|
612
|
+
cancellation_state cancel_state)
|
613
|
+
: bottom_of_stack_(std::move(p))
|
614
|
+
{
|
615
|
+
bottom_of_stack_.frame_->top_of_stack_ = bottom_of_stack_.frame_;
|
616
|
+
new (&bottom_of_stack_.frame_->u_.executor_) Executor(ex);
|
617
|
+
bottom_of_stack_.frame_->has_executor_ = true;
|
618
|
+
bottom_of_stack_.frame_->parent_cancellation_slot_ = parent_cancel_slot;
|
619
|
+
bottom_of_stack_.frame_->cancellation_state_ = cancel_state;
|
347
620
|
}
|
348
621
|
|
349
622
|
// Transfer ownership from another awaitable_thread.
|
350
623
|
awaitable_thread(awaitable_thread&& other) noexcept
|
351
|
-
: bottom_of_stack_(std::move(other.bottom_of_stack_))
|
352
|
-
top_of_stack_(std::exchange(other.top_of_stack_, nullptr)),
|
353
|
-
executor_(std::move(other.executor_))
|
624
|
+
: bottom_of_stack_(std::move(other.bottom_of_stack_))
|
354
625
|
{
|
355
626
|
}
|
356
627
|
|
@@ -361,23 +632,74 @@ public:
|
|
361
632
|
if (bottom_of_stack_.valid())
|
362
633
|
{
|
363
634
|
// Coroutine "stack unwinding" must be performed through the executor.
|
364
|
-
|
635
|
+
auto* bottom_frame = bottom_of_stack_.frame_;
|
636
|
+
(post)(bottom_frame->u_.executor_,
|
365
637
|
[a = std::move(bottom_of_stack_)]() mutable
|
366
638
|
{
|
367
|
-
awaitable<
|
639
|
+
(void)awaitable<awaitable_thread_entry_point, Executor>(
|
640
|
+
std::move(a));
|
368
641
|
});
|
369
642
|
}
|
370
643
|
}
|
371
644
|
|
645
|
+
awaitable_frame<awaitable_thread_entry_point, Executor>* entry_point()
|
646
|
+
{
|
647
|
+
return bottom_of_stack_.frame_;
|
648
|
+
}
|
649
|
+
|
372
650
|
executor_type get_executor() const noexcept
|
373
651
|
{
|
374
|
-
return executor_;
|
652
|
+
return bottom_of_stack_.frame_->u_.executor_;
|
653
|
+
}
|
654
|
+
|
655
|
+
cancellation_state get_cancellation_state() const noexcept
|
656
|
+
{
|
657
|
+
return bottom_of_stack_.frame_->cancellation_state_;
|
658
|
+
}
|
659
|
+
|
660
|
+
void reset_cancellation_state()
|
661
|
+
{
|
662
|
+
bottom_of_stack_.frame_->cancellation_state_ =
|
663
|
+
cancellation_state(bottom_of_stack_.frame_->parent_cancellation_slot_);
|
664
|
+
}
|
665
|
+
|
666
|
+
template <typename Filter>
|
667
|
+
void reset_cancellation_state(BOOST_ASIO_MOVE_ARG(Filter) filter)
|
668
|
+
{
|
669
|
+
bottom_of_stack_.frame_->cancellation_state_ =
|
670
|
+
cancellation_state(bottom_of_stack_.frame_->parent_cancellation_slot_,
|
671
|
+
BOOST_ASIO_MOVE_CAST(Filter)(filter));
|
672
|
+
}
|
673
|
+
|
674
|
+
template <typename InFilter, typename OutFilter>
|
675
|
+
void reset_cancellation_state(BOOST_ASIO_MOVE_ARG(InFilter) in_filter,
|
676
|
+
BOOST_ASIO_MOVE_ARG(OutFilter) out_filter)
|
677
|
+
{
|
678
|
+
bottom_of_stack_.frame_->cancellation_state_ =
|
679
|
+
cancellation_state(bottom_of_stack_.frame_->parent_cancellation_slot_,
|
680
|
+
BOOST_ASIO_MOVE_CAST(InFilter)(in_filter),
|
681
|
+
BOOST_ASIO_MOVE_CAST(OutFilter)(out_filter));
|
682
|
+
}
|
683
|
+
|
684
|
+
bool throw_if_cancelled() const
|
685
|
+
{
|
686
|
+
return bottom_of_stack_.frame_->throw_if_cancelled_;
|
687
|
+
}
|
688
|
+
|
689
|
+
void throw_if_cancelled(bool value)
|
690
|
+
{
|
691
|
+
bottom_of_stack_.frame_->throw_if_cancelled_ = value;
|
692
|
+
}
|
693
|
+
|
694
|
+
cancellation_slot_type get_cancellation_slot() const noexcept
|
695
|
+
{
|
696
|
+
return bottom_of_stack_.frame_->cancellation_state_.slot();
|
375
697
|
}
|
376
698
|
|
377
699
|
// Launch a new thread of execution.
|
378
700
|
void launch()
|
379
701
|
{
|
380
|
-
top_of_stack_->attach_thread(this);
|
702
|
+
bottom_of_stack_.frame_->top_of_stack_->attach_thread(this);
|
381
703
|
pump();
|
382
704
|
}
|
383
705
|
|
@@ -388,17 +710,19 @@ protected:
|
|
388
710
|
// has been transferred to another resumable_thread object.
|
389
711
|
void pump()
|
390
712
|
{
|
391
|
-
do
|
392
|
-
|
713
|
+
do
|
714
|
+
bottom_of_stack_.frame_->top_of_stack_->resume();
|
715
|
+
while (bottom_of_stack_.frame_ && bottom_of_stack_.frame_->top_of_stack_);
|
716
|
+
|
717
|
+
if (bottom_of_stack_.frame_)
|
393
718
|
{
|
394
|
-
awaitable<
|
719
|
+
awaitable<awaitable_thread_entry_point, Executor> a(
|
720
|
+
std::move(bottom_of_stack_));
|
395
721
|
a.frame_->rethrow_exception();
|
396
722
|
}
|
397
723
|
}
|
398
724
|
|
399
|
-
awaitable<
|
400
|
-
awaitable_frame_base<Executor>* top_of_stack_;
|
401
|
-
executor_type executor_;
|
725
|
+
awaitable<awaitable_thread_entry_point, Executor> bottom_of_stack_;
|
402
726
|
};
|
403
727
|
|
404
728
|
} // namespace detail
|
@@ -15,8 +15,7 @@
|
|
15
15
|
# pragma once
|
16
16
|
#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
|
17
17
|
|
18
|
-
#include <boost/asio/
|
19
|
-
#include <boost/asio/associated_executor.hpp>
|
18
|
+
#include <boost/asio/associator.hpp>
|
20
19
|
#include <boost/asio/detail/handler_alloc_helpers.hpp>
|
21
20
|
#include <boost/asio/detail/handler_cont_helpers.hpp>
|
22
21
|
#include <boost/asio/detail/handler_invoke_helpers.hpp>
|
@@ -92,7 +91,7 @@ namespace detail
|
|
92
91
|
const std::size_t bytes_transferred)
|
93
92
|
{
|
94
93
|
storage_.resize(previous_size_ + bytes_transferred);
|
95
|
-
handler_(ec, bytes_transferred);
|
94
|
+
BOOST_ASIO_MOVE_OR_LVALUE(ReadHandler)(handler_)(ec, bytes_transferred);
|
96
95
|
}
|
97
96
|
|
98
97
|
//private:
|
@@ -203,30 +202,18 @@ namespace detail
|
|
203
202
|
|
204
203
|
#if !defined(GENERATING_DOCUMENTATION)
|
205
204
|
|
206
|
-
template <typename
|
207
|
-
|
208
|
-
|
205
|
+
template <template <typename, typename> class Associator,
|
206
|
+
typename ReadHandler, typename DefaultCandidate>
|
207
|
+
struct associator<Associator,
|
208
|
+
detail::buffered_fill_handler<ReadHandler>,
|
209
|
+
DefaultCandidate>
|
210
|
+
: Associator<ReadHandler, DefaultCandidate>
|
209
211
|
{
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
const Allocator& a = Allocator()) BOOST_ASIO_NOEXCEPT
|
214
|
-
{
|
215
|
-
return associated_allocator<ReadHandler, Allocator>::get(h.handler_, a);
|
216
|
-
}
|
217
|
-
};
|
218
|
-
|
219
|
-
template <typename ReadHandler, typename Executor>
|
220
|
-
struct associated_executor<
|
221
|
-
detail::buffered_fill_handler<ReadHandler>, Executor>
|
222
|
-
: detail::associated_executor_forwarding_base<ReadHandler, Executor>
|
223
|
-
{
|
224
|
-
typedef typename associated_executor<ReadHandler, Executor>::type type;
|
225
|
-
|
226
|
-
static type get(const detail::buffered_fill_handler<ReadHandler>& h,
|
227
|
-
const Executor& ex = Executor()) BOOST_ASIO_NOEXCEPT
|
212
|
+
static typename Associator<ReadHandler, DefaultCandidate>::type get(
|
213
|
+
const detail::buffered_fill_handler<ReadHandler>& h,
|
214
|
+
const DefaultCandidate& c = DefaultCandidate()) BOOST_ASIO_NOEXCEPT
|
228
215
|
{
|
229
|
-
return
|
216
|
+
return Associator<ReadHandler, DefaultCandidate>::get(h.handler_, c);
|
230
217
|
}
|
231
218
|
};
|
232
219
|
|
@@ -314,14 +301,14 @@ namespace detail
|
|
314
301
|
if (ec || storage_.empty())
|
315
302
|
{
|
316
303
|
const std::size_t length = 0;
|
317
|
-
handler_(ec, length);
|
304
|
+
BOOST_ASIO_MOVE_OR_LVALUE(ReadHandler)(handler_)(ec, length);
|
318
305
|
}
|
319
306
|
else
|
320
307
|
{
|
321
308
|
const std::size_t bytes_copied = boost::asio::buffer_copy(
|
322
309
|
buffers_, storage_.data(), storage_.size());
|
323
310
|
storage_.consume(bytes_copied);
|
324
|
-
handler_(ec, bytes_copied);
|
311
|
+
BOOST_ASIO_MOVE_OR_LVALUE(ReadHandler)(handler_)(ec, bytes_copied);
|
325
312
|
}
|
326
313
|
}
|
327
314
|
|
@@ -449,38 +436,20 @@ namespace detail
|
|
449
436
|
|
450
437
|
#if !defined(GENERATING_DOCUMENTATION)
|
451
438
|
|
452
|
-
template <typename
|
453
|
-
typename
|
454
|
-
|
439
|
+
template <template <typename, typename> class Associator,
|
440
|
+
typename MutableBufferSequence, typename ReadHandler,
|
441
|
+
typename DefaultCandidate>
|
442
|
+
struct associator<Associator,
|
455
443
|
detail::buffered_read_some_handler<MutableBufferSequence, ReadHandler>,
|
456
|
-
|
444
|
+
DefaultCandidate>
|
445
|
+
: Associator<ReadHandler, DefaultCandidate>
|
457
446
|
{
|
458
|
-
|
459
|
-
|
460
|
-
static type get(
|
461
|
-
const detail::buffered_read_some_handler<
|
462
|
-
MutableBufferSequence, ReadHandler>& h,
|
463
|
-
const Allocator& a = Allocator()) BOOST_ASIO_NOEXCEPT
|
464
|
-
{
|
465
|
-
return associated_allocator<ReadHandler, Allocator>::get(h.handler_, a);
|
466
|
-
}
|
467
|
-
};
|
468
|
-
|
469
|
-
template <typename MutableBufferSequence,
|
470
|
-
typename ReadHandler, typename Executor>
|
471
|
-
struct associated_executor<
|
472
|
-
detail::buffered_read_some_handler<MutableBufferSequence, ReadHandler>,
|
473
|
-
Executor>
|
474
|
-
: detail::associated_executor_forwarding_base<ReadHandler, Executor>
|
475
|
-
{
|
476
|
-
typedef typename associated_executor<ReadHandler, Executor>::type type;
|
477
|
-
|
478
|
-
static type get(
|
447
|
+
static typename Associator<ReadHandler, DefaultCandidate>::type get(
|
479
448
|
const detail::buffered_read_some_handler<
|
480
449
|
MutableBufferSequence, ReadHandler>& h,
|
481
|
-
const
|
450
|
+
const DefaultCandidate& c = DefaultCandidate()) BOOST_ASIO_NOEXCEPT
|
482
451
|
{
|
483
|
-
return
|
452
|
+
return Associator<ReadHandler, DefaultCandidate>::get(h.handler_, c);
|
484
453
|
}
|
485
454
|
};
|
486
455
|
|