passenger 6.0.27 → 6.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG +42 -2
- data/CONTRIBUTORS +2 -0
- data/Rakefile +6 -13
- data/bin/passenger-install-apache2-module +21 -22
- data/bin/passenger-install-nginx-module +50 -47
- data/bin/passenger-status +9 -10
- data/build/common_library.rb +4 -4
- data/build/support/cxx_dependency_map.rb +3 -621
- data/build/support/vendor/cxxcodebuilder/lib/cxxcodebuilder/builder.rb +1 -1
- data/build/test_basics.rb +4 -3
- data/dev/copy_boost_headers +54 -40
- data/dev/index_cxx_dependencies.rb +4 -0
- data/dev/ruby_server.rb +1 -1
- data/package.json +1 -1
- data/src/agent/Core/ApplicationPool/Implementation.cpp +1 -1
- data/src/agent/Core/ApplicationPool/Socket.h +3 -3
- data/src/agent/Core/ApplicationPool/TestSession.h +3 -4
- data/src/agent/Core/Config.h +1 -6
- data/src/agent/Core/Controller/Config.h +1 -1
- data/src/agent/Core/CoreMain.cpp +1 -0
- data/src/agent/Core/SecurityUpdateChecker.h +10 -1
- data/src/agent/Core/SpawningKit/Exceptions.h +0 -1
- data/src/agent/Core/SpawningKit/Handshake/Perform.h +13 -2
- data/src/agent/Shared/Fundamentals/AbortHandler.cpp +23 -5
- data/src/agent/Shared/Fundamentals/AbortHandler.h +10 -22
- data/src/agent/Shared/Fundamentals/Initialization.cpp +1 -0
- data/src/agent/Watchdog/Config.h +1 -1
- data/src/apache2_module/ConfigGeneral/AutoGeneratedDefinitions.cpp +5 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.cpp +5 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedSetterFuncs.cpp +14 -0
- data/src/apache2_module/DirConfig/AutoGeneratedCreateFunction.cpp +3 -0
- data/src/apache2_module/DirConfig/AutoGeneratedHeaderSerialization.cpp +3 -0
- data/src/apache2_module/DirConfig/AutoGeneratedManifestGeneration.cpp +11 -0
- data/src/apache2_module/DirConfig/AutoGeneratedMergeFunction.cpp +7 -0
- data/src/apache2_module/DirConfig/AutoGeneratedStruct.h +17 -0
- data/src/apache2_module/Hooks.cpp +0 -6
- data/src/cxx_supportlib/ConfigKit/IN_PRACTICE.md +2 -12
- data/src/cxx_supportlib/ConfigKit/Store.h +1 -6
- data/src/cxx_supportlib/Constants.h +1 -1
- data/src/cxx_supportlib/DataStructures/StringKeyTable.h +1 -7
- data/src/cxx_supportlib/Exceptions.cpp +178 -0
- data/src/cxx_supportlib/Exceptions.h +62 -177
- data/src/cxx_supportlib/IOTools/IOUtils.cpp +255 -228
- data/src/cxx_supportlib/IOTools/IOUtils.h +84 -121
- data/src/cxx_supportlib/ServerKit/Config.h +1 -6
- data/src/cxx_supportlib/ServerKit/FileBufferedChannel.h +1 -1
- data/src/cxx_supportlib/StaticString.h +1 -6
- data/src/cxx_supportlib/Utils/Curl.h +1 -6
- data/src/cxx_supportlib/Utils/ScopeGuard.h +0 -32
- data/src/cxx_supportlib/oxt/implementation.cpp +2 -2
- data/src/cxx_supportlib/oxt/spin_lock.hpp +94 -23
- data/src/cxx_supportlib/vendor-modified/boost/assert/source_location.hpp +8 -1
- data/src/cxx_supportlib/vendor-modified/boost/assert.hpp +6 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/atomic.hpp +94 -110
- data/src/cxx_supportlib/vendor-modified/boost/atomic/atomic_flag.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/atomic_ref.hpp +14 -14
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/addressof.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/atomic_flag_impl.hpp +52 -24
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/atomic_impl.hpp +641 -285
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/atomic_ref_impl.hpp +593 -260
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/bitwise_cast.hpp +37 -24
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/bitwise_fp_cast.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/cas_based_exchange.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/chrono.hpp +93 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/classify.hpp +16 -17
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/config.hpp +25 -34
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_gcc_aarch32.hpp +204 -97
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_gcc_aarch64.hpp +251 -122
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_gcc_alpha.hpp +56 -56
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_gcc_arm.hpp +129 -129
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_gcc_ppc.hpp +253 -125
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_gcc_sparc.hpp +25 -25
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_gcc_x86.hpp +193 -126
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_msvc_arm.hpp +57 -57
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_arch_ops_msvc_x86.hpp +96 -97
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_operations_emulated.hpp +24 -24
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_ops_cas_based.hpp +10 -10
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_ops_gcc_atomic.hpp +27 -24
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_ops_gcc_sync.hpp +39 -37
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/core_ops_linux_arm.hpp +17 -17
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extending_cas_based_arithmetic.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_fp_ops_emulated.hpp +12 -12
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_fp_ops_generic.hpp +21 -21
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_emulated.hpp +30 -30
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_gcc_aarch32.hpp +170 -98
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_gcc_aarch64.hpp +209 -119
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_gcc_arm.hpp +95 -95
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_gcc_ppc.hpp +148 -76
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_gcc_x86.hpp +293 -123
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_generic.hpp +87 -71
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_msvc_arm.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/extra_ops_msvc_x86.hpp +88 -88
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_operations.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_gcc_aarch32.hpp +4 -5
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_gcc_aarch64.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_gcc_alpha.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_gcc_arm.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_gcc_ppc.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_gcc_sparc.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_gcc_x86.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_msvc_arm.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_arch_ops_msvc_x86.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_operations.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_operations_emulated.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_ops_gcc_atomic.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_ops_gcc_sync.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fence_ops_linux_arm.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fp_ops_emulated.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/fp_ops_generic.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/futex.hpp +110 -49
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/gcc_atomic_memory_order_utils.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/has_posix_clock_traits.hpp +51 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/int_sizes.hpp +26 -32
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/integral_conversions.hpp +15 -15
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/interlocked.hpp +69 -30
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/intptr.hpp +8 -8
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/lock_pool.hpp +51 -31
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/memory_order_utils.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/once_flag.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_arm_common.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/ops_gcc_ppc_common.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/platform.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/storage_traits.hpp +31 -31
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/alignment_of.hpp +2 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/has_unique_object_representations.hpp +2 -5
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_floating_point.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_iec559.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_integral.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_signed.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_trivially_copyable.hpp +20 -13
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_trivially_default_constructible.hpp +13 -13
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/make_signed.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/make_unsigned.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/wait_ops_darwin_ulock.hpp +90 -16
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/wait_ops_dragonfly_umtx.hpp +80 -11
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/wait_ops_emulated.hpp +160 -15
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/wait_ops_freebsd_umtx.hpp +327 -38
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/wait_ops_futex.hpp +276 -33
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/wait_ops_generic.hpp +260 -20
- data/src/cxx_supportlib/vendor-modified/boost/atomic/fences.hpp +4 -3
- data/src/cxx_supportlib/vendor-modified/boost/atomic/ipc_atomic.hpp +14 -18
- data/src/cxx_supportlib/vendor-modified/boost/atomic/ipc_atomic_flag.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/atomic/ipc_atomic_ref.hpp +13 -13
- data/src/cxx_supportlib/vendor-modified/boost/atomic/posix_clock_traits_fwd.hpp +59 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/thread_pause.hpp +102 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic/wait_result.hpp +56 -0
- data/src/cxx_supportlib/vendor-modified/boost/atomic.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libcpp.hpp +5 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/allocator_traits.hpp +108 -41
- data/src/cxx_supportlib/vendor-modified/boost/container/deque.hpp +1235 -1009
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/advanced_insert_int.hpp +3 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/algorithm.hpp +56 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/alloc_helpers.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/alloc_lib.h +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/compare_functors.hpp +23 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/config_begin.hpp +0 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/copy_move_algo.hpp +88 -23
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/flat_tree.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/node_pool_impl.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/operator_new_helpers.hpp +68 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/pair.hpp +72 -13
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/std_fwd.hpp +13 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/detail/tree.hpp +8 -5
- data/src/cxx_supportlib/vendor-modified/boost/container/devector.hpp +31 -10
- data/src/cxx_supportlib/vendor-modified/boost/container/flat_map.hpp +37 -10
- data/src/cxx_supportlib/vendor-modified/boost/container/flat_set.hpp +19 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/list.hpp +23 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/map.hpp +72 -5
- data/src/cxx_supportlib/vendor-modified/boost/container/new_allocator.hpp +3 -10
- data/src/cxx_supportlib/vendor-modified/boost/container/options.hpp +54 -23
- data/src/cxx_supportlib/vendor-modified/boost/container/pmr/devector.hpp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/container/set.hpp +19 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/slist.hpp +32 -5
- data/src/cxx_supportlib/vendor-modified/boost/container/small_vector.hpp +27 -2
- data/src/cxx_supportlib/vendor-modified/boost/container/stable_vector.hpp +22 -0
- data/src/cxx_supportlib/vendor-modified/boost/container/static_vector.hpp +37 -17
- data/src/cxx_supportlib/vendor-modified/boost/container/string.hpp +23 -1
- data/src/cxx_supportlib/vendor-modified/boost/container/vector.hpp +41 -20
- data/src/cxx_supportlib/vendor-modified/boost/container_hash/hash.hpp +5 -8
- data/src/cxx_supportlib/vendor-modified/boost/container_hash/hash_fwd.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/container_hash/hash_is_avalanching.hpp +57 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/bit.hpp +29 -29
- data/src/cxx_supportlib/vendor-modified/boost/core/cmath.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/core/data.hpp +15 -1
- data/src/cxx_supportlib/vendor-modified/boost/core/default_allocator.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/demangle.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/core/detail/assert.hpp +18 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/detail/sp_thread_sleep.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/core/detail/static_assert.hpp +42 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/detail/string_view.hpp +16 -10
- data/src/cxx_supportlib/vendor-modified/boost/core/lightweight_test.hpp +35 -27
- data/src/cxx_supportlib/vendor-modified/boost/core/scoped_enum.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/core/size.hpp +14 -0
- data/src/cxx_supportlib/vendor-modified/boost/core/span.hpp +20 -9
- data/src/cxx_supportlib/vendor-modified/boost/cregex.hpp +0 -5
- data/src/cxx_supportlib/vendor-modified/boost/describe/detail/config.hpp +8 -0
- data/src/cxx_supportlib/vendor-modified/boost/describe/modifiers.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/foreach.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/ebo_functor_holder.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/list.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_rebind.hpp +9 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree_algorithms.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/iterator/advance.hpp +43 -64
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/config_def.hpp +0 -83
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/config_undef.hpp +1 -5
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/eval_if_default.hpp +44 -0
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/facade_iterator_category.hpp +103 -117
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/type_traits/conjunction.hpp +53 -0
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/type_traits/disjunction.hpp +53 -0
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/type_traits/negation.hpp +53 -0
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/type_traits/type_identity.hpp +54 -0
- data/src/cxx_supportlib/vendor-modified/boost/iterator/distance.hpp +32 -38
- data/src/cxx_supportlib/vendor-modified/boost/iterator/enable_if_convertible.hpp +84 -0
- data/src/cxx_supportlib/vendor-modified/boost/iterator/interoperable.hpp +22 -34
- data/src/cxx_supportlib/vendor-modified/boost/iterator/is_iterator.hpp +16 -16
- data/src/cxx_supportlib/vendor-modified/boost/iterator/iterator_adaptor.hpp +162 -309
- data/src/cxx_supportlib/vendor-modified/boost/iterator/iterator_categories.hpp +52 -161
- data/src/cxx_supportlib/vendor-modified/boost/iterator/iterator_concepts.hpp +3 -11
- data/src/cxx_supportlib/vendor-modified/boost/iterator/iterator_facade.hpp +804 -977
- data/src/cxx_supportlib/vendor-modified/boost/iterator/iterator_traits.hpp +24 -17
- data/src/cxx_supportlib/vendor-modified/boost/iterator/min_category.hpp +83 -0
- data/src/cxx_supportlib/vendor-modified/boost/iterator/minimum_category.hpp +11 -73
- data/src/cxx_supportlib/vendor-modified/boost/iterator/reverse_iterator.hpp +56 -57
- data/src/cxx_supportlib/vendor-modified/boost/iterator/transform_iterator.hpp +123 -156
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/bad_lexical_cast.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/buffer_view.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_lexical.hpp +36 -33
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_lexical_streams.hpp +43 -50
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_numeric.hpp +23 -27
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/inf_nan.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/is_character.hpp +10 -11
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/lcast_basic_unlockedbuf.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/lcast_char_constants.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/lcast_unsigned_converters.hpp +6 -7
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/type_traits.hpp +81 -0
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/widest_char.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/try_lexical_convert.hpp +8 -9
- data/src/cxx_supportlib/vendor-modified/boost/lexical_cast.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/libs/regex/src/wide_posix_api.cpp +1 -12
- data/src/cxx_supportlib/vendor-modified/boost/memory_order.hpp +8 -26
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/iterator_to_raw_pointer.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/launder.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/std_ns_begin.hpp +6 -0
- data/src/cxx_supportlib/vendor-modified/boost/move/detail/unique_ptr_meta_utils.hpp +2 -2
- data/src/cxx_supportlib/vendor-modified/boost/mp11/algorithm.hpp +11 -44
- data/src/cxx_supportlib/vendor-modified/boost/mp11/detail/mp_map_find.hpp +34 -0
- data/src/cxx_supportlib/vendor-modified/boost/mp11/set.hpp +33 -1
- data/src/cxx_supportlib/vendor-modified/boost/mp11/version.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/mpl/and.hpp +4 -8
- data/src/cxx_supportlib/vendor-modified/boost/mpl/aux_/na_assert.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/mpl/aux_/ptr_to_ref.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/mpl/bitand.hpp +2 -6
- data/src/cxx_supportlib/vendor-modified/boost/mpl/bitor.hpp +2 -6
- data/src/cxx_supportlib/vendor-modified/boost/mpl/or.hpp +2 -6
- data/src/cxx_supportlib/vendor-modified/boost/pool/pool.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/pool/simple_segregated_storage.hpp +0 -13
- data/src/cxx_supportlib/vendor-modified/boost/preprocessor/tuple/limits/to_seq_256.hpp +190 -190
- data/src/cxx_supportlib/vendor-modified/boost/random/beta_distribution.hpp +12 -2
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/config.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/size.hpp +41 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/xoshiro_base.hpp +472 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/discrete_distribution.hpp +7 -10
- data/src/cxx_supportlib/vendor-modified/boost/random/gamma_distribution.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/random/generalized_inverse_gaussian_distribution.hpp +339 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/hyperexponential_distribution.hpp +12 -14
- data/src/cxx_supportlib/vendor-modified/boost/random/inverse_gaussian_distribution.hpp +226 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/mersenne_twister.hpp +1 -4
- data/src/cxx_supportlib/vendor-modified/boost/random/mixmax.hpp +63 -63
- data/src/cxx_supportlib/vendor-modified/boost/random/piecewise_constant_distribution.hpp +7 -10
- data/src/cxx_supportlib/vendor-modified/boost/random/piecewise_linear_distribution.hpp +8 -11
- data/src/cxx_supportlib/vendor-modified/boost/random/seed_seq.hpp +1 -3
- data/src/cxx_supportlib/vendor-modified/boost/random/splitmix64.hpp +1 -4
- data/src/cxx_supportlib/vendor-modified/boost/random/xoshiro.hpp +488 -0
- data/src/cxx_supportlib/vendor-modified/boost/random.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/range/concepts.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/range/detail/has_member_size.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/range/detail/msvc_has_iterator_workaround.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/range/has_range_iterator.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/range/iterator.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/range/iterator_range_core.hpp +4 -1
- data/src/cxx_supportlib/vendor-modified/boost/range/size_type.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/concepts.hpp +35 -18
- data/src/cxx_supportlib/vendor-modified/boost/regex/config.hpp +18 -101
- data/src/cxx_supportlib/vendor-modified/boost/regex/pattern_except.hpp +0 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/pending/object_cache.hpp +0 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/pending/unicode_iterator.hpp +0 -6
- data/src/cxx_supportlib/vendor-modified/boost/regex/regex_traits.hpp +0 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/user.hpp +4 -10
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/basic_regex.hpp +63 -17
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/basic_regex_creator.hpp +71 -16
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/basic_regex_parser.hpp +22 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/c_regex_traits.hpp +11 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/char_regex_traits.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/cpp_regex_traits.hpp +11 -8
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/cregex.hpp +2 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/error_type.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/icu.hpp +40 -38
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/iterator_category.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/iterator_traits.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/match_flags.hpp +39 -37
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/match_results.hpp +46 -9
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/mem_block_cache.hpp +4 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/object_cache.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/pattern_except.hpp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/perl_matcher.hpp +57 -8
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/perl_matcher_common.hpp +21 -6
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/perl_matcher_non_recursive.hpp +18 -3
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regbase.hpp +4 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex.hpp +6 -6
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_format.hpp +23 -18
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_fwd.hpp +9 -9
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_grep.hpp +9 -5
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_iterator.hpp +11 -7
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_match.hpp +10 -7
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_merge.hpp +4 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_raw_buffer.hpp +3 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_replace.hpp +6 -2
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_search.hpp +12 -9
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_split.hpp +6 -3
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_token_iterator.hpp +16 -11
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_traits.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_traits_defaults.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/regex_workaround.hpp +2 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/states.hpp +7 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/sub_match.hpp +54 -49
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/syntax_type.hpp +64 -62
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/u32regex_iterator.hpp +16 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/u32regex_token_iterator.hpp +12 -0
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/unicode_iterator.hpp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex/v5/w32_regex_traits.hpp +3 -1
- data/src/cxx_supportlib/vendor-modified/boost/regex.hpp +0 -4
- data/src/cxx_supportlib/vendor-modified/boost/regex_fwd.hpp +0 -4
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/atomic_count.hpp +1 -43
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/deprecated_macros.hpp +7 -7
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/shared_count.hpp +2 -77
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base.hpp +1 -64
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_nt.hpp +3 -3
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_impl.hpp +0 -77
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_cxx20_constexpr.hpp +37 -0
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/spinlock.hpp +5 -28
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/intrusive_ptr.hpp +41 -40
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/scoped_array.hpp +0 -15
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/scoped_ptr.hpp +0 -18
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/shared_ptr.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/thread/future.hpp +1 -1
- data/src/cxx_supportlib/vendor-modified/boost/tuple/detail/tuple_basic.hpp +1 -0
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/integral_constant.hpp +8 -6
- data/src/cxx_supportlib/vendor-modified/boost/type_traits/is_complete.hpp +31 -10
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/fca.hpp +34 -8
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/foa/core.hpp +6 -4
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/foa/table.hpp +9 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/detail/implementation.hpp +5 -5
- data/src/cxx_supportlib/vendor-modified/boost/unordered/{unordered_printers.hpp → detail/unordered_printers.hpp} +34 -36
- data/src/cxx_supportlib/vendor-modified/boost/unordered/hash_traits.hpp +6 -49
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_flat_map.hpp +6 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_flat_set.hpp +6 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_node_map.hpp +6 -1
- data/src/cxx_supportlib/vendor-modified/boost/unordered/unordered_node_set.hpp +6 -1
- data/src/cxx_supportlib/vendor-modified/boost/version.hpp +2 -2
- data/src/nginx_module/ContentHandler.c +2 -0
- data/src/ruby_supportlib/phusion_passenger/config/download_agent_command.rb +3 -5
- data/src/ruby_supportlib/phusion_passenger/config/download_nginx_engine_command.rb +3 -5
- data/src/ruby_supportlib/phusion_passenger/config/install_agent_command.rb +3 -5
- data/src/ruby_supportlib/phusion_passenger/config/install_standalone_runtime_command.rb +3 -5
- data/src/ruby_supportlib/phusion_passenger/config/installation_utils.rb +1 -1
- data/src/ruby_supportlib/phusion_passenger/config/nginx_engine_compiler.rb +2 -2
- data/src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb +5 -3
- data/src/ruby_supportlib/phusion_passenger/platform_info/apache.rb +2 -2
- data/src/ruby_supportlib/phusion_passenger/platform_info/compiler.rb +12 -23
- data/src/ruby_supportlib/phusion_passenger/platform_info/cxx_portability.rb +31 -32
- data/src/ruby_supportlib/phusion_passenger/rack_handler.rb +2 -2
- data/src/ruby_supportlib/phusion_passenger/request_handler/thread_handler.rb +2 -3
- data/src/ruby_supportlib/phusion_passenger/standalone/config_utils.rb +2 -0
- data/src/ruby_supportlib/phusion_passenger/standalone/start_command/builtin_engine.rb +1 -1
- data/src/ruby_supportlib/phusion_passenger/utils/json.rb +1 -1
- data/src/ruby_supportlib/phusion_passenger/utils/terminal_choice_menu.rb +1 -1
- data/src/ruby_supportlib/phusion_passenger/vendor/crash_watch/gdb_controller.rb +1 -1
- data/src/ruby_supportlib/phusion_passenger.rb +8 -8
- metadata +27 -104
- data/src/cxx_supportlib/oxt/detail/spin_lock_darwin.hpp +0 -75
- data/src/cxx_supportlib/oxt/detail/spin_lock_gcc_x86.hpp +0 -85
- data/src/cxx_supportlib/oxt/detail/spin_lock_portable.hpp +0 -38
- data/src/cxx_supportlib/oxt/detail/spin_lock_pthreads.hpp +0 -111
- data/src/cxx_supportlib/vendor-modified/boost/align/aligned_alloc.hpp +0 -47
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/aligned_alloc_posix.hpp +0 -41
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/aligned_alloc_sunos.hpp +0 -34
- data/src/cxx_supportlib/vendor-modified/boost/align/detail/is_alignment.hpp +0 -28
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/pause.hpp +0 -68
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/conditional.hpp +0 -42
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/integral_constant.hpp +0 -46
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_enum.hpp +0 -42
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_function.hpp +0 -42
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/is_nothrow_default_constructible.hpp +0 -46
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/type_traits/remove_cv.hpp +0 -42
- data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/wait_on_address.hpp +0 -64
- data/src/cxx_supportlib/vendor-modified/boost/cerrno.hpp +0 -15
- data/src/cxx_supportlib/vendor-modified/boost/detail/indirect_traits.hpp +0 -195
- data/src/cxx_supportlib/vendor-modified/boost/detail/select_type.hpp +0 -36
- data/src/cxx_supportlib/vendor-modified/boost/iterator/detail/enable_if.hpp +0 -83
- data/src/cxx_supportlib/vendor-modified/boost/libs/regex/src/internals.hpp +0 -35
- data/src/cxx_supportlib/vendor-modified/boost/libs/regex/src/regex.cpp +0 -120
- data/src/cxx_supportlib/vendor-modified/boost/libs/regex/src/regex_debug.cpp +0 -59
- data/src/cxx_supportlib/vendor-modified/boost/libs/regex/src/static_mutex.cpp +0 -189
- data/src/cxx_supportlib/vendor-modified/boost/libs/system/src/error_code.cpp +0 -31
- data/src/cxx_supportlib/vendor-modified/boost/regex/config/borland.hpp +0 -72
- data/src/cxx_supportlib/vendor-modified/boost/regex/config/cwchar.hpp +0 -207
- data/src/cxx_supportlib/vendor-modified/boost/regex/pending/static_mutex.hpp +0 -182
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex.hpp +0 -797
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_creator.hpp +0 -1598
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_parser.hpp +0 -3174
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/c_regex_traits.hpp +0 -511
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/char_regex_traits.hpp +0 -81
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/cpp_regex_traits.hpp +0 -1237
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/cregex.hpp +0 -213
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/error_type.hpp +0 -59
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/icu.hpp +0 -1516
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/indexed_bit_flag.hpp +0 -54
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/iterator_category.hpp +0 -91
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/iterator_traits.hpp +0 -135
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/match_flags.hpp +0 -161
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/match_results.hpp +0 -716
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/mem_block_cache.hpp +0 -183
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/object_cache.hpp +0 -171
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/pattern_except.hpp +0 -128
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher.hpp +0 -645
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher_common.hpp +0 -1030
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher_non_recursive.hpp +0 -1947
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/perl_matcher_recursive.hpp +0 -1131
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/primary_transform.hpp +0 -146
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/protected_call.hpp +0 -83
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regbase.hpp +0 -180
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex.hpp +0 -166
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_format.hpp +0 -1158
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_fwd.hpp +0 -73
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_grep.hpp +0 -155
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_iterator.hpp +0 -195
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_match.hpp +0 -382
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_merge.hpp +0 -93
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_raw_buffer.hpp +0 -241
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_replace.hpp +0 -99
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_search.hpp +0 -217
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_split.hpp +0 -174
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_token_iterator.hpp +0 -327
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_traits.hpp +0 -189
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_traits_defaults.hpp +0 -997
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/regex_workaround.hpp +0 -237
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/states.hpp +0 -321
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/sub_match.hpp +0 -516
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/syntax_type.hpp +0 -105
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/u32regex_iterator.hpp +0 -185
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/u32regex_token_iterator.hpp +0 -360
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/unicode_iterator.hpp +0 -871
- data/src/cxx_supportlib/vendor-modified/boost/regex/v4/w32_regex_traits.hpp +0 -1229
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/atomic_count_gcc.hpp +0 -79
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/atomic_count_gcc_atomic.hpp +0 -63
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/atomic_count_gcc_x86.hpp +0 -88
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/atomic_count_pt.hpp +0 -104
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/atomic_count_spin.hpp +0 -69
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/atomic_count_sync.hpp +0 -72
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_acc_ia64.hpp +0 -163
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_aix.hpp +0 -152
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_cw_ppc.hpp +0 -185
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_atomic.hpp +0 -148
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_ia64.hpp +0 -170
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_mips.hpp +0 -200
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_ppc.hpp +0 -194
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_sparc.hpp +0 -179
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_gcc_x86.hpp +0 -186
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_pt.hpp +0 -147
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_snc_ps3.hpp +0 -174
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_spin.hpp +0 -141
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_sync.hpp +0 -165
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_base_vacpp_ppc.hpp +0 -163
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_has_gcc_intrinsics.hpp +0 -30
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_has_sync_intrinsics.hpp +0 -69
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/spinlock_gcc_arm.hpp +0 -128
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/spinlock_nt.hpp +0 -96
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/spinlock_pt.hpp +0 -86
- data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/spinlock_sync.hpp +0 -94
|
@@ -29,6 +29,7 @@
|
|
|
29
29
|
// https://bugzilla.redhat.com/show_bug.cgi?id=165427
|
|
30
30
|
// Also needed for SO_PEERCRED.
|
|
31
31
|
#define _GNU_SOURCE
|
|
32
|
+
#include <exception>
|
|
32
33
|
#endif
|
|
33
34
|
|
|
34
35
|
#include <oxt/system_calls.hpp>
|
|
@@ -86,18 +87,7 @@ using namespace oxt;
|
|
|
86
87
|
static WritevFunction writevFunction = syscalls::writev;
|
|
87
88
|
|
|
88
89
|
|
|
89
|
-
|
|
90
|
-
purgeStdio(FILE *f) {
|
|
91
|
-
#if defined(HAVE_FPURGE)
|
|
92
|
-
fpurge(f);
|
|
93
|
-
return true;
|
|
94
|
-
#elif defined(HAVE___FPURGE)
|
|
95
|
-
__fpurge(f);
|
|
96
|
-
return true;
|
|
97
|
-
#else
|
|
98
|
-
return false;
|
|
99
|
-
#endif
|
|
100
|
-
}
|
|
90
|
+
/****** Server address types support ******/
|
|
101
91
|
|
|
102
92
|
ServerAddressType
|
|
103
93
|
getSocketAddressType(const StaticString &address) {
|
|
@@ -182,67 +172,8 @@ isLocalSocketAddress(const StaticString &address) {
|
|
|
182
172
|
}
|
|
183
173
|
}
|
|
184
174
|
|
|
185
|
-
void
|
|
186
|
-
setBlocking(int fd) {
|
|
187
|
-
int flags, ret;
|
|
188
|
-
|
|
189
|
-
do {
|
|
190
|
-
flags = fcntl(fd, F_GETFL);
|
|
191
|
-
} while (flags == -1 && errno == EINTR);
|
|
192
|
-
if (flags == -1) {
|
|
193
|
-
int e = errno;
|
|
194
|
-
throw SystemException("Cannot set socket to blocking mode: "
|
|
195
|
-
"cannot get socket flags",
|
|
196
|
-
e);
|
|
197
|
-
}
|
|
198
|
-
do {
|
|
199
|
-
ret = fcntl(fd, F_SETFL, flags & ~O_NONBLOCK);
|
|
200
|
-
} while (ret == -1 && errno == EINTR);
|
|
201
|
-
if (ret == -1) {
|
|
202
|
-
int e = errno;
|
|
203
|
-
throw SystemException("Cannot set socket to blocking mode: "
|
|
204
|
-
"cannot set socket flags",
|
|
205
|
-
e);
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
175
|
|
|
209
|
-
|
|
210
|
-
setNonBlocking(int fd) {
|
|
211
|
-
int flags, ret;
|
|
212
|
-
|
|
213
|
-
do {
|
|
214
|
-
flags = fcntl(fd, F_GETFL);
|
|
215
|
-
} while (flags == -1 && errno == EINTR);
|
|
216
|
-
if (flags == -1) {
|
|
217
|
-
int e = errno;
|
|
218
|
-
throw SystemException("Cannot set socket to non-blocking mode: "
|
|
219
|
-
"cannot get socket flags",
|
|
220
|
-
e);
|
|
221
|
-
}
|
|
222
|
-
do {
|
|
223
|
-
ret = fcntl(fd, F_SETFL, flags | O_NONBLOCK);
|
|
224
|
-
} while (ret == -1 && errno == EINTR);
|
|
225
|
-
if (ret == -1) {
|
|
226
|
-
int e = errno;
|
|
227
|
-
throw SystemException("Cannot set socket to non-blocking mode: "
|
|
228
|
-
"cannot set socket flags",
|
|
229
|
-
e);
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
int
|
|
234
|
-
callAccept4(int sock, struct sockaddr *addr, socklen_t *addr_len, int options) {
|
|
235
|
-
#if defined(HAVE_ACCEPT4)
|
|
236
|
-
int ret;
|
|
237
|
-
do {
|
|
238
|
-
ret = ::accept4(sock, addr, addr_len, options);
|
|
239
|
-
} while (ret == -1 && errno == EINTR);
|
|
240
|
-
return ret;
|
|
241
|
-
#else
|
|
242
|
-
errno = ENOSYS;
|
|
243
|
-
return -1;
|
|
244
|
-
#endif
|
|
245
|
-
}
|
|
176
|
+
/****** Server socket creation ******/
|
|
246
177
|
|
|
247
178
|
int
|
|
248
179
|
createServer(const StaticString &address, unsigned int backlogSize, bool autoDelete,
|
|
@@ -285,7 +216,7 @@ createUnixServer(const StaticString &filename, unsigned int backlogSize, bool au
|
|
|
285
216
|
throw SystemException("Cannot create a Unix socket file descriptor", e);
|
|
286
217
|
}
|
|
287
218
|
|
|
288
|
-
FdGuard guard(fd, file, line
|
|
219
|
+
FdGuard guard(fd, file, line);
|
|
289
220
|
addr.sun_family = AF_LOCAL;
|
|
290
221
|
strncpy(addr.sun_path, filename.c_str(), filename.size());
|
|
291
222
|
addr.sun_path[filename.size()] = '\0';
|
|
@@ -376,7 +307,7 @@ createTcpServer(const char *address, unsigned short port, unsigned int backlogSi
|
|
|
376
307
|
}
|
|
377
308
|
// Ignore SO_REUSEADDR error, it's not fatal.
|
|
378
309
|
|
|
379
|
-
FdGuard guard(fd, file, line
|
|
310
|
+
FdGuard guard(fd, file, line);
|
|
380
311
|
if (family == AF_INET) {
|
|
381
312
|
ret = syscalls::bind(fd, (const struct sockaddr *) &addr.v4, sizeof(struct sockaddr_in));
|
|
382
313
|
} else {
|
|
@@ -408,6 +339,9 @@ createTcpServer(const char *address, unsigned short port, unsigned int backlogSi
|
|
|
408
339
|
return fd;
|
|
409
340
|
}
|
|
410
341
|
|
|
342
|
+
|
|
343
|
+
/****** Socket connection establishment (blocking) ******/
|
|
344
|
+
|
|
411
345
|
int
|
|
412
346
|
connectToServer(const StaticString &address, const char *file, unsigned int line) {
|
|
413
347
|
TRACE_POINT();
|
|
@@ -436,7 +370,7 @@ connectToUnixServer(const StaticString &filename, const char *file,
|
|
|
436
370
|
throw SystemException("Cannot create a Unix socket file descriptor", e);
|
|
437
371
|
}
|
|
438
372
|
|
|
439
|
-
FdGuard guard(fd, file, line
|
|
373
|
+
FdGuard guard(fd, file, line);
|
|
440
374
|
int ret;
|
|
441
375
|
struct sockaddr_un addr;
|
|
442
376
|
|
|
@@ -486,54 +420,6 @@ connectToUnixServer(const StaticString &filename, const char *file,
|
|
|
486
420
|
abort(); // Never reached.
|
|
487
421
|
}
|
|
488
422
|
|
|
489
|
-
void
|
|
490
|
-
setupNonBlockingUnixSocket(NUnix_State &state, const StaticString &filename,
|
|
491
|
-
const char *file, unsigned int line)
|
|
492
|
-
{
|
|
493
|
-
state.fd.assign(syscalls::socket(PF_UNIX, SOCK_STREAM, 0), file, line);
|
|
494
|
-
if (state.fd == -1) {
|
|
495
|
-
int e = errno;
|
|
496
|
-
throw SystemException("Cannot create a Unix socket file descriptor", e);
|
|
497
|
-
}
|
|
498
|
-
|
|
499
|
-
state.filename = filename;
|
|
500
|
-
setNonBlocking(state.fd);
|
|
501
|
-
}
|
|
502
|
-
|
|
503
|
-
bool
|
|
504
|
-
connectToUnixServer(NUnix_State &state) {
|
|
505
|
-
struct sockaddr_un addr;
|
|
506
|
-
int ret;
|
|
507
|
-
|
|
508
|
-
if (state.filename.size() > sizeof(addr.sun_path) - 1) {
|
|
509
|
-
string message = "Cannot connect to Unix socket '";
|
|
510
|
-
message.append(state.filename.data(), state.filename.size());
|
|
511
|
-
message.append("': filename is too long.");
|
|
512
|
-
throw RuntimeException(message);
|
|
513
|
-
}
|
|
514
|
-
|
|
515
|
-
addr.sun_family = AF_UNIX;
|
|
516
|
-
memcpy(addr.sun_path, state.filename.data(), state.filename.size());
|
|
517
|
-
addr.sun_path[state.filename.size()] = '\0';
|
|
518
|
-
|
|
519
|
-
ret = syscalls::connect(state.fd, (const sockaddr *) &addr, sizeof(addr));
|
|
520
|
-
if (ret == -1) {
|
|
521
|
-
if (errno == EINPROGRESS || errno == EWOULDBLOCK) {
|
|
522
|
-
return false;
|
|
523
|
-
} else if (errno == EISCONN) {
|
|
524
|
-
return true;
|
|
525
|
-
} else {
|
|
526
|
-
int e = errno;
|
|
527
|
-
string message = "Cannot connect to Unix socket '";
|
|
528
|
-
message.append(state.filename.data(), state.filename.size());
|
|
529
|
-
message.append("'");
|
|
530
|
-
throw SystemException(message, e);
|
|
531
|
-
}
|
|
532
|
-
} else {
|
|
533
|
-
return true;
|
|
534
|
-
}
|
|
535
|
-
}
|
|
536
|
-
|
|
537
423
|
int
|
|
538
424
|
connectToTcpServer(const StaticString &hostname, unsigned int port,
|
|
539
425
|
const char *file, unsigned int line)
|
|
@@ -591,145 +477,285 @@ connectToTcpServer(const StaticString &hostname, unsigned int port,
|
|
|
591
477
|
return fd;
|
|
592
478
|
}
|
|
593
479
|
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
480
|
+
|
|
481
|
+
/****** Socket connection establishment (non-blocking) ******/
|
|
482
|
+
|
|
483
|
+
std::pair<int, bool>
|
|
484
|
+
createNonBlockingSocketConnection(const StaticString &address, const char *file, unsigned int line) {
|
|
485
|
+
TRACE_POINT();
|
|
486
|
+
switch (getSocketAddressType(address)) {
|
|
487
|
+
case SAT_UNIX:
|
|
488
|
+
return createNonBlockingUnixSocketConnection(parseUnixSocketAddress(address), file, line);
|
|
489
|
+
case SAT_TCP: {
|
|
490
|
+
string host;
|
|
491
|
+
unsigned short port;
|
|
492
|
+
|
|
493
|
+
parseTcpSocketAddress(address, host, port);
|
|
494
|
+
return createNonBlockingTcpSocketConnection(host, port, file, line);
|
|
495
|
+
}
|
|
496
|
+
default:
|
|
497
|
+
throw ArgumentException(string("Unknown address type for '") + address + "'");
|
|
498
|
+
}
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
std::pair<int, bool>
|
|
502
|
+
createNonBlockingUnixSocketConnection(const StaticString &filename, const char *file, unsigned int line) {
|
|
503
|
+
struct sockaddr_un addr;
|
|
504
|
+
|
|
505
|
+
if (filename.size() > sizeof(addr.sun_path) - 1) {
|
|
506
|
+
string message = "Cannot connect to Unix socket '";
|
|
507
|
+
message.append(filename.data(), filename.size());
|
|
508
|
+
message.append("': filename is too long.");
|
|
509
|
+
throw ArgumentException(message);
|
|
510
|
+
}
|
|
511
|
+
|
|
512
|
+
|
|
513
|
+
int fd = syscalls::socket(PF_UNIX, SOCK_STREAM, 0);
|
|
514
|
+
if (fd == -1) {
|
|
515
|
+
int e = errno;
|
|
516
|
+
throw SystemException("Cannot create a Unix socket file descriptor", e);
|
|
517
|
+
}
|
|
518
|
+
|
|
598
519
|
int ret;
|
|
520
|
+
FdGuard guard(fd, nullptr, 0);
|
|
521
|
+
P_LOG_FILE_DESCRIPTOR_OPEN4(fd, file, line, "NonBlockingUnixSocketConnection");
|
|
522
|
+
setNonBlocking(fd);
|
|
599
523
|
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
524
|
+
addr.sun_family = AF_UNIX;
|
|
525
|
+
memcpy(addr.sun_path, filename.data(), filename.size());
|
|
526
|
+
addr.sun_path[filename.size()] = '\0';
|
|
527
|
+
|
|
528
|
+
ret = syscalls::connect(fd, (const sockaddr *) &addr, sizeof(addr));
|
|
529
|
+
if (ret == -1) {
|
|
530
|
+
if (errno == EINPROGRESS || errno == EWOULDBLOCK) {
|
|
531
|
+
guard.clear();
|
|
532
|
+
return std::make_pair(fd, false);
|
|
533
|
+
} else if (errno == EISCONN) {
|
|
534
|
+
guard.clear();
|
|
535
|
+
return std::make_pair(fd, true);
|
|
536
|
+
} else {
|
|
537
|
+
int e = errno;
|
|
538
|
+
string message = "Cannot connect to Unix socket '";
|
|
539
|
+
message.append(filename.data(), filename.size());
|
|
540
|
+
message.append("'");
|
|
541
|
+
throw SystemException(message, e);
|
|
542
|
+
}
|
|
543
|
+
} else {
|
|
544
|
+
guard.clear();
|
|
545
|
+
return std::make_pair(fd, true);
|
|
546
|
+
}
|
|
547
|
+
}
|
|
548
|
+
|
|
549
|
+
std::pair<int, bool>
|
|
550
|
+
createNonBlockingTcpSocketConnection(const StaticString &hostname, unsigned int port, const char *file, unsigned int line) {
|
|
551
|
+
const string hostnameCopy = string(hostname.data(), hostname.size());
|
|
552
|
+
const string portString = toString(port);
|
|
553
|
+
struct addrinfo hints, *res;
|
|
554
|
+
int ret;
|
|
555
|
+
|
|
556
|
+
memset(&hints, 0, sizeof(hints));
|
|
557
|
+
hints.ai_family = PF_UNSPEC;
|
|
558
|
+
hints.ai_socktype = SOCK_STREAM;
|
|
559
|
+
ret = getaddrinfo(hostnameCopy.c_str(), portString.c_str(),
|
|
560
|
+
&hints, &res);
|
|
605
561
|
if (ret != 0) {
|
|
606
562
|
string message = "Cannot resolve IP address '";
|
|
607
563
|
message.append(hostname.data(), hostname.size());
|
|
608
564
|
message.append(":");
|
|
609
|
-
message.append(
|
|
565
|
+
message.append(portString);
|
|
610
566
|
message.append("': ");
|
|
611
567
|
message.append(gai_strerror(ret));
|
|
612
568
|
throw IOException(message);
|
|
613
569
|
}
|
|
614
570
|
|
|
615
|
-
|
|
616
|
-
|
|
571
|
+
|
|
572
|
+
int fd = syscalls::socket(PF_INET, SOCK_STREAM, 0);
|
|
573
|
+
if (fd == -1) {
|
|
617
574
|
int e = errno;
|
|
618
575
|
throw SystemException("Cannot create a TCP socket file descriptor", e);
|
|
619
576
|
}
|
|
620
577
|
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
setNonBlocking(
|
|
624
|
-
}
|
|
578
|
+
FdGuard guard(fd, nullptr, 0);
|
|
579
|
+
P_LOG_FILE_DESCRIPTOR_OPEN4(fd, file, line, "NonBlockingTcpSocketConnection");
|
|
580
|
+
setNonBlocking(fd);
|
|
625
581
|
|
|
626
|
-
bool
|
|
627
|
-
connectToTcpServer(NTCP_State &state) {
|
|
628
|
-
int ret;
|
|
629
582
|
|
|
630
|
-
ret = syscalls::connect(
|
|
583
|
+
ret = syscalls::connect(fd, res->ai_addr, res->ai_addrlen);
|
|
631
584
|
if (ret == -1) {
|
|
632
585
|
if (errno == EINPROGRESS || errno == EWOULDBLOCK) {
|
|
633
|
-
|
|
586
|
+
guard.clear();
|
|
587
|
+
return make_pair(fd, false);
|
|
634
588
|
} else if (errno == EISCONN) {
|
|
635
|
-
freeaddrinfo(
|
|
636
|
-
|
|
637
|
-
return true;
|
|
589
|
+
freeaddrinfo(res);
|
|
590
|
+
guard.clear();
|
|
591
|
+
return make_pair(fd, true);
|
|
638
592
|
} else {
|
|
639
593
|
int e = errno;
|
|
640
594
|
string message = "Cannot connect to TCP socket '";
|
|
641
|
-
message.append(
|
|
595
|
+
message.append(hostname);
|
|
642
596
|
message.append(":");
|
|
643
|
-
message.append(
|
|
597
|
+
message.append(portString);
|
|
644
598
|
message.append("'");
|
|
645
599
|
throw SystemException(message, e);
|
|
646
600
|
}
|
|
647
601
|
} else {
|
|
648
|
-
freeaddrinfo(
|
|
649
|
-
|
|
650
|
-
return true;
|
|
602
|
+
freeaddrinfo(res);
|
|
603
|
+
guard.clear();
|
|
604
|
+
return make_pair(fd, true);
|
|
651
605
|
}
|
|
652
606
|
}
|
|
653
607
|
|
|
654
|
-
|
|
608
|
+
|
|
609
|
+
/****** Scope guards ******/
|
|
610
|
+
|
|
611
|
+
FdGuard::FdGuard(FdGuard &&other)
|
|
612
|
+
: mFd(other.mFd)
|
|
655
613
|
{
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
switch (type) {
|
|
659
|
-
case SAT_UNIX:
|
|
660
|
-
setupNonBlockingUnixSocket(s_unix, parseUnixSocketAddress(address),
|
|
661
|
-
file, line);
|
|
662
|
-
break;
|
|
663
|
-
case SAT_TCP: {
|
|
664
|
-
string host;
|
|
665
|
-
unsigned short port;
|
|
614
|
+
other.mFd = -1;
|
|
615
|
+
}
|
|
666
616
|
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
617
|
+
FdGuard::FdGuard(int fd, const char *sourceFile, unsigned int sourceLine)
|
|
618
|
+
: mFd(fd)
|
|
619
|
+
{
|
|
620
|
+
if (mFd != -1 && sourceFile != nullptr) {
|
|
621
|
+
P_LOG_FILE_DESCRIPTOR_OPEN3(fd, sourceFile, sourceLine);
|
|
670
622
|
}
|
|
671
|
-
|
|
672
|
-
|
|
623
|
+
}
|
|
624
|
+
|
|
625
|
+
FdGuard::~FdGuard() noexcept(false) {
|
|
626
|
+
if (mFd != -1) {
|
|
627
|
+
try {
|
|
628
|
+
safelyClose(mFd);
|
|
629
|
+
} catch (const std::exception &e) {
|
|
630
|
+
bool uncaughtException =
|
|
631
|
+
#if __cplusplus >= 201703L
|
|
632
|
+
std::uncaught_exceptions() > 0;
|
|
633
|
+
#else
|
|
634
|
+
std::uncaught_exception();
|
|
635
|
+
#endif
|
|
636
|
+
if (uncaughtException) {
|
|
637
|
+
P_WARN("Error closing file descriptor " << mFd << ": " << e.what());
|
|
638
|
+
return;
|
|
639
|
+
} else {
|
|
640
|
+
throw e;
|
|
641
|
+
}
|
|
642
|
+
}
|
|
643
|
+
P_LOG_FILE_DESCRIPTOR_CLOSE(mFd);
|
|
673
644
|
}
|
|
674
645
|
}
|
|
675
646
|
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
647
|
+
FdGuard &
|
|
648
|
+
FdGuard::operator=(FdGuard &&other) {
|
|
649
|
+
if (this != &other) {
|
|
650
|
+
if (mFd != -1) {
|
|
651
|
+
safelyClose(mFd);
|
|
652
|
+
P_LOG_FILE_DESCRIPTOR_CLOSE(mFd);
|
|
653
|
+
}
|
|
654
|
+
mFd = other.mFd;
|
|
655
|
+
other.mFd = -1;
|
|
685
656
|
}
|
|
657
|
+
return *this;
|
|
686
658
|
}
|
|
687
659
|
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
660
|
+
void
|
|
661
|
+
FdGuard::clear() noexcept {
|
|
662
|
+
mFd = -1;
|
|
663
|
+
}
|
|
664
|
+
|
|
665
|
+
void
|
|
666
|
+
FdGuard::runNow() noexcept(false) {
|
|
667
|
+
if (mFd != -1) {
|
|
668
|
+
safelyClose(mFd);
|
|
669
|
+
P_LOG_FILE_DESCRIPTOR_CLOSE(mFd);
|
|
670
|
+
mFd = -1;
|
|
697
671
|
}
|
|
698
672
|
}
|
|
699
673
|
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
674
|
+
|
|
675
|
+
/****** Other ******/
|
|
676
|
+
|
|
677
|
+
bool
|
|
678
|
+
purgeStdio(FILE *f) {
|
|
679
|
+
#if defined(HAVE_FPURGE)
|
|
680
|
+
fpurge(f);
|
|
681
|
+
return true;
|
|
682
|
+
#elif defined(HAVE___FPURGE)
|
|
683
|
+
__fpurge(f);
|
|
684
|
+
return true;
|
|
685
|
+
#else
|
|
686
|
+
return false;
|
|
687
|
+
#endif
|
|
709
688
|
}
|
|
710
689
|
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
690
|
+
void
|
|
691
|
+
setBlocking(int fd) {
|
|
692
|
+
int flags, ret;
|
|
693
|
+
|
|
694
|
+
do {
|
|
695
|
+
flags = fcntl(fd, F_GETFL);
|
|
696
|
+
} while (flags == -1 && errno == EINTR);
|
|
697
|
+
if (flags == -1) {
|
|
698
|
+
int e = errno;
|
|
699
|
+
throw SystemException("Cannot set socket to blocking mode: "
|
|
700
|
+
"cannot get socket flags",
|
|
701
|
+
e);
|
|
702
|
+
}
|
|
703
|
+
do {
|
|
704
|
+
ret = fcntl(fd, F_SETFL, flags & ~O_NONBLOCK);
|
|
705
|
+
} while (ret == -1 && errno == EINTR);
|
|
706
|
+
if (ret == -1) {
|
|
707
|
+
int e = errno;
|
|
708
|
+
throw SystemException("Cannot set socket to blocking mode: "
|
|
709
|
+
"cannot set socket flags",
|
|
710
|
+
e);
|
|
711
|
+
}
|
|
712
|
+
}
|
|
713
|
+
|
|
714
|
+
void
|
|
715
|
+
setNonBlocking(int fd) {
|
|
716
|
+
int flags, ret;
|
|
717
|
+
|
|
718
|
+
do {
|
|
719
|
+
flags = fcntl(fd, F_GETFL);
|
|
720
|
+
} while (flags == -1 && errno == EINTR);
|
|
721
|
+
if (flags == -1) {
|
|
722
|
+
int e = errno;
|
|
723
|
+
throw SystemException("Cannot set socket to non-blocking mode: "
|
|
724
|
+
"cannot get socket flags",
|
|
725
|
+
e);
|
|
726
|
+
}
|
|
727
|
+
do {
|
|
728
|
+
ret = fcntl(fd, F_SETFL, flags | O_NONBLOCK);
|
|
729
|
+
} while (ret == -1 && errno == EINTR);
|
|
730
|
+
if (ret == -1) {
|
|
731
|
+
int e = errno;
|
|
732
|
+
throw SystemException("Cannot set socket to non-blocking mode: "
|
|
733
|
+
"cannot set socket flags",
|
|
734
|
+
e);
|
|
735
|
+
}
|
|
736
|
+
}
|
|
737
|
+
|
|
738
|
+
int
|
|
739
|
+
callAccept4(int sock, struct sockaddr *addr, socklen_t *addr_len, int options) {
|
|
740
|
+
#if defined(HAVE_ACCEPT4)
|
|
741
|
+
int ret;
|
|
742
|
+
do {
|
|
743
|
+
ret = ::accept4(sock, addr, addr_len, options);
|
|
744
|
+
} while (ret == -1 && errno == EINTR);
|
|
745
|
+
return ret;
|
|
746
|
+
#else
|
|
747
|
+
errno = ENOSYS;
|
|
748
|
+
return -1;
|
|
749
|
+
#endif
|
|
720
750
|
}
|
|
721
751
|
|
|
722
752
|
bool
|
|
723
753
|
pingTcpServer(const StaticString &host, unsigned int port, unsigned long long *timeout) {
|
|
724
754
|
TRACE_POINT();
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
setupNonBlockingTcpSocket(state, host, port, __FILE__, __LINE__);
|
|
755
|
+
std::pair<int, bool> nbcResult;
|
|
728
756
|
|
|
729
757
|
try {
|
|
730
|
-
|
|
731
|
-
return true;
|
|
732
|
-
}
|
|
758
|
+
nbcResult = createNonBlockingTcpSocketConnection(host, port, __FILE__, __LINE__);
|
|
733
759
|
} catch (const SystemException &e) {
|
|
734
760
|
if (e.code() == ECONNREFUSED) {
|
|
735
761
|
return false;
|
|
@@ -737,13 +763,17 @@ pingTcpServer(const StaticString &host, unsigned int port, unsigned long long *t
|
|
|
737
763
|
throw e;
|
|
738
764
|
}
|
|
739
765
|
}
|
|
766
|
+
FdGuard guard(nbcResult.first, nullptr, 0);
|
|
767
|
+
if (nbcResult.second) {
|
|
768
|
+
return true;
|
|
769
|
+
}
|
|
740
770
|
|
|
741
771
|
// Cannot connect to the port yet, but that may not mean the
|
|
742
772
|
// port is unavailable. So poll the socket.
|
|
743
773
|
|
|
744
774
|
bool connectable;
|
|
745
775
|
try {
|
|
746
|
-
connectable = waitUntilWritable(
|
|
776
|
+
connectable = waitUntilWritable(nbcResult.first, timeout);
|
|
747
777
|
} catch (const SystemException &e) {
|
|
748
778
|
throw SystemException("Error polling TCP socket "
|
|
749
779
|
+ host + ":" + toString(port), e.code());
|
|
@@ -753,24 +783,21 @@ pingTcpServer(const StaticString &host, unsigned int port, unsigned long long *t
|
|
|
753
783
|
return false;
|
|
754
784
|
}
|
|
755
785
|
|
|
756
|
-
//
|
|
786
|
+
// Now check the final connection establishment status.
|
|
757
787
|
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
} else {
|
|
772
|
-
throw e;
|
|
773
|
-
}
|
|
788
|
+
int connectError = 0;
|
|
789
|
+
socklen_t connectErrorLen = sizeof(connectError);
|
|
790
|
+
if (getsockopt(nbcResult.first, SOL_SOCKET, SO_ERROR, &connectError, &connectErrorLen) == -1) {
|
|
791
|
+
throw SystemException("Error checking TCP socket " + host + ":" + toString(port)
|
|
792
|
+
+ " connection establishment status", connectError);
|
|
793
|
+
}
|
|
794
|
+
if (connectError == 0) {
|
|
795
|
+
return true;
|
|
796
|
+
} else if (connectError == ECONNREFUSED) {
|
|
797
|
+
return false;
|
|
798
|
+
} else {
|
|
799
|
+
throw SystemException("Error connecting to TCP socket " + host + ":"
|
|
800
|
+
+ toString(port), connectError);
|
|
774
801
|
}
|
|
775
802
|
}
|
|
776
803
|
|