passenger 3.0.0 → 3.0.1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of passenger might be problematic. Click here for more details.
- data/DEVELOPERS.TXT +9 -6
- data/NEWS +50 -0
- data/Rakefile +2 -1
- data/bin/passenger-install-apache2-module +4 -4
- data/bin/passenger-install-nginx-module +1 -1
- data/bin/passenger-make-enterprisey +1 -1
- data/build/agents.rb +26 -19
- data/build/apache2.rb +49 -46
- data/build/basics.rb +37 -13
- data/build/common_library.rb +134 -64
- data/build/config.rb +18 -11
- data/build/cplusplus_support.rb +4 -0
- data/build/cxx_tests.rb +26 -12
- data/build/documentation.rb +18 -11
- data/build/integration_tests.rb +18 -11
- data/build/misc.rb +18 -11
- data/build/nginx.rb +27 -19
- data/build/oxt_tests.rb +18 -11
- data/build/packaging.rb +45 -37
- data/build/rpm.rb +98 -0
- data/build/ruby_extension.rb +19 -13
- data/build/ruby_tests.rb +19 -12
- data/build/test_basics.rb +23 -11
- data/debian/README.Debian +15 -0
- data/debian/changelog +185 -0
- data/debian/control +47 -19
- data/debian/copyright +20 -0
- data/debian/libapache2-mod-passenger.install +1 -0
- data/debian/libapache2-mod-passenger.postinst +36 -0
- data/debian/libapache2-mod-passenger.prerm +15 -0
- data/debian/passenger-common.install +4 -0
- data/debian/passenger.conf +4 -0
- data/debian/passenger.load +1 -0
- data/debian/rules +37 -0
- data/debian/watch +3 -0
- data/{misc → dev}/copy_boost_headers.rb +3 -0
- data/{misc → dev}/find_owner_pipe_leaks.rb +0 -0
- data/{misc → dev}/render_error_pages.rb +0 -0
- data/doc/Users guide Apache.html +39 -1
- data/doc/Users guide Apache.txt +40 -0
- data/doc/Users guide Nginx.html +1 -1
- data/doc/Users guide Standalone.html +1 -1
- data/doc/cxxapi/Constants_8h_source.html +1 -1
- data/doc/cxxapi/DirectoryMapper_8h_source.html +6 -22
- data/doc/cxxapi/EventedClient_8h_source.html +572 -468
- data/doc/cxxapi/Exceptions_8h_source.html +142 -129
- data/doc/cxxapi/FileDescriptor_8h_source.html +263 -199
- data/doc/cxxapi/MessageChannel_8h_source.html +686 -770
- data/doc/cxxapi/MessageServer_8h_source.html +1 -1
- data/doc/cxxapi/PoolOptions_8h_source.html +79 -78
- data/doc/cxxapi/ResourceLocator_8h_source.html +105 -55
- data/doc/cxxapi/SafeLibev_8h_source.html +180 -0
- data/doc/cxxapi/ServerInstanceDir_8h_source.html +114 -110
- data/doc/cxxapi/Session_8h_source.html +1 -1
- data/doc/cxxapi/SpawnManager_8h_source.html +208 -208
- data/doc/cxxapi/StaticString_8h_source.html +258 -183
- data/doc/cxxapi/Utils_8h_source.html +71 -54
- data/doc/cxxapi/annotated.html +3 -0
- data/doc/cxxapi/classAgentWatcher.html +2 -2
- data/doc/cxxapi/classPassenger_1_1DirectoryMapper-members.html +0 -1
- data/doc/cxxapi/classPassenger_1_1DirectoryMapper.html +0 -27
- data/doc/cxxapi/classPassenger_1_1EventedClient-members.html +5 -0
- data/doc/cxxapi/classPassenger_1_1EventedClient.html +102 -7
- data/doc/cxxapi/classPassenger_1_1FileDescriptor-members.html +2 -1
- data/doc/cxxapi/classPassenger_1_1FileDescriptor.html +34 -8
- data/doc/cxxapi/classPassenger_1_1FileDescriptorPair-members.html +36 -0
- data/doc/cxxapi/classPassenger_1_1FileDescriptorPair.html +52 -0
- data/doc/cxxapi/classPassenger_1_1MessageChannel-members.html +0 -3
- data/doc/cxxapi/classPassenger_1_1MessageChannel.html +0 -120
- data/doc/cxxapi/classPassenger_1_1SafeLibev-members.html +36 -0
- data/doc/cxxapi/classPassenger_1_1SafeLibev.html +51 -0
- data/doc/cxxapi/classPassenger_1_1SpawnException-members.html +1 -0
- data/doc/cxxapi/classPassenger_1_1SpawnException.html +22 -0
- data/doc/cxxapi/classes.html +14 -14
- data/doc/cxxapi/files.html +2 -0
- data/doc/cxxapi/functions_0x63.html +6 -3
- data/doc/cxxapi/functions_0x64.html +9 -2
- data/doc/cxxapi/functions_0x67.html +6 -9
- data/doc/cxxapi/functions_0x69.html +3 -0
- data/doc/cxxapi/functions_0x77.html +8 -8
- data/doc/cxxapi/functions_eval.html +6 -0
- data/doc/cxxapi/functions_func.html +18 -17
- data/doc/cxxapi/functions_vars.html +8 -0
- data/doc/cxxapi/graph_legend.png +0 -0
- data/doc/cxxapi/group__Core.png +0 -0
- data/doc/cxxapi/group__Hooks.png +0 -0
- data/doc/cxxapi/hierarchy.html +3 -0
- data/doc/cxxapi/inherit__graph__14.map +1 -1
- data/doc/cxxapi/inherit__graph__14.md5 +1 -1
- data/doc/cxxapi/inherit__graph__14.png +0 -0
- data/doc/cxxapi/inherit__graph__15.map +1 -3
- data/doc/cxxapi/inherit__graph__15.md5 +1 -1
- data/doc/cxxapi/inherit__graph__15.png +0 -0
- data/doc/cxxapi/inherit__graph__16.map +3 -1
- data/doc/cxxapi/inherit__graph__16.md5 +1 -1
- data/doc/cxxapi/inherit__graph__16.png +0 -0
- data/doc/cxxapi/inherit__graph__17.map +1 -1
- data/doc/cxxapi/inherit__graph__17.md5 +1 -1
- data/doc/cxxapi/inherit__graph__17.png +0 -0
- data/doc/cxxapi/inherit__graph__18.map +1 -2
- data/doc/cxxapi/inherit__graph__18.md5 +1 -1
- data/doc/cxxapi/inherit__graph__18.png +0 -0
- data/doc/cxxapi/inherit__graph__19.map +2 -1
- data/doc/cxxapi/inherit__graph__19.md5 +1 -1
- data/doc/cxxapi/inherit__graph__19.png +0 -0
- data/doc/cxxapi/inherit__graph__20.map +1 -1
- data/doc/cxxapi/inherit__graph__20.md5 +1 -1
- data/doc/cxxapi/inherit__graph__20.png +0 -0
- data/doc/cxxapi/inherit__graph__21.map +1 -1
- data/doc/cxxapi/inherit__graph__21.md5 +1 -1
- data/doc/cxxapi/inherit__graph__21.png +0 -0
- data/doc/cxxapi/inherit__graph__22.map +1 -1
- data/doc/cxxapi/inherit__graph__22.md5 +1 -1
- data/doc/cxxapi/inherit__graph__22.png +0 -0
- data/doc/cxxapi/inherit__graph__23.map +1 -1
- data/doc/cxxapi/inherit__graph__23.md5 +1 -1
- data/doc/cxxapi/inherit__graph__23.png +0 -0
- data/doc/cxxapi/inherit__graph__24.map +1 -1
- data/doc/cxxapi/inherit__graph__24.md5 +1 -1
- data/doc/cxxapi/inherit__graph__24.png +0 -0
- data/doc/cxxapi/inherit__graph__25.map +1 -1
- data/doc/cxxapi/inherit__graph__25.md5 +1 -1
- data/doc/cxxapi/inherit__graph__25.png +0 -0
- data/doc/cxxapi/inherit__graph__26.map +1 -1
- data/doc/cxxapi/inherit__graph__26.md5 +1 -1
- data/doc/cxxapi/inherit__graph__26.png +0 -0
- data/doc/cxxapi/inherit__graph__27.map +1 -1
- data/doc/cxxapi/inherit__graph__27.md5 +1 -1
- data/doc/cxxapi/inherit__graph__27.png +0 -0
- data/doc/cxxapi/inherit__graph__28.map +1 -2
- data/doc/cxxapi/inherit__graph__28.md5 +1 -1
- data/doc/cxxapi/inherit__graph__28.png +0 -0
- data/doc/cxxapi/inherit__graph__29.map +1 -1
- data/doc/cxxapi/inherit__graph__29.md5 +1 -1
- data/doc/cxxapi/inherit__graph__29.png +0 -0
- data/doc/cxxapi/inherit__graph__30.map +1 -1
- data/doc/cxxapi/inherit__graph__30.md5 +1 -1
- data/doc/cxxapi/inherit__graph__30.png +0 -0
- data/doc/cxxapi/inherit__graph__31.map +2 -1
- data/doc/cxxapi/inherit__graph__31.md5 +1 -1
- data/doc/cxxapi/inherit__graph__31.png +0 -0
- data/doc/cxxapi/inherit__graph__32.map +1 -3
- data/doc/cxxapi/inherit__graph__32.md5 +1 -1
- data/doc/cxxapi/inherit__graph__32.png +0 -0
- data/doc/cxxapi/inherit__graph__33.map +1 -1
- data/doc/cxxapi/inherit__graph__33.md5 +1 -1
- data/doc/cxxapi/inherit__graph__33.png +0 -0
- data/doc/cxxapi/inherit__graph__34.map +1 -1
- data/doc/cxxapi/inherit__graph__34.md5 +1 -1
- data/doc/cxxapi/inherit__graph__34.png +0 -0
- data/doc/cxxapi/inherit__graph__35.map +3 -1
- data/doc/cxxapi/inherit__graph__35.md5 +1 -1
- data/doc/cxxapi/inherit__graph__35.png +0 -0
- data/doc/cxxapi/inherit__graph__36.map +1 -1
- data/doc/cxxapi/inherit__graph__36.md5 +1 -1
- data/doc/cxxapi/inherit__graph__36.png +0 -0
- data/doc/cxxapi/inherit__graph__37.map +1 -1
- data/doc/cxxapi/inherit__graph__37.md5 +1 -1
- data/doc/cxxapi/inherit__graph__37.png +0 -0
- data/doc/cxxapi/inherit__graph__38.map +3 -1
- data/doc/cxxapi/inherit__graph__38.md5 +1 -1
- data/doc/cxxapi/inherit__graph__38.png +0 -0
- data/doc/cxxapi/inherit__graph__39.map +3 -1
- data/doc/cxxapi/inherit__graph__39.md5 +1 -1
- data/doc/cxxapi/inherit__graph__39.png +0 -0
- data/doc/cxxapi/inherits.html +33 -24
- data/doc/cxxapi/namespacePassenger.html +52 -0
- data/doc/cxxapi/namespacemembers.html +6 -0
- data/doc/cxxapi/namespacemembers_func.html +6 -0
- data/doc/cxxapi/tree.html +8 -0
- data/ext/apache2/Configuration.cpp +30 -8
- data/ext/apache2/Configuration.hpp +15 -14
- data/ext/apache2/DirectoryMapper.h +0 -16
- data/ext/apache2/Hooks.cpp +30 -29
- data/ext/boost/algorithm/string/detail/case_conv.hpp +6 -6
- data/ext/boost/algorithm/string/detail/find_format.hpp +14 -4
- data/ext/boost/algorithm/string/detail/find_format_all.hpp +13 -3
- data/ext/boost/algorithm/string/detail/find_format_store.hpp +11 -0
- data/ext/boost/algorithm/string/erase.hpp +2 -2
- data/ext/boost/bind/placeholders.hpp +2 -2
- data/ext/boost/concept/detail/backward_compatibility.hpp +16 -0
- data/ext/boost/concept/detail/general.hpp +15 -6
- data/ext/boost/concept/detail/has_constraints.hpp +5 -3
- data/ext/boost/concept/usage.hpp +5 -4
- data/ext/boost/concept_check.hpp +10 -1
- data/ext/boost/config/abi/borland_prefix.hpp +1 -1
- data/ext/boost/config/auto_link.hpp +68 -21
- data/ext/boost/config/compiler/borland.hpp +11 -3
- data/ext/boost/config/compiler/clang.hpp +62 -0
- data/ext/boost/config/compiler/codegear.hpp +21 -7
- data/ext/boost/config/compiler/common_edg.hpp +4 -2
- data/ext/boost/config/compiler/digitalmars.hpp +1 -1
- data/ext/boost/config/compiler/gcc.hpp +46 -7
- data/ext/boost/config/compiler/gcc_xml.hpp +25 -0
- data/ext/boost/config/compiler/intel.hpp +23 -0
- data/ext/boost/config/compiler/kai.hpp +1 -1
- data/ext/boost/config/compiler/metrowerks.hpp +1 -1
- data/ext/boost/config/compiler/nvcc.hpp +86 -0
- data/ext/boost/config/compiler/pgi.hpp +18 -3
- data/ext/boost/config/compiler/sunpro_cc.hpp +19 -5
- data/ext/boost/config/compiler/vacpp.hpp +8 -0
- data/ext/boost/config/compiler/visualc.hpp +27 -11
- data/ext/boost/config/platform/cygwin.hpp +0 -3
- data/ext/boost/config/platform/symbian.hpp +94 -0
- data/ext/boost/config/platform/win32.hpp +8 -1
- data/ext/boost/config/select_compiler_config.hpp +10 -0
- data/ext/boost/config/select_platform_config.hpp +4 -0
- data/ext/boost/config/stdlib/dinkumware.hpp +11 -1
- data/ext/boost/config/stdlib/libcomo.hpp +1 -0
- data/ext/boost/config/stdlib/libstdcpp3.hpp +1 -0
- data/ext/boost/config/stdlib/modena.hpp +1 -0
- data/ext/boost/config/stdlib/msl.hpp +1 -0
- data/ext/boost/config/stdlib/roguewave.hpp +1 -0
- data/ext/boost/config/stdlib/sgi.hpp +1 -0
- data/ext/boost/config/stdlib/stlport.hpp +1 -0
- data/ext/boost/config/stdlib/vacpp.hpp +1 -0
- data/ext/boost/config/suffix.hpp +40 -2
- data/ext/boost/cstdint.hpp +36 -7
- data/ext/boost/date_time/gregorian/conversion.hpp +4 -2
- data/ext/boost/date_time/microsec_time_clock.hpp +7 -7
- data/ext/boost/date_time/posix_time/conversion.hpp +4 -2
- data/ext/boost/date_time/time_facet.hpp +43 -4
- data/ext/boost/detail/endian.hpp +5 -2
- data/ext/boost/detail/lcast_precision.hpp +2 -2
- data/ext/boost/detail/sp_typeinfo.hpp +1 -1
- data/ext/boost/detail/workaround.hpp +5 -0
- data/ext/boost/exception/detail/error_info_impl.hpp +3 -3
- data/ext/boost/exception/detail/exception_ptr.hpp +76 -135
- data/ext/boost/exception/detail/is_output_streamable.hpp +15 -2
- data/ext/boost/exception/detail/type_info.hpp +9 -5
- data/ext/boost/exception/diagnostic_information.hpp +5 -3
- data/ext/boost/exception/exception.hpp +60 -46
- data/ext/boost/exception/info.hpp +47 -14
- data/ext/boost/function/function_base.hpp +4 -4
- data/ext/boost/integer.hpp +4 -0
- data/ext/boost/integer_fwd.hpp +9 -3
- data/ext/boost/iterator/iterator_concepts.hpp +284 -0
- data/ext/boost/iterator/transform_iterator.hpp +0 -1
- data/ext/boost/make_shared.hpp +17 -0
- data/ext/boost/mpl/aux_/config/has_xxx.hpp +4 -3
- data/ext/boost/mpl/aux_/preprocessed/gcc/template_arity.hpp +2 -6
- data/ext/boost/mpl/aux_/template_arity.hpp +4 -4
- data/ext/boost/mpl/eval_if.hpp +3 -3
- data/ext/boost/mpl/has_xxx.hpp +369 -3
- data/ext/boost/optional/optional.hpp +3 -1
- data/ext/boost/optional/optional_fwd.hpp +1 -1
- data/ext/boost/preprocessor/repetition/enum_trailing_params.hpp +38 -0
- data/ext/boost/range/algorithm/equal.hpp +188 -0
- data/ext/boost/range/as_literal.hpp +15 -15
- data/ext/boost/range/concepts.hpp +331 -0
- data/ext/boost/range/const_iterator.hpp +7 -4
- data/ext/boost/range/detail/extract_optional_type.hpp +52 -0
- data/ext/boost/range/detail/implementation_help.hpp +7 -7
- data/ext/boost/range/detail/misc_concept.hpp +33 -0
- data/ext/boost/range/iterator.hpp +32 -32
- data/ext/boost/range/iterator_range.hpp +8 -651
- data/ext/boost/range/iterator_range_core.hpp +542 -0
- data/ext/boost/range/iterator_range_io.hpp +93 -0
- data/ext/boost/range/mutable_iterator.hpp +7 -4
- data/ext/boost/range/size.hpp +1 -1
- data/ext/boost/range/size_type.hpp +2 -1
- data/ext/boost/shared_array.hpp +19 -0
- data/ext/boost/smart_ptr/detail/sp_convertible.hpp +2 -2
- data/ext/boost/smart_ptr/detail/yield_k.hpp +1 -1
- data/ext/boost/smart_ptr/make_shared.hpp +508 -0
- data/ext/boost/smart_ptr/shared_array.hpp +147 -0
- data/ext/boost/src/pthread/thread.cpp +16 -21
- data/ext/boost/src/pthread/timeconv.inl +7 -4
- data/ext/boost/thread/barrier.hpp +2 -1
- data/ext/boost/thread/detail/config.hpp +7 -1
- data/ext/boost/thread/detail/platform.hpp +1 -1
- data/ext/boost/thread/detail/thread.hpp +62 -18
- data/ext/boost/thread/detail/thread_group.hpp +5 -2
- data/ext/boost/thread/detail/tss_hooks.hpp +8 -25
- data/ext/boost/thread/future.hpp +45 -34
- data/ext/boost/thread/locks.hpp +184 -55
- data/ext/boost/thread/pthread/condition_variable.hpp +7 -7
- data/ext/boost/thread/pthread/condition_variable_fwd.hpp +4 -2
- data/ext/boost/thread/pthread/mutex.hpp +29 -17
- data/ext/boost/thread/pthread/once.hpp +5 -0
- data/ext/boost/thread/pthread/recursive_mutex.hpp +97 -18
- data/ext/boost/thread/pthread/shared_mutex.hpp +1 -1
- data/ext/boost/thread/pthread/thread_heap_alloc.hpp +1 -1
- data/ext/boost/thread/tss.hpp +2 -0
- data/ext/boost/throw_exception.hpp +21 -5
- data/ext/boost/token_functions.hpp +111 -91
- data/ext/boost/type_traits/add_reference.hpp +19 -1
- data/ext/boost/type_traits/function_traits.hpp +2 -2
- data/ext/boost/type_traits/is_const.hpp +24 -5
- data/ext/boost/type_traits/is_convertible.hpp +1 -1
- data/ext/boost/type_traits/is_function.hpp +3 -0
- data/ext/boost/type_traits/is_lvalue_reference.hpp +118 -0
- data/ext/boost/type_traits/is_reference.hpp +8 -81
- data/ext/boost/type_traits/is_rvalue_reference.hpp +29 -0
- data/ext/boost/type_traits/is_same.hpp +2 -2
- data/ext/boost/type_traits/is_volatile.hpp +26 -7
- data/ext/boost/type_traits/remove_const.hpp +12 -0
- data/ext/boost/type_traits/remove_cv.hpp +23 -1
- data/ext/boost/type_traits/remove_reference.hpp +21 -1
- data/ext/boost/type_traits/type_with_alignment.hpp +10 -10
- data/ext/boost/units/detail/utility.hpp +104 -0
- data/ext/boost/utility/compare_pointees.hpp +1 -1
- data/ext/common/AgentsStarter.hpp +151 -161
- data/ext/common/ApplicationPool/Pool.h +16 -4
- data/ext/common/Constants.h +1 -1
- data/ext/common/EventedClient.h +130 -26
- data/ext/common/Exceptions.h +15 -2
- data/ext/common/FileDescriptor.h +76 -12
- data/ext/common/IniFile.h +488 -0
- data/ext/common/LoggingAgent/LoggingServer.h +2 -2
- data/ext/common/LoggingAgent/RemoteSender.h +15 -6
- data/ext/common/MessageChannel.h +17 -101
- data/ext/common/PoolOptions.h +1 -0
- data/ext/common/ResourceLocator.h +78 -28
- data/ext/common/SafeLibev.h +149 -0
- data/ext/common/ServerInstanceDir.h +11 -7
- data/ext/common/Session.h +1 -1
- data/ext/common/SpawnManager.h +14 -14
- data/ext/common/StaticString.h +75 -0
- data/ext/common/Utils.cpp +304 -12
- data/ext/common/Utils.h +17 -0
- data/ext/common/Utils/BufferedIO.h +196 -0
- data/ext/common/Utils/IOUtils.cpp +159 -0
- data/ext/common/Utils/IOUtils.h +118 -1
- data/ext/common/Utils/ProcessMetricsCollector.h +184 -56
- data/ext/common/Utils/StrIntUtils.cpp +45 -11
- data/ext/common/Utils/StrIntUtils.h +8 -5
- data/ext/common/Utils/Timer.h +22 -0
- data/ext/common/Utils/utf8.h +35 -0
- data/ext/common/Utils/utf8/checked.h +324 -0
- data/ext/common/Utils/utf8/core.h +359 -0
- data/ext/common/Utils/utf8/unchecked.h +229 -0
- data/ext/common/Watchdog.cpp +52 -85
- data/ext/libev/config.h +122 -0
- data/ext/nginx/Configuration.c +7 -1
- data/ext/nginx/HelperAgent.cpp +16 -18
- data/ext/nginx/config +6 -4
- data/ext/oxt/system_calls.cpp +10 -0
- data/ext/oxt/system_calls.hpp +2 -0
- data/lib/phusion_passenger.rb +6 -11
- data/lib/phusion_passenger/dependencies.rb +2 -0
- data/lib/phusion_passenger/packaging.rb +5 -5
- data/lib/phusion_passenger/platform_info.rb +88 -0
- data/lib/phusion_passenger/platform_info/binary_compatibility.rb +3 -17
- data/lib/phusion_passenger/platform_info/compiler.rb +14 -32
- data/lib/phusion_passenger/platform_info/curl.rb +6 -1
- data/lib/phusion_passenger/platform_info/operating_system.rb +107 -0
- data/lib/phusion_passenger/public_api.rb +2 -2
- data/lib/phusion_passenger/rails3_extensions/init.rb +5 -2
- data/lib/phusion_passenger/standalone/command.rb +6 -2
- data/lib/phusion_passenger/standalone/package_runtime_command.rb +2 -2
- data/lib/phusion_passenger/standalone/runtime_installer.rb +17 -5
- data/lib/phusion_passenger/standalone/start_command.rb +12 -12
- data/lib/phusion_passenger/standalone/stop_command.rb +3 -3
- data/lib/phusion_passenger/standalone/utils.rb +6 -2
- data/lib/phusion_passenger/templates/standalone/config.erb +37 -5
- data/lib/phusion_passenger/utils.rb +4 -7
- data/resources/mime.types +73 -0
- data/{misc → resources}/union_station_gateway.crt +0 -0
- data/test/cxx/BufferedIOTest.cpp +364 -0
- data/test/cxx/EventedClientTest.cpp +150 -13
- data/test/cxx/IOUtilsTest.cpp +399 -1
- data/test/cxx/MessageChannelTest.cpp +5 -120
- data/test/cxx/ProcessMetricsCollectorTest.cpp +121 -0
- data/test/cxx/StaticStringTest.cpp +134 -0
- data/test/cxx/UtilsTest.cpp +16 -46
- data/test/stub/rails_apps/2.3/mycook/public/dispatch.cgi +2 -2
- data/test/stub/rails_apps/2.3/mycook/public/dispatch.fcgi +1 -1
- data/test/stub/rails_apps/2.3/mycook/public/dispatch.rb +1 -1
- data/test/stub/rails_apps/3.0/empty/Gemfile.lock +73 -0
- data/test/support/allocate_memory.c +14 -0
- data/test/support/test_helper.rb +3 -0
- metadata +57 -174
- data/bin/passenger-stress-test +0 -345
- data/debian/postinst +0 -24
- data/doc/rdoc/classes/ConditionVariable.html +0 -215
- data/doc/rdoc/classes/Exception.html +0 -120
- data/doc/rdoc/classes/GC.html +0 -113
- data/doc/rdoc/classes/IO.html +0 -221
- data/doc/rdoc/classes/PhusionPassenger.html +0 -397
- data/doc/rdoc/classes/PhusionPassenger/AbstractInstaller.html +0 -180
- data/doc/rdoc/classes/PhusionPassenger/AbstractRequestHandler.html +0 -647
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer.html +0 -654
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/InvalidPassword.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerAlreadyStarted.html +0 -97
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerError.html +0 -96
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerNotStarted.html +0 -97
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer/UnknownMessage.html +0 -96
- data/doc/rdoc/classes/PhusionPassenger/AbstractServerCollection.html +0 -619
- data/doc/rdoc/classes/PhusionPassenger/AdminTools.html +0 -142
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/MemoryStats.html +0 -368
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/MemoryStats/Process.html +0 -231
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance.html +0 -588
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/CorruptedDirectoryError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/GenerationsAbsentError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Group.html +0 -147
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Process.html +0 -279
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/RoleDeniedError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/StaleDirectoryError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Stats.html +0 -123
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/UnsupportedGenerationStructureVersionError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger.html +0 -341
- data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/Log.html +0 -294
- data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/SharedData.html +0 -199
- data/doc/rdoc/classes/PhusionPassenger/AppInitError.html +0 -155
- data/doc/rdoc/classes/PhusionPassenger/AppProcess.html +0 -367
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails.html +0 -95
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/ApplicationSpawner.html +0 -351
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/ApplicationSpawner/Error.html +0 -98
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/CGIFixed.html +0 -200
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/FrameworkSpawner.html +0 -410
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/FrameworkSpawner/Error.html +0 -98
- data/doc/rdoc/classes/PhusionPassenger/ClassicRails/RequestHandler.html +0 -156
- data/doc/rdoc/classes/PhusionPassenger/ClassicRailsExtensions.html +0 -115
- data/doc/rdoc/classes/PhusionPassenger/ClassicRailsExtensions/AnalyticsLogging.html +0 -202
- data/doc/rdoc/classes/PhusionPassenger/ConsoleTextTemplate.html +0 -172
- data/doc/rdoc/classes/PhusionPassenger/DebugLogging.html +0 -273
- data/doc/rdoc/classes/PhusionPassenger/FrameworkInitError.html +0 -145
- data/doc/rdoc/classes/PhusionPassenger/HTMLTemplate.html +0 -162
- data/doc/rdoc/classes/PhusionPassenger/InitializationError.html +0 -141
- data/doc/rdoc/classes/PhusionPassenger/InvalidPath.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/MessageChannel.html +0 -673
- data/doc/rdoc/classes/PhusionPassenger/MessageChannel/InvalidHashError.html +0 -92
- data/doc/rdoc/classes/PhusionPassenger/MessageClient.html +0 -415
- data/doc/rdoc/classes/PhusionPassenger/NativeSupportLoader.html +0 -134
- data/doc/rdoc/classes/PhusionPassenger/Packaging.html +0 -129
- data/doc/rdoc/classes/PhusionPassenger/PlatformInfo.html +0 -1809
- data/doc/rdoc/classes/PhusionPassenger/Plugin.html +0 -237
- data/doc/rdoc/classes/PhusionPassenger/Rack.html +0 -91
- data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner.html +0 -312
- data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner/Error.html +0 -98
- data/doc/rdoc/classes/PhusionPassenger/Rack/RequestHandler.html +0 -218
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions.html +0 -114
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging.html +0 -256
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ACExtension.html +0 -139
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ASBenchmarkableExtension.html +0 -118
- data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ExceptionLogger.html +0 -135
- data/doc/rdoc/classes/PhusionPassenger/SpawnManager.html +0 -378
- data/doc/rdoc/classes/PhusionPassenger/Standalone.html +0 -111
- data/doc/rdoc/classes/PhusionPassenger/Standalone/AppFinder.html +0 -252
- data/doc/rdoc/classes/PhusionPassenger/Standalone/Command.html +0 -161
- data/doc/rdoc/classes/PhusionPassenger/Standalone/ConfigFile.html +0 -368
- data/doc/rdoc/classes/PhusionPassenger/Standalone/ConfigFile/DisallowedContextError.html +0 -132
- data/doc/rdoc/classes/PhusionPassenger/Standalone/HelpCommand.html +0 -151
- data/doc/rdoc/classes/PhusionPassenger/Standalone/Main.html +0 -189
- data/doc/rdoc/classes/PhusionPassenger/Standalone/PackageRuntimeCommand.html +0 -177
- data/doc/rdoc/classes/PhusionPassenger/Standalone/RuntimeInstaller.html +0 -341
- data/doc/rdoc/classes/PhusionPassenger/Standalone/StartCommand.html +0 -203
- data/doc/rdoc/classes/PhusionPassenger/Standalone/StatusCommand.html +0 -156
- data/doc/rdoc/classes/PhusionPassenger/Standalone/StopCommand.html +0 -168
- data/doc/rdoc/classes/PhusionPassenger/Standalone/Utils.html +0 -86
- data/doc/rdoc/classes/PhusionPassenger/Standalone/VersionCommand.html +0 -135
- data/doc/rdoc/classes/PhusionPassenger/UnknownError.html +0 -125
- data/doc/rdoc/classes/PhusionPassenger/Utils.html +0 -1550
- data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher.html +0 -204
- data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher/DirInfo.html +0 -171
- data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher/FileInfo.html +0 -140
- data/doc/rdoc/classes/PhusionPassenger/Utils/HostsFileParser.html +0 -260
- data/doc/rdoc/classes/PhusionPassenger/Utils/PseudoIO.html +0 -169
- data/doc/rdoc/classes/PhusionPassenger/Utils/RewindableInput.html +0 -265
- data/doc/rdoc/classes/PhusionPassenger/Utils/RewindableInput/Tempfile.html +0 -120
- data/doc/rdoc/classes/PhusionPassenger/Utils/UnseekableSocket.html +0 -561
- data/doc/rdoc/classes/PhusionPassenger/VersionNotFound.html +0 -140
- data/doc/rdoc/classes/PhusionPassenger/WSGI.html +0 -89
- data/doc/rdoc/classes/PhusionPassenger/WSGI/ApplicationSpawner.html +0 -182
- data/doc/rdoc/classes/Process.html +0 -115
- data/doc/rdoc/classes/Signal.html +0 -139
- data/doc/rdoc/created.rid +0 -1
- data/doc/rdoc/files/DEVELOPERS_TXT.html +0 -276
- data/doc/rdoc/files/README.html +0 -157
- data/doc/rdoc/files/lib/phusion_passenger/abstract_installer_rb.html +0 -130
- data/doc/rdoc/files/lib/phusion_passenger/abstract_request_handler_rb.html +0 -135
- data/doc/rdoc/files/lib/phusion_passenger/abstract_server_collection_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/abstract_server_rb.html +0 -128
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools/memory_stats_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools/server_instance_rb.html +0 -132
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/analytics_logger_rb.html +0 -129
- data/doc/rdoc/files/lib/phusion_passenger/app_process_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails/application_spawner_rb.html +0 -141
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails/cgi_fixed_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails/framework_spawner_rb.html +0 -146
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails/request_handler_rb.html +0 -125
- data/doc/rdoc/files/lib/phusion_passenger/classic_rails_extensions/init_rb.html +0 -132
- data/doc/rdoc/files/lib/phusion_passenger/console_text_template_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/constants_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/debug_logging_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/dependencies_rb.html +0 -147
- data/doc/rdoc/files/lib/phusion_passenger/exceptions_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/html_template_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/message_channel_rb.html +0 -120
- data/doc/rdoc/files/lib/phusion_passenger/message_client_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/native_support_rb.html +0 -132
- data/doc/rdoc/files/lib/phusion_passenger/packaging_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/apache_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/binary_compatibility_rb.html +0 -129
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/compiler_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/curl_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/documentation_tools_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/linux_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/operating_system_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/ruby_rb.html +0 -128
- data/doc/rdoc/files/lib/phusion_passenger/platform_info/zlib_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/platform_info_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/plugin_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/public_api_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/rack/application_spawner_rb.html +0 -137
- data/doc/rdoc/files/lib/phusion_passenger/rack/request_handler_rb.html +0 -125
- data/doc/rdoc/files/lib/phusion_passenger/rails3_extensions/init_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/simple_benchmarking_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/spawn_manager_rb.html +0 -160
- data/doc/rdoc/files/lib/phusion_passenger/standalone/app_finder_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/standalone/command_rb.html +0 -135
- data/doc/rdoc/files/lib/phusion_passenger/standalone/config_file_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/help_command_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/main_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/package_runtime_command_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/standalone/runtime_installer_rb.html +0 -133
- data/doc/rdoc/files/lib/phusion_passenger/standalone/start_command_rb.html +0 -136
- data/doc/rdoc/files/lib/phusion_passenger/standalone/status_command_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/stop_command_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/utils_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/standalone/version_command_rb.html +0 -127
- data/doc/rdoc/files/lib/phusion_passenger/utils/file_system_watcher_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/utils/hosts_file_parser_rb.html +0 -120
- data/doc/rdoc/files/lib/phusion_passenger/utils/rewindable_input_rb.html +0 -100
- data/doc/rdoc/files/lib/phusion_passenger/utils/tmpdir_rb.html +0 -122
- data/doc/rdoc/files/lib/phusion_passenger/utils/unseekable_socket_rb.html +0 -126
- data/doc/rdoc/files/lib/phusion_passenger/utils_rb.html +0 -179
- data/doc/rdoc/files/lib/phusion_passenger/wsgi/application_spawner_rb.html +0 -132
- data/doc/rdoc/fr_class_index.html +0 -138
- data/doc/rdoc/fr_file_index.html +0 -108
- data/doc/rdoc/fr_method_index.html +0 -430
- data/doc/rdoc/index.html +0 -26
- data/doc/rdoc/rdoc-style.css +0 -187
- data/ext/apache2/LICENSE-CNRI.TXT +0 -79
- data/ext/common/Utils/BlockingScalar.h +0 -50
- data/ext/common/Utils/FileHandleGuard.h +0 -81
@@ -3,7 +3,7 @@
|
|
3
3
|
// Distributed under the Boost Software License, Version 1.0. (See
|
4
4
|
// accompanying file LICENSE_1_0.txt or copy at
|
5
5
|
// http://www.boost.org/LICENSE_1_0.txt)
|
6
|
-
// (C) Copyright 2007-
|
6
|
+
// (C) Copyright 2007-10 Anthony Williams
|
7
7
|
|
8
8
|
#include "timespec.hpp"
|
9
9
|
#include "pthread_mutex_scoped_lock.hpp"
|
@@ -51,8 +51,8 @@ namespace boost
|
|
51
51
|
pthread_mutex_t internal_mutex;
|
52
52
|
pthread_cond_t cond;
|
53
53
|
|
54
|
-
condition_variable_any(
|
55
|
-
condition_variable_any& operator=(
|
54
|
+
condition_variable_any(condition_variable_any&);
|
55
|
+
condition_variable_any& operator=(condition_variable_any&);
|
56
56
|
|
57
57
|
public:
|
58
58
|
condition_variable_any()
|
@@ -60,13 +60,13 @@ namespace boost
|
|
60
60
|
int const res=pthread_mutex_init(&internal_mutex,NULL);
|
61
61
|
if(res)
|
62
62
|
{
|
63
|
-
|
63
|
+
boost::throw_exception(thread_resource_error("Cannot initialize a mutex", res));
|
64
64
|
}
|
65
65
|
int const res2=pthread_cond_init(&cond,NULL);
|
66
66
|
if(res2)
|
67
67
|
{
|
68
68
|
BOOST_VERIFY(!pthread_mutex_destroy(&internal_mutex));
|
69
|
-
|
69
|
+
boost::throw_exception(thread_resource_error("Cannot initialize a condition variable", res2));
|
70
70
|
}
|
71
71
|
}
|
72
72
|
~condition_variable_any()
|
@@ -90,7 +90,7 @@ namespace boost
|
|
90
90
|
}
|
91
91
|
if(res)
|
92
92
|
{
|
93
|
-
|
93
|
+
boost::throw_exception(condition_error());
|
94
94
|
}
|
95
95
|
}
|
96
96
|
|
@@ -120,7 +120,7 @@ namespace boost
|
|
120
120
|
}
|
121
121
|
if(res)
|
122
122
|
{
|
123
|
-
|
123
|
+
boost::throw_exception(condition_error());
|
124
124
|
}
|
125
125
|
return true;
|
126
126
|
}
|
@@ -6,6 +6,7 @@
|
|
6
6
|
// (C) Copyright 2007-8 Anthony Williams
|
7
7
|
|
8
8
|
#include <boost/assert.hpp>
|
9
|
+
#include <boost/throw_exception.hpp>
|
9
10
|
#include <pthread.h>
|
10
11
|
#include <boost/thread/mutex.hpp>
|
11
12
|
#include <boost/thread/locks.hpp>
|
@@ -30,7 +31,7 @@ namespace boost
|
|
30
31
|
int const res=pthread_cond_init(&cond,NULL);
|
31
32
|
if(res)
|
32
33
|
{
|
33
|
-
|
34
|
+
boost::throw_exception(thread_resource_error("Cannot initialize a condition variable", res));
|
34
35
|
}
|
35
36
|
}
|
36
37
|
~condition_variable()
|
@@ -49,7 +50,8 @@ namespace boost
|
|
49
50
|
while(!pred()) wait(m);
|
50
51
|
}
|
51
52
|
|
52
|
-
bool timed_wait(unique_lock<mutex>& m,
|
53
|
+
inline bool timed_wait(unique_lock<mutex>& m,
|
54
|
+
boost::system_time const& wait_until);
|
53
55
|
bool timed_wait(unique_lock<mutex>& m,xtime const& wait_until)
|
54
56
|
{
|
55
57
|
return timed_wait(m,system_time(wait_until));
|
@@ -7,6 +7,7 @@
|
|
7
7
|
|
8
8
|
#include <pthread.h>
|
9
9
|
#include <boost/utility.hpp>
|
10
|
+
#include <boost/throw_exception.hpp>
|
10
11
|
#include <boost/thread/exceptions.hpp>
|
11
12
|
#include <boost/thread/locks.hpp>
|
12
13
|
#include <boost/thread/thread_time.hpp>
|
@@ -26,10 +27,11 @@
|
|
26
27
|
|
27
28
|
namespace boost
|
28
29
|
{
|
29
|
-
class mutex
|
30
|
-
boost::noncopyable
|
30
|
+
class mutex
|
31
31
|
{
|
32
32
|
private:
|
33
|
+
mutex(mutex const&);
|
34
|
+
mutex& operator=(mutex const&);
|
33
35
|
pthread_mutex_t m;
|
34
36
|
public:
|
35
37
|
mutex()
|
@@ -37,32 +39,37 @@ namespace boost
|
|
37
39
|
int const res=pthread_mutex_init(&m,NULL);
|
38
40
|
if(res)
|
39
41
|
{
|
40
|
-
|
42
|
+
boost::throw_exception(thread_resource_error("Cannot initialize a mutex", res));
|
41
43
|
}
|
42
44
|
}
|
43
45
|
~mutex()
|
44
46
|
{
|
45
47
|
int ret;
|
46
|
-
do
|
48
|
+
do
|
49
|
+
{
|
47
50
|
ret = pthread_mutex_destroy(&m);
|
48
|
-
} while
|
51
|
+
} while(ret==EINTR);
|
49
52
|
}
|
50
53
|
|
51
54
|
void lock()
|
52
55
|
{
|
53
|
-
int
|
54
|
-
do
|
55
|
-
|
56
|
-
|
57
|
-
|
56
|
+
int res;
|
57
|
+
do
|
58
|
+
{
|
59
|
+
res = pthread_mutex_lock(&m);
|
60
|
+
} while (res==EINTR);
|
61
|
+
if(res) {
|
62
|
+
boost::throw_exception(lock_error(res));
|
63
|
+
}
|
58
64
|
}
|
59
65
|
|
60
66
|
void unlock()
|
61
67
|
{
|
62
68
|
int ret;
|
63
|
-
do
|
69
|
+
do
|
70
|
+
{
|
64
71
|
ret = pthread_mutex_unlock(&m);
|
65
|
-
} while (ret
|
72
|
+
} while (ret==EINTR);
|
66
73
|
BOOST_VERIFY(!ret);
|
67
74
|
}
|
68
75
|
|
@@ -72,7 +79,10 @@ namespace boost
|
|
72
79
|
do {
|
73
80
|
res = pthread_mutex_trylock(&m);
|
74
81
|
} while (res == EINTR);
|
75
|
-
|
82
|
+
if(res && (res!=EBUSY))
|
83
|
+
{
|
84
|
+
boost::throw_exception(lock_error(res));
|
85
|
+
}
|
76
86
|
return !res;
|
77
87
|
}
|
78
88
|
|
@@ -88,9 +98,11 @@ namespace boost
|
|
88
98
|
|
89
99
|
typedef mutex try_mutex;
|
90
100
|
|
91
|
-
class timed_mutex
|
92
|
-
boost::noncopyable
|
101
|
+
class timed_mutex
|
93
102
|
{
|
103
|
+
private:
|
104
|
+
timed_mutex(timed_mutex const&);
|
105
|
+
timed_mutex& operator=(timed_mutex const&);
|
94
106
|
private:
|
95
107
|
pthread_mutex_t m;
|
96
108
|
#ifndef BOOST_PTHREAD_HAS_TIMEDLOCK
|
@@ -103,14 +115,14 @@ namespace boost
|
|
103
115
|
int const res=pthread_mutex_init(&m,NULL);
|
104
116
|
if(res)
|
105
117
|
{
|
106
|
-
|
118
|
+
boost::throw_exception(thread_resource_error("Cannot initialize a mutex", res));
|
107
119
|
}
|
108
120
|
#ifndef BOOST_PTHREAD_HAS_TIMEDLOCK
|
109
121
|
int const res2=pthread_cond_init(&cond,NULL);
|
110
122
|
if(res2)
|
111
123
|
{
|
112
124
|
BOOST_VERIFY(!pthread_mutex_destroy(&m));
|
113
|
-
|
125
|
+
boost::throw_exception(thread_resource_error("Cannot initialize a condition variable", res2));
|
114
126
|
}
|
115
127
|
is_locked=false;
|
116
128
|
#endif
|
@@ -10,6 +10,7 @@
|
|
10
10
|
// http://www.boost.org/LICENSE_1_0.txt)
|
11
11
|
|
12
12
|
#include <boost/thread/detail/config.hpp>
|
13
|
+
#include <boost/config.hpp>
|
13
14
|
|
14
15
|
#include <pthread.h>
|
15
16
|
#include <boost/assert.hpp>
|
@@ -58,10 +59,13 @@ namespace boost
|
|
58
59
|
if(flag.epoch==uninitialized_flag)
|
59
60
|
{
|
60
61
|
flag.epoch=being_initialized;
|
62
|
+
#ifndef BOOST_NO_EXCEPTIONS
|
61
63
|
try
|
62
64
|
{
|
65
|
+
#endif
|
63
66
|
pthread::pthread_mutex_scoped_unlock relocker(&detail::once_epoch_mutex);
|
64
67
|
f();
|
68
|
+
#ifndef BOOST_NO_EXCEPTIONS
|
65
69
|
}
|
66
70
|
catch(...)
|
67
71
|
{
|
@@ -69,6 +73,7 @@ namespace boost
|
|
69
73
|
BOOST_VERIFY(!pthread_cond_broadcast(&detail::once_epoch_cv));
|
70
74
|
throw;
|
71
75
|
}
|
76
|
+
#endif
|
72
77
|
flag.epoch=--detail::once_global_epoch;
|
73
78
|
BOOST_VERIFY(!pthread_cond_broadcast(&detail::once_epoch_cv));
|
74
79
|
}
|
@@ -7,6 +7,7 @@
|
|
7
7
|
|
8
8
|
#include <pthread.h>
|
9
9
|
#include <boost/utility.hpp>
|
10
|
+
#include <boost/throw_exception.hpp>
|
10
11
|
#include <boost/thread/exceptions.hpp>
|
11
12
|
#include <boost/thread/locks.hpp>
|
12
13
|
#include <boost/thread/thread_time.hpp>
|
@@ -25,43 +26,76 @@
|
|
25
26
|
#endif
|
26
27
|
#endif
|
27
28
|
|
29
|
+
#if defined(BOOST_PTHREAD_HAS_MUTEXATTR_SETTYPE) && defined(BOOST_PTHREAD_HAS_TIMEDLOCK)
|
30
|
+
#define BOOST_USE_PTHREAD_RECURSIVE_TIMEDLOCK
|
31
|
+
#endif
|
32
|
+
|
28
33
|
#include <boost/config/abi_prefix.hpp>
|
29
34
|
|
30
35
|
namespace boost
|
31
36
|
{
|
32
|
-
class recursive_mutex
|
33
|
-
boost::noncopyable
|
37
|
+
class recursive_mutex
|
34
38
|
{
|
35
39
|
private:
|
40
|
+
recursive_mutex(recursive_mutex const&);
|
41
|
+
recursive_mutex& operator=(recursive_mutex const&);
|
36
42
|
pthread_mutex_t m;
|
43
|
+
#ifndef BOOST_PTHREAD_HAS_MUTEXATTR_SETTYPE
|
44
|
+
pthread_cond_t cond;
|
45
|
+
bool is_locked;
|
46
|
+
pthread_t owner;
|
47
|
+
unsigned count;
|
48
|
+
#endif
|
37
49
|
public:
|
38
50
|
recursive_mutex()
|
39
51
|
{
|
52
|
+
#ifdef BOOST_PTHREAD_HAS_MUTEXATTR_SETTYPE
|
40
53
|
pthread_mutexattr_t attr;
|
41
54
|
|
42
55
|
int const init_attr_res=pthread_mutexattr_init(&attr);
|
43
56
|
if(init_attr_res)
|
44
57
|
{
|
45
|
-
|
58
|
+
boost::throw_exception(thread_resource_error());
|
46
59
|
}
|
47
60
|
int const set_attr_res=pthread_mutexattr_settype(&attr,PTHREAD_MUTEX_RECURSIVE);
|
48
61
|
if(set_attr_res)
|
49
62
|
{
|
50
|
-
|
63
|
+
BOOST_VERIFY(!pthread_mutexattr_destroy(&attr));
|
64
|
+
boost::throw_exception(thread_resource_error());
|
51
65
|
}
|
52
66
|
|
53
67
|
int const res=pthread_mutex_init(&m,&attr);
|
54
68
|
if(res)
|
55
69
|
{
|
56
|
-
|
70
|
+
BOOST_VERIFY(!pthread_mutexattr_destroy(&attr));
|
71
|
+
boost::throw_exception(thread_resource_error());
|
57
72
|
}
|
58
73
|
BOOST_VERIFY(!pthread_mutexattr_destroy(&attr));
|
74
|
+
#else
|
75
|
+
int const res=pthread_mutex_init(&m,NULL);
|
76
|
+
if(res)
|
77
|
+
{
|
78
|
+
boost::throw_exception(thread_resource_error());
|
79
|
+
}
|
80
|
+
int const res2=pthread_cond_init(&cond,NULL);
|
81
|
+
if(res2)
|
82
|
+
{
|
83
|
+
BOOST_VERIFY(!pthread_mutex_destroy(&m));
|
84
|
+
boost::throw_exception(thread_resource_error());
|
85
|
+
}
|
86
|
+
is_locked=false;
|
87
|
+
count=0;
|
88
|
+
#endif
|
59
89
|
}
|
60
90
|
~recursive_mutex()
|
61
91
|
{
|
62
92
|
BOOST_VERIFY(!pthread_mutex_destroy(&m));
|
93
|
+
#ifndef BOOST_PTHREAD_HAS_MUTEXATTR_SETTYPE
|
94
|
+
BOOST_VERIFY(!pthread_cond_destroy(&cond));
|
95
|
+
#endif
|
63
96
|
}
|
64
|
-
|
97
|
+
|
98
|
+
#ifdef BOOST_PTHREAD_HAS_MUTEXATTR_SETTYPE
|
65
99
|
void lock()
|
66
100
|
{
|
67
101
|
BOOST_VERIFY(!pthread_mutex_lock(&m));
|
@@ -78,25 +112,70 @@ namespace boost
|
|
78
112
|
BOOST_ASSERT(!res || res==EBUSY);
|
79
113
|
return !res;
|
80
114
|
}
|
81
|
-
|
82
115
|
typedef pthread_mutex_t* native_handle_type;
|
83
116
|
native_handle_type native_handle()
|
84
117
|
{
|
85
118
|
return &m;
|
86
119
|
}
|
87
120
|
|
121
|
+
#else
|
122
|
+
void lock()
|
123
|
+
{
|
124
|
+
boost::pthread::pthread_mutex_scoped_lock const local_lock(&m);
|
125
|
+
if(is_locked && pthread_equal(owner,pthread_self()))
|
126
|
+
{
|
127
|
+
++count;
|
128
|
+
return;
|
129
|
+
}
|
130
|
+
|
131
|
+
while(is_locked)
|
132
|
+
{
|
133
|
+
BOOST_VERIFY(!pthread_cond_wait(&cond,&m));
|
134
|
+
}
|
135
|
+
is_locked=true;
|
136
|
+
++count;
|
137
|
+
owner=pthread_self();
|
138
|
+
}
|
139
|
+
|
140
|
+
void unlock()
|
141
|
+
{
|
142
|
+
boost::pthread::pthread_mutex_scoped_lock const local_lock(&m);
|
143
|
+
if(!--count)
|
144
|
+
{
|
145
|
+
is_locked=false;
|
146
|
+
}
|
147
|
+
BOOST_VERIFY(!pthread_cond_signal(&cond));
|
148
|
+
}
|
149
|
+
|
150
|
+
bool try_lock()
|
151
|
+
{
|
152
|
+
boost::pthread::pthread_mutex_scoped_lock const local_lock(&m);
|
153
|
+
if(is_locked && !pthread_equal(owner,pthread_self()))
|
154
|
+
{
|
155
|
+
return false;
|
156
|
+
}
|
157
|
+
is_locked=true;
|
158
|
+
++count;
|
159
|
+
owner=pthread_self();
|
160
|
+
return true;
|
161
|
+
}
|
162
|
+
|
163
|
+
#endif
|
164
|
+
|
88
165
|
typedef unique_lock<recursive_mutex> scoped_lock;
|
89
166
|
typedef detail::try_lock_wrapper<recursive_mutex> scoped_try_lock;
|
90
167
|
};
|
91
168
|
|
92
169
|
typedef recursive_mutex recursive_try_mutex;
|
93
170
|
|
94
|
-
class recursive_timed_mutex
|
95
|
-
boost::noncopyable
|
171
|
+
class recursive_timed_mutex
|
96
172
|
{
|
173
|
+
private:
|
174
|
+
recursive_timed_mutex(recursive_timed_mutex const&);
|
175
|
+
recursive_timed_mutex& operator=(recursive_timed_mutex const&);
|
97
176
|
private:
|
98
177
|
pthread_mutex_t m;
|
99
|
-
#ifndef
|
178
|
+
#ifndef BOOST_USE_PTHREAD_RECURSIVE_TIMEDLOCK
|
100
179
|
pthread_cond_t cond;
|
101
180
|
bool is_locked;
|
102
181
|
pthread_t owner;
|
@@ -105,38 +184,38 @@ namespace boost
|
|
105
184
|
public:
|
106
185
|
recursive_timed_mutex()
|
107
186
|
{
|
108
|
-
#ifdef
|
187
|
+
#ifdef BOOST_USE_PTHREAD_RECURSIVE_TIMEDLOCK
|
109
188
|
pthread_mutexattr_t attr;
|
110
189
|
|
111
190
|
int const init_attr_res=pthread_mutexattr_init(&attr);
|
112
191
|
if(init_attr_res)
|
113
192
|
{
|
114
|
-
|
193
|
+
boost::throw_exception(thread_resource_error());
|
115
194
|
}
|
116
195
|
int const set_attr_res=pthread_mutexattr_settype(&attr,PTHREAD_MUTEX_RECURSIVE);
|
117
196
|
if(set_attr_res)
|
118
197
|
{
|
119
|
-
|
198
|
+
boost::throw_exception(thread_resource_error());
|
120
199
|
}
|
121
200
|
|
122
201
|
int const res=pthread_mutex_init(&m,&attr);
|
123
202
|
if(res)
|
124
203
|
{
|
125
204
|
BOOST_VERIFY(!pthread_mutexattr_destroy(&attr));
|
126
|
-
|
205
|
+
boost::throw_exception(thread_resource_error());
|
127
206
|
}
|
128
207
|
BOOST_VERIFY(!pthread_mutexattr_destroy(&attr));
|
129
208
|
#else
|
130
209
|
int const res=pthread_mutex_init(&m,NULL);
|
131
210
|
if(res)
|
132
211
|
{
|
133
|
-
|
212
|
+
boost::throw_exception(thread_resource_error());
|
134
213
|
}
|
135
214
|
int const res2=pthread_cond_init(&cond,NULL);
|
136
215
|
if(res2)
|
137
216
|
{
|
138
217
|
BOOST_VERIFY(!pthread_mutex_destroy(&m));
|
139
|
-
|
218
|
+
boost::throw_exception(thread_resource_error());
|
140
219
|
}
|
141
220
|
is_locked=false;
|
142
221
|
count=0;
|
@@ -145,7 +224,7 @@ namespace boost
|
|
145
224
|
~recursive_timed_mutex()
|
146
225
|
{
|
147
226
|
BOOST_VERIFY(!pthread_mutex_destroy(&m));
|
148
|
-
#ifndef
|
227
|
+
#ifndef BOOST_USE_PTHREAD_RECURSIVE_TIMEDLOCK
|
149
228
|
BOOST_VERIFY(!pthread_cond_destroy(&cond));
|
150
229
|
#endif
|
151
230
|
}
|
@@ -156,7 +235,7 @@ namespace boost
|
|
156
235
|
return timed_lock(get_system_time()+relative_time);
|
157
236
|
}
|
158
237
|
|
159
|
-
#ifdef
|
238
|
+
#ifdef BOOST_USE_PTHREAD_RECURSIVE_TIMEDLOCK
|
160
239
|
void lock()
|
161
240
|
{
|
162
241
|
BOOST_VERIFY(!pthread_mutex_lock(&m));
|
@@ -225,7 +225,7 @@ namespace boost
|
|
225
225
|
template<typename TimeDuration>
|
226
226
|
bool timed_lock_upgrade(TimeDuration const & relative_time)
|
227
227
|
{
|
228
|
-
return
|
228
|
+
return timed_lock_upgrade(get_system_time()+relative_time);
|
229
229
|
}
|
230
230
|
|
231
231
|
bool try_lock_upgrade()
|