passenger 6.0.23 → 6.0.24
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG +26 -1
- data/Rakefile +7 -3
- data/bin/passenger-install-apache2-module +5 -0
- data/bin/passenger-install-nginx-module +17 -2
- data/build/apache2.rb +1 -1
- data/build/basics.rb +10 -4
- data/build/cxx_tests.rb +18 -7
- data/build/support/cxx_dependency_map.rb +40 -6
- data/build/test_basics.rb +4 -12
- data/package.json +1 -1
- data/passenger.gemspec +1 -1
- data/src/agent/Core/ApplicationPool/Group/InitializationAndShutdown.cpp +8 -0
- data/src/agent/Core/ApplicationPool/Group/InternalUtils.cpp +10 -2
- data/src/agent/Core/ApplicationPool/Group/LifetimeAndBasics.cpp +8 -0
- data/src/agent/Core/ApplicationPool/Group/Miscellaneous.cpp +9 -0
- data/src/agent/Core/ApplicationPool/Group/OutOfBandWork.cpp +9 -0
- data/src/agent/Core/ApplicationPool/Group/ProcessListManagement.cpp +63 -50
- data/src/agent/Core/ApplicationPool/Group/SessionManagement.cpp +19 -9
- data/src/agent/Core/ApplicationPool/Group/SpawningAndRestarting.cpp +8 -0
- data/src/agent/Core/ApplicationPool/Group/StateInspection.cpp +8 -0
- data/src/agent/Core/ApplicationPool/Group/Verification.cpp +8 -0
- data/src/agent/Core/ApplicationPool/Group.h +15 -5
- data/src/agent/Core/ApplicationPool/Pool/AnalyticsCollection.cpp +5 -0
- data/src/agent/Core/ApplicationPool/Pool/GarbageCollection.cpp +5 -0
- data/src/agent/Core/ApplicationPool/Pool/GeneralUtils.cpp +5 -0
- data/src/agent/Core/ApplicationPool/Pool/GroupUtils.cpp +5 -0
- data/src/agent/Core/ApplicationPool/Pool/InitializationAndShutdown.cpp +5 -0
- data/src/agent/Core/ApplicationPool/Pool/Miscellaneous.cpp +5 -0
- data/src/agent/Core/ApplicationPool/Pool/ProcessUtils.cpp +5 -0
- data/src/agent/Core/ApplicationPool/Pool/StateInspection.cpp +11 -1
- data/src/agent/Core/ApplicationPool/Pool.h +0 -2
- data/src/agent/Core/ApplicationPool/Process.h +22 -6
- data/src/agent/Core/ApplicationPool/Session.h +6 -1
- data/src/agent/Core/Config.h +7 -3
- data/src/agent/Core/Controller/Config.h +1 -1
- data/src/agent/Core/CoreMain.cpp +10 -17
- data/src/agent/Core/SpawningKit/Handshake/Prepare.h +1 -53
- data/src/agent/Core/SpawningKit/Handshake/Session.h +3 -0
- data/src/agent/Core/SpawningKit/Handshake/WorkDir.h +5 -2
- data/src/agent/Core/SpawningKit/SmartSpawner.h +6 -2
- data/src/agent/Core/SpawningKit/Spawner.h +4 -0
- data/src/agent/Shared/Fundamentals/AbortHandler.cpp +88 -9
- data/src/agent/Shared/Fundamentals/AbortHandler.h +2 -0
- data/src/agent/Shared/Fundamentals/Initialization.cpp +9 -3
- data/src/agent/Shared/Fundamentals/Initialization.h +3 -3
- data/src/agent/SpawnEnvSetupper/SpawnEnvSetupperMain.cpp +6 -7
- data/src/agent/Watchdog/Config.h +1 -1
- data/src/agent/Watchdog/WatchdogMain.cpp +4 -7
- data/src/apache2_module/ConfigGeneral/ManifestGeneration.h +5 -3
- data/src/apache2_module/DirConfig/AutoGeneratedStruct.h +3 -0
- data/src/apache2_module/DirConfig/AutoGeneratedStruct.h.cxxcodebuilder +3 -0
- data/src/apache2_module/ServerConfig/AutoGeneratedStruct.h +2 -1
- data/src/apache2_module/ServerConfig/AutoGeneratedStruct.h.cxxcodebuilder +2 -1
- data/src/cxx_supportlib/Constants.h +1 -1
- data/src/cxx_supportlib/DataStructures/StringMap.h +0 -1
- data/src/cxx_supportlib/FileTools/PathManip.cpp +1 -1
- data/src/cxx_supportlib/SafeLibev.h +1 -3
- data/src/cxx_supportlib/ServerKit/Hooks.h +2 -2
- data/src/cxx_supportlib/ServerKit/HttpHeaderParser.h +0 -1
- data/src/cxx_supportlib/ServerKit/HttpServer.h +15 -10
- data/src/cxx_supportlib/ServerKit/Server.h +0 -6
- data/src/cxx_supportlib/Utils/AsyncSignalSafeUtils.h +2 -0
- data/src/cxx_supportlib/Utils/SpeedMeter.h +0 -3
- data/src/cxx_supportlib/oxt/implementation.cpp +11 -0
- data/src/cxx_supportlib/oxt/system_calls.cpp +10 -3
- data/src/cxx_supportlib/oxt/thread.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/as_tuple.hpp +35 -9
- data/src/cxx_supportlib/vendor-modified/boost/asio/associated_immediate_executor.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/associator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/async_result.hpp +74 -68
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_datagram_socket.hpp +11 -11
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_deadline_timer.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_random_access_file.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_raw_socket.hpp +10 -10
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_readable_pipe.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_seq_packet_socket.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_serial_port.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_signal_set.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket_acceptor.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_stream_file.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_stream_socket.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_waitable_timer.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_writable_pipe.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/bind_allocator.hpp +88 -22
- data/src/cxx_supportlib/vendor-modified/boost/asio/bind_cancellation_slot.hpp +91 -22
- data/src/cxx_supportlib/vendor-modified/boost/asio/bind_executor.hpp +105 -23
- data/src/cxx_supportlib/vendor-modified/boost/asio/bind_immediate_executor.hpp +90 -23
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffer.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffer_registration.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/cancel_after.hpp +303 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/cancel_at.hpp +296 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/{experimental/impl/co_composed.hpp → co_composed.hpp} +208 -61
- data/src/cxx_supportlib/vendor-modified/boost/asio/completion_condition.hpp +49 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/compose.hpp +10 -201
- data/src/cxx_supportlib/vendor-modified/boost/asio/composed.hpp +415 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/connect.hpp +214 -48
- data/src/cxx_supportlib/vendor-modified/boost/asio/coroutine.hpp +3 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/default_completion_token.hpp +91 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/deferred.hpp +9 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/detached.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/buffered_stream_storage.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/{experimental/detail/channel_message.hpp → detail/completion_message.hpp} +14 -16
- data/src/cxx_supportlib/vendor-modified/boost/asio/{experimental/detail/channel_payload.hpp → detail/completion_payload.hpp} +30 -32
- data/src/cxx_supportlib/vendor-modified/boost/asio/{experimental/detail/channel_handler.hpp → detail/completion_payload_handler.hpp} +15 -13
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/config.hpp +26 -32
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/deadline_timer_service.hpp +5 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_alloc_helpers.hpp +14 -118
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/descriptor_ops.ipp +36 -33
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.ipp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/reactive_descriptor_service.ipp +7 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/reactive_socket_service_base.ipp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/socket_ops.ipp +44 -35
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/socket_select_interrupter.ipp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/initiation_base.hpp +64 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/memory.hpp +0 -11
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_descriptor_service.hpp +20 -16
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_send_op.hpp +0 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service_base.hpp +23 -18
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/recycling_allocator.hpp +9 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolve_endpoint_op.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolve_query_op.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/thread_info_base.hpp +11 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timed_cancel_op.hpp +363 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/wrapped_handler.hpp +29 -51
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/allocator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/blocking.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/blocking_adaptation.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/context.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/mapping.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/occupancy.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/outstanding_work.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/execution/relationship.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/basic_channel.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/basic_concurrent_channel.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/co_composed.hpp +2 -114
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/channel_receive_op.hpp +2 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/channel_send_functions.hpp +27 -19
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/channel_send_op.hpp +0 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/channel_service.hpp +17 -15
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/coro_promise_allocator.hpp +2 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/impl/channel_service.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/partial_promise.hpp +3 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/as_single.hpp +12 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/coro.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/parallel_group.hpp +38 -40
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/promise.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/use_coro.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/use_promise.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/immediate.hpp +144 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/append.hpp +14 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/as_tuple.hpp +45 -14
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/awaitable.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/cancel_after.hpp +270 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/cancel_at.hpp +270 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/co_spawn.hpp +8 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/connect.hpp +60 -166
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/consign.hpp +14 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/detached.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/prepend.hpp +14 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read.hpp +26 -177
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_at.hpp +16 -82
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_until.hpp +13 -286
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/redirect_error.hpp +55 -18
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/spawn.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write.hpp +26 -185
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write_at.hpp +16 -87
- data/src/cxx_supportlib/vendor-modified/boost/asio/io_context_strand.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/basic_resolver.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/detail/socket_option.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/address_v6.ipp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/placeholders.hpp +12 -6
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_descriptor.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_stream_descriptor.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/read.hpp +127 -28
- data/src/cxx_supportlib/vendor-modified/boost/asio/read_at.hpp +70 -20
- data/src/cxx_supportlib/vendor-modified/boost/asio/read_until.hpp +114 -36
- data/src/cxx_supportlib/vendor-modified/boost/asio/redirect_error.hpp +43 -3
- data/src/cxx_supportlib/vendor-modified/boost/asio/registered_buffer.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/spawn.hpp +0 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/impl/openssl_init.ipp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/context.ipp +10 -7
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/stream.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/asio/this_coro.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/use_awaitable.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/asio/use_future.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/uses_executor.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/version.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/asio/write.hpp +147 -35
- data/src/cxx_supportlib/vendor-modified/boost/asio/write_at.hpp +74 -22
- data/src/cxx_supportlib/vendor-modified/boost/asio.hpp +6 -0
- data/src/cxx_supportlib/vendor-modified/boost/assert/source_location.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/futex.hpp +42 -11
- data/src/cxx_supportlib/vendor-modified/boost/bind/bind.hpp +15 -37
- data/src/cxx_supportlib/vendor-modified/boost/container/adaptive_pool.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator_traits.hpp +151 -10
- data/src/cxx_supportlib/vendor-modified/boost/container/container_fwd.hpp +11 -9
- data/src/cxx_supportlib/vendor-modified/boost/container/deque.hpp +611 -102
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/adaptive_node_pool.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/adaptive_node_pool_impl.hpp +47 -47
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/advanced_insert_int.hpp +25 -24
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/allocation_type.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/block_list.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/block_slist.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/construct_in_place.hpp +35 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/copy_move_algo.hpp +14 -14
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/dispatch_uses_allocator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/flat_tree.hpp +55 -23
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/function_detector.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/is_container.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/is_contiguous_container.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/is_pair.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/iterators.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/math_functions.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/mpl.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/multiallocation_chain.hpp +96 -10
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/node_alloc_holder.hpp +19 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/node_pool.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/pair.hpp +17 -17
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/pool_common.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/pool_common_alloc.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/pool_resource.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/tree.hpp +86 -52
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/version_type.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/workaround.hpp +12 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/devector.hpp +145 -65
- data/src/cxx_supportlib/vendor-modified/boost/container/flat_map.hpp +105 -22
- data/src/cxx_supportlib/vendor-modified/boost/container/flat_set.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/list.hpp +30 -22
- data/src/cxx_supportlib/vendor-modified/boost/container/map.hpp +19 -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 +15 -8
- data/src/cxx_supportlib/vendor-modified/boost/container/node_handle.hpp +6 -5
- data/src/cxx_supportlib/vendor-modified/boost/container/options.hpp +15 -15
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/memory_resource.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/monotonic_buffer_resource.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/resource_adaptor.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/container/scoped_allocator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/set.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/slist.hpp +31 -24
- data/src/cxx_supportlib/vendor-modified/boost/container/small_vector.hpp +45 -43
- data/src/cxx_supportlib/vendor-modified/boost/container/stable_vector.hpp +45 -33
- data/src/cxx_supportlib/vendor-modified/boost/container/static_vector.hpp +5 -7
- data/src/cxx_supportlib/vendor-modified/boost/container/string.hpp +55 -47
- data/src/cxx_supportlib/vendor-modified/boost/container/uses_allocator.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/container/vector.hpp +222 -73
- data/src/cxx_supportlib/vendor-modified/boost/core/detail/minstd_rand.hpp +58 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/detail/string_view.hpp +13 -13
- data/src/cxx_supportlib/vendor-modified/boost/core/empty_value.hpp +53 -5
- data/src/cxx_supportlib/vendor-modified/boost/core/lightweight_test.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/pointer_in_range.hpp +49 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/span.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/type_name.hpp +7 -2
- data/src/cxx_supportlib/vendor-modified/boost/function/function_base.hpp +22 -34
- data/src/cxx_supportlib/vendor-modified/boost/function/function_template.hpp +141 -38
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/algorithm.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hash.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hook_traits.hpp +8 -6
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_traits.hpp +18 -18
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_lexical_streams.hpp +22 -17
- data/src/cxx_supportlib/vendor-modified/boost/libs/random/src/random_device.cpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/config_begin.hpp +0 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/launder.hpp +53 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/type_traits.hpp +9 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/workaround.hpp +6 -1
- data/src/cxx_supportlib/vendor-modified/boost/mp11/version.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/mpl/aux_/integral_wrapper.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/predef/version.h +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/requires_cxx11.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_has_gcc_intrinsics.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/system/detail/generic_category_message.hpp +13 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/concurrent_flat_map.hpp +13 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/concurrent_flat_map_fwd.hpp +15 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/concurrent_flat_set.hpp +13 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/concurrent_flat_set_fwd.hpp +15 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/fca.hpp +22 -6
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/foa/concurrent_table.hpp +38 -10
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/foa/core.hpp +111 -2
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/foa/cumulative_stats.hpp +177 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/foa/table.hpp +11 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/hash_traits.hpp +33 -7
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_flat_map.hpp +12 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_flat_map_fwd.hpp +15 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_flat_set.hpp +12 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_flat_set_fwd.hpp +14 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_map_fwd.hpp +19 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_node_map.hpp +12 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_node_map_fwd.hpp +15 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_node_set.hpp +12 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_node_set_fwd.hpp +14 -0
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_set_fwd.hpp +17 -0
- data/src/cxx_supportlib/vendor-modified/boost/utility/detail/minstd_rand.hpp +1 -43
- data/src/cxx_supportlib/vendor-modified/boost/version.hpp +2 -2
- data/src/ruby_supportlib/phusion_passenger/config/compile_nginx_engine_command.rb +6 -2
- data/src/ruby_supportlib/phusion_passenger/config/install_standalone_runtime_command.rb +10 -0
- data/src/ruby_supportlib/phusion_passenger/config/nginx_engine_compiler.rb +12 -4
- data/src/ruby_supportlib/phusion_passenger/platform_info/compiler.rb +32 -5
- data/src/ruby_supportlib/phusion_passenger/standalone/start_command.rb +0 -4
- data/src/ruby_supportlib/phusion_passenger/utils/json.rb +5 -1
- data/src/ruby_supportlib/phusion_passenger/utils.rb +5 -15
- data/src/ruby_supportlib/phusion_passenger.rb +5 -5
- metadata +21 -8
@@ -0,0 +1,303 @@
|
|
1
|
+
//
|
2
|
+
// cancel_after.hpp
|
3
|
+
// ~~~~~~~~~~~~~~~~
|
4
|
+
//
|
5
|
+
// Copyright (c) 2003-2024 Christopher M. Kohlhoff (chris at kohlhoff dot com)
|
6
|
+
//
|
7
|
+
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
8
|
+
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
9
|
+
//
|
10
|
+
|
11
|
+
#ifndef BOOST_ASIO_CANCEL_AFTER_HPP
|
12
|
+
#define BOOST_ASIO_CANCEL_AFTER_HPP
|
13
|
+
|
14
|
+
#if defined(_MSC_VER) && (_MSC_VER >= 1200)
|
15
|
+
# pragma once
|
16
|
+
#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
|
17
|
+
|
18
|
+
#include <boost/asio/detail/config.hpp>
|
19
|
+
#include <boost/asio/basic_waitable_timer.hpp>
|
20
|
+
#include <boost/asio/cancellation_type.hpp>
|
21
|
+
#include <boost/asio/detail/chrono.hpp>
|
22
|
+
#include <boost/asio/detail/type_traits.hpp>
|
23
|
+
#include <boost/asio/wait_traits.hpp>
|
24
|
+
|
25
|
+
#include <boost/asio/detail/push_options.hpp>
|
26
|
+
|
27
|
+
namespace boost {
|
28
|
+
namespace asio {
|
29
|
+
|
30
|
+
/// A @ref completion_token adapter that cancels an operation after a timeout.
|
31
|
+
/**
|
32
|
+
* The cancel_after_t class is used to indicate that an asynchronous operation
|
33
|
+
* should be cancelled if not complete before the specified duration has
|
34
|
+
* elapsed.
|
35
|
+
*/
|
36
|
+
template <typename CompletionToken, typename Clock,
|
37
|
+
typename WaitTraits = boost::asio::wait_traits<Clock>>
|
38
|
+
class cancel_after_t
|
39
|
+
{
|
40
|
+
public:
|
41
|
+
/// Constructor.
|
42
|
+
template <typename T>
|
43
|
+
cancel_after_t(T&& completion_token, const typename Clock::duration& timeout,
|
44
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
45
|
+
: token_(static_cast<T&&>(completion_token)),
|
46
|
+
timeout_(timeout),
|
47
|
+
cancel_type_(cancel_type)
|
48
|
+
{
|
49
|
+
}
|
50
|
+
|
51
|
+
//private:
|
52
|
+
CompletionToken token_;
|
53
|
+
typename Clock::duration timeout_;
|
54
|
+
cancellation_type_t cancel_type_;
|
55
|
+
};
|
56
|
+
|
57
|
+
/// A @ref completion_token adapter that cancels an operation after a timeout.
|
58
|
+
/**
|
59
|
+
* The cancel_after_timer class is used to indicate that an asynchronous
|
60
|
+
* operation should be cancelled if not complete before the specified duration
|
61
|
+
* has elapsed.
|
62
|
+
*/
|
63
|
+
template <typename CompletionToken, typename Clock,
|
64
|
+
typename WaitTraits = boost::asio::wait_traits<Clock>,
|
65
|
+
typename Executor = any_io_executor>
|
66
|
+
class cancel_after_timer
|
67
|
+
{
|
68
|
+
public:
|
69
|
+
/// Constructor.
|
70
|
+
template <typename T>
|
71
|
+
cancel_after_timer(T&& completion_token,
|
72
|
+
basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
73
|
+
const typename Clock::duration& timeout,
|
74
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
75
|
+
: token_(static_cast<T&&>(completion_token)),
|
76
|
+
timer_(timer),
|
77
|
+
timeout_(timeout),
|
78
|
+
cancel_type_(cancel_type)
|
79
|
+
{
|
80
|
+
}
|
81
|
+
|
82
|
+
//private:
|
83
|
+
CompletionToken token_;
|
84
|
+
basic_waitable_timer<Clock, WaitTraits, Executor>& timer_;
|
85
|
+
typename Clock::duration timeout_;
|
86
|
+
cancellation_type_t cancel_type_;
|
87
|
+
};
|
88
|
+
|
89
|
+
/// A function object type that adapts a @ref completion_token to cancel an
|
90
|
+
/// operation after a timeout.
|
91
|
+
/**
|
92
|
+
* May also be used directly as a completion token, in which case it adapts the
|
93
|
+
* asynchronous operation's default completion token (or boost::asio::deferred
|
94
|
+
* if no default is available).
|
95
|
+
*/
|
96
|
+
template <typename Clock, typename WaitTraits = boost::asio::wait_traits<Clock>>
|
97
|
+
class partial_cancel_after
|
98
|
+
{
|
99
|
+
public:
|
100
|
+
/// Constructor that specifies the timeout duration and cancellation type.
|
101
|
+
explicit partial_cancel_after(const typename Clock::duration& timeout,
|
102
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
103
|
+
: timeout_(timeout),
|
104
|
+
cancel_type_(cancel_type)
|
105
|
+
{
|
106
|
+
}
|
107
|
+
|
108
|
+
/// Adapt a @ref completion_token to specify that the completion handler
|
109
|
+
/// arguments should be combined into a single tuple argument.
|
110
|
+
template <typename CompletionToken>
|
111
|
+
BOOST_ASIO_NODISCARD inline
|
112
|
+
cancel_after_t<decay_t<CompletionToken>, Clock, WaitTraits>
|
113
|
+
operator()(CompletionToken&& completion_token) const
|
114
|
+
{
|
115
|
+
return cancel_after_t<decay_t<CompletionToken>, Clock, WaitTraits>(
|
116
|
+
static_cast<CompletionToken&&>(completion_token),
|
117
|
+
timeout_, cancel_type_);
|
118
|
+
}
|
119
|
+
|
120
|
+
//private:
|
121
|
+
typename Clock::duration timeout_;
|
122
|
+
cancellation_type_t cancel_type_;
|
123
|
+
};
|
124
|
+
|
125
|
+
/// A function object type that adapts a @ref completion_token to cancel an
|
126
|
+
/// operation after a timeout.
|
127
|
+
/**
|
128
|
+
* May also be used directly as a completion token, in which case it adapts the
|
129
|
+
* asynchronous operation's default completion token (or boost::asio::deferred
|
130
|
+
* if no default is available).
|
131
|
+
*/
|
132
|
+
template <typename Clock, typename WaitTraits = boost::asio::wait_traits<Clock>,
|
133
|
+
typename Executor = any_io_executor>
|
134
|
+
class partial_cancel_after_timer
|
135
|
+
{
|
136
|
+
public:
|
137
|
+
/// Constructor that specifies the timeout duration and cancellation type.
|
138
|
+
explicit partial_cancel_after_timer(
|
139
|
+
basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
140
|
+
const typename Clock::duration& timeout,
|
141
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
142
|
+
: timer_(timer),
|
143
|
+
timeout_(timeout),
|
144
|
+
cancel_type_(cancel_type)
|
145
|
+
{
|
146
|
+
}
|
147
|
+
|
148
|
+
/// Adapt a @ref completion_token to specify that the completion handler
|
149
|
+
/// arguments should be combined into a single tuple argument.
|
150
|
+
template <typename CompletionToken>
|
151
|
+
BOOST_ASIO_NODISCARD inline
|
152
|
+
cancel_after_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>
|
153
|
+
operator()(CompletionToken&& completion_token) const
|
154
|
+
{
|
155
|
+
return cancel_after_timer<decay_t<CompletionToken>,
|
156
|
+
Clock, WaitTraits, Executor>(
|
157
|
+
static_cast<CompletionToken&&>(completion_token),
|
158
|
+
timeout_, cancel_type_);
|
159
|
+
}
|
160
|
+
|
161
|
+
//private:
|
162
|
+
basic_waitable_timer<Clock, WaitTraits, Executor>& timer_;
|
163
|
+
typename Clock::duration timeout_;
|
164
|
+
cancellation_type_t cancel_type_;
|
165
|
+
};
|
166
|
+
|
167
|
+
/// Create a partial completion token adapter that cancels an operation if not
|
168
|
+
/// complete before the specified relative timeout has elapsed.
|
169
|
+
/**
|
170
|
+
* @par Thread Safety
|
171
|
+
* When an asynchronous operation is used with cancel_after, a timer async_wait
|
172
|
+
* operation is performed in parallel to the main operation. If this parallel
|
173
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
174
|
+
* main operation. Consequently, the application must ensure that the
|
175
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
176
|
+
*/
|
177
|
+
template <typename Rep, typename Period>
|
178
|
+
BOOST_ASIO_NODISCARD inline partial_cancel_after<chrono::steady_clock>
|
179
|
+
cancel_after(const chrono::duration<Rep, Period>& timeout,
|
180
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
181
|
+
{
|
182
|
+
return partial_cancel_after<chrono::steady_clock>(timeout, cancel_type);
|
183
|
+
}
|
184
|
+
|
185
|
+
/// Create a partial completion token adapter that cancels an operation if not
|
186
|
+
/// complete before the specified relative timeout has elapsed.
|
187
|
+
/**
|
188
|
+
* @par Thread Safety
|
189
|
+
* When an asynchronous operation is used with cancel_after, a timer async_wait
|
190
|
+
* operation is performed in parallel to the main operation. If this parallel
|
191
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
192
|
+
* main operation. Consequently, the application must ensure that the
|
193
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
194
|
+
*/
|
195
|
+
template <typename Clock, typename WaitTraits,
|
196
|
+
typename Executor, typename Rep, typename Period>
|
197
|
+
BOOST_ASIO_NODISCARD inline
|
198
|
+
partial_cancel_after_timer<Clock, WaitTraits, Executor>
|
199
|
+
cancel_after(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
200
|
+
const chrono::duration<Rep, Period>& timeout,
|
201
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
202
|
+
{
|
203
|
+
return partial_cancel_after_timer<Clock, WaitTraits, Executor>(
|
204
|
+
timer, timeout, cancel_type);
|
205
|
+
}
|
206
|
+
|
207
|
+
/// Adapt a @ref completion_token to cancel an operation if not complete before
|
208
|
+
/// the specified relative timeout has elapsed.
|
209
|
+
/**
|
210
|
+
* @par Thread Safety
|
211
|
+
* When an asynchronous operation is used with cancel_after, a timer async_wait
|
212
|
+
* operation is performed in parallel to the main operation. If this parallel
|
213
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
214
|
+
* main operation. Consequently, the application must ensure that the
|
215
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
216
|
+
*/
|
217
|
+
template <typename Rep, typename Period, typename CompletionToken>
|
218
|
+
BOOST_ASIO_NODISCARD inline
|
219
|
+
cancel_after_t<decay_t<CompletionToken>, chrono::steady_clock>
|
220
|
+
cancel_after(const chrono::duration<Rep, Period>& timeout,
|
221
|
+
CompletionToken&& completion_token)
|
222
|
+
{
|
223
|
+
return cancel_after_t<decay_t<CompletionToken>, chrono::steady_clock>(
|
224
|
+
static_cast<CompletionToken&&>(completion_token),
|
225
|
+
timeout, cancellation_type::terminal);
|
226
|
+
}
|
227
|
+
|
228
|
+
/// Adapt a @ref completion_token to cancel an operation if not complete before
|
229
|
+
/// the specified relative timeout has elapsed.
|
230
|
+
/**
|
231
|
+
* @par Thread Safety
|
232
|
+
* When an asynchronous operation is used with cancel_after, a timer async_wait
|
233
|
+
* operation is performed in parallel to the main operation. If this parallel
|
234
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
235
|
+
* main operation. Consequently, the application must ensure that the
|
236
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
237
|
+
*/
|
238
|
+
template <typename Rep, typename Period, typename CompletionToken>
|
239
|
+
BOOST_ASIO_NODISCARD inline
|
240
|
+
cancel_after_t<decay_t<CompletionToken>, chrono::steady_clock>
|
241
|
+
cancel_after(const chrono::duration<Rep, Period>& timeout,
|
242
|
+
cancellation_type_t cancel_type, CompletionToken&& completion_token)
|
243
|
+
{
|
244
|
+
return cancel_after_t<decay_t<CompletionToken>, chrono::steady_clock>(
|
245
|
+
static_cast<CompletionToken&&>(completion_token), timeout, cancel_type);
|
246
|
+
}
|
247
|
+
|
248
|
+
/// Adapt a @ref completion_token to cancel an operation if not complete before
|
249
|
+
/// the specified relative timeout has elapsed.
|
250
|
+
/**
|
251
|
+
* @par Thread Safety
|
252
|
+
* When an asynchronous operation is used with cancel_after, a timer async_wait
|
253
|
+
* operation is performed in parallel to the main operation. If this parallel
|
254
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
255
|
+
* main operation. Consequently, the application must ensure that the
|
256
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
257
|
+
*/
|
258
|
+
template <typename Clock, typename WaitTraits, typename Executor,
|
259
|
+
typename Rep, typename Period, typename CompletionToken>
|
260
|
+
BOOST_ASIO_NODISCARD inline
|
261
|
+
cancel_after_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>
|
262
|
+
cancel_after(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
263
|
+
const chrono::duration<Rep, Period>& timeout,
|
264
|
+
CompletionToken&& completion_token)
|
265
|
+
{
|
266
|
+
return cancel_after_timer<decay_t<CompletionToken>,
|
267
|
+
Clock, WaitTraits, Executor>(
|
268
|
+
static_cast<CompletionToken&&>(completion_token),
|
269
|
+
timer, timeout, cancellation_type::terminal);
|
270
|
+
}
|
271
|
+
|
272
|
+
/// Adapt a @ref completion_token to cancel an operation if not complete before
|
273
|
+
/// the specified relative timeout has elapsed.
|
274
|
+
/**
|
275
|
+
* @par Thread Safety
|
276
|
+
* When an asynchronous operation is used with cancel_after, a timer async_wait
|
277
|
+
* operation is performed in parallel to the main operation. If this parallel
|
278
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
279
|
+
* main operation. Consequently, the application must ensure that the
|
280
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
281
|
+
*/
|
282
|
+
template <typename Clock, typename WaitTraits, typename Executor,
|
283
|
+
typename Rep, typename Period, typename CompletionToken>
|
284
|
+
BOOST_ASIO_NODISCARD inline
|
285
|
+
cancel_after_timer<decay_t<CompletionToken>, chrono::steady_clock>
|
286
|
+
cancel_after(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
287
|
+
const chrono::duration<Rep, Period>& timeout,
|
288
|
+
cancellation_type_t cancel_type, CompletionToken&& completion_token)
|
289
|
+
{
|
290
|
+
return cancel_after_timer<decay_t<CompletionToken>,
|
291
|
+
Clock, WaitTraits, Executor>(
|
292
|
+
static_cast<CompletionToken&&>(completion_token),
|
293
|
+
timer, timeout, cancel_type);
|
294
|
+
}
|
295
|
+
|
296
|
+
} // namespace asio
|
297
|
+
} // namespace boost
|
298
|
+
|
299
|
+
#include <boost/asio/detail/pop_options.hpp>
|
300
|
+
|
301
|
+
#include <boost/asio/impl/cancel_after.hpp>
|
302
|
+
|
303
|
+
#endif // BOOST_ASIO_CANCEL_AFTER_HPP
|
@@ -0,0 +1,296 @@
|
|
1
|
+
//
|
2
|
+
// cancel_at.hpp
|
3
|
+
// ~~~~~~~~~~~~~
|
4
|
+
//
|
5
|
+
// Copyright (c) 2003-2024 Christopher M. Kohlhoff (chris at kohlhoff dot com)
|
6
|
+
//
|
7
|
+
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
8
|
+
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
9
|
+
//
|
10
|
+
|
11
|
+
#ifndef BOOST_ASIO_CANCEL_AT_HPP
|
12
|
+
#define BOOST_ASIO_CANCEL_AT_HPP
|
13
|
+
|
14
|
+
#if defined(_MSC_VER) && (_MSC_VER >= 1200)
|
15
|
+
# pragma once
|
16
|
+
#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
|
17
|
+
|
18
|
+
#include <boost/asio/detail/config.hpp>
|
19
|
+
#include <boost/asio/basic_waitable_timer.hpp>
|
20
|
+
#include <boost/asio/cancellation_type.hpp>
|
21
|
+
#include <boost/asio/detail/chrono.hpp>
|
22
|
+
#include <boost/asio/detail/type_traits.hpp>
|
23
|
+
#include <boost/asio/wait_traits.hpp>
|
24
|
+
|
25
|
+
#include <boost/asio/detail/push_options.hpp>
|
26
|
+
|
27
|
+
namespace boost {
|
28
|
+
namespace asio {
|
29
|
+
|
30
|
+
/// A @ref completion_token adapter that cancels an operation at a given time.
|
31
|
+
/**
|
32
|
+
* The cancel_at_t class is used to indicate that an asynchronous operation
|
33
|
+
* should be cancelled if not complete at the specified absolute time.
|
34
|
+
*/
|
35
|
+
template <typename CompletionToken, typename Clock,
|
36
|
+
typename WaitTraits = boost::asio::wait_traits<Clock>>
|
37
|
+
class cancel_at_t
|
38
|
+
{
|
39
|
+
public:
|
40
|
+
/// Constructor.
|
41
|
+
template <typename T>
|
42
|
+
cancel_at_t(T&& completion_token, const typename Clock::time_point& expiry,
|
43
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
44
|
+
: token_(static_cast<T&&>(completion_token)),
|
45
|
+
expiry_(expiry),
|
46
|
+
cancel_type_(cancel_type)
|
47
|
+
{
|
48
|
+
}
|
49
|
+
|
50
|
+
//private:
|
51
|
+
CompletionToken token_;
|
52
|
+
typename Clock::time_point expiry_;
|
53
|
+
cancellation_type_t cancel_type_;
|
54
|
+
};
|
55
|
+
|
56
|
+
/// A @ref completion_token adapter that cancels an operation at a given time.
|
57
|
+
/**
|
58
|
+
* The cancel_at_timer class is used to indicate that an asynchronous operation
|
59
|
+
* should be cancelled if not complete at the specified absolute time.
|
60
|
+
*/
|
61
|
+
template <typename CompletionToken, typename Clock,
|
62
|
+
typename WaitTraits = boost::asio::wait_traits<Clock>,
|
63
|
+
typename Executor = any_io_executor>
|
64
|
+
class cancel_at_timer
|
65
|
+
{
|
66
|
+
public:
|
67
|
+
/// Constructor.
|
68
|
+
template <typename T>
|
69
|
+
cancel_at_timer(T&& completion_token,
|
70
|
+
basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
71
|
+
const typename Clock::time_point& expiry,
|
72
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
73
|
+
: token_(static_cast<T&&>(completion_token)),
|
74
|
+
timer_(timer),
|
75
|
+
expiry_(expiry),
|
76
|
+
cancel_type_(cancel_type)
|
77
|
+
{
|
78
|
+
}
|
79
|
+
|
80
|
+
//private:
|
81
|
+
CompletionToken token_;
|
82
|
+
basic_waitable_timer<Clock, WaitTraits, Executor>& timer_;
|
83
|
+
typename Clock::time_point expiry_;
|
84
|
+
cancellation_type_t cancel_type_;
|
85
|
+
};
|
86
|
+
|
87
|
+
/// A function object type that adapts a @ref completion_token to cancel an
|
88
|
+
/// operation at a given time.
|
89
|
+
/**
|
90
|
+
* May also be used directly as a completion token, in which case it adapts the
|
91
|
+
* asynchronous operation's default completion token (or boost::asio::deferred
|
92
|
+
* if no default is available).
|
93
|
+
*/
|
94
|
+
template <typename Clock, typename WaitTraits = boost::asio::wait_traits<Clock>>
|
95
|
+
class partial_cancel_at
|
96
|
+
{
|
97
|
+
public:
|
98
|
+
/// Constructor that specifies the expiry and cancellation type.
|
99
|
+
explicit partial_cancel_at(const typename Clock::time_point& expiry,
|
100
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
101
|
+
: expiry_(expiry),
|
102
|
+
cancel_type_(cancel_type)
|
103
|
+
{
|
104
|
+
}
|
105
|
+
|
106
|
+
/// Adapt a @ref completion_token to specify that the completion handler
|
107
|
+
/// arguments should be combined into a single tuple argument.
|
108
|
+
template <typename CompletionToken>
|
109
|
+
BOOST_ASIO_NODISCARD inline
|
110
|
+
constexpr cancel_at_t<decay_t<CompletionToken>, Clock, WaitTraits>
|
111
|
+
operator()(CompletionToken&& completion_token) const
|
112
|
+
{
|
113
|
+
return cancel_at_t<decay_t<CompletionToken>, Clock, WaitTraits>(
|
114
|
+
static_cast<CompletionToken&&>(completion_token),
|
115
|
+
expiry_, cancel_type_);
|
116
|
+
}
|
117
|
+
|
118
|
+
//private:
|
119
|
+
typename Clock::time_point expiry_;
|
120
|
+
cancellation_type_t cancel_type_;
|
121
|
+
};
|
122
|
+
|
123
|
+
/// A function object type that adapts a @ref completion_token to cancel an
|
124
|
+
/// operation at a given time.
|
125
|
+
/**
|
126
|
+
* May also be used directly as a completion token, in which case it adapts the
|
127
|
+
* asynchronous operation's default completion token (or boost::asio::deferred
|
128
|
+
* if no default is available).
|
129
|
+
*/
|
130
|
+
template <typename Clock, typename WaitTraits = boost::asio::wait_traits<Clock>,
|
131
|
+
typename Executor = any_io_executor>
|
132
|
+
class partial_cancel_at_timer
|
133
|
+
{
|
134
|
+
public:
|
135
|
+
/// Constructor that specifies the expiry and cancellation type.
|
136
|
+
explicit partial_cancel_at_timer(
|
137
|
+
basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
138
|
+
const typename Clock::time_point& expiry,
|
139
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
140
|
+
: timer_(timer),
|
141
|
+
expiry_(expiry),
|
142
|
+
cancel_type_(cancel_type)
|
143
|
+
{
|
144
|
+
}
|
145
|
+
|
146
|
+
/// Adapt a @ref completion_token to specify that the completion handler
|
147
|
+
/// arguments should be combined into a single tuple argument.
|
148
|
+
template <typename CompletionToken>
|
149
|
+
BOOST_ASIO_NODISCARD inline
|
150
|
+
cancel_at_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>
|
151
|
+
operator()(CompletionToken&& completion_token) const
|
152
|
+
{
|
153
|
+
return cancel_at_timer<decay_t<CompletionToken>,
|
154
|
+
Clock, WaitTraits, Executor>(
|
155
|
+
static_cast<CompletionToken&&>(completion_token),
|
156
|
+
timer_, expiry_, cancel_type_);
|
157
|
+
}
|
158
|
+
|
159
|
+
//private:
|
160
|
+
basic_waitable_timer<Clock, WaitTraits, Executor>& timer_;
|
161
|
+
typename Clock::time_point expiry_;
|
162
|
+
cancellation_type_t cancel_type_;
|
163
|
+
};
|
164
|
+
|
165
|
+
/// Create a partial completion token adapter that cancels an operation if not
|
166
|
+
/// complete by the specified absolute time.
|
167
|
+
/**
|
168
|
+
* @par Thread Safety
|
169
|
+
* When an asynchronous operation is used with cancel_at, a timer async_wait
|
170
|
+
* operation is performed in parallel to the main operation. If this parallel
|
171
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
172
|
+
* main operation. Consequently, the application must ensure that the
|
173
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
174
|
+
*/
|
175
|
+
template <typename Clock, typename Duration>
|
176
|
+
BOOST_ASIO_NODISCARD inline partial_cancel_at<Clock>
|
177
|
+
cancel_at(const chrono::time_point<Clock, Duration>& expiry,
|
178
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
179
|
+
{
|
180
|
+
return partial_cancel_at<Clock>(expiry, cancel_type);
|
181
|
+
}
|
182
|
+
|
183
|
+
/// Create a partial completion token adapter that cancels an operation if not
|
184
|
+
/// complete by the specified absolute time.
|
185
|
+
/**
|
186
|
+
* @par Thread Safety
|
187
|
+
* When an asynchronous operation is used with cancel_at, a timer async_wait
|
188
|
+
* operation is performed in parallel to the main operation. If this parallel
|
189
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
190
|
+
* main operation. Consequently, the application must ensure that the
|
191
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
192
|
+
*/
|
193
|
+
template <typename Clock, typename WaitTraits,
|
194
|
+
typename Executor, typename Duration>
|
195
|
+
BOOST_ASIO_NODISCARD inline partial_cancel_at_timer<Clock, WaitTraits, Executor>
|
196
|
+
cancel_at(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
197
|
+
const chrono::time_point<Clock, Duration>& expiry,
|
198
|
+
cancellation_type_t cancel_type = cancellation_type::terminal)
|
199
|
+
{
|
200
|
+
return partial_cancel_at_timer<Clock, WaitTraits, Executor>(
|
201
|
+
timer, expiry, cancel_type);
|
202
|
+
}
|
203
|
+
|
204
|
+
/// Adapt a @ref completion_token to cancel an operation if not complete by the
|
205
|
+
/// specified absolute time.
|
206
|
+
/**
|
207
|
+
* @par Thread Safety
|
208
|
+
* When an asynchronous operation is used with cancel_at, a timer async_wait
|
209
|
+
* operation is performed in parallel to the main operation. If this parallel
|
210
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
211
|
+
* main operation. Consequently, the application must ensure that the
|
212
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
213
|
+
*/
|
214
|
+
template <typename CompletionToken, typename Clock, typename Duration>
|
215
|
+
BOOST_ASIO_NODISCARD inline cancel_at_t<decay_t<CompletionToken>, Clock>
|
216
|
+
cancel_at(const chrono::time_point<Clock, Duration>& expiry,
|
217
|
+
CompletionToken&& completion_token)
|
218
|
+
{
|
219
|
+
return cancel_at_t<decay_t<CompletionToken>, Clock>(
|
220
|
+
static_cast<CompletionToken&&>(completion_token),
|
221
|
+
expiry, cancellation_type::terminal);
|
222
|
+
}
|
223
|
+
|
224
|
+
/// Adapt a @ref completion_token to cancel an operation if not complete by the
|
225
|
+
/// specified absolute time.
|
226
|
+
/**
|
227
|
+
* @par Thread Safety
|
228
|
+
* When an asynchronous operation is used with cancel_at, a timer async_wait
|
229
|
+
* operation is performed in parallel to the main operation. If this parallel
|
230
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
231
|
+
* main operation. Consequently, the application must ensure that the
|
232
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
233
|
+
*/
|
234
|
+
template <typename CompletionToken, typename Clock, typename Duration>
|
235
|
+
BOOST_ASIO_NODISCARD inline cancel_at_t<decay_t<CompletionToken>, Clock>
|
236
|
+
cancel_at(const chrono::time_point<Clock, Duration>& expiry,
|
237
|
+
cancellation_type_t cancel_type, CompletionToken&& completion_token)
|
238
|
+
{
|
239
|
+
return cancel_at_t<decay_t<CompletionToken>, Clock>(
|
240
|
+
static_cast<CompletionToken&&>(completion_token), expiry, cancel_type);
|
241
|
+
}
|
242
|
+
|
243
|
+
/// Adapt a @ref completion_token to cancel an operation if not complete by the
|
244
|
+
/// specified absolute time.
|
245
|
+
/**
|
246
|
+
* @par Thread Safety
|
247
|
+
* When an asynchronous operation is used with cancel_at, a timer async_wait
|
248
|
+
* operation is performed in parallel to the main operation. If this parallel
|
249
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
250
|
+
* main operation. Consequently, the application must ensure that the
|
251
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
252
|
+
*/
|
253
|
+
template <typename CompletionToken, typename Clock,
|
254
|
+
typename WaitTraits, typename Executor, typename Duration>
|
255
|
+
BOOST_ASIO_NODISCARD inline
|
256
|
+
cancel_at_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>
|
257
|
+
cancel_at(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
258
|
+
const chrono::time_point<Clock, Duration>& expiry,
|
259
|
+
CompletionToken&& completion_token)
|
260
|
+
{
|
261
|
+
return cancel_at_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>(
|
262
|
+
static_cast<CompletionToken&&>(completion_token),
|
263
|
+
timer, expiry, cancellation_type::terminal);
|
264
|
+
}
|
265
|
+
|
266
|
+
/// Adapt a @ref completion_token to cancel an operation if not complete by the
|
267
|
+
/// specified absolute time.
|
268
|
+
/**
|
269
|
+
* @par Thread Safety
|
270
|
+
* When an asynchronous operation is used with cancel_at, a timer async_wait
|
271
|
+
* operation is performed in parallel to the main operation. If this parallel
|
272
|
+
* async_wait completes first, a cancellation request is emitted to cancel the
|
273
|
+
* main operation. Consequently, the application must ensure that the
|
274
|
+
* asynchronous operation is performed within an implicit or explicit strand.
|
275
|
+
*/
|
276
|
+
template <typename CompletionToken, typename Clock,
|
277
|
+
typename WaitTraits, typename Executor, typename Duration>
|
278
|
+
BOOST_ASIO_NODISCARD inline
|
279
|
+
cancel_at_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>
|
280
|
+
cancel_at(basic_waitable_timer<Clock, WaitTraits, Executor>& timer,
|
281
|
+
const chrono::time_point<Clock, Duration>& expiry,
|
282
|
+
cancellation_type_t cancel_type, CompletionToken&& completion_token)
|
283
|
+
{
|
284
|
+
return cancel_at_timer<decay_t<CompletionToken>, Clock, WaitTraits, Executor>(
|
285
|
+
static_cast<CompletionToken&&>(completion_token),
|
286
|
+
timer, expiry, cancel_type);
|
287
|
+
}
|
288
|
+
|
289
|
+
} // namespace asio
|
290
|
+
} // namespace boost
|
291
|
+
|
292
|
+
#include <boost/asio/detail/pop_options.hpp>
|
293
|
+
|
294
|
+
#include <boost/asio/impl/cancel_at.hpp>
|
295
|
+
|
296
|
+
#endif // BOOST_ASIO_CANCEL_AT_HPP
|