passenger 6.0.11 → 6.0.14

Sign up to get free protection for your applications and to get access to all the features.
Files changed (359) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG +83 -1
  3. data/CONTRIBUTORS +3 -0
  4. data/bin/passenger-install-nginx-module +1 -1
  5. data/bin/passenger-status +29 -4
  6. data/build/test_basics.rb +2 -2
  7. data/dev/copy_boost_headers +30 -15
  8. data/doc/templates/markdown.html.erb +2 -6
  9. data/package.json +19 -17
  10. data/resources/mime.types +1 -0
  11. data/resources/templates/error_renderer/with_details/dist/bundle.js +2 -33
  12. data/resources/templates/error_renderer/with_details/dist/styles.css +2 -2
  13. data/resources/templates/error_renderer/with_details/src/index.html.template +0 -2
  14. data/resources/templates/error_renderer/with_details/webpack.config.js +13 -16
  15. data/resources/templates/error_renderer/without_details/dist/bundle.js +0 -1
  16. data/resources/templates/error_renderer/without_details/dist/styles.css +1 -1
  17. data/resources/templates/error_renderer/without_details/webpack.config.js +13 -16
  18. data/resources/templates/standalone/server.erb +1 -0
  19. data/src/agent/Core/ApiServer.h +35 -0
  20. data/src/agent/Core/ApplicationPool/Group/StateInspection.cpp +1 -0
  21. data/src/agent/Core/ApplicationPool/Options.h +5 -0
  22. data/src/agent/Core/ApplicationPool/Pool.h +9 -1
  23. data/src/agent/Core/Config.h +2 -1
  24. data/src/agent/Core/Controller/CheckoutSession.cpp +24 -13
  25. data/src/agent/Core/Controller/Config.h +6 -2
  26. data/src/agent/Core/Controller/InitRequest.cpp +2 -0
  27. data/src/agent/Core/Controller/InternalUtils.cpp +32 -6
  28. data/src/agent/Core/Controller.h +4 -1
  29. data/src/agent/Core/OptionParser.h +4 -0
  30. data/src/agent/Core/SpawningKit/Config/AutoGeneratedCode.h +7 -0
  31. data/src/agent/Core/SpawningKit/Config.h +13 -0
  32. data/src/agent/Core/SpawningKit/Handshake/Prepare.h +4 -0
  33. data/src/agent/Core/SpawningKit/Spawner.h +1 -0
  34. data/src/agent/SpawnEnvSetupper/SpawnEnvSetupperMain.cpp +4 -0
  35. data/src/agent/Watchdog/Config.h +2 -1
  36. data/src/apache2_module/ConfigGeneral/AutoGeneratedDefinitions.cpp +5 -0
  37. data/src/apache2_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.cpp +5 -0
  38. data/src/apache2_module/ConfigGeneral/AutoGeneratedSetterFuncs.cpp +18 -0
  39. data/src/apache2_module/DirConfig/AutoGeneratedCreateFunction.cpp +3 -0
  40. data/src/apache2_module/DirConfig/AutoGeneratedHeaderSerialization.cpp +3 -0
  41. data/src/apache2_module/DirConfig/AutoGeneratedManifestGeneration.cpp +11 -0
  42. data/src/apache2_module/DirConfig/AutoGeneratedMergeFunction.cpp +7 -0
  43. data/src/apache2_module/DirConfig/AutoGeneratedStruct.h +17 -0
  44. data/src/apache2_module/Hooks.cpp +1 -0
  45. data/src/cxx_supportlib/Constants.h +1 -1
  46. data/src/cxx_supportlib/IOTools/IOUtils.cpp +4 -4
  47. data/src/cxx_supportlib/vendor-modified/boost/align/align.hpp +19 -0
  48. data/src/cxx_supportlib/vendor-modified/boost/align/aligned_alloc.hpp +47 -0
  49. data/src/cxx_supportlib/vendor-modified/boost/align/alignment_of.hpp +54 -0
  50. data/src/cxx_supportlib/vendor-modified/boost/align/alignment_of_forward.hpp +20 -0
  51. data/src/cxx_supportlib/vendor-modified/boost/align/detail/align_cxx11.hpp +21 -0
  52. data/src/cxx_supportlib/vendor-modified/boost/align/detail/aligned_alloc.hpp +52 -0
  53. data/src/cxx_supportlib/vendor-modified/boost/align/detail/aligned_alloc_posix.hpp +41 -0
  54. data/src/cxx_supportlib/vendor-modified/boost/align/detail/alignment_of.hpp +31 -0
  55. data/src/cxx_supportlib/vendor-modified/boost/align/detail/alignment_of_cxx11.hpp +23 -0
  56. data/src/cxx_supportlib/vendor-modified/boost/align/detail/element_type.hpp +91 -0
  57. data/src/cxx_supportlib/vendor-modified/boost/align/detail/integral_constant.hpp +53 -0
  58. data/src/cxx_supportlib/vendor-modified/boost/align/detail/is_alignment.hpp +28 -0
  59. data/src/cxx_supportlib/vendor-modified/boost/align/detail/min_size.hpp +26 -0
  60. data/src/cxx_supportlib/vendor-modified/boost/asio/associated_allocator.hpp +53 -1
  61. data/src/cxx_supportlib/vendor-modified/boost/asio/associated_cancellation_slot.hpp +179 -0
  62. data/src/cxx_supportlib/vendor-modified/boost/asio/associated_executor.hpp +57 -1
  63. data/src/cxx_supportlib/vendor-modified/boost/asio/associator.hpp +37 -0
  64. data/src/cxx_supportlib/vendor-modified/boost/asio/async_result.hpp +789 -106
  65. data/src/cxx_supportlib/vendor-modified/boost/asio/awaitable.hpp +1 -1
  66. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_datagram_socket.hpp +80 -0
  67. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_deadline_timer.hpp +10 -0
  68. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_raw_socket.hpp +80 -0
  69. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_seq_packet_socket.hpp +30 -0
  70. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket.hpp +20 -0
  71. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket_acceptor.hpp +90 -0
  72. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_stream_socket.hpp +60 -0
  73. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_waitable_timer.hpp +10 -0
  74. data/src/cxx_supportlib/vendor-modified/boost/asio/bind_cancellation_slot.hpp +723 -0
  75. data/src/cxx_supportlib/vendor-modified/boost/asio/bind_executor.hpp +191 -12
  76. data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_signal.hpp +361 -0
  77. data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_state.hpp +237 -0
  78. data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_type.hpp +176 -0
  79. data/src/cxx_supportlib/vendor-modified/boost/asio/co_spawn.hpp +30 -2
  80. data/src/cxx_supportlib/vendor-modified/boost/asio/connect.hpp +60 -0
  81. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/base_from_cancellation_state.hpp +165 -0
  82. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/bind_handler.hpp +209 -76
  83. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/config.hpp +149 -60
  84. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/deadline_timer_service.hpp +40 -0
  85. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/dev_poll_reactor.hpp +8 -4
  86. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/epoll_reactor.hpp +14 -4
  87. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/functional.hpp +6 -0
  88. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_alloc_helpers.hpp +14 -10
  89. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_type_requirements.hpp +21 -18
  90. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_work.hpp +30 -19
  91. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.hpp +8 -0
  92. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.ipp +14 -0
  93. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/epoll_reactor.hpp +20 -0
  94. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/epoll_reactor.ipp +30 -0
  95. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/kqueue_reactor.hpp +20 -0
  96. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/kqueue_reactor.ipp +29 -0
  97. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/select_reactor.hpp +24 -0
  98. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/select_reactor.ipp +19 -0
  99. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/strand_executor_service.hpp +3 -1
  100. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/timer_queue_ptime.ipp +6 -0
  101. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/kqueue_reactor.hpp +15 -5
  102. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/memory.hpp +60 -0
  103. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/pop_options.hpp +8 -0
  104. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/push_options.hpp +27 -0
  105. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_descriptor_service.hpp +93 -0
  106. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service.hpp +77 -0
  107. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service_base.hpp +111 -0
  108. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_op.hpp +4 -0
  109. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_op_queue.hpp +44 -0
  110. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/recycling_allocator.hpp +2 -1
  111. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolve_endpoint_op.hpp +2 -2
  112. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/select_reactor.hpp +14 -4
  113. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/thread_info_base.hpp +90 -24
  114. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue.hpp +30 -1
  115. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue_ptime.hpp +4 -0
  116. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/wait_op.hpp +5 -1
  117. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/work_dispatcher.hpp +5 -2
  118. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/any_executor.hpp +12 -12
  119. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/bulk_execute.hpp +10 -8
  120. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/connect.hpp +8 -8
  121. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/execute.hpp +7 -7
  122. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/schedule.hpp +7 -7
  123. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_done.hpp +7 -7
  124. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_error.hpp +7 -7
  125. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_value.hpp +13 -13
  126. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/start.hpp +7 -7
  127. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/submit.hpp +8 -8
  128. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/append.hpp +73 -0
  129. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/as_tuple.hpp +133 -0
  130. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/awaitable_operators.hpp +538 -0
  131. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/cancellation_condition.hpp +157 -0
  132. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/coro.hpp +1057 -0
  133. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/deferred.hpp +607 -0
  134. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/completion_handler_erasure.hpp +160 -0
  135. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/coro_promise_allocator.hpp +120 -0
  136. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/coro_traits.hpp +185 -0
  137. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/partial_promise.hpp +181 -0
  138. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/append.hpp +219 -0
  139. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/as_single.hpp +14 -28
  140. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/as_tuple.hpp +248 -0
  141. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/deferred.hpp +106 -0
  142. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/parallel_group.hpp +434 -0
  143. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/prepend.hpp +219 -0
  144. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/promise.hpp +100 -0
  145. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/parallel_group.hpp +217 -0
  146. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/prepend.hpp +73 -0
  147. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/promise.hpp +608 -0
  148. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/use_coro.hpp +284 -0
  149. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/awaitable.hpp +344 -20
  150. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/buffered_read_stream.hpp +23 -54
  151. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/buffered_write_stream.hpp +23 -54
  152. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/co_spawn.hpp +66 -18
  153. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/compose.hpp +55 -5
  154. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/connect.hpp +68 -80
  155. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/defer.hpp +8 -4
  156. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/dispatch.hpp +8 -4
  157. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/handler_alloc_hook.ipp +3 -2
  158. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/post.hpp +8 -4
  159. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read.hpp +98 -113
  160. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_at.hpp +71 -82
  161. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_until.hpp +210 -266
  162. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/redirect_error.hpp +248 -30
  163. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/spawn.hpp +11 -21
  164. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/use_awaitable.hpp +15 -3
  165. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write.hpp +71 -87
  166. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write_at.hpp +46 -68
  167. data/src/cxx_supportlib/vendor-modified/boost/asio/io_context.hpp +4 -4
  168. data/src/cxx_supportlib/vendor-modified/boost/asio/local/detail/impl/endpoint.ipp +2 -7
  169. data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_descriptor.hpp +10 -0
  170. data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_stream_descriptor.hpp +23 -3
  171. data/src/cxx_supportlib/vendor-modified/boost/asio/prefer.hpp +21 -21
  172. data/src/cxx_supportlib/vendor-modified/boost/asio/query.hpp +9 -9
  173. data/src/cxx_supportlib/vendor-modified/boost/asio/read.hpp +88 -0
  174. data/src/cxx_supportlib/vendor-modified/boost/asio/read_at.hpp +44 -0
  175. data/src/cxx_supportlib/vendor-modified/boost/asio/read_until.hpp +132 -0
  176. data/src/cxx_supportlib/vendor-modified/boost/asio/require.hpp +21 -21
  177. data/src/cxx_supportlib/vendor-modified/boost/asio/require_concept.hpp +9 -9
  178. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/buffered_handshake_op.hpp +1 -1
  179. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/engine.hpp +5 -0
  180. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/handshake_op.hpp +1 -1
  181. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/impl/engine.ipp +14 -0
  182. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/io.hpp +36 -27
  183. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/read_op.hpp +1 -1
  184. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/shutdown_op.hpp +2 -2
  185. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/stream_core.hpp +37 -0
  186. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/write_op.hpp +1 -1
  187. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/context.ipp +14 -7
  188. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/stream.hpp +73 -1
  189. data/src/cxx_supportlib/vendor-modified/boost/asio/system_executor.hpp +4 -4
  190. data/src/cxx_supportlib/vendor-modified/boost/asio/this_coro.hpp +235 -0
  191. data/src/cxx_supportlib/vendor-modified/boost/asio/thread_pool.hpp +4 -4
  192. data/src/cxx_supportlib/vendor-modified/boost/asio/use_awaitable.hpp +7 -10
  193. data/src/cxx_supportlib/vendor-modified/boost/asio/version.hpp +1 -1
  194. data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_random_access_handle.hpp +20 -0
  195. data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_stream_handle.hpp +20 -0
  196. data/src/cxx_supportlib/vendor-modified/boost/asio/write.hpp +88 -0
  197. data/src/cxx_supportlib/vendor-modified/boost/asio/write_at.hpp +44 -0
  198. data/src/cxx_supportlib/vendor-modified/boost/asio.hpp +6 -0
  199. data/src/cxx_supportlib/vendor-modified/boost/atomic/atomic_ref.hpp +14 -1
  200. data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/config.hpp +17 -13
  201. data/src/cxx_supportlib/vendor-modified/boost/atomic/ipc_atomic_ref.hpp +14 -1
  202. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx03.hpp +2 -5
  203. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx11.hpp +2 -5
  204. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx14.hpp +2 -2
  205. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx17.hpp +2 -2
  206. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx20.hpp +56 -0
  207. data/src/cxx_supportlib/vendor-modified/boost/config/auto_link.hpp +1 -5
  208. data/src/cxx_supportlib/vendor-modified/boost/config/compiler/common_edg.hpp +31 -11
  209. data/src/cxx_supportlib/vendor-modified/boost/config/detail/cxx_composite.hpp +20 -4
  210. data/src/cxx_supportlib/vendor-modified/boost/config/detail/select_platform_config.hpp +5 -0
  211. data/src/cxx_supportlib/vendor-modified/boost/config/detail/suffix.hpp +81 -0
  212. data/src/cxx_supportlib/vendor-modified/boost/config/platform/bsd.hpp +5 -8
  213. data/src/cxx_supportlib/vendor-modified/boost/config/platform/wasm.hpp +17 -0
  214. data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/dinkumware.hpp +26 -0
  215. data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libcpp.hpp +49 -0
  216. data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libstdcpp3.hpp +46 -4
  217. data/src/cxx_supportlib/vendor-modified/boost/container/adaptive_pool.hpp +2 -2
  218. data/src/cxx_supportlib/vendor-modified/boost/container/allocator.hpp +1 -1
  219. data/src/cxx_supportlib/vendor-modified/boost/container/detail/adaptive_node_pool.hpp +2 -2
  220. data/src/cxx_supportlib/vendor-modified/boost/container/detail/node_pool.hpp +2 -2
  221. data/src/cxx_supportlib/vendor-modified/boost/container/detail/std_fwd.hpp +3 -0
  222. data/src/cxx_supportlib/vendor-modified/boost/container/devector.hpp +2 -2
  223. data/src/cxx_supportlib/vendor-modified/boost/container/new_allocator.hpp +1 -1
  224. data/src/cxx_supportlib/vendor-modified/boost/container/node_allocator.hpp +1 -1
  225. data/src/cxx_supportlib/vendor-modified/boost/container/pmr/polymorphic_allocator.hpp +6 -6
  226. data/src/cxx_supportlib/vendor-modified/boost/container/static_vector.hpp +4 -4
  227. data/src/cxx_supportlib/vendor-modified/boost/container/throw_exception.hpp +45 -38
  228. data/src/cxx_supportlib/vendor-modified/boost/container/vector.hpp +24 -0
  229. data/src/cxx_supportlib/vendor-modified/boost/core/ignore_unused.hpp +32 -2
  230. data/src/cxx_supportlib/vendor-modified/boost/core/uncaught_exceptions.hpp +7 -7
  231. data/src/cxx_supportlib/vendor-modified/boost/date_time/compiler_config.hpp +0 -24
  232. data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/time_parsers.hpp +4 -0
  233. data/src/cxx_supportlib/vendor-modified/boost/intrusive/any_hook.hpp +4 -4
  234. data/src/cxx_supportlib/vendor-modified/boost/intrusive/avl_set.hpp +83 -83
  235. data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree.hpp +43 -43
  236. data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree_algorithms.hpp +31 -31
  237. data/src/cxx_supportlib/vendor-modified/boost/intrusive/bs_set.hpp +85 -85
  238. data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree.hpp +68 -68
  239. data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree_algorithms.hpp +72 -62
  240. data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_list_algorithms.hpp +19 -20
  241. data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_slist_algorithms.hpp +19 -19
  242. data/src/cxx_supportlib/vendor-modified/boost/intrusive/derivation_value_traits.hpp +4 -4
  243. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/any_node_and_algorithms.hpp +2 -2
  244. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/bstree_algorithms_base.hpp +3 -3
  245. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/common_slist_algorithms.hpp +5 -5
  246. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/config_begin.hpp +1 -0
  247. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/generic_hook.hpp +8 -8
  248. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hash_combine.hpp +2 -4
  249. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hashtable_node.hpp +1 -1
  250. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/math.hpp +2 -50
  251. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/node_cloner_disposer.hpp +1 -1
  252. data/src/cxx_supportlib/vendor-modified/boost/intrusive/hashtable.hpp +71 -70
  253. data/src/cxx_supportlib/vendor-modified/boost/intrusive/linear_slist_algorithms.hpp +15 -14
  254. data/src/cxx_supportlib/vendor-modified/boost/intrusive/list.hpp +84 -82
  255. data/src/cxx_supportlib/vendor-modified/boost/intrusive/list_hook.hpp +10 -10
  256. data/src/cxx_supportlib/vendor-modified/boost/intrusive/member_value_traits.hpp +4 -4
  257. data/src/cxx_supportlib/vendor-modified/boost/intrusive/parent_from_member.hpp +2 -2
  258. data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_plus_bits.hpp +4 -4
  259. data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_traits.hpp +18 -18
  260. data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree.hpp +43 -43
  261. data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree_algorithms.hpp +26 -26
  262. data/src/cxx_supportlib/vendor-modified/boost/intrusive/set.hpp +85 -85
  263. data/src/cxx_supportlib/vendor-modified/boost/intrusive/set_hook.hpp +12 -12
  264. data/src/cxx_supportlib/vendor-modified/boost/intrusive/sg_set.hpp +93 -93
  265. data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree.hpp +51 -51
  266. data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree_algorithms.hpp +24 -24
  267. data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist.hpp +104 -104
  268. data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist_hook.hpp +8 -6
  269. data/src/cxx_supportlib/vendor-modified/boost/intrusive/splay_set.hpp +91 -91
  270. data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree.hpp +46 -46
  271. data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree_algorithms.hpp +31 -31
  272. data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap.hpp +51 -51
  273. data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_algorithms.hpp +18 -18
  274. data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_set.hpp +97 -97
  275. data/src/cxx_supportlib/vendor-modified/boost/intrusive/trivial_value_traits.hpp +6 -4
  276. data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set.hpp +63 -63
  277. data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set_hook.hpp +15 -15
  278. data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_numeric.hpp +4 -1
  279. data/src/cxx_supportlib/vendor-modified/boost/move/detail/config_begin.hpp +1 -0
  280. data/src/cxx_supportlib/vendor-modified/boost/move/detail/iterator_traits.hpp +1 -0
  281. data/src/cxx_supportlib/vendor-modified/boost/move/detail/nsec_clock.hpp +1 -1
  282. data/src/cxx_supportlib/vendor-modified/boost/operators.hpp +2 -0
  283. data/src/cxx_supportlib/vendor-modified/boost/regex/concepts.hpp +1 -1
  284. data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_parser.hpp +3 -0
  285. data/src/cxx_supportlib/vendor-modified/boost/regex/v4/unicode_iterator.hpp +112 -31
  286. data/src/cxx_supportlib/vendor-modified/boost/regex/v5/basic_regex_parser.hpp +3 -0
  287. data/src/cxx_supportlib/vendor-modified/boost/regex/v5/mem_block_cache.hpp +4 -8
  288. data/src/cxx_supportlib/vendor-modified/boost/regex/v5/unicode_iterator.hpp +0 -2
  289. data/src/cxx_supportlib/vendor-modified/boost/regex/v5/w32_regex_traits.hpp +6 -2
  290. data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/shared_count.hpp +1 -1
  291. data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_impl.hpp +22 -2
  292. data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/shared_ptr.hpp +59 -1
  293. data/src/cxx_supportlib/vendor-modified/boost/system/detail/config.hpp +9 -11
  294. data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_category.hpp +27 -21
  295. data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_category_impl.hpp +34 -3
  296. data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_code.hpp +378 -36
  297. data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_condition.hpp +97 -21
  298. data/src/cxx_supportlib/vendor-modified/boost/system/detail/interop_category.hpp +107 -0
  299. data/src/cxx_supportlib/vendor-modified/boost/system/detail/is_same.hpp +33 -0
  300. data/src/cxx_supportlib/vendor-modified/boost/system/detail/snprintf.hpp +70 -0
  301. data/src/cxx_supportlib/vendor-modified/boost/system/detail/{to_std_category.hpp → std_category.hpp} +5 -55
  302. data/src/cxx_supportlib/vendor-modified/boost/system/detail/system_category_impl.hpp +2 -12
  303. data/src/cxx_supportlib/vendor-modified/boost/system/error_code.hpp +0 -33
  304. data/src/cxx_supportlib/vendor-modified/boost/utility/detail/result_of_variadic.hpp +190 -0
  305. data/src/cxx_supportlib/vendor-modified/boost/utility/result_of.hpp +20 -9
  306. data/src/cxx_supportlib/vendor-modified/boost/utility/string_view.hpp +3 -1
  307. data/src/cxx_supportlib/vendor-modified/boost/version.hpp +2 -2
  308. data/src/nginx_module/ConfigGeneral/AutoGeneratedDefinitions.c +16 -0
  309. data/src/nginx_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.c +12 -0
  310. data/src/nginx_module/ConfigGeneral/AutoGeneratedSetterFuncs.c +24 -0
  311. data/src/nginx_module/LocationConfig/AutoGeneratedCreateFunction.c +10 -0
  312. data/src/nginx_module/LocationConfig/AutoGeneratedHeaderSerialization.c +39 -0
  313. data/src/nginx_module/LocationConfig/AutoGeneratedManifestGeneration.c +26 -0
  314. data/src/nginx_module/LocationConfig/AutoGeneratedMergeFunction.c +6 -0
  315. data/src/nginx_module/LocationConfig/AutoGeneratedStruct.h +8 -0
  316. data/src/nginx_module/ngx_http_passenger_module.c +1 -0
  317. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/common.js +50 -29
  318. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/config/cli-config.js +20 -20
  319. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/config/npm-config.js +11 -11
  320. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/config/syslog-config.js +3 -3
  321. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/config.js +8 -2
  322. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/container.js +2 -1
  323. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/logger.js +174 -146
  324. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/console.js +4 -2
  325. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/file.js +15 -5
  326. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/http.js +14 -4
  327. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports.js +26 -24
  328. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston.js +5 -5
  329. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/async/package.json +4 -13
  330. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/colors/package.json +19 -33
  331. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/cycle/package.json +11 -29
  332. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/eyes/package.json +12 -40
  333. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/isstream/package.json +3 -12
  334. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/stack-trace/lib/stack-trace.js +49 -24
  335. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/stack-trace/package.json +4 -16
  336. data/src/nodejs_supportlib/vendor-copy/winston/package.json +11 -55
  337. data/src/ruby_supportlib/phusion_passenger/admin_tools/instance_registry.rb +3 -2
  338. data/src/ruby_supportlib/phusion_passenger/apache2/config_options.rb +6 -0
  339. data/src/ruby_supportlib/phusion_passenger/config/restart_app_command.rb +16 -12
  340. data/src/ruby_supportlib/phusion_passenger/console_text_template.rb +7 -2
  341. data/src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb +8 -1
  342. data/src/ruby_supportlib/phusion_passenger/nginx/config_options.rb +12 -0
  343. data/src/ruby_supportlib/phusion_passenger/packaging.rb +2 -1
  344. data/src/ruby_supportlib/phusion_passenger/platform_info/linux.rb +2 -1
  345. data/src/ruby_supportlib/phusion_passenger/platform_info/openssl.rb +1 -1
  346. data/src/ruby_supportlib/phusion_passenger/platform_info/operating_system.rb +8 -0
  347. data/src/ruby_supportlib/phusion_passenger/request_handler/thread_handler.rb +18 -18
  348. data/src/ruby_supportlib/phusion_passenger/request_handler.rb +4 -1
  349. data/src/ruby_supportlib/phusion_passenger/standalone/config_options_list.rb +7 -1
  350. data/src/ruby_supportlib/phusion_passenger/standalone/start_command/builtin_engine.rb +1 -0
  351. data/src/ruby_supportlib/phusion_passenger/standalone/start_command/nginx_engine.rb +28 -17
  352. data/src/ruby_supportlib/phusion_passenger.rb +5 -5
  353. metadata +49 -9
  354. data/src/cxx_supportlib/vendor-modified/boost/system/detail/is_generic_value.hpp +0 -125
  355. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/daily-rotate-file.js +0 -601
  356. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/webhook.js +0 -146
  357. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/pkginfo/LICENSE +0 -19
  358. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/pkginfo/lib/pkginfo.js +0 -136
  359. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/pkginfo/package.json +0 -56
@@ -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<void, Executor> p, const Executor& ex)
343
- : bottom_of_stack_(std::move(p)),
344
- top_of_stack_(bottom_of_stack_.frame_),
345
- executor_(ex)
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
- (post)(executor_,
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<void, Executor>(std::move(a));
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 top_of_stack_->resume(); while (top_of_stack_);
392
- if (bottom_of_stack_.valid())
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<void, Executor> a(std::move(bottom_of_stack_));
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<void, Executor> bottom_of_stack_;
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/associated_allocator.hpp>
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 ReadHandler, typename Allocator>
207
- struct associated_allocator<
208
- detail::buffered_fill_handler<ReadHandler>, Allocator>
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
- typedef typename associated_allocator<ReadHandler, Allocator>::type type;
211
-
212
- static type get(const detail::buffered_fill_handler<ReadHandler>& h,
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 associated_executor<ReadHandler, Executor>::get(h.handler_, ex);
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 MutableBufferSequence,
453
- typename ReadHandler, typename Allocator>
454
- struct associated_allocator<
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
- Allocator>
444
+ DefaultCandidate>
445
+ : Associator<ReadHandler, DefaultCandidate>
457
446
  {
458
- typedef typename associated_allocator<ReadHandler, Allocator>::type type;
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 Executor& ex = Executor()) BOOST_ASIO_NOEXCEPT
450
+ const DefaultCandidate& c = DefaultCandidate()) BOOST_ASIO_NOEXCEPT
482
451
  {
483
- return associated_executor<ReadHandler, Executor>::get(h.handler_, ex);
452
+ return Associator<ReadHandler, DefaultCandidate>::get(h.handler_, c);
484
453
  }
485
454
  };
486
455