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
@@ -229,135 +229,148 @@
|
|
229
229
|
<a name="l00204"></a>00204 <span class="keyword">private</span>:
|
230
230
|
<a name="l00205"></a>00205 <span class="keywordtype">string</span> msg;
|
231
231
|
<a name="l00206"></a>00206 <span class="keywordtype">bool</span> m_hasErrorPage;
|
232
|
-
<a name="l00207"></a>00207 <span class="keywordtype">
|
233
|
-
<a name="l00208"></a>00208
|
234
|
-
<a name="l00209"></a>00209
|
235
|
-
<a name="l00210"></a>00210
|
236
|
-
<a name="l00211"></a>00211
|
237
|
-
<a name="l00212"></a>00212
|
238
|
-
<a name="l00213"></a>00213
|
239
|
-
<a name="l00214"></a>00214
|
240
|
-
<a name="l00215"></a>00215
|
241
|
-
<a name="l00216"></a>00216
|
242
|
-
<a name="l00217"></a>00217
|
243
|
-
<a name="l00218"></a>00218
|
244
|
-
<a name="l00219"></a>00219
|
245
|
-
<a name="l00220"></a>00220
|
246
|
-
<a name="l00221"></a>00221
|
247
|
-
<a name="l00222"></a>00222
|
248
|
-
<a name="l00223"></a>00223
|
249
|
-
<a name="l00224"></a>00224 <span class="
|
250
|
-
<a name="l00225"></a
|
251
|
-
<a name="l00226"></a>00226
|
252
|
-
<a name="l00227"></a>00227
|
253
|
-
<a name="l00228"></a>00228
|
254
|
-
<a name="l00229"></a>00229 <span class="
|
255
|
-
<a name="l00230"></a>00230
|
256
|
-
<a name="l00231"></a>00231
|
257
|
-
<a name="l00232"></a>00232
|
258
|
-
<a name="l00233"></a>00233 <span class="comment">
|
259
|
-
<a name="l00234"></a
|
260
|
-
<a name="l00235"></a>00235
|
261
|
-
<a name="l00236"></a>00236
|
262
|
-
<a name="l00237"></a>00237
|
263
|
-
<a name="l00238"></a>00238 <span class="
|
264
|
-
<a name="l00239"></a>00239
|
265
|
-
<a name="l00240"></a>00240
|
266
|
-
<a name="l00241"></a>00241
|
267
|
-
<a name="l00242"></a>00242 <span class="comment">
|
268
|
-
<a name="l00243"></a>00243 <span class="comment">
|
269
|
-
<a name="l00244"></a
|
270
|
-
<a name="l00245"></a>00245 <span class="
|
271
|
-
<a name="l00246"></a>00246
|
272
|
-
<a name="l00247"></a>00247 <span class="keyword">
|
273
|
-
<a name="l00248"></a>00248
|
274
|
-
<a name="l00249"></a>00249
|
275
|
-
<a name="l00250"></a>00250
|
276
|
-
<a name="l00251"></a>00251
|
277
|
-
<a name="l00252"></a>00252
|
278
|
-
<a name="l00253"></a>00253 <span class="comment"
|
279
|
-
<a name="l00254"></a>00254 <span class="comment">
|
280
|
-
<a name="l00255"></a>00255 <span class="comment">
|
281
|
-
<a name="l00256"></a>00256 <span class="
|
282
|
-
<a name="l00257"></a>00257 <span class="keyword">public</span
|
283
|
-
<a name="l00258"></a>00258
|
284
|
-
<a name="l00259"></a>00259
|
285
|
-
<a name="l00260"></a>00260 <span class="
|
286
|
-
<a name="l00261"></a>00261 <span class="
|
287
|
-
<a name="l00262"></a>00262
|
288
|
-
<a name="l00263"></a>00263 <span class="
|
289
|
-
<a name="l00264"></a>00264
|
290
|
-
<a name="l00265"></a>00265
|
291
|
-
<a name="l00266"></a
|
292
|
-
<a name="l00267"></a>00267 <span class="
|
293
|
-
<a name="l00268"></a>00268
|
294
|
-
<a name="l00269"></a>00269 <span class="keyword">public</span
|
295
|
-
<a name="l00270"></a>00270
|
296
|
-
<a name="l00271"></a>00271 <span class="keyword">
|
297
|
-
<a name="l00272"></a>00272
|
298
|
-
<a name="l00273"></a>00273
|
299
|
-
<a name="l00274"></a>00274 <span class="comment"
|
300
|
-
<a name="l00275"></a>00275 <span class="comment"
|
301
|
-
<a name="l00276"></a>00276 <span class="comment">
|
302
|
-
<a name="l00277"></a>00277 <span class="comment">
|
303
|
-
<a name="l00278"></a>00278 <span class="comment">
|
304
|
-
<a name="l00279"></a>00279 <span class="
|
305
|
-
<a name="l00280"></a
|
306
|
-
<a name="l00281"></a>00281
|
307
|
-
<a name="l00282"></a>00282
|
308
|
-
<a name="l00283"></a>00283 <span class="keyword">
|
309
|
-
<a name="l00284"></a>00284 <a class="code" href="
|
310
|
-
<a name="l00285"></a>00285 <span class="keyword">virtual</span>
|
311
|
-
<a name="l00286"></a>00286
|
312
|
-
<a name="l00287"></a>00287
|
313
|
-
<a name="l00288"></a>00288 <span class="comment"
|
314
|
-
<a name="l00289"></a>00289 <span class="comment"
|
315
|
-
<a name="l00290"></a>00290 <span class="comment">
|
316
|
-
<a name="l00291"></a>00291 <span class="comment">
|
317
|
-
<a name="l00292"></a>00292 <span class="comment">
|
318
|
-
<a name="l00293"></a>00293 <span class="
|
319
|
-
<a name="l00294"></a
|
320
|
-
<a name="l00295"></a>00295
|
321
|
-
<a name="l00296"></a>00296
|
322
|
-
<a name="l00297"></a>00297 <span class="keyword">
|
323
|
-
<a name="l00298"></a>00298 <a class="code" href="
|
324
|
-
<a name="l00299"></a>00299 <span class="keyword">virtual</span>
|
325
|
-
<a name="l00300"></a>00300
|
326
|
-
<a name="l00301"></a>00301
|
327
|
-
<a name="l00302"></a>00302 <span class="comment"
|
328
|
-
<a name="l00303"></a>00303 <span class="comment"
|
329
|
-
<a name="l00304"></a>00304 <span class="comment">
|
330
|
-
<a name="l00305"></a>00305 <span class="comment">
|
331
|
-
<a name="l00306"></a>00306 <span class="
|
332
|
-
<a name="l00307"></a>00307 <span class="keyword">public</span
|
333
|
-
<a name="l00308"></a>00308
|
334
|
-
<a name="l00309"></a>00309
|
335
|
-
<a name="l00310"></a>00310 <span class="
|
336
|
-
<a name="l00311"></a>00311 <span class="
|
337
|
-
<a name="l00312"></a>00312
|
338
|
-
<a name="l00313"></a>00313 <span class="
|
339
|
-
<a name="l00314"></a>00314
|
340
|
-
<a name="l00315"></a>00315 <span class="
|
341
|
-
<a name="l00316"></a>00316
|
342
|
-
<a name="l00317"></a>00317
|
343
|
-
<a name="l00318"></a>00318 <span class="comment"
|
344
|
-
<a name="l00319"></a>00319 <span class="
|
345
|
-
<a name="l00320"></a>00320 <span class="
|
346
|
-
<a name="l00321"></a>00321
|
347
|
-
<a name="l00322"></a>00322
|
348
|
-
<a name="l00323"></a>00323 <span class="comment"
|
349
|
-
<a name="l00324"></a
|
350
|
-
<a name="l00325"></a>00325 <span class="
|
351
|
-
<a name="l00326"></a>00326
|
352
|
-
<a name="l00327"></a>00327 <span class="keyword">public</span
|
353
|
-
<a name="l00328"></a>00328
|
354
|
-
<a name="l00329"></a>00329 <span class="keyword">
|
355
|
-
<a name="l00330"></a>00330
|
356
|
-
<a name="l00331"></a>00331
|
357
|
-
<a name="l00332"></a>00332
|
358
|
-
<a name="l00333"></a>00333
|
359
|
-
<a name="l00334"></a>00334
|
360
|
-
<a name="l00335"></a>00335 <span class="
|
232
|
+
<a name="l00207"></a>00207 <span class="keywordtype">bool</span> m_isHTML;
|
233
|
+
<a name="l00208"></a>00208 <span class="keywordtype">string</span> m_errorPage;
|
234
|
+
<a name="l00209"></a>00209 <span class="keyword">public</span>:
|
235
|
+
<a name="l00210"></a>00210 <a class="code" href="classPassenger_1_1SpawnException.html" title="Thrown when SpawnManager or ApplicationPool fails to spawn an application instance...">SpawnException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message)
|
236
|
+
<a name="l00211"></a>00211 : msg(message) {
|
237
|
+
<a name="l00212"></a>00212 m_hasErrorPage = <span class="keyword">false</span>;
|
238
|
+
<a name="l00213"></a>00213 m_isHTML = <span class="keyword">false</span>;
|
239
|
+
<a name="l00214"></a>00214 }
|
240
|
+
<a name="l00215"></a>00215
|
241
|
+
<a name="l00216"></a>00216 <a class="code" href="classPassenger_1_1SpawnException.html" title="Thrown when SpawnManager or ApplicationPool fails to spawn an application instance...">SpawnException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message, <span class="keyword">const</span> <span class="keywordtype">string</span> &errorPage, <span class="keywordtype">bool</span> <a class="code" href="classPassenger_1_1SpawnException.html#a99538fa117c984660607a7e163ab4158" title="Whether the error page content is HTML.">isHTML</a> = <span class="keyword">true</span>)
|
242
|
+
<a name="l00217"></a>00217 : msg(message), m_errorPage(errorPage)
|
243
|
+
<a name="l00218"></a>00218 {
|
244
|
+
<a name="l00219"></a>00219 m_hasErrorPage = <span class="keyword">true</span>;
|
245
|
+
<a name="l00220"></a>00220 m_isHTML = <a class="code" href="classPassenger_1_1SpawnException.html#a99538fa117c984660607a7e163ab4158" title="Whether the error page content is HTML.">isHTML</a>;
|
246
|
+
<a name="l00221"></a>00221 }
|
247
|
+
<a name="l00222"></a>00222
|
248
|
+
<a name="l00223"></a>00223 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1SpawnException.html" title="Thrown when SpawnManager or ApplicationPool fails to spawn an application instance...">SpawnException</a>() <span class="keywordflow">throw</span>() {}
|
249
|
+
<a name="l00224"></a>00224 <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *what() <span class="keyword">const</span> <span class="keywordflow">throw</span>() { <span class="keywordflow">return</span> msg.c_str(); }
|
250
|
+
<a name="l00225"></a>00225 <span class="comment"></span>
|
251
|
+
<a name="l00226"></a>00226 <span class="comment"> /**</span>
|
252
|
+
<a name="l00227"></a>00227 <span class="comment"> * Check whether an error page is available.</span>
|
253
|
+
<a name="l00228"></a>00228 <span class="comment"> */</span>
|
254
|
+
<a name="l00229"></a><a class="code" href="classPassenger_1_1SpawnException.html#ae65dc272e183fd9e5637a4091cc6bbf4">00229</a> <span class="keywordtype">bool</span> <a class="code" href="classPassenger_1_1SpawnException.html#ae65dc272e183fd9e5637a4091cc6bbf4" title="Check whether an error page is available.">hasErrorPage</a>()<span class="keyword"> const </span>{
|
255
|
+
<a name="l00230"></a>00230 <span class="keywordflow">return</span> m_hasErrorPage;
|
256
|
+
<a name="l00231"></a>00231 }
|
257
|
+
<a name="l00232"></a>00232 <span class="comment"></span>
|
258
|
+
<a name="l00233"></a>00233 <span class="comment"> /**</span>
|
259
|
+
<a name="l00234"></a>00234 <span class="comment"> * Return the error page content.</span>
|
260
|
+
<a name="l00235"></a>00235 <span class="comment"> *</span>
|
261
|
+
<a name="l00236"></a>00236 <span class="comment"> * @pre hasErrorPage()</span>
|
262
|
+
<a name="l00237"></a>00237 <span class="comment"> */</span>
|
263
|
+
<a name="l00238"></a><a class="code" href="classPassenger_1_1SpawnException.html#a6f675a37edd7070875d0744e7dd010a1">00238</a> <span class="keyword">const</span> <span class="keywordtype">string</span> <a class="code" href="classPassenger_1_1SpawnException.html#a6f675a37edd7070875d0744e7dd010a1" title="Return the error page content.">getErrorPage</a>()<span class="keyword"> const </span>{
|
264
|
+
<a name="l00239"></a>00239 <span class="keywordflow">return</span> m_errorPage;
|
265
|
+
<a name="l00240"></a>00240 }
|
266
|
+
<a name="l00241"></a>00241 <span class="comment"></span>
|
267
|
+
<a name="l00242"></a>00242 <span class="comment"> /**</span>
|
268
|
+
<a name="l00243"></a>00243 <span class="comment"> * Whether the error page content is HTML.</span>
|
269
|
+
<a name="l00244"></a>00244 <span class="comment"> *</span>
|
270
|
+
<a name="l00245"></a>00245 <span class="comment"> * @pre hasErrorPage()</span>
|
271
|
+
<a name="l00246"></a>00246 <span class="comment"> */</span>
|
272
|
+
<a name="l00247"></a><a class="code" href="classPassenger_1_1SpawnException.html#a99538fa117c984660607a7e163ab4158">00247</a> <span class="keywordtype">bool</span> <a class="code" href="classPassenger_1_1SpawnException.html#a99538fa117c984660607a7e163ab4158" title="Whether the error page content is HTML.">isHTML</a>()<span class="keyword"> const </span>{
|
273
|
+
<a name="l00248"></a>00248 <span class="keywordflow">return</span> m_isHTML;
|
274
|
+
<a name="l00249"></a>00249 }
|
275
|
+
<a name="l00250"></a>00250 };
|
276
|
+
<a name="l00251"></a>00251 <span class="comment"></span>
|
277
|
+
<a name="l00252"></a>00252 <span class="comment">/**</span>
|
278
|
+
<a name="l00253"></a>00253 <span class="comment"> * Indicates that a specified argument is incorrect or violates a requirement.</span>
|
279
|
+
<a name="l00254"></a>00254 <span class="comment"> *</span>
|
280
|
+
<a name="l00255"></a>00255 <span class="comment"> * @ingroup Exceptions</span>
|
281
|
+
<a name="l00256"></a>00256 <span class="comment"> */</span>
|
282
|
+
<a name="l00257"></a><a class="code" href="classPassenger_1_1ArgumentException.html">00257</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1ArgumentException.html" title="Indicates that a specified argument is incorrect or violates a requirement.">ArgumentException</a>: <span class="keyword">public</span> oxt::tracable_exception {
|
283
|
+
<a name="l00258"></a>00258 <span class="keyword">private</span>:
|
284
|
+
<a name="l00259"></a>00259 <span class="keywordtype">string</span> msg;
|
285
|
+
<a name="l00260"></a>00260 <span class="keyword">public</span>:
|
286
|
+
<a name="l00261"></a>00261 <a class="code" href="classPassenger_1_1ArgumentException.html" title="Indicates that a specified argument is incorrect or violates a requirement.">ArgumentException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): msg(message) {}
|
287
|
+
<a name="l00262"></a>00262 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1ArgumentException.html" title="Indicates that a specified argument is incorrect or violates a requirement.">ArgumentException</a>() <span class="keywordflow">throw</span>() {}
|
288
|
+
<a name="l00263"></a>00263 <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *what() <span class="keyword">const</span> <span class="keywordflow">throw</span>() { <span class="keywordflow">return</span> msg.c_str(); }
|
289
|
+
<a name="l00264"></a>00264 };
|
290
|
+
<a name="l00265"></a>00265
|
291
|
+
<a name="l00266"></a>00266 <span class="comment">/*</span>
|
292
|
+
<a name="l00267"></a>00267 <span class="comment"> * @ingroup Exceptions</span>
|
293
|
+
<a name="l00268"></a>00268 <span class="comment"> */</span>
|
294
|
+
<a name="l00269"></a>00269 <span class="keyword">class </span>InvalidModeStringException: <span class="keyword">public</span> <a class="code" href="classPassenger_1_1ArgumentException.html" title="Indicates that a specified argument is incorrect or violates a requirement.">ArgumentException</a> {
|
295
|
+
<a name="l00270"></a>00270 <span class="keyword">public</span>:
|
296
|
+
<a name="l00271"></a>00271 InvalidModeStringException(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): <a class="code" href="classPassenger_1_1ArgumentException.html" title="Indicates that a specified argument is incorrect or violates a requirement.">ArgumentException</a>(message) {}
|
297
|
+
<a name="l00272"></a>00272 };
|
298
|
+
<a name="l00273"></a>00273 <span class="comment"></span>
|
299
|
+
<a name="l00274"></a>00274 <span class="comment">/**</span>
|
300
|
+
<a name="l00275"></a>00275 <span class="comment"> * A generic runtime exception.</span>
|
301
|
+
<a name="l00276"></a>00276 <span class="comment"> *</span>
|
302
|
+
<a name="l00277"></a>00277 <span class="comment"> * @ingroup Exceptions</span>
|
303
|
+
<a name="l00278"></a>00278 <span class="comment"> */</span>
|
304
|
+
<a name="l00279"></a><a class="code" href="classPassenger_1_1RuntimeException.html">00279</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1RuntimeException.html" title="A generic runtime exception.">RuntimeException</a>: <span class="keyword">public</span> oxt::tracable_exception {
|
305
|
+
<a name="l00280"></a>00280 <span class="keyword">private</span>:
|
306
|
+
<a name="l00281"></a>00281 <span class="keywordtype">string</span> msg;
|
307
|
+
<a name="l00282"></a>00282 <span class="keyword">public</span>:
|
308
|
+
<a name="l00283"></a>00283 <a class="code" href="classPassenger_1_1RuntimeException.html" title="A generic runtime exception.">RuntimeException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): msg(message) {}
|
309
|
+
<a name="l00284"></a>00284 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1RuntimeException.html" title="A generic runtime exception.">RuntimeException</a>() <span class="keywordflow">throw</span>() {}
|
310
|
+
<a name="l00285"></a>00285 <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *what() <span class="keyword">const</span> <span class="keywordflow">throw</span>() { <span class="keywordflow">return</span> msg.c_str(); }
|
311
|
+
<a name="l00286"></a>00286 };
|
312
|
+
<a name="l00287"></a>00287 <span class="comment"></span>
|
313
|
+
<a name="l00288"></a>00288 <span class="comment">/**</span>
|
314
|
+
<a name="l00289"></a>00289 <span class="comment"> * An exception indicating that some timeout expired.</span>
|
315
|
+
<a name="l00290"></a>00290 <span class="comment"> *</span>
|
316
|
+
<a name="l00291"></a>00291 <span class="comment"> * @ingroup Exceptions</span>
|
317
|
+
<a name="l00292"></a>00292 <span class="comment"> */</span>
|
318
|
+
<a name="l00293"></a><a class="code" href="classPassenger_1_1TimeoutException.html">00293</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1TimeoutException.html" title="An exception indicating that some timeout expired.">TimeoutException</a>: <span class="keyword">public</span> oxt::tracable_exception {
|
319
|
+
<a name="l00294"></a>00294 <span class="keyword">private</span>:
|
320
|
+
<a name="l00295"></a>00295 <span class="keywordtype">string</span> msg;
|
321
|
+
<a name="l00296"></a>00296 <span class="keyword">public</span>:
|
322
|
+
<a name="l00297"></a>00297 <a class="code" href="classPassenger_1_1TimeoutException.html" title="An exception indicating that some timeout expired.">TimeoutException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): msg(message) {}
|
323
|
+
<a name="l00298"></a>00298 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1TimeoutException.html" title="An exception indicating that some timeout expired.">TimeoutException</a>() <span class="keywordflow">throw</span>() {}
|
324
|
+
<a name="l00299"></a>00299 <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *what() <span class="keyword">const</span> <span class="keywordflow">throw</span>() { <span class="keywordflow">return</span> msg.c_str(); }
|
325
|
+
<a name="l00300"></a>00300 };
|
326
|
+
<a name="l00301"></a>00301 <span class="comment"></span>
|
327
|
+
<a name="l00302"></a>00302 <span class="comment">/**</span>
|
328
|
+
<a name="l00303"></a>00303 <span class="comment"> * Represents some kind of security error.</span>
|
329
|
+
<a name="l00304"></a>00304 <span class="comment"> *</span>
|
330
|
+
<a name="l00305"></a>00305 <span class="comment"> * @ingroup Exceptions</span>
|
331
|
+
<a name="l00306"></a>00306 <span class="comment"> */</span>
|
332
|
+
<a name="l00307"></a><a class="code" href="classPassenger_1_1SecurityException.html">00307</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1SecurityException.html" title="Represents some kind of security error.">SecurityException</a>: <span class="keyword">public</span> oxt::tracable_exception {
|
333
|
+
<a name="l00308"></a>00308 <span class="keyword">private</span>:
|
334
|
+
<a name="l00309"></a>00309 <span class="keywordtype">string</span> msg;
|
335
|
+
<a name="l00310"></a>00310 <span class="keyword">public</span>:
|
336
|
+
<a name="l00311"></a>00311 <a class="code" href="classPassenger_1_1SecurityException.html" title="Represents some kind of security error.">SecurityException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): msg(message) {}
|
337
|
+
<a name="l00312"></a>00312 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1SecurityException.html" title="Represents some kind of security error.">SecurityException</a>() <span class="keywordflow">throw</span>() {}
|
338
|
+
<a name="l00313"></a>00313 <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *what() <span class="keyword">const</span> <span class="keywordflow">throw</span>() { <span class="keywordflow">return</span> msg.c_str(); }
|
339
|
+
<a name="l00314"></a>00314 };
|
340
|
+
<a name="l00315"></a>00315 <span class="comment"></span>
|
341
|
+
<a name="l00316"></a>00316 <span class="comment">/**</span>
|
342
|
+
<a name="l00317"></a>00317 <span class="comment"> * @ingroup Exceptions</span>
|
343
|
+
<a name="l00318"></a>00318 <span class="comment"> */</span>
|
344
|
+
<a name="l00319"></a>00319 <span class="keyword">class </span>NonExistentUserException: <span class="keyword">public</span> <a class="code" href="classPassenger_1_1SecurityException.html" title="Represents some kind of security error.">SecurityException</a> {
|
345
|
+
<a name="l00320"></a>00320 <span class="keyword">public</span>:
|
346
|
+
<a name="l00321"></a>00321 NonExistentUserException(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): <a class="code" href="classPassenger_1_1SecurityException.html" title="Represents some kind of security error.">SecurityException</a>(message) {}
|
347
|
+
<a name="l00322"></a>00322 };
|
348
|
+
<a name="l00323"></a>00323 <span class="comment"></span>
|
349
|
+
<a name="l00324"></a>00324 <span class="comment">/**</span>
|
350
|
+
<a name="l00325"></a>00325 <span class="comment"> * @ingroup Exceptions</span>
|
351
|
+
<a name="l00326"></a>00326 <span class="comment"> */</span>
|
352
|
+
<a name="l00327"></a>00327 <span class="keyword">class </span>NonExistentGroupException: <span class="keyword">public</span> SecurityException {
|
353
|
+
<a name="l00328"></a>00328 <span class="keyword">public</span>:
|
354
|
+
<a name="l00329"></a>00329 NonExistentGroupException(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): SecurityException(message) {}
|
355
|
+
<a name="l00330"></a>00330 };
|
356
|
+
<a name="l00331"></a>00331 <span class="comment"></span>
|
357
|
+
<a name="l00332"></a>00332 <span class="comment">/**</span>
|
358
|
+
<a name="l00333"></a>00333 <span class="comment"> * The application pool is too busy and cannot fulfill a get() request.</span>
|
359
|
+
<a name="l00334"></a>00334 <span class="comment"> *</span>
|
360
|
+
<a name="l00335"></a>00335 <span class="comment"> * @ingroup Exceptions</span>
|
361
|
+
<a name="l00336"></a>00336 <span class="comment"> */</span>
|
362
|
+
<a name="l00337"></a><a class="code" href="classPassenger_1_1BusyException.html">00337</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1BusyException.html" title="The application pool is too busy and cannot fulfill a get() request.">BusyException</a>: <span class="keyword">public</span> oxt::tracable_exception {
|
363
|
+
<a name="l00338"></a>00338 <span class="keyword">private</span>:
|
364
|
+
<a name="l00339"></a>00339 <span class="keywordtype">string</span> msg;
|
365
|
+
<a name="l00340"></a>00340 <span class="keyword">public</span>:
|
366
|
+
<a name="l00341"></a>00341 <a class="code" href="classPassenger_1_1BusyException.html" title="The application pool is too busy and cannot fulfill a get() request.">BusyException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): msg(message) {}
|
367
|
+
<a name="l00342"></a>00342 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1BusyException.html" title="The application pool is too busy and cannot fulfill a get() request.">BusyException</a>() <span class="keywordflow">throw</span>() {}
|
368
|
+
<a name="l00343"></a>00343 <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *what() <span class="keyword">const</span> <span class="keywordflow">throw</span>() { <span class="keywordflow">return</span> msg.c_str(); }
|
369
|
+
<a name="l00344"></a>00344 };
|
370
|
+
<a name="l00345"></a>00345
|
371
|
+
<a name="l00346"></a>00346 } <span class="comment">// namespace Passenger</span>
|
372
|
+
<a name="l00347"></a>00347
|
373
|
+
<a name="l00348"></a>00348 <span class="preprocessor">#endif </span><span class="comment">/* _PASSENGER_EXCEPTIONS_H_ */</span>
|
361
374
|
</pre></div></div>
|
362
375
|
<hr size="1"/><address style="text-align: right;"><small>Generated by
|
363
376
|
<a href="http://www.doxygen.org/index.html">
|
@@ -51,207 +51,271 @@
|
|
51
51
|
<a name="l00026"></a>00026 <span class="preprocessor"></span><span class="preprocessor">#define _PASSENGER_FILE_DESCRIPTOR_H_</span>
|
52
52
|
<a name="l00027"></a>00027 <span class="preprocessor"></span>
|
53
53
|
<a name="l00028"></a>00028 <span class="preprocessor">#include <boost/shared_ptr.hpp></span>
|
54
|
-
<a name="l00029"></a>00029 <span class="preprocessor">#include <
|
55
|
-
<a name="l00030"></a>00030
|
56
|
-
<a name="l00031"></a>00031
|
57
|
-
<a name="l00032"></a>00032 <span class="preprocessor">#include <
|
58
|
-
<a name="l00033"></a>00033
|
59
|
-
<a name="l00034"></a>00034 <span class="preprocessor">#include &
|
60
|
-
<a name="l00035"></a>00035
|
61
|
-
<a name="l00036"></a>00036
|
62
|
-
<a name="l00037"></a>00037
|
63
|
-
<a name="l00038"></a>00038
|
64
|
-
<a name="l00039"></a>00039
|
65
|
-
<a name="l00040"></a>00040 <span class="keyword">using namespace </span>
|
66
|
-
<a name="l00041"></a>00041
|
67
|
-
<a name="l00042"></a>00042 <span class="
|
68
|
-
<a name="l00043"></a>00043
|
69
|
-
<a name="l00044"></a>00044
|
70
|
-
<a name="l00045"></a>00045 <span class="
|
71
|
-
<a name="l00046"></a>00046
|
72
|
-
<a name="l00047"></a>00047 <span class="comment"
|
73
|
-
<a name="l00048"></a>00048 <span class="comment"
|
74
|
-
<a name="l00049"></a>00049 <span class="comment"> *
|
75
|
-
<a name="l00050"></a>00050 <span class="comment">
|
76
|
-
<a name="l00051"></a>00051 <span class="comment"> *
|
77
|
-
<a name="l00052"></a>00052 <span class="comment">
|
78
|
-
<a name="l00053"></a>00053 <span class="comment"> *
|
79
|
-
<a name="l00054"></a>00054 <span class="comment"> *
|
80
|
-
<a name="l00055"></a>00055 <span class="comment"> *
|
81
|
-
<a name="l00056"></a>00056 <span class="comment"> *
|
82
|
-
<a name="l00057"></a>00057 <span class="comment">
|
83
|
-
<a name="l00058"></a
|
84
|
-
<a name="l00059"></a>00059 <span class="
|
85
|
-
<a name="l00060"></a>00060
|
86
|
-
<a name="l00061"></a>00061
|
87
|
-
<a name="l00062"></a>00062
|
88
|
-
<a name="l00063"></a>00063
|
89
|
-
<a name="l00064"></a>00064
|
90
|
-
<a name="l00065"></a>00065
|
91
|
-
<a name="l00066"></a>00066
|
92
|
-
<a name="l00067"></a>00067
|
93
|
-
<a name="l00068"></a>00068
|
94
|
-
<a name="l00069"></a>00069
|
95
|
-
<a name="l00070"></a>00070
|
96
|
-
<a name="l00071"></a>00071
|
97
|
-
<a name="l00072"></a>00072
|
98
|
-
<a name="l00073"></a>00073
|
99
|
-
<a name="l00074"></a>00074
|
100
|
-
<a name="l00075"></a>00075
|
101
|
-
<a name="l00076"></a>00076
|
102
|
-
<a name="l00077"></a>00077
|
103
|
-
<a name="l00078"></a>00078
|
104
|
-
<a name="l00079"></a>00079
|
105
|
-
<a name="l00080"></a>00080
|
106
|
-
<a name="l00081"></a>00081
|
107
|
-
<a name="l00082"></a>00082
|
108
|
-
<a name="l00083"></a>00083
|
109
|
-
<a name="l00084"></a>00084
|
110
|
-
<a name="l00085"></a>00085
|
111
|
-
<a name="l00086"></a>00086 <span class="
|
112
|
-
<a name="l00087"></a>00087
|
113
|
-
<a name="l00088"></a>00088
|
114
|
-
<a name="l00089"></a>00089
|
115
|
-
<a name="l00090"></a>00090
|
116
|
-
<a name="l00091"></a>00091
|
117
|
-
<a name="l00092"></a>00092
|
118
|
-
<a name="l00093"></a>00093
|
119
|
-
<a name="l00094"></a>00094
|
120
|
-
<a name="l00095"></a>00095
|
121
|
-
<a name="l00096"></a>00096 <span class="comment"
|
122
|
-
<a name="l00097"></a
|
123
|
-
<a name="l00098"></a>00098
|
124
|
-
<a name="l00099"></a>00099
|
125
|
-
<a name="l00100"></a>00100 <span class="
|
126
|
-
<a name="l00101"></a>00101 <span class="comment">
|
127
|
-
<a name="l00102"></a>00102 <span class="comment"> *
|
128
|
-
<a name="l00103"></a>00103 <span class="comment">
|
129
|
-
<a name="l00104"></a
|
130
|
-
<a name="l00105"></a>00105
|
131
|
-
<a name="l00106"></a>00106
|
132
|
-
<a name="l00107"></a>00107
|
133
|
-
<a name="l00108"></a>00108
|
134
|
-
<a name="l00109"></a>00109 <span class="comment">
|
135
|
-
<a name="l00110"></a>00110 <span class="comment">
|
136
|
-
<a name="l00111"></a>00111 <span class="comment">
|
137
|
-
<a name="l00112"></a>00112 <span class="comment">
|
138
|
-
<a name="l00113"></a>00113 <span class="comment">
|
139
|
-
<a name="l00114"></a>00114
|
140
|
-
<a name="l00115"></a>00115
|
141
|
-
<a name="l00116"></a>00116
|
142
|
-
<a name="l00117"></a>00117
|
143
|
-
<a name="l00118"></a>00118
|
144
|
-
<a name="l00119"></a>00119
|
145
|
-
<a name="l00120"></a>00120 <span class="comment">
|
146
|
-
<a name="l00121"></a>00121 <span class="comment">
|
147
|
-
<a name="l00122"></a>00122 <span class="comment">
|
148
|
-
<a name="l00123"></a>00123 <span class="comment">
|
149
|
-
<a name="l00124"></a>00124
|
150
|
-
<a name="l00125"></a>00125
|
151
|
-
<a name="l00126"></a>00126
|
152
|
-
<a name="l00127"></a>00127
|
153
|
-
<a name="l00128"></a>00128
|
154
|
-
<a name="l00129"></a
|
155
|
-
<a name="l00130"></a>00130
|
156
|
-
<a name="l00131"></a>00131
|
157
|
-
<a name="l00132"></a>00132
|
158
|
-
<a name="l00133"></a>00133
|
159
|
-
<a name="l00134"></a>00134
|
160
|
-
<a name="l00135"></a>00135
|
161
|
-
<a name="l00136"></a>00136 <span class="comment">
|
162
|
-
<a name="l00137"></a>00137 <span class="comment"> *
|
163
|
-
<a name="l00138"></a>00138 <span class="comment"> *
|
164
|
-
<a name="l00139"></a>00139 <span class="comment">
|
165
|
-
<a name="l00140"></a>00140 <span class="comment"> *
|
166
|
-
<a name="l00141"></a>00141 <span class="comment">
|
167
|
-
<a name="l00142"></a
|
168
|
-
<a name="l00143"></a>00143
|
169
|
-
<a name="l00144"></a>00144
|
170
|
-
<a name="l00145"></a>00145
|
171
|
-
<a name="l00146"></a>00146
|
54
|
+
<a name="l00029"></a>00029 <span class="preprocessor">#include <boost/make_shared.hpp></span>
|
55
|
+
<a name="l00030"></a>00030 <span class="preprocessor">#include <oxt/system_calls.hpp></span>
|
56
|
+
<a name="l00031"></a>00031
|
57
|
+
<a name="l00032"></a>00032 <span class="preprocessor">#include <utility></span>
|
58
|
+
<a name="l00033"></a>00033 <span class="preprocessor">#include <unistd.h></span>
|
59
|
+
<a name="l00034"></a>00034 <span class="preprocessor">#include <cerrno></span>
|
60
|
+
<a name="l00035"></a>00035
|
61
|
+
<a name="l00036"></a>00036 <span class="preprocessor">#include <Exceptions.h></span>
|
62
|
+
<a name="l00037"></a>00037
|
63
|
+
<a name="l00038"></a>00038 <span class="keyword">namespace </span>Passenger {
|
64
|
+
<a name="l00039"></a>00039
|
65
|
+
<a name="l00040"></a>00040 <span class="keyword">using namespace </span>std;
|
66
|
+
<a name="l00041"></a>00041 <span class="keyword">using namespace </span>boost;
|
67
|
+
<a name="l00042"></a>00042 <span class="keyword">using namespace </span>oxt;
|
68
|
+
<a name="l00043"></a>00043
|
69
|
+
<a name="l00044"></a>00044
|
70
|
+
<a name="l00045"></a>00045 <span class="keywordtype">void</span> safelyClose(<span class="keywordtype">int</span> fd);
|
71
|
+
<a name="l00046"></a>00046
|
72
|
+
<a name="l00047"></a>00047 <span class="comment"></span>
|
73
|
+
<a name="l00048"></a>00048 <span class="comment">/**</span>
|
74
|
+
<a name="l00049"></a>00049 <span class="comment"> * Wrapper class around a file descriptor integer, for RAII behavior.</span>
|
75
|
+
<a name="l00050"></a>00050 <span class="comment"> *</span>
|
76
|
+
<a name="l00051"></a>00051 <span class="comment"> * A FileDescriptor object behaves just like an int, so that you can pass it to</span>
|
77
|
+
<a name="l00052"></a>00052 <span class="comment"> * system calls such as read(). It performs reference counting. When the last</span>
|
78
|
+
<a name="l00053"></a>00053 <span class="comment"> * copy of a FileDescriptor has been destroyed, the underlying file descriptor</span>
|
79
|
+
<a name="l00054"></a>00054 <span class="comment"> * will be automatically closed. In this case, any close() system call errors</span>
|
80
|
+
<a name="l00055"></a>00055 <span class="comment"> * are silently ignored. If you are interested in whether the close() system</span>
|
81
|
+
<a name="l00056"></a>00056 <span class="comment"> * call succeeded, then you should call FileDescriptor::close().</span>
|
82
|
+
<a name="l00057"></a>00057 <span class="comment"> *</span>
|
83
|
+
<a name="l00058"></a>00058 <span class="comment"> * This class is *not* thread-safe. It is safe to call system calls on the</span>
|
84
|
+
<a name="l00059"></a>00059 <span class="comment"> * underlying file descriptor from multiple threads, but it's not safe to</span>
|
85
|
+
<a name="l00060"></a>00060 <span class="comment"> * call FileDescriptor::close() from multiple threads if all those</span>
|
86
|
+
<a name="l00061"></a>00061 <span class="comment"> * FileDescriptor objects point to the same underlying file descriptor.</span>
|
87
|
+
<a name="l00062"></a>00062 <span class="comment"> */</span>
|
88
|
+
<a name="l00063"></a><a class="code" href="classPassenger_1_1FileDescriptor.html">00063</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1FileDescriptor.html" title="Wrapper class around a file descriptor integer, for RAII behavior.">FileDescriptor</a> {
|
89
|
+
<a name="l00064"></a>00064 <span class="keyword">private</span>:
|
90
|
+
<a name="l00065"></a>00065 <span class="keyword">struct </span>SharedData {
|
91
|
+
<a name="l00066"></a>00066 <span class="keywordtype">int</span> fd;
|
92
|
+
<a name="l00067"></a>00067
|
93
|
+
<a name="l00068"></a>00068 SharedData(<span class="keywordtype">int</span> fd) {
|
94
|
+
<a name="l00069"></a>00069 this->fd = fd;
|
95
|
+
<a name="l00070"></a>00070 }
|
96
|
+
<a name="l00071"></a>00071
|
97
|
+
<a name="l00072"></a>00072 ~SharedData() {
|
98
|
+
<a name="l00073"></a>00073 <span class="keywordflow">if</span> (fd >= 0) {
|
99
|
+
<a name="l00074"></a>00074 this_thread::disable_syscall_interruption dsi;
|
100
|
+
<a name="l00075"></a>00075 <a class="code" href="classPassenger_1_1FileDescriptor.html#a02062f3cfb689b32781e11114c0abe5b" title="Close the underlying file descriptor.">syscalls::close</a>(fd);
|
101
|
+
<a name="l00076"></a>00076 }
|
102
|
+
<a name="l00077"></a>00077 }
|
103
|
+
<a name="l00078"></a>00078
|
104
|
+
<a name="l00079"></a>00079 <span class="keywordtype">void</span> <a class="code" href="classPassenger_1_1FileDescriptor.html#a02062f3cfb689b32781e11114c0abe5b" title="Close the underlying file descriptor.">close</a>(<span class="keywordtype">bool</span> checkErrors = <span class="keyword">true</span>) {
|
105
|
+
<a name="l00080"></a>00080 <span class="keywordflow">if</span> (fd >= 0) {
|
106
|
+
<a name="l00081"></a>00081 this_thread::disable_syscall_interruption dsi;
|
107
|
+
<a name="l00082"></a>00082 <span class="keywordtype">int</span> theFd = fd;
|
108
|
+
<a name="l00083"></a>00083 fd = -1;
|
109
|
+
<a name="l00084"></a>00084 <span class="keywordflow">if</span> (checkErrors) {
|
110
|
+
<a name="l00085"></a>00085 safelyClose(theFd);
|
111
|
+
<a name="l00086"></a>00086 } <span class="keywordflow">else</span> {
|
112
|
+
<a name="l00087"></a>00087 <a class="code" href="classPassenger_1_1FileDescriptor.html#a02062f3cfb689b32781e11114c0abe5b" title="Close the underlying file descriptor.">syscalls::close</a>(fd);
|
113
|
+
<a name="l00088"></a>00088 }
|
114
|
+
<a name="l00089"></a>00089 }
|
115
|
+
<a name="l00090"></a>00090 }
|
116
|
+
<a name="l00091"></a>00091
|
117
|
+
<a name="l00092"></a>00092 <span class="keywordtype">void</span> <a class="code" href="classPassenger_1_1FileDescriptor.html#ad9f7acde3003ab0730bc248948a63777" title="Detach from the underlying file descriptor without closing it.">detach</a>() {
|
118
|
+
<a name="l00093"></a>00093 fd = -1;
|
119
|
+
<a name="l00094"></a>00094 }
|
120
|
+
<a name="l00095"></a>00095 };
|
121
|
+
<a name="l00096"></a>00096 <span class="comment"></span>
|
122
|
+
<a name="l00097"></a>00097 <span class="comment"> /** Shared pointer for reference counting on this file descriptor */</span>
|
123
|
+
<a name="l00098"></a>00098 shared_ptr<SharedData> data;
|
124
|
+
<a name="l00099"></a>00099
|
125
|
+
<a name="l00100"></a>00100 <span class="keyword">public</span>:<span class="comment"></span>
|
126
|
+
<a name="l00101"></a>00101 <span class="comment"> /** </span>
|
127
|
+
<a name="l00102"></a>00102 <span class="comment"> * Creates a new empty FileDescriptor instance that has no underlying</span>
|
128
|
+
<a name="l00103"></a>00103 <span class="comment"> * file descriptor.</span>
|
129
|
+
<a name="l00104"></a>00104 <span class="comment"> *</span>
|
130
|
+
<a name="l00105"></a>00105 <span class="comment"> * @post *this == -1</span>
|
131
|
+
<a name="l00106"></a>00106 <span class="comment"> */</span>
|
132
|
+
<a name="l00107"></a><a class="code" href="classPassenger_1_1FileDescriptor.html#a05d83ad9cc77c493a3ce4f2b51d44559">00107</a> <a class="code" href="classPassenger_1_1FileDescriptor.html#a05d83ad9cc77c493a3ce4f2b51d44559" title="Creates a new empty FileDescriptor instance that has no underlying file descriptor...">FileDescriptor</a>() { }
|
133
|
+
<a name="l00108"></a>00108 <span class="comment"></span>
|
134
|
+
<a name="l00109"></a>00109 <span class="comment"> /**</span>
|
135
|
+
<a name="l00110"></a>00110 <span class="comment"> * Creates a new FileDescriptor instance with the given fd as a handle.</span>
|
136
|
+
<a name="l00111"></a>00111 <span class="comment"> *</span>
|
137
|
+
<a name="l00112"></a>00112 <span class="comment"> * @post *this == fd</span>
|
138
|
+
<a name="l00113"></a>00113 <span class="comment"> */</span>
|
139
|
+
<a name="l00114"></a><a class="code" href="classPassenger_1_1FileDescriptor.html#a62c05b925cb1cf964169cef7635650ee">00114</a> <a class="code" href="classPassenger_1_1FileDescriptor.html#a62c05b925cb1cf964169cef7635650ee" title="Creates a new FileDescriptor instance with the given fd as a handle.">FileDescriptor</a>(<span class="keywordtype">int</span> fd) {
|
140
|
+
<a name="l00115"></a>00115 <span class="keywordflow">if</span> (fd >= 0) {
|
141
|
+
<a name="l00116"></a>00116 <span class="comment">/* Make sure that the 'new' operator doesn't overwrite</span>
|
142
|
+
<a name="l00117"></a>00117 <span class="comment"> * errno so that we can write code like this:</span>
|
143
|
+
<a name="l00118"></a>00118 <span class="comment"> *</span>
|
144
|
+
<a name="l00119"></a>00119 <span class="comment"> * FileDescriptor fd = open(...);</span>
|
145
|
+
<a name="l00120"></a>00120 <span class="comment"> * if (fd == -1) {</span>
|
146
|
+
<a name="l00121"></a>00121 <span class="comment"> * print_error(errno);</span>
|
147
|
+
<a name="l00122"></a>00122 <span class="comment"> * }</span>
|
148
|
+
<a name="l00123"></a>00123 <span class="comment"> */</span>
|
149
|
+
<a name="l00124"></a>00124 <span class="keywordtype">int</span> e = errno;
|
150
|
+
<a name="l00125"></a>00125 data = make_shared<SharedData>(fd);
|
151
|
+
<a name="l00126"></a>00126 errno = e;
|
152
|
+
<a name="l00127"></a>00127 }
|
153
|
+
<a name="l00128"></a>00128 }
|
154
|
+
<a name="l00129"></a>00129 <span class="comment"></span>
|
155
|
+
<a name="l00130"></a>00130 <span class="comment"> /**</span>
|
156
|
+
<a name="l00131"></a>00131 <span class="comment"> * Close the underlying file descriptor. If it was already closed, then</span>
|
157
|
+
<a name="l00132"></a>00132 <span class="comment"> * nothing will happen. If there are multiple copies of this FileDescriptor</span>
|
158
|
+
<a name="l00133"></a>00133 <span class="comment"> * then the underlying file descriptor will be closed for every one of them.</span>
|
159
|
+
<a name="l00134"></a>00134 <span class="comment"> *</span>
|
160
|
+
<a name="l00135"></a>00135 <span class="comment"> * @params checkErrors Whether a SystemException should be thrown in case</span>
|
161
|
+
<a name="l00136"></a>00136 <span class="comment"> * closing the file descriptor fails. If false, errors</span>
|
162
|
+
<a name="l00137"></a>00137 <span class="comment"> * are silently ignored.</span>
|
163
|
+
<a name="l00138"></a>00138 <span class="comment"> * @throws SystemException Something went wrong while closing</span>
|
164
|
+
<a name="l00139"></a>00139 <span class="comment"> * the file descriptor. Only thrown if</span>
|
165
|
+
<a name="l00140"></a>00140 <span class="comment"> * checkErrors is true.</span>
|
166
|
+
<a name="l00141"></a>00141 <span class="comment"> * @post *this == -1</span>
|
167
|
+
<a name="l00142"></a>00142 <span class="comment"> */</span>
|
168
|
+
<a name="l00143"></a><a class="code" href="classPassenger_1_1FileDescriptor.html#a02062f3cfb689b32781e11114c0abe5b">00143</a> <span class="keywordtype">void</span> <a class="code" href="classPassenger_1_1FileDescriptor.html#a02062f3cfb689b32781e11114c0abe5b" title="Close the underlying file descriptor.">close</a>(<span class="keywordtype">bool</span> checkErrors = <span class="keyword">true</span>) {
|
169
|
+
<a name="l00144"></a>00144 <span class="keywordflow">if</span> (data != NULL) {
|
170
|
+
<a name="l00145"></a>00145 data->close(checkErrors);
|
171
|
+
<a name="l00146"></a>00146 data.reset();
|
172
172
|
<a name="l00147"></a>00147 }
|
173
173
|
<a name="l00148"></a>00148 }
|
174
|
-
<a name="l00149"></a>00149
|
175
|
-
<a name="l00150"></a>00150
|
176
|
-
<a name="l00151"></a>00151
|
177
|
-
<a name="l00152"></a>00152 <span class="comment">
|
178
|
-
<a name="l00153"></a>00153 <span class="comment">
|
179
|
-
<a name="l00154"></a>00154 <span class="comment">
|
180
|
-
<a name="l00155"></a>00155 <span class="comment">
|
181
|
-
<a name="l00156"></a>00156 <span class="comment">
|
182
|
-
<a name="l00157"></a>00157 <span class="comment">
|
183
|
-
<a name="l00158"></a>00158
|
184
|
-
<a name="l00159"></a>00159
|
185
|
-
<a name="l00160"></a>00160
|
186
|
-
<a name="l00161"></a>00161
|
187
|
-
<a name="l00162"></a>00162 data.reset(
|
188
|
-
<a name="l00163"></a>00163
|
189
|
-
<a name="l00164"></a>00164
|
190
|
-
<a name="l00165"></a>00165
|
191
|
-
<a name="l00166"></a>00166
|
192
|
-
<a name="l00167"></a>00167
|
193
|
-
<a name="l00168"></a>00168
|
194
|
-
<a name="l00169"></a>00169
|
195
|
-
<a name="l00170"></a>00170
|
196
|
-
<a name="l00171"></a>00171
|
197
|
-
<a name="l00172"></a>00172 <span class="comment">
|
198
|
-
<a name="l00173"></a>00173 <span class="comment">
|
199
|
-
<a name="l00174"></a>00174 <span class="comment">
|
200
|
-
<a name="l00175"></a>00175 <span class="
|
201
|
-
<a name="l00176"></a>00176
|
202
|
-
<a name="l00177"></a>00177
|
203
|
-
<a name="l00178"></a>00178 <span class="
|
204
|
-
<a name="l00179"></a>00179
|
205
|
-
<a name="l00180"></a>00180
|
206
|
-
<a name="l00181"></a>00181
|
207
|
-
<a name="l00182"></a>00182
|
208
|
-
<a name="l00183"></a>00183
|
209
|
-
<a name="l00184"></a>00184 <span class="
|
210
|
-
<a name="l00185"></a>00185
|
211
|
-
<a name="l00186"></a>00186
|
212
|
-
<a name="l00187"></a>00187 <span class="comment"
|
213
|
-
<a name="l00188"></a>00188 <span class="comment"
|
214
|
-
<a name="l00189"></a>00189 <span class="comment">
|
215
|
-
<a name="l00190"></a>00190 <span class="comment">
|
216
|
-
<a name="l00191"></a>00191 <span class="comment">
|
217
|
-
<a name="l00192"></a>00192 <span class="comment">
|
218
|
-
<a name="l00193"></a>00193
|
219
|
-
<a name="l00194"></a>00194
|
220
|
-
<a name="l00195"></a
|
221
|
-
<a name="l00196"></a>00196 <span class="
|
222
|
-
<a name="l00197"></a>00197
|
223
|
-
<a name="l00198"></a>00198
|
224
|
-
<a name="l00199"></a>00199
|
225
|
-
<a name="l00200"></a>00200
|
226
|
-
<a name="l00201"></a>00201
|
227
|
-
<a name="l00202"></a>00202
|
228
|
-
<a name="l00203"></a>00203
|
229
|
-
<a name="l00204"></a>00204 <span class="
|
230
|
-
<a name="l00205"></a>00205
|
231
|
-
<a name="l00206"></a>00206
|
232
|
-
<a name="l00207"></a>00207
|
233
|
-
<a name="l00208"></a>00208
|
234
|
-
<a name="l00209"></a>00209
|
235
|
-
<a name="l00210"></a>00210
|
236
|
-
<a name="l00211"></a>00211
|
237
|
-
<a name="l00212"></a>00212
|
238
|
-
<a name="l00213"></a>00213
|
239
|
-
<a name="l00214"></a>00214
|
240
|
-
<a name="l00215"></a>00215
|
241
|
-
<a name="l00216"></a>00216
|
242
|
-
<a name="l00217"></a>00217
|
243
|
-
<a name="l00218"></a>00218
|
244
|
-
<a name="l00219"></a>00219
|
245
|
-
<a name="l00220"></a>00220
|
246
|
-
<a name="l00221"></a>00221
|
247
|
-
<a name="l00222"></a>00222
|
248
|
-
<a name="l00223"></a>00223
|
249
|
-
<a name="l00224"></a>00224
|
250
|
-
<a name="l00225"></a>00225
|
251
|
-
<a name="l00226"></a>00226
|
252
|
-
<a name="l00227"></a>00227
|
253
|
-
<a name="l00228"></a>00228
|
254
|
-
<a name="l00229"></a>00229 <span class="
|
174
|
+
<a name="l00149"></a>00149 <span class="comment"></span>
|
175
|
+
<a name="l00150"></a>00150 <span class="comment"> /**</span>
|
176
|
+
<a name="l00151"></a>00151 <span class="comment"> * Detach from the underlying file descriptor without closing it.</span>
|
177
|
+
<a name="l00152"></a>00152 <span class="comment"> * This FileDescriptor and all copies will no longer affect the</span>
|
178
|
+
<a name="l00153"></a>00153 <span class="comment"> * underlying file descriptors.</span>
|
179
|
+
<a name="l00154"></a>00154 <span class="comment"> *</span>
|
180
|
+
<a name="l00155"></a>00155 <span class="comment"> * @return The underlying file descriptor, or -1 if already closed.</span>
|
181
|
+
<a name="l00156"></a>00156 <span class="comment"> * @post *this == -1</span>
|
182
|
+
<a name="l00157"></a>00157 <span class="comment"> */</span>
|
183
|
+
<a name="l00158"></a><a class="code" href="classPassenger_1_1FileDescriptor.html#ad9f7acde3003ab0730bc248948a63777">00158</a> <span class="keywordtype">int</span> <a class="code" href="classPassenger_1_1FileDescriptor.html#ad9f7acde3003ab0730bc248948a63777" title="Detach from the underlying file descriptor without closing it.">detach</a>() {
|
184
|
+
<a name="l00159"></a>00159 <span class="keywordflow">if</span> (data != NULL) {
|
185
|
+
<a name="l00160"></a>00160 <span class="keywordtype">int</span> fd = data->fd;
|
186
|
+
<a name="l00161"></a>00161 data->detach();
|
187
|
+
<a name="l00162"></a>00162 data.reset();
|
188
|
+
<a name="l00163"></a>00163 <span class="keywordflow">return</span> fd;
|
189
|
+
<a name="l00164"></a>00164 } <span class="keywordflow">else</span> {
|
190
|
+
<a name="l00165"></a>00165 <span class="keywordflow">return</span> -1;
|
191
|
+
<a name="l00166"></a>00166 }
|
192
|
+
<a name="l00167"></a>00167 }
|
193
|
+
<a name="l00168"></a>00168 <span class="comment"></span>
|
194
|
+
<a name="l00169"></a>00169 <span class="comment"> /**</span>
|
195
|
+
<a name="l00170"></a>00170 <span class="comment"> * Overloads the integer cast operator so that it will return the underlying</span>
|
196
|
+
<a name="l00171"></a>00171 <span class="comment"> * file descriptor handle as an integer.</span>
|
197
|
+
<a name="l00172"></a>00172 <span class="comment"> *</span>
|
198
|
+
<a name="l00173"></a>00173 <span class="comment"> * Returns -1 if FileDescriptor::close() was called.</span>
|
199
|
+
<a name="l00174"></a>00174 <span class="comment"> */</span>
|
200
|
+
<a name="l00175"></a><a class="code" href="classPassenger_1_1FileDescriptor.html#ac335c2a97f3a6c8e3920f573b0d04081">00175</a> <a class="code" href="classPassenger_1_1FileDescriptor.html#ac335c2a97f3a6c8e3920f573b0d04081" title="Overloads the integer cast operator so that it will return the underlying file descriptor...">operator int </a>()<span class="keyword"> const </span>{
|
201
|
+
<a name="l00176"></a>00176 <span class="keywordflow">if</span> (data == NULL) {
|
202
|
+
<a name="l00177"></a>00177 <span class="keywordflow">return</span> -1;
|
203
|
+
<a name="l00178"></a>00178 } <span class="keywordflow">else</span> {
|
204
|
+
<a name="l00179"></a>00179 <span class="keywordflow">return</span> data->fd;
|
205
|
+
<a name="l00180"></a>00180 }
|
206
|
+
<a name="l00181"></a>00181 }
|
207
|
+
<a name="l00182"></a>00182
|
208
|
+
<a name="l00183"></a>00183 <a class="code" href="classPassenger_1_1FileDescriptor.html" title="Wrapper class around a file descriptor integer, for RAII behavior.">FileDescriptor</a> &operator=(<span class="keywordtype">int</span> fd) {
|
209
|
+
<a name="l00184"></a>00184 <span class="comment">/* Make sure that the 'new' and 'delete' operators don't</span>
|
210
|
+
<a name="l00185"></a>00185 <span class="comment"> * overwrite errno so that we can write code like this:</span>
|
211
|
+
<a name="l00186"></a>00186 <span class="comment"> *</span>
|
212
|
+
<a name="l00187"></a>00187 <span class="comment"> * FileDescriptor fd;</span>
|
213
|
+
<a name="l00188"></a>00188 <span class="comment"> * fd = open(...);</span>
|
214
|
+
<a name="l00189"></a>00189 <span class="comment"> * if (fd == -1) {</span>
|
215
|
+
<a name="l00190"></a>00190 <span class="comment"> * print_error(errno);</span>
|
216
|
+
<a name="l00191"></a>00191 <span class="comment"> * }</span>
|
217
|
+
<a name="l00192"></a>00192 <span class="comment"> */</span>
|
218
|
+
<a name="l00193"></a>00193 <span class="keywordtype">int</span> e = errno;
|
219
|
+
<a name="l00194"></a>00194 <span class="keywordflow">if</span> (fd >= 0) {
|
220
|
+
<a name="l00195"></a>00195 data = make_shared<SharedData>(fd);
|
221
|
+
<a name="l00196"></a>00196 } <span class="keywordflow">else</span> {
|
222
|
+
<a name="l00197"></a>00197 data.reset();
|
223
|
+
<a name="l00198"></a>00198 }
|
224
|
+
<a name="l00199"></a>00199 errno = e;
|
225
|
+
<a name="l00200"></a>00200 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
|
226
|
+
<a name="l00201"></a>00201 }
|
227
|
+
<a name="l00202"></a>00202
|
228
|
+
<a name="l00203"></a>00203 <a class="code" href="classPassenger_1_1FileDescriptor.html#a05d83ad9cc77c493a3ce4f2b51d44559" title="Creates a new empty FileDescriptor instance that has no underlying file descriptor...">FileDescriptor</a> &operator=(<span class="keyword">const</span> <a class="code" href="classPassenger_1_1FileDescriptor.html#a05d83ad9cc77c493a3ce4f2b51d44559" title="Creates a new empty FileDescriptor instance that has no underlying file descriptor...">FileDescriptor</a> &other) {
|
229
|
+
<a name="l00204"></a>00204 <span class="comment">/* Make sure that the 'delete' operator implicitly invoked by</span>
|
230
|
+
<a name="l00205"></a>00205 <span class="comment"> * shared_ptr doesn't overwrite errno so that we can write code</span>
|
231
|
+
<a name="l00206"></a>00206 <span class="comment"> * like this:</span>
|
232
|
+
<a name="l00207"></a>00207 <span class="comment"> *</span>
|
233
|
+
<a name="l00208"></a>00208 <span class="comment"> * FileDescriptor fd;</span>
|
234
|
+
<a name="l00209"></a>00209 <span class="comment"> * fd = other_file_descriptor_object;</span>
|
235
|
+
<a name="l00210"></a>00210 <span class="comment"> * if (fd == -1) {</span>
|
236
|
+
<a name="l00211"></a>00211 <span class="comment"> * print_error(errno);</span>
|
237
|
+
<a name="l00212"></a>00212 <span class="comment"> * }</span>
|
238
|
+
<a name="l00213"></a>00213 <span class="comment"> */</span>
|
239
|
+
<a name="l00214"></a>00214 <span class="keywordtype">int</span> e = errno;
|
240
|
+
<a name="l00215"></a>00215 data = other.data;
|
241
|
+
<a name="l00216"></a>00216 errno = e;
|
242
|
+
<a name="l00217"></a>00217 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
|
243
|
+
<a name="l00218"></a>00218 }
|
244
|
+
<a name="l00219"></a>00219 };
|
245
|
+
<a name="l00220"></a>00220 <span class="comment"></span>
|
246
|
+
<a name="l00221"></a>00221 <span class="comment">/**</span>
|
247
|
+
<a name="l00222"></a>00222 <span class="comment"> * A structure containing two FileDescriptor objects. Behaves like a pair</span>
|
248
|
+
<a name="l00223"></a>00223 <span class="comment"> * and like a two-element array.</span>
|
249
|
+
<a name="l00224"></a>00224 <span class="comment"> */</span>
|
250
|
+
<a name="l00225"></a><a class="code" href="classPassenger_1_1FileDescriptorPair.html">00225</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1FileDescriptorPair.html" title="A structure containing two FileDescriptor objects.">FileDescriptorPair</a>: <span class="keyword">public</span> pair<FileDescriptor, FileDescriptor> {
|
251
|
+
<a name="l00226"></a>00226 <span class="keyword">public</span>:
|
252
|
+
<a name="l00227"></a>00227 <a class="code" href="classPassenger_1_1FileDescriptorPair.html" title="A structure containing two FileDescriptor objects.">FileDescriptorPair</a>() { }
|
253
|
+
<a name="l00228"></a>00228
|
254
|
+
<a name="l00229"></a>00229 <a class="code" href="classPassenger_1_1FileDescriptorPair.html" title="A structure containing two FileDescriptor objects.">FileDescriptorPair</a>(<span class="keyword">const</span> <a class="code" href="classPassenger_1_1FileDescriptor.html" title="Wrapper class around a file descriptor integer, for RAII behavior.">FileDescriptor</a> &a, <span class="keyword">const</span> <a class="code" href="classPassenger_1_1FileDescriptor.html" title="Wrapper class around a file descriptor integer, for RAII behavior.">FileDescriptor</a> &b)
|
255
|
+
<a name="l00230"></a>00230 : pair<FileDescriptor, FileDescriptor>(a, b)
|
256
|
+
<a name="l00231"></a>00231 { }
|
257
|
+
<a name="l00232"></a>00232
|
258
|
+
<a name="l00233"></a>00233 <a class="code" href="classPassenger_1_1FileDescriptor.html" title="Wrapper class around a file descriptor integer, for RAII behavior.">FileDescriptor</a> &operator[](<span class="keywordtype">int</span> index) {
|
259
|
+
<a name="l00234"></a>00234 <span class="keywordflow">if</span> (index == 0) {
|
260
|
+
<a name="l00235"></a>00235 <span class="keywordflow">return</span> first;
|
261
|
+
<a name="l00236"></a>00236 } <span class="keywordflow">else</span> <span class="keywordflow">if</span> (index == 1) {
|
262
|
+
<a name="l00237"></a>00237 <span class="keywordflow">return</span> second;
|
263
|
+
<a name="l00238"></a>00238 } <span class="keywordflow">else</span> {
|
264
|
+
<a name="l00239"></a>00239 <span class="keywordflow">throw</span> <a class="code" href="classPassenger_1_1ArgumentException.html" title="Indicates that a specified argument is incorrect or violates a requirement.">ArgumentException</a>(<span class="stringliteral">"Index must be either 0 of 1"</span>);
|
265
|
+
<a name="l00240"></a>00240 }
|
266
|
+
<a name="l00241"></a>00241 }
|
267
|
+
<a name="l00242"></a>00242 };
|
268
|
+
<a name="l00243"></a>00243
|
269
|
+
<a name="l00244"></a>00244 <span class="comment">// Convenience aliases.</span>
|
270
|
+
<a name="l00245"></a>00245 <span class="keyword">typedef</span> <a class="code" href="classPassenger_1_1FileDescriptorPair.html" title="A structure containing two FileDescriptor objects.">FileDescriptorPair</a> <a class="code" href="classPassenger_1_1FileDescriptorPair.html" title="A structure containing two FileDescriptor objects.">Pipe</a>;
|
271
|
+
<a name="l00246"></a>00246 <span class="keyword">typedef</span> <a class="code" href="classPassenger_1_1FileDescriptorPair.html" title="A structure containing two FileDescriptor objects.">FileDescriptorPair</a> <a class="code" href="classPassenger_1_1FileDescriptorPair.html" title="A structure containing two FileDescriptor objects.">SocketPair</a>;
|
272
|
+
<a name="l00247"></a>00247 <span class="comment"></span>
|
273
|
+
<a name="l00248"></a>00248 <span class="comment">/**</span>
|
274
|
+
<a name="l00249"></a>00249 <span class="comment"> * A synchronization mechanism that's implemented with file descriptors,</span>
|
275
|
+
<a name="l00250"></a>00250 <span class="comment"> * and as such can be used in combination with select() and friends.</span>
|
276
|
+
<a name="l00251"></a>00251 <span class="comment"> *</span>
|
277
|
+
<a name="l00252"></a>00252 <span class="comment"> * One can wait for an event on an EventFd by select()ing it on read events.</span>
|
278
|
+
<a name="l00253"></a>00253 <span class="comment"> * Another thread can signal the EventFd by calling notify().</span>
|
279
|
+
<a name="l00254"></a>00254 <span class="comment"> */</span>
|
280
|
+
<a name="l00255"></a><a class="code" href="classPassenger_1_1EventFd.html">00255</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1EventFd.html" title="A synchronization mechanism that&#39;s implemented with file descriptors, and as...">EventFd</a> {
|
281
|
+
<a name="l00256"></a>00256 <span class="keyword">private</span>:
|
282
|
+
<a name="l00257"></a>00257 <span class="keywordtype">int</span> reader;
|
283
|
+
<a name="l00258"></a>00258 <span class="keywordtype">int</span> writer;
|
284
|
+
<a name="l00259"></a>00259
|
285
|
+
<a name="l00260"></a>00260 <span class="keyword">public</span>:
|
286
|
+
<a name="l00261"></a>00261 <a class="code" href="classPassenger_1_1EventFd.html" title="A synchronization mechanism that&#39;s implemented with file descriptors, and as...">EventFd</a>() {
|
287
|
+
<a name="l00262"></a>00262 <span class="keywordtype">int</span> fds[2];
|
288
|
+
<a name="l00263"></a>00263
|
289
|
+
<a name="l00264"></a>00264 <span class="keywordflow">if</span> (syscalls::pipe(fds) == -1) {
|
290
|
+
<a name="l00265"></a>00265 <span class="keywordtype">int</span> e = errno;
|
291
|
+
<a name="l00266"></a>00266 <span class="keywordflow">throw</span> <a class="code" href="classPassenger_1_1SystemException.html" title="Represents an error returned by a system call or a standard library call.">SystemException</a>(<span class="stringliteral">"Cannot create a pipe"</span>, e);
|
292
|
+
<a name="l00267"></a>00267 }
|
293
|
+
<a name="l00268"></a>00268 reader = fds[0];
|
294
|
+
<a name="l00269"></a>00269 writer = fds[1];
|
295
|
+
<a name="l00270"></a>00270 }
|
296
|
+
<a name="l00271"></a>00271
|
297
|
+
<a name="l00272"></a>00272 ~<a class="code" href="classPassenger_1_1EventFd.html" title="A synchronization mechanism that&#39;s implemented with file descriptors, and as...">EventFd</a>() {
|
298
|
+
<a name="l00273"></a>00273 this_thread::disable_syscall_interruption dsi;
|
299
|
+
<a name="l00274"></a>00274 syscalls::close(reader);
|
300
|
+
<a name="l00275"></a>00275 syscalls::close(writer);
|
301
|
+
<a name="l00276"></a>00276 }
|
302
|
+
<a name="l00277"></a>00277
|
303
|
+
<a name="l00278"></a>00278 <span class="keywordtype">void</span> notify() {
|
304
|
+
<a name="l00279"></a>00279 ssize_t ret = syscalls::write(writer, <span class="stringliteral">"x"</span>, 1);
|
305
|
+
<a name="l00280"></a>00280 <span class="keywordflow">if</span> (ret == -1 && errno != EAGAIN) {
|
306
|
+
<a name="l00281"></a>00281 <span class="keywordtype">int</span> e = errno;
|
307
|
+
<a name="l00282"></a>00282 <span class="keywordflow">throw</span> <a class="code" href="classPassenger_1_1SystemException.html" title="Represents an error returned by a system call or a standard library call.">SystemException</a>(<span class="stringliteral">"Cannot write notification data"</span>, e);
|
308
|
+
<a name="l00283"></a>00283 }
|
309
|
+
<a name="l00284"></a>00284 }
|
310
|
+
<a name="l00285"></a>00285
|
311
|
+
<a name="l00286"></a>00286 <span class="keywordtype">int</span> fd()<span class="keyword"> const </span>{
|
312
|
+
<a name="l00287"></a>00287 <span class="keywordflow">return</span> reader;
|
313
|
+
<a name="l00288"></a>00288 }
|
314
|
+
<a name="l00289"></a>00289 };
|
315
|
+
<a name="l00290"></a>00290
|
316
|
+
<a name="l00291"></a>00291 } <span class="comment">// namespace Passenger</span>
|
317
|
+
<a name="l00292"></a>00292
|
318
|
+
<a name="l00293"></a>00293 <span class="preprocessor">#endif </span><span class="comment">/* _PASSENGER_FILE_DESCRIPTOR_H_ */</span>
|
255
319
|
</pre></div></div>
|
256
320
|
<hr size="1"/><address style="text-align: right;"><small>Generated by
|
257
321
|
<a href="http://www.doxygen.org/index.html">
|