passenger 2.0.6 → 2.1.2
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 +10 -4
- data/LICENSE +1 -1
- data/NEWS +0 -0
- data/Rakefile +183 -117
- data/benchmark/dispatcher.rb +5 -9
- data/bin/passenger-install-apache2-module +52 -18
- data/bin/passenger-memory-stats +67 -13
- data/bin/passenger-spawn-server +8 -4
- data/bin/passenger-status +21 -46
- data/bin/passenger-stress-test +5 -5
- data/debian/postinst +1 -1
- data/doc/ApplicationPool algorithm.txt +180 -128
- data/doc/Architectural overview.html +1 -778
- data/doc/Security of user switching support.html +1 -643
- data/doc/Users guide Apache.html +3127 -0
- data/doc/Users guide Nginx.html +1458 -0
- data/doc/Users guide.html +1404 -467
- data/doc/Users guide.txt +843 -105
- data/doc/cxxapi/ApplicationPoolServer_8h-source.html +751 -641
- data/doc/cxxapi/ApplicationPool_8h-source.html +168 -171
- data/doc/cxxapi/Application_8h-source.html +494 -394
- data/doc/cxxapi/Bucket_8h-source.html +21 -15
- data/doc/cxxapi/CachedFileStat_8h-source.html +191 -0
- data/doc/cxxapi/Configuration_8h-source.html +311 -149
- data/doc/cxxapi/DirectoryMapper_8h-source.html +309 -0
- data/doc/cxxapi/DummySpawnManager_8h-source.html +3 -4
- data/doc/cxxapi/Exceptions_8h-source.html +182 -165
- data/doc/cxxapi/FileChecker_8h-source.html +130 -0
- data/doc/cxxapi/Hooks_8h-source.html +2 -3
- data/doc/cxxapi/Logging_8h-source.html +92 -89
- data/doc/cxxapi/MessageChannel_8h-source.html +585 -477
- data/doc/cxxapi/PoolOptions_8h-source.html +305 -0
- data/doc/cxxapi/SpawnManager_8h-source.html +515 -540
- data/doc/cxxapi/StandardApplicationPool_8h-source.html +779 -679
- data/doc/cxxapi/SystemTime_8h-source.html +104 -0
- data/doc/cxxapi/Utils_8h-source.html +331 -227
- data/doc/cxxapi/annotated.html +6 -7
- data/doc/cxxapi/classClient-members.html +1 -2
- data/doc/cxxapi/classClient.html +1 -2
- data/doc/cxxapi/classHooks-members.html +5 -2
- data/doc/cxxapi/classHooks.html +112 -2
- data/doc/cxxapi/classPassenger_1_1Application-members.html +2 -3
- data/doc/cxxapi/classPassenger_1_1Application.html +8 -9
- data/doc/cxxapi/classPassenger_1_1ApplicationPool-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1ApplicationPool.html +42 -81
- data/doc/cxxapi/classPassenger_1_1ApplicationPoolServer-members.html +1 -2
- data/doc/cxxapi/classPassenger_1_1ApplicationPoolServer.html +3 -4
- data/doc/cxxapi/classPassenger_1_1ApplicationPool__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1Application_1_1Session-members.html +3 -2
- data/doc/cxxapi/classPassenger_1_1Application_1_1Session.html +74 -3
- data/doc/cxxapi/classPassenger_1_1BusyException-members.html +1 -2
- data/doc/cxxapi/classPassenger_1_1BusyException.html +2 -3
- data/doc/cxxapi/classPassenger_1_1ConfigurationException-members.html +1 -2
- data/doc/cxxapi/classPassenger_1_1ConfigurationException.html +2 -3
- data/doc/cxxapi/classPassenger_1_1DirectoryMapper-members.html +38 -0
- data/doc/cxxapi/classPassenger_1_1DirectoryMapper.html +256 -0
- data/doc/cxxapi/classPassenger_1_1DummySpawnManager-members.html +1 -2
- data/doc/cxxapi/classPassenger_1_1DummySpawnManager.html +2 -3
- data/doc/cxxapi/{classPassenger_1_1Thread-members.html → classPassenger_1_1FileChecker-members.html} +4 -5
- data/doc/cxxapi/classPassenger_1_1FileChecker.html +121 -0
- data/doc/cxxapi/classPassenger_1_1FileNotFoundException-members.html +1 -2
- data/doc/cxxapi/classPassenger_1_1FileNotFoundException.html +2 -3
- data/doc/cxxapi/classPassenger_1_1FileNotFoundException__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1FileSystemException-members.html +2 -3
- data/doc/cxxapi/classPassenger_1_1FileSystemException.html +2 -3
- data/doc/cxxapi/classPassenger_1_1FileSystemException__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1IOException-members.html +1 -2
- data/doc/cxxapi/classPassenger_1_1IOException.html +2 -3
- data/doc/cxxapi/classPassenger_1_1IOException__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1MessageChannel-members.html +5 -2
- data/doc/cxxapi/classPassenger_1_1MessageChannel.html +155 -5
- data/doc/cxxapi/{classboost_1_1this__thread_1_1enable__syscall__interruption-members.html → classPassenger_1_1RuntimeException-members.html} +2 -3
- data/doc/cxxapi/{classboost_1_1this__thread_1_1enable__syscall__interruption.html → classPassenger_1_1RuntimeException.html} +10 -8
- data/doc/cxxapi/classPassenger_1_1SpawnException-members.html +1 -2
- data/doc/cxxapi/classPassenger_1_1SpawnException.html +2 -3
- data/doc/cxxapi/classPassenger_1_1SpawnManager-members.html +2 -3
- data/doc/cxxapi/classPassenger_1_1SpawnManager.html +15 -56
- data/doc/cxxapi/classPassenger_1_1StandardApplicationPool-members.html +5 -4
- data/doc/cxxapi/classPassenger_1_1StandardApplicationPool.html +20 -81
- data/doc/cxxapi/classPassenger_1_1StandardApplicationPool__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1SystemException-members.html +2 -3
- data/doc/cxxapi/classPassenger_1_1SystemException.html +9 -10
- data/doc/cxxapi/classPassenger_1_1SystemException__inherit__graph.png +0 -0
- data/doc/cxxapi/{classboost_1_1this__thread_1_1disable__syscall__interruption-members.html → classPassenger_1_1SystemTime-members.html} +5 -3
- data/doc/cxxapi/classPassenger_1_1SystemTime.html +86 -0
- data/doc/cxxapi/classPassenger_1_1TempFile-members.html +2 -3
- data/doc/cxxapi/classPassenger_1_1TempFile.html +17 -9
- data/doc/cxxapi/definitions_8h-source.html +1 -2
- data/doc/cxxapi/files.html +6 -3
- data/doc/cxxapi/functions.html +98 -35
- data/doc/cxxapi/functions_func.html +60 -32
- data/doc/cxxapi/functions_type.html +1 -2
- data/doc/cxxapi/functions_vars.html +27 -2
- data/doc/cxxapi/graph_legend.html +1 -2
- data/doc/cxxapi/graph_legend.png +0 -0
- data/doc/cxxapi/group__Configuration.html +3 -4
- data/doc/cxxapi/group__Configuration.png +0 -0
- data/doc/cxxapi/group__Core.html +3 -4
- data/doc/cxxapi/group__Core.png +0 -0
- data/doc/cxxapi/group__Exceptions.html +4 -2
- data/doc/cxxapi/group__Hooks.html +1 -6
- data/doc/cxxapi/group__Hooks.png +0 -0
- data/doc/cxxapi/group__Support.html +259 -36
- data/doc/cxxapi/hierarchy.html +6 -7
- data/doc/cxxapi/inherit__graph__0.map +1 -1
- data/doc/cxxapi/inherit__graph__0.md5 +1 -1
- data/doc/cxxapi/inherit__graph__0.png +0 -0
- data/doc/cxxapi/inherit__graph__1.map +1 -1
- data/doc/cxxapi/inherit__graph__1.md5 +1 -1
- data/doc/cxxapi/inherit__graph__1.png +0 -0
- data/doc/cxxapi/inherit__graph__10.map +1 -1
- data/doc/cxxapi/inherit__graph__10.md5 +1 -1
- data/doc/cxxapi/inherit__graph__10.png +0 -0
- data/doc/cxxapi/inherit__graph__11.map +1 -1
- data/doc/cxxapi/inherit__graph__11.md5 +1 -1
- data/doc/cxxapi/inherit__graph__11.png +0 -0
- data/doc/cxxapi/inherit__graph__12.map +2 -1
- data/doc/cxxapi/inherit__graph__12.md5 +1 -1
- data/doc/cxxapi/inherit__graph__12.png +0 -0
- data/doc/cxxapi/inherit__graph__13.map +1 -1
- data/doc/cxxapi/inherit__graph__13.md5 +1 -1
- data/doc/cxxapi/inherit__graph__13.png +0 -0
- data/doc/cxxapi/inherit__graph__14.map +1 -2
- 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 -1
- 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 +1 -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.png +0 -0
- data/doc/cxxapi/inherit__graph__18.png +0 -0
- data/doc/cxxapi/inherit__graph__19.png +0 -0
- data/doc/cxxapi/inherit__graph__2.map +1 -1
- data/doc/cxxapi/inherit__graph__2.md5 +1 -1
- data/doc/cxxapi/inherit__graph__2.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__3.map +1 -1
- data/doc/cxxapi/inherit__graph__3.md5 +1 -1
- data/doc/cxxapi/inherit__graph__3.png +0 -0
- data/doc/cxxapi/inherit__graph__4.map +1 -1
- data/doc/cxxapi/inherit__graph__4.md5 +1 -1
- data/doc/cxxapi/inherit__graph__4.png +0 -0
- data/doc/cxxapi/inherit__graph__5.map +2 -1
- data/doc/cxxapi/inherit__graph__5.md5 +1 -1
- data/doc/cxxapi/inherit__graph__5.png +0 -0
- data/doc/cxxapi/inherit__graph__6.map +1 -1
- data/doc/cxxapi/inherit__graph__6.md5 +1 -1
- data/doc/cxxapi/inherit__graph__6.png +0 -0
- data/doc/cxxapi/inherit__graph__7.map +1 -1
- data/doc/cxxapi/inherit__graph__7.md5 +1 -1
- data/doc/cxxapi/inherit__graph__7.png +0 -0
- data/doc/cxxapi/inherit__graph__8.map +1 -1
- data/doc/cxxapi/inherit__graph__8.md5 +1 -1
- data/doc/cxxapi/inherit__graph__8.png +0 -0
- data/doc/cxxapi/inherit__graph__9.map +1 -2
- data/doc/cxxapi/inherit__graph__9.md5 +1 -1
- data/doc/cxxapi/inherit__graph__9.png +0 -0
- data/doc/cxxapi/inherits.html +30 -31
- data/doc/cxxapi/main.html +1 -2
- data/doc/cxxapi/modules.html +1 -2
- data/doc/cxxapi/structPassenger_1_1AnythingToString-members.html +1 -2
- data/doc/cxxapi/structPassenger_1_1AnythingToString.html +2 -3
- data/doc/cxxapi/structPassenger_1_1AnythingToString_3_01vector_3_01string_01_4_01_4-members.html +1 -2
- data/doc/cxxapi/structPassenger_1_1AnythingToString_3_01vector_3_01string_01_4_01_4.html +2 -3
- data/doc/cxxapi/structPassenger_1_1PoolOptions-members.html +49 -0
- data/doc/cxxapi/structPassenger_1_1PoolOptions.html +404 -0
- data/doc/cxxapi/tree.html +18 -20
- data/doc/images/conservative_spawning.png +0 -0
- data/doc/images/conservative_spawning.svg +248 -0
- data/doc/images/smart-lv2.png +0 -0
- data/doc/images/smart-lv2.svg +320 -0
- data/doc/rdoc/classes/ConditionVariable.html +68 -34
- data/doc/rdoc/classes/Exception.html +16 -16
- data/doc/rdoc/classes/GC.html +9 -9
- data/doc/rdoc/classes/IO.html +36 -17
- data/doc/rdoc/classes/PhusionPassenger.html +183 -0
- data/doc/rdoc/classes/PhusionPassenger/AbstractRequestHandler.html +511 -0
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/AbstractServer.html +285 -242
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/AbstractServer/ServerAlreadyStarted.html +3 -3
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/AbstractServer/ServerError.html +3 -3
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/AbstractServer/ServerNotStarted.html +3 -3
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/AbstractServer/UnknownMessage.html +3 -3
- data/doc/rdoc/classes/PhusionPassenger/AbstractServerCollection.html +598 -0
- data/doc/rdoc/classes/PhusionPassenger/AdminTools.html +140 -0
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ControlProcess.html +247 -0
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ControlProcess/Instance.html +138 -0
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/AppInitError.html +36 -19
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/Application.html +81 -96
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/ConsoleTextTemplate.html +18 -18
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/FrameworkInitError.html +20 -18
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/HTMLTemplate.html +18 -18
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/InitializationError.html +9 -9
- data/doc/rdoc/classes/PhusionPassenger/InvalidPath.html +92 -0
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/MessageChannel.html +93 -92
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/NativeSupport.html +55 -25
- data/doc/rdoc/classes/PhusionPassenger/Rack.html +91 -0
- data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner.html +185 -0
- data/doc/rdoc/classes/PhusionPassenger/Rack/RequestHandler.html +182 -0
- data/doc/rdoc/classes/PhusionPassenger/Railz.html +95 -0
- data/doc/rdoc/classes/PhusionPassenger/Railz/ApplicationSpawner.html +424 -0
- data/doc/rdoc/classes/PhusionPassenger/Railz/ApplicationSpawner/Error.html +98 -0
- data/doc/rdoc/classes/PhusionPassenger/Railz/CGIFixed.html +200 -0
- data/doc/rdoc/classes/PhusionPassenger/Railz/FrameworkSpawner.html +444 -0
- data/doc/rdoc/classes/PhusionPassenger/Railz/FrameworkSpawner/Error.html +98 -0
- data/doc/rdoc/classes/PhusionPassenger/Railz/RequestHandler.html +154 -0
- data/doc/rdoc/classes/PhusionPassenger/SpawnManager.html +408 -0
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/UnknownError.html +13 -13
- data/doc/rdoc/classes/PhusionPassenger/Utils.html +687 -0
- data/doc/rdoc/classes/{Passenger → PhusionPassenger}/VersionNotFound.html +8 -8
- data/doc/rdoc/classes/PhusionPassenger/WSGI.html +89 -0
- data/doc/rdoc/classes/PhusionPassenger/WSGI/ApplicationSpawner.html +188 -0
- data/doc/rdoc/classes/PlatformInfo.html +663 -159
- data/doc/rdoc/classes/RakeExtensions.html +4 -4
- data/doc/rdoc/classes/Signal.html +134 -0
- data/doc/rdoc/created.rid +1 -1
- data/doc/rdoc/files/DEVELOPERS_TXT.html +15 -10
- data/doc/rdoc/files/README.html +5 -7
- data/doc/rdoc/files/ext/{passenger → phusion_passenger}/native_support_c.html +2 -2
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/abstract_request_handler_rb.html +7 -9
- data/doc/rdoc/files/lib/phusion_passenger/abstract_server_collection_rb.html +120 -0
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/abstract_server_rb.html +7 -10
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools/control_process_rb.html +99 -0
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools_rb.html +92 -0
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/application_rb.html +6 -8
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/console_text_template_rb.html +5 -7
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/constants_rb.html +4 -5
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/dependencies_rb.html +6 -8
- data/doc/rdoc/files/lib/phusion_passenger/events_rb.html +116 -0
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/exceptions_rb.html +5 -7
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/html_template_rb.html +5 -7
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/message_channel_rb.html +5 -7
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/platform_info_rb.html +6 -7
- data/doc/rdoc/files/lib/phusion_passenger/rack/application_spawner_rb.html +123 -0
- data/doc/rdoc/files/lib/phusion_passenger/rack/request_handler_rb.html +117 -0
- data/doc/rdoc/files/lib/{passenger/utils_rb.html → phusion_passenger/railz/application_spawner_rb.html} +24 -17
- data/doc/rdoc/files/lib/phusion_passenger/railz/cgi_fixed_rb.html +126 -0
- data/doc/rdoc/files/lib/phusion_passenger/railz/framework_spawner_rb.html +139 -0
- data/doc/rdoc/files/lib/phusion_passenger/railz/request_handler_rb.html +118 -0
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/simple_benchmarking_rb.html +5 -7
- data/doc/rdoc/files/lib/{passenger → phusion_passenger}/spawn_manager_rb.html +40 -24
- data/doc/rdoc/files/lib/phusion_passenger/utils_rb.html +169 -0
- data/doc/rdoc/files/lib/phusion_passenger/wsgi/application_spawner_rb.html +120 -0
- data/doc/rdoc/files/lib/rake/extensions_rb.html +3 -4
- data/doc/rdoc/fr_class_index.html +37 -19
- data/doc/rdoc/fr_file_index.html +25 -14
- data/doc/rdoc/fr_method_index.html +145 -74
- data/ext/apache2/Application.h +145 -44
- data/ext/apache2/ApplicationPool.h +27 -29
- data/ext/apache2/ApplicationPoolServer.h +183 -72
- data/ext/apache2/ApplicationPoolServerExecutable.cpp +249 -42
- data/ext/apache2/Bucket.cpp +61 -9
- data/ext/apache2/Bucket.h +15 -8
- data/ext/apache2/CachedFileStat.cpp +114 -0
- data/ext/apache2/CachedFileStat.h +169 -0
- data/ext/apache2/Configuration.cpp +213 -22
- data/ext/apache2/Configuration.h +176 -13
- data/ext/apache2/DirectoryMapper.h +287 -0
- data/ext/apache2/Exceptions.h +30 -12
- data/ext/apache2/FileChecker.h +108 -0
- data/ext/apache2/Hooks.cpp +709 -493
- data/ext/apache2/LICENSE-CNRI.TXT +15 -0
- data/ext/apache2/Logging.h +26 -22
- data/ext/apache2/MessageChannel.h +124 -15
- data/ext/apache2/PoolOptions.h +283 -0
- data/ext/apache2/SpawnManager.h +75 -99
- data/ext/apache2/StandardApplicationPool.h +296 -195
- data/ext/apache2/SystemTime.cpp +28 -0
- data/ext/apache2/SystemTime.h +82 -0
- data/ext/apache2/Utils.cpp +172 -18
- data/ext/apache2/Utils.h +124 -19
- data/ext/boost/cstdint.hpp +4 -2
- data/ext/boost/current_function.hpp +67 -0
- data/ext/boost/detail/sp_counted_base.hpp +4 -4
- data/ext/boost/thread/exceptions.hpp +2 -1
- data/ext/boost/thread/pthread/thread.hpp +11 -3
- data/ext/boost/thread/pthread/thread_data.hpp +2 -1
- data/ext/oxt/backtrace.cpp +172 -0
- data/ext/oxt/backtrace.hpp +135 -0
- data/ext/oxt/detail/backtrace_disabled.hpp +39 -0
- data/ext/oxt/detail/backtrace_enabled.hpp +155 -0
- data/ext/oxt/detail/spin_lock_gcc_x86.hpp +82 -0
- data/ext/oxt/detail/spin_lock_portable.hpp +38 -0
- data/ext/oxt/detail/spin_lock_pthreads.hpp +97 -0
- data/ext/oxt/detail/tracable_exception_disabled.hpp +46 -0
- data/ext/oxt/detail/tracable_exception_enabled.hpp +48 -0
- data/ext/oxt/macros.hpp +58 -0
- data/ext/oxt/spin_lock.hpp +55 -0
- data/ext/{apache2/System.cpp → oxt/system_calls.cpp} +87 -52
- data/ext/oxt/system_calls.hpp +234 -0
- data/ext/oxt/thread.cpp +32 -0
- data/ext/oxt/thread.hpp +223 -0
- data/ext/oxt/tracable_exception.cpp +87 -0
- data/ext/oxt/tracable_exception.hpp +35 -0
- data/{lib/passenger/constants.rb → ext/phusion_passenger/extconf.rb} +14 -9
- data/ext/{passenger → phusion_passenger}/native_support.c +33 -6
- data/lib/{passenger → phusion_passenger}/abstract_request_handler.rb +209 -93
- data/lib/{passenger → phusion_passenger}/abstract_server.rb +23 -8
- data/lib/phusion_passenger/abstract_server_collection.rb +301 -0
- data/lib/phusion_passenger/admin_tools.rb +25 -0
- data/lib/phusion_passenger/admin_tools/control_process.rb +107 -0
- data/lib/{passenger → phusion_passenger}/application.rb +13 -16
- data/lib/{passenger → phusion_passenger}/console_text_template.rb +2 -2
- data/{ext/passenger/extconf.rb → lib/phusion_passenger/constants.rb} +5 -5
- data/lib/{passenger → phusion_passenger}/dependencies.rb +38 -32
- data/lib/phusion_passenger/events.rb +45 -0
- data/lib/{passenger → phusion_passenger}/exceptions.rb +12 -5
- data/lib/{passenger → phusion_passenger}/html_template.rb +2 -2
- data/lib/{passenger → phusion_passenger}/message_channel.rb +3 -2
- data/lib/phusion_passenger/platform_info.rb +500 -0
- data/lib/{passenger → phusion_passenger}/rack/application_spawner.rb +29 -22
- data/lib/{passenger → phusion_passenger}/rack/request_handler.rb +14 -9
- data/lib/{passenger → phusion_passenger}/railz/application_spawner.rb +94 -74
- data/lib/{passenger → phusion_passenger}/railz/cgi_fixed.rb +2 -2
- data/lib/{passenger → phusion_passenger}/railz/framework_spawner.rb +86 -98
- data/lib/{passenger → phusion_passenger}/railz/request_handler.rb +6 -6
- data/lib/{passenger → phusion_passenger}/simple_benchmarking.rb +0 -0
- data/lib/{passenger → phusion_passenger}/spawn_manager.rb +136 -128
- data/lib/{passenger → phusion_passenger}/templates/apache2_config_snippets.txt.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/apache_must_be_compiled_with_compatible_mpm.txt.erb +0 -0
- data/lib/phusion_passenger/templates/app_exited_during_initialization.html.erb +38 -0
- data/lib/{passenger → phusion_passenger}/templates/app_init_error.html.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/database_error.html.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/deployment_example.txt.erb +1 -1
- data/lib/{passenger → phusion_passenger}/templates/error_layout.css +0 -0
- data/lib/{passenger → phusion_passenger}/templates/error_layout.html.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/framework_init_error.html.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/general_error.html.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/invalid_app_root.html.erb +1 -1
- data/lib/{passenger → phusion_passenger}/templates/load_error.html.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/no_write_permission_to_passenger_root.txt.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/possible_solutions_for_compilation_and_installation_problems.txt.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/run_installer_as_root.txt.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/version_not_found.html.erb +0 -0
- data/lib/{passenger → phusion_passenger}/templates/welcome.txt.erb +0 -0
- data/lib/{passenger → phusion_passenger}/utils.rb +210 -44
- data/lib/{passenger → phusion_passenger}/wsgi/application_spawner.rb +18 -15
- data/lib/{passenger → phusion_passenger}/wsgi/request_handler.py +7 -1
- data/man/passenger-memory-stats.8 +1 -1
- data/misc/render_error_pages.rb +1 -1
- data/test/ApplicationPoolServerTest.cpp +0 -28
- data/test/ApplicationPoolServer_ApplicationPoolTest.cpp +4 -0
- data/test/ApplicationPoolTest.cpp +307 -69
- data/test/CachedFileStatTest.cpp +262 -0
- data/test/FileCheckerTest.cpp +79 -0
- data/test/MessageChannelTest.cpp +3 -3
- data/test/PoolOptionsTest.cpp +37 -0
- data/test/SpawnManagerTest.cpp +4 -4
- data/test/StandardApplicationPoolTest.cpp +4 -0
- data/test/SystemTimeTest.cpp +37 -0
- data/test/UtilsTest.cpp +137 -0
- data/test/integration_tests.rb +270 -23
- data/test/oxt/backtrace_test.cpp +128 -0
- data/test/oxt/oxt_test_main.cpp +25 -0
- data/test/oxt/syscall_interruption_test.cpp +50 -0
- data/test/ruby/abstract_request_handler_spec.rb +83 -0
- data/test/ruby/abstract_server_collection_spec.rb +246 -0
- data/test/ruby/application_spec.rb +3 -3
- data/test/ruby/message_channel_spec.rb +2 -2
- data/test/ruby/rack/application_spawner_spec.rb +3 -5
- data/test/ruby/rails/application_spawner_spec.rb +54 -15
- data/test/ruby/rails/framework_spawner_spec.rb +6 -8
- data/test/ruby/rails/minimal_spawner_spec.rb +29 -0
- data/test/ruby/rails/spawner_error_handling_spec.rb +1 -1
- data/test/ruby/rails/spawner_privilege_lowering_spec.rb +3 -3
- data/test/ruby/spawn_manager_spec.rb +23 -12
- data/test/ruby/utils_spec.rb +36 -2
- data/test/ruby/wsgi/application_spawner_spec.rb +47 -0
- data/test/stub/apache2/httpd.conf.erb +3 -5
- data/test/stub/message_channel.rb +2 -2
- data/test/stub/message_channel_2.rb +2 -2
- data/test/stub/message_channel_3.rb +3 -3
- data/test/stub/minimal-railsapp/README +0 -0
- data/test/stub/minimal-railsapp/config/application.rb +0 -0
- data/test/stub/minimal-railsapp/config/environment.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/actionmailer/lib/action_mailer.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/actionpack/lib/action_controller.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/actionpack/lib/action_pack.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/actionpack/lib/action_view.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/activerecord/lib/active_record.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/activeresource/lib/active_resource.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/activesupport/lib/active_support.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/activesupport/lib/active_support/whiny_nil.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/railties/lib/dispatcher.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/railties/lib/initializer.rb +0 -0
- data/test/stub/minimal-railsapp/vendor/rails/railties/lib/ruby_version_check.rb +0 -0
- data/test/stub/rails_apps/foobar/app/controllers/foo_controller.rb +8 -0
- data/test/stub/rails_apps/foobar/config/environments/development.rb +1 -2
- data/test/stub/rails_apps/mycook/app/controllers/welcome_controller.rb +21 -1
- data/test/stub/rails_apps/mycook/sites/some.site/public/uploads.html +26 -0
- data/test/stub/rails_apps/mycook/sites/some.site/public/welcome/cached.html +26 -0
- data/test/stub/railsapp/app/controllers/application.rb +0 -0
- data/test/stub/railsapp/app/controllers/bar_controller_1.rb +0 -0
- data/test/stub/railsapp/app/controllers/bar_controller_2.rb +1 -1
- data/test/stub/railsapp/app/controllers/foo_controller.rb +4 -0
- data/test/stub/railsapp/app/helpers/application_helper.rb +0 -0
- data/test/stub/railsapp/config/boot.rb +0 -0
- data/test/stub/railsapp/config/database.yml +0 -0
- data/test/stub/railsapp/config/environment.rb +0 -0
- data/test/stub/railsapp/config/environments/development.rb +0 -0
- data/test/stub/railsapp/config/environments/production.rb +0 -0
- data/test/stub/railsapp/config/initializers/inflections.rb +0 -0
- data/test/stub/railsapp/config/initializers/mime_types.rb +0 -0
- data/test/stub/railsapp/config/routes.rb +0 -0
- data/test/stub/railsapp/public/useless.txt +0 -0
- data/test/stub/spawn_server.rb +3 -4
- data/test/stub/wsgi/passenger_wsgi.pyc +0 -0
- data/test/support/apache2_controller.rb +57 -7
- data/test/support/tut.h +15 -0
- data/vendor/README +12 -0
- data/vendor/README_FOR_PACKAGERS +1 -0
- data/vendor/rack-0.9.1/AUTHORS +8 -0
- data/vendor/rack-0.9.1/COPYING +18 -0
- data/vendor/rack-0.9.1/ChangeLog +1423 -0
- data/vendor/rack-0.9.1/KNOWN-ISSUES +18 -0
- data/vendor/rack-0.9.1/README +306 -0
- data/vendor/rack-0.9.1/Rakefile +188 -0
- data/vendor/rack-0.9.1/SPEC +129 -0
- data/vendor/rack-0.9.1/lib/rack.rb +86 -0
- data/vendor/rack-0.9.1/lib/rack/adapter/camping.rb +22 -0
- data/vendor/rack-0.9.1/lib/rack/auth/abstract/handler.rb +28 -0
- data/vendor/rack-0.9.1/lib/rack/auth/abstract/request.rb +37 -0
- data/vendor/rack-0.9.1/lib/rack/auth/basic.rb +58 -0
- data/vendor/rack-0.9.1/lib/rack/auth/digest/md5.rb +124 -0
- data/vendor/rack-0.9.1/lib/rack/auth/digest/nonce.rb +51 -0
- data/vendor/rack-0.9.1/lib/rack/auth/digest/params.rb +55 -0
- data/vendor/rack-0.9.1/lib/rack/auth/digest/request.rb +40 -0
- data/vendor/rack-0.9.1/lib/rack/auth/openid.rb +438 -0
- data/vendor/rack-0.9.1/lib/rack/builder.rb +67 -0
- data/vendor/rack-0.9.1/lib/rack/cascade.rb +36 -0
- data/vendor/rack-0.9.1/lib/rack/commonlogger.rb +61 -0
- data/vendor/rack-0.9.1/lib/rack/conditionalget.rb +43 -0
- data/vendor/rack-0.9.1/lib/rack/content_length.rb +25 -0
- data/vendor/rack-0.9.1/lib/rack/deflater.rb +87 -0
- data/vendor/rack-0.9.1/lib/rack/directory.rb +150 -0
- data/vendor/rack-0.9.1/lib/rack/file.rb +85 -0
- data/vendor/rack-0.9.1/lib/rack/handler.rb +48 -0
- data/vendor/rack-0.9.1/lib/rack/handler/cgi.rb +57 -0
- data/vendor/rack-0.9.1/lib/rack/handler/evented_mongrel.rb +8 -0
- data/vendor/rack-0.9.1/lib/rack/handler/fastcgi.rb +86 -0
- data/vendor/rack-0.9.1/lib/rack/handler/lsws.rb +52 -0
- data/vendor/rack-0.9.1/lib/rack/handler/mongrel.rb +82 -0
- data/vendor/rack-0.9.1/lib/rack/handler/scgi.rb +57 -0
- data/vendor/rack-0.9.1/lib/rack/handler/swiftiplied_mongrel.rb +8 -0
- data/vendor/rack-0.9.1/lib/rack/handler/thin.rb +15 -0
- data/vendor/rack-0.9.1/lib/rack/handler/webrick.rb +61 -0
- data/vendor/rack-0.9.1/lib/rack/head.rb +19 -0
- data/vendor/rack-0.9.1/lib/rack/lint.rb +465 -0
- data/vendor/rack-0.9.1/lib/rack/lobster.rb +65 -0
- data/vendor/rack-0.9.1/lib/rack/methodoverride.rb +27 -0
- data/vendor/rack-0.9.1/lib/rack/mime.rb +204 -0
- data/vendor/rack-0.9.1/lib/rack/mock.rb +160 -0
- data/vendor/rack-0.9.1/lib/rack/recursive.rb +57 -0
- data/vendor/rack-0.9.1/lib/rack/reloader.rb +64 -0
- data/vendor/rack-0.9.1/lib/rack/request.rb +218 -0
- data/vendor/rack-0.9.1/lib/rack/response.rb +171 -0
- data/vendor/rack-0.9.1/lib/rack/session/abstract/id.rb +153 -0
- data/vendor/rack-0.9.1/lib/rack/session/cookie.rb +89 -0
- data/vendor/rack-0.9.1/lib/rack/session/memcache.rb +97 -0
- data/vendor/rack-0.9.1/lib/rack/session/pool.rb +73 -0
- data/vendor/rack-0.9.1/lib/rack/showexceptions.rb +348 -0
- data/vendor/rack-0.9.1/lib/rack/showstatus.rb +106 -0
- data/vendor/rack-0.9.1/lib/rack/static.rb +38 -0
- data/vendor/rack-0.9.1/lib/rack/urlmap.rb +48 -0
- data/vendor/rack-0.9.1/lib/rack/utils.rb +347 -0
- metadata +1197 -1055
- data/doc/cxxapi/System_8h-source.html +0 -251
- data/doc/cxxapi/classDirectoryMapper-members.html +0 -38
- data/doc/cxxapi/classDirectoryMapper.html +0 -203
- data/doc/cxxapi/classPassenger_1_1Thread.html +0 -100
- data/doc/cxxapi/classboost_1_1this__thread_1_1disable__syscall__interruption.html +0 -46
- data/doc/cxxapi/classboost_1_1this__thread_1_1restore__syscall__interruption-members.html +0 -33
- data/doc/cxxapi/classboost_1_1this__thread_1_1restore__syscall__interruption.html +0 -44
- data/doc/cxxapi/namespacePassenger.html +0 -208
- data/doc/cxxapi/namespacePassenger_1_1InterruptableCalls.html +0 -43
- data/doc/cxxapi/namespacemembers.html +0 -70
- data/doc/cxxapi/namespacemembers_func.html +0 -66
- data/doc/cxxapi/namespacemembers_type.html +0 -46
- data/doc/cxxapi/namespaces.html +0 -35
- data/doc/rdoc/classes/Passenger.html +0 -136
- data/doc/rdoc/classes/Passenger/AbstractRequestHandler.html +0 -402
- data/doc/rdoc/classes/Passenger/SpawnManager.html +0 -379
- data/doc/rdoc/classes/Passenger/Utils.html +0 -578
- data/ext/apache2/System.h +0 -228
- data/lib/passenger/platform_info.rb +0 -302
- data/lib/passenger/templates/app_exited_during_initialization.html.erb +0 -19
- data/test/stub/apache2/httpd.conf +0 -75
- data/test/stub/rails_apps/foobar/config/environments/test.rb +0 -22
- data/test/stub/rails_apps/mycook/config/environments/test.rb +0 -22
- data/test/stub/railsapp/config/environments/test.rb +0 -22
- data/test/stub/railsapp2/config/environments/test.rb +0 -22
@@ -0,0 +1,309 @@
|
|
1
|
+
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
2
|
+
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
|
3
|
+
<title>Passenger: DirectoryMapper.h Source File</title>
|
4
|
+
<link href="doxygen.css" rel="stylesheet" type="text/css">
|
5
|
+
<link href="tabs.css" rel="stylesheet" type="text/css">
|
6
|
+
</head><body>
|
7
|
+
<!-- Generated by Doxygen 1.5.5 -->
|
8
|
+
<div class="navigation" id="top">
|
9
|
+
<div class="tabs">
|
10
|
+
<ul>
|
11
|
+
<li><a href="main.html"><span>Main Page</span></a></li>
|
12
|
+
<li><a href="modules.html"><span>Modules</span></a></li>
|
13
|
+
<li><a href="annotated.html"><span>Classes</span></a></li>
|
14
|
+
<li class="current"><a href="files.html"><span>Files</span></a></li>
|
15
|
+
</ul>
|
16
|
+
</div>
|
17
|
+
<h1>DirectoryMapper.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span>
|
18
|
+
<a name="l00002"></a>00002 <span class="comment"> * Phusion Passenger - http://www.modrails.com/</span>
|
19
|
+
<a name="l00003"></a>00003 <span class="comment"> * Copyright (C) 2008 Phusion</span>
|
20
|
+
<a name="l00004"></a>00004 <span class="comment"> *</span>
|
21
|
+
<a name="l00005"></a>00005 <span class="comment"> * Phusion Passenger is a trademark of Hongli Lai & Ninh Bui.</span>
|
22
|
+
<a name="l00006"></a>00006 <span class="comment"> *</span>
|
23
|
+
<a name="l00007"></a>00007 <span class="comment"> * This program is free software; you can redistribute it and/or modify</span>
|
24
|
+
<a name="l00008"></a>00008 <span class="comment"> * it under the terms of the GNU General Public License as published by</span>
|
25
|
+
<a name="l00009"></a>00009 <span class="comment"> * the Free Software Foundation; version 2 of the License.</span>
|
26
|
+
<a name="l00010"></a>00010 <span class="comment"> *</span>
|
27
|
+
<a name="l00011"></a>00011 <span class="comment"> * This program is distributed in the hope that it will be useful,</span>
|
28
|
+
<a name="l00012"></a>00012 <span class="comment"> * but WITHOUT ANY WARRANTY; without even the implied warranty of</span>
|
29
|
+
<a name="l00013"></a>00013 <span class="comment"> * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the</span>
|
30
|
+
<a name="l00014"></a>00014 <span class="comment"> * GNU General Public License for more details.</span>
|
31
|
+
<a name="l00015"></a>00015 <span class="comment"> *</span>
|
32
|
+
<a name="l00016"></a>00016 <span class="comment"> * You should have received a copy of the GNU General Public License along</span>
|
33
|
+
<a name="l00017"></a>00017 <span class="comment"> * with this program; if not, write to the Free Software Foundation, Inc.,</span>
|
34
|
+
<a name="l00018"></a>00018 <span class="comment"> * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.</span>
|
35
|
+
<a name="l00019"></a>00019 <span class="comment"> */</span>
|
36
|
+
<a name="l00020"></a>00020 <span class="preprocessor">#ifndef _PASSENGER_DIRECTORY_MAPPER_H_</span>
|
37
|
+
<a name="l00021"></a>00021 <span class="preprocessor"></span><span class="preprocessor">#define _PASSENGER_DIRECTORY_MAPPER_H_</span>
|
38
|
+
<a name="l00022"></a>00022 <span class="preprocessor"></span>
|
39
|
+
<a name="l00023"></a>00023 <span class="preprocessor">#include <string></span>
|
40
|
+
<a name="l00024"></a>00024 <span class="preprocessor">#include <set></span>
|
41
|
+
<a name="l00025"></a>00025 <span class="preprocessor">#include <cstring></span>
|
42
|
+
<a name="l00026"></a>00026
|
43
|
+
<a name="l00027"></a>00027 <span class="preprocessor">#include <oxt/backtrace.hpp></span>
|
44
|
+
<a name="l00028"></a>00028
|
45
|
+
<a name="l00029"></a>00029 <span class="preprocessor">#include "CachedFileStat.h"</span>
|
46
|
+
<a name="l00030"></a>00030 <span class="preprocessor">#include "Configuration.h"</span>
|
47
|
+
<a name="l00031"></a>00031 <span class="preprocessor">#include "Utils.h"</span>
|
48
|
+
<a name="l00032"></a>00032
|
49
|
+
<a name="l00033"></a>00033 <span class="comment">// The Apache/APR headers *must* come after the Boost headers, otherwise</span>
|
50
|
+
<a name="l00034"></a>00034 <span class="comment">// compilation will fail on OpenBSD.</span>
|
51
|
+
<a name="l00035"></a>00035 <span class="preprocessor">#include <httpd.h></span>
|
52
|
+
<a name="l00036"></a>00036 <span class="preprocessor">#include <http_core.h></span>
|
53
|
+
<a name="l00037"></a>00037
|
54
|
+
<a name="l00038"></a>00038 <span class="keyword">namespace </span>Passenger {
|
55
|
+
<a name="l00039"></a>00039
|
56
|
+
<a name="l00040"></a>00040 <span class="keyword">using namespace </span>std;
|
57
|
+
<a name="l00041"></a>00041 <span class="keyword">using namespace </span>oxt;
|
58
|
+
<a name="l00042"></a>00042 <span class="comment"></span>
|
59
|
+
<a name="l00043"></a>00043 <span class="comment">/**</span>
|
60
|
+
<a name="l00044"></a>00044 <span class="comment"> * Utility class for determining URI-to-application directory mappings.</span>
|
61
|
+
<a name="l00045"></a>00045 <span class="comment"> * Given a URI, it will determine whether that URI belongs to a Phusion</span>
|
62
|
+
<a name="l00046"></a>00046 <span class="comment"> * Passenger-handled application, what the base URI of that application is,</span>
|
63
|
+
<a name="l00047"></a>00047 <span class="comment"> * and what the associated 'public' directory is.</span>
|
64
|
+
<a name="l00048"></a>00048 <span class="comment"> *</span>
|
65
|
+
<a name="l00049"></a>00049 <span class="comment"> * @note This class is not thread-safe, but is reentrant.</span>
|
66
|
+
<a name="l00050"></a>00050 <span class="comment"> * @ingroup Core</span>
|
67
|
+
<a name="l00051"></a>00051 <span class="comment"> */</span>
|
68
|
+
<a name="l00052"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html">00052</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1DirectoryMapper.html" title="Utility class for determining URI-to-application directory mappings.">DirectoryMapper</a> {
|
69
|
+
<a name="l00053"></a>00053 <span class="keyword">public</span>:
|
70
|
+
<a name="l00054"></a>00054 <span class="keyword">enum</span> ApplicationType {
|
71
|
+
<a name="l00055"></a>00055 NONE,
|
72
|
+
<a name="l00056"></a>00056 RAILS,
|
73
|
+
<a name="l00057"></a>00057 RACK,
|
74
|
+
<a name="l00058"></a>00058 WSGI
|
75
|
+
<a name="l00059"></a>00059 };
|
76
|
+
<a name="l00060"></a>00060
|
77
|
+
<a name="l00061"></a>00061 <span class="keyword">private</span>:
|
78
|
+
<a name="l00062"></a>00062 DirConfig *config;
|
79
|
+
<a name="l00063"></a>00063 request_rec *r;
|
80
|
+
<a name="l00064"></a>00064 CachedMultiFileStat *mstat;
|
81
|
+
<a name="l00065"></a>00065 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> throttleRate;
|
82
|
+
<a name="l00066"></a>00066 <span class="keywordtype">bool</span> baseURIKnown;
|
83
|
+
<a name="l00067"></a>00067 <span class="keyword">const</span> <span class="keywordtype">char</span> *baseURI;
|
84
|
+
<a name="l00068"></a>00068 ApplicationType appType;
|
85
|
+
<a name="l00069"></a>00069
|
86
|
+
<a name="l00070"></a>00070 <span class="keyword">inline</span> <span class="keywordtype">bool</span> shouldAutoDetectRails() {
|
87
|
+
<a name="l00071"></a>00071 <span class="keywordflow">return</span> config->autoDetectRails == DirConfig::ENABLED ||
|
88
|
+
<a name="l00072"></a>00072 config->autoDetectRails == DirConfig::UNSET;
|
89
|
+
<a name="l00073"></a>00073 }
|
90
|
+
<a name="l00074"></a>00074
|
91
|
+
<a name="l00075"></a>00075 <span class="keyword">inline</span> <span class="keywordtype">bool</span> shouldAutoDetectRack() {
|
92
|
+
<a name="l00076"></a>00076 <span class="keywordflow">return</span> config->autoDetectRack == DirConfig::ENABLED ||
|
93
|
+
<a name="l00077"></a>00077 config->autoDetectRack == DirConfig::UNSET;
|
94
|
+
<a name="l00078"></a>00078 }
|
95
|
+
<a name="l00079"></a>00079
|
96
|
+
<a name="l00080"></a>00080 <span class="keyword">inline</span> <span class="keywordtype">bool</span> shouldAutoDetectWSGI() {
|
97
|
+
<a name="l00081"></a>00081 <span class="keywordflow">return</span> config->autoDetectWSGI == DirConfig::ENABLED ||
|
98
|
+
<a name="l00082"></a>00082 config->autoDetectWSGI == DirConfig::UNSET;
|
99
|
+
<a name="l00083"></a>00083 }
|
100
|
+
<a name="l00084"></a>00084
|
101
|
+
<a name="l00085"></a>00085 <span class="keyword">public</span>:<span class="comment"></span>
|
102
|
+
<a name="l00086"></a>00086 <span class="comment"> /**</span>
|
103
|
+
<a name="l00087"></a>00087 <span class="comment"> * Create a new DirectoryMapper object.</span>
|
104
|
+
<a name="l00088"></a>00088 <span class="comment"> *</span>
|
105
|
+
<a name="l00089"></a>00089 <span class="comment"> * @param mstat A CachedMultiFileStat object used for statting files.</span>
|
106
|
+
<a name="l00090"></a>00090 <span class="comment"> * @param throttleRate A throttling rate for mstat.</span>
|
107
|
+
<a name="l00091"></a>00091 <span class="comment"> * @warning Do not use this object after the destruction of <tt>r</tt>,</span>
|
108
|
+
<a name="l00092"></a>00092 <span class="comment"> * <tt>config</tt> or <tt>mstat</tt>.</span>
|
109
|
+
<a name="l00093"></a>00093 <span class="comment"> */</span>
|
110
|
+
<a name="l00094"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#e2725c3280a5e5d63dbc099fe3c3d82a">00094</a> <a class="code" href="classPassenger_1_1DirectoryMapper.html#e2725c3280a5e5d63dbc099fe3c3d82a" title="Create a new DirectoryMapper object.">DirectoryMapper</a>(request_rec *r, DirConfig *config,
|
111
|
+
<a name="l00095"></a>00095 CachedMultiFileStat *mstat, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> throttleRate) {
|
112
|
+
<a name="l00096"></a>00096 this->r = r;
|
113
|
+
<a name="l00097"></a>00097 this->config = config;
|
114
|
+
<a name="l00098"></a>00098 this->mstat = mstat;
|
115
|
+
<a name="l00099"></a>00099 this->throttleRate = throttleRate;
|
116
|
+
<a name="l00100"></a>00100 appType = NONE;
|
117
|
+
<a name="l00101"></a>00101 baseURIKnown = <span class="keyword">false</span>;
|
118
|
+
<a name="l00102"></a>00102 baseURI = NULL;
|
119
|
+
<a name="l00103"></a>00103 }
|
120
|
+
<a name="l00104"></a>00104 <span class="comment"></span>
|
121
|
+
<a name="l00105"></a>00105 <span class="comment"> /**</span>
|
122
|
+
<a name="l00106"></a>00106 <span class="comment"> * Determine whether the given HTTP request falls under one of the specified</span>
|
123
|
+
<a name="l00107"></a>00107 <span class="comment"> * RailsBaseURIs or RackBaseURIs. If yes, then the first matching base URI will</span>
|
124
|
+
<a name="l00108"></a>00108 <span class="comment"> * be returned.</span>
|
125
|
+
<a name="l00109"></a>00109 <span class="comment"> *</span>
|
126
|
+
<a name="l00110"></a>00110 <span class="comment"> * If Rails/Rack autodetection was enabled in the configuration, and the document</span>
|
127
|
+
<a name="l00111"></a>00111 <span class="comment"> * root seems to be a valid Rails/Rack 'public' folder, then this method will</span>
|
128
|
+
<a name="l00112"></a>00112 <span class="comment"> * return "/".</span>
|
129
|
+
<a name="l00113"></a>00113 <span class="comment"> *</span>
|
130
|
+
<a name="l00114"></a>00114 <span class="comment"> * Otherwise, NULL will be returned.</span>
|
131
|
+
<a name="l00115"></a>00115 <span class="comment"> *</span>
|
132
|
+
<a name="l00116"></a>00116 <span class="comment"> * @throws FileSystemException This method might also examine the filesystem in</span>
|
133
|
+
<a name="l00117"></a>00117 <span class="comment"> * order to detect the application's type. During that process, a</span>
|
134
|
+
<a name="l00118"></a>00118 <span class="comment"> * FileSystemException might be thrown.</span>
|
135
|
+
<a name="l00119"></a>00119 <span class="comment"> * @warning The return value may only be used as long as <tt>config</tt></span>
|
136
|
+
<a name="l00120"></a>00120 <span class="comment"> * hasn't been destroyed.</span>
|
137
|
+
<a name="l00121"></a>00121 <span class="comment"> */</span>
|
138
|
+
<a name="l00122"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821">00122</a> <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821" title="Determine whether the given HTTP request falls under one of the specified RailsBaseURIs...">getBaseURI</a>() {
|
139
|
+
<a name="l00123"></a>00123 TRACE_POINT();
|
140
|
+
<a name="l00124"></a>00124 <span class="keywordflow">if</span> (baseURIKnown) {
|
141
|
+
<a name="l00125"></a>00125 <span class="keywordflow">return</span> baseURI;
|
142
|
+
<a name="l00126"></a>00126 }
|
143
|
+
<a name="l00127"></a>00127
|
144
|
+
<a name="l00128"></a>00128 set<string>::const_iterator it;
|
145
|
+
<a name="l00129"></a>00129 <span class="keyword">const</span> <span class="keywordtype">char</span> *uri = r->uri;
|
146
|
+
<a name="l00130"></a>00130 <span class="keywordtype">size_t</span> uri_len = strlen(uri);
|
147
|
+
<a name="l00131"></a>00131
|
148
|
+
<a name="l00132"></a>00132 <span class="keywordflow">if</span> (uri_len == 0 || uri[0] != <span class="charliteral">'/'</span>) {
|
149
|
+
<a name="l00133"></a>00133 baseURIKnown = <span class="keyword">true</span>;
|
150
|
+
<a name="l00134"></a>00134 <span class="keywordflow">return</span> NULL;
|
151
|
+
<a name="l00135"></a>00135 }
|
152
|
+
<a name="l00136"></a>00136
|
153
|
+
<a name="l00137"></a>00137 UPDATE_TRACE_POINT();
|
154
|
+
<a name="l00138"></a>00138 <span class="keywordflow">for</span> (it = config->railsBaseURIs.begin(); it != config->railsBaseURIs.end(); it++) {
|
155
|
+
<a name="l00139"></a>00139 <span class="keyword">const</span> <span class="keywordtype">string</span> &base(*it);
|
156
|
+
<a name="l00140"></a>00140 <span class="keywordflow">if</span> ( base == <span class="stringliteral">"/"</span>
|
157
|
+
<a name="l00141"></a>00141 || ( uri_len == base.size() && memcmp(uri, base.c_str(), uri_len) == 0 )
|
158
|
+
<a name="l00142"></a>00142 || ( uri_len > base.size() && memcmp(uri, base.c_str(), base.size()) == 0
|
159
|
+
<a name="l00143"></a>00143 && uri[base.size()] == <span class="charliteral">'/'</span> )
|
160
|
+
<a name="l00144"></a>00144 ) {
|
161
|
+
<a name="l00145"></a>00145 baseURIKnown = <span class="keyword">true</span>;
|
162
|
+
<a name="l00146"></a>00146 baseURI = base.c_str();
|
163
|
+
<a name="l00147"></a>00147 appType = RAILS;
|
164
|
+
<a name="l00148"></a>00148 <span class="keywordflow">return</span> baseURI;
|
165
|
+
<a name="l00149"></a>00149 }
|
166
|
+
<a name="l00150"></a>00150 }
|
167
|
+
<a name="l00151"></a>00151
|
168
|
+
<a name="l00152"></a>00152 UPDATE_TRACE_POINT();
|
169
|
+
<a name="l00153"></a>00153 <span class="keywordflow">for</span> (it = config->rackBaseURIs.begin(); it != config->rackBaseURIs.end(); it++) {
|
170
|
+
<a name="l00154"></a>00154 <span class="keyword">const</span> <span class="keywordtype">string</span> &base(*it);
|
171
|
+
<a name="l00155"></a>00155 <span class="keywordflow">if</span> ( base == <span class="stringliteral">"/"</span>
|
172
|
+
<a name="l00156"></a>00156 || ( uri_len == base.size() && memcmp(uri, base.c_str(), uri_len) == 0 )
|
173
|
+
<a name="l00157"></a>00157 || ( uri_len > base.size() && memcmp(uri, base.c_str(), base.size()) == 0
|
174
|
+
<a name="l00158"></a>00158 && uri[base.size()] == <span class="charliteral">'/'</span> )
|
175
|
+
<a name="l00159"></a>00159 ) {
|
176
|
+
<a name="l00160"></a>00160 baseURIKnown = <span class="keyword">true</span>;
|
177
|
+
<a name="l00161"></a>00161 baseURI = base.c_str();
|
178
|
+
<a name="l00162"></a>00162 appType = RACK;
|
179
|
+
<a name="l00163"></a>00163 <span class="keywordflow">return</span> baseURI;
|
180
|
+
<a name="l00164"></a>00164 }
|
181
|
+
<a name="l00165"></a>00165 }
|
182
|
+
<a name="l00166"></a>00166
|
183
|
+
<a name="l00167"></a>00167 UPDATE_TRACE_POINT();
|
184
|
+
<a name="l00168"></a>00168 <span class="keywordflow">if</span> (shouldAutoDetectRails()
|
185
|
+
<a name="l00169"></a>00169 && <a class="code" href="group__Support.html#g02c80bd02d38cea295f24250ca8e2502" title="Check whether the specified directory is a valid Ruby on Rails application root directory...">verifyRailsDir</a>(config->getAppRoot(ap_document_root(r)), mstat, throttleRate)) {
|
186
|
+
<a name="l00170"></a>00170 baseURIKnown = <span class="keyword">true</span>;
|
187
|
+
<a name="l00171"></a>00171 baseURI = <span class="stringliteral">"/"</span>;
|
188
|
+
<a name="l00172"></a>00172 appType = RAILS;
|
189
|
+
<a name="l00173"></a>00173 <span class="keywordflow">return</span> baseURI;
|
190
|
+
<a name="l00174"></a>00174 }
|
191
|
+
<a name="l00175"></a>00175
|
192
|
+
<a name="l00176"></a>00176 UPDATE_TRACE_POINT();
|
193
|
+
<a name="l00177"></a>00177 <span class="keywordflow">if</span> (shouldAutoDetectRack()
|
194
|
+
<a name="l00178"></a>00178 && <a class="code" href="group__Support.html#g7bb22ba786fa3c88dbbd9f84aaaed59a" title="Check whether the specified directory is a valid Rack application root directory...">verifyRackDir</a>(config->getAppRoot(ap_document_root(r)), mstat, throttleRate)) {
|
195
|
+
<a name="l00179"></a>00179 baseURIKnown = <span class="keyword">true</span>;
|
196
|
+
<a name="l00180"></a>00180 baseURI = <span class="stringliteral">"/"</span>;
|
197
|
+
<a name="l00181"></a>00181 appType = RACK;
|
198
|
+
<a name="l00182"></a>00182 <span class="keywordflow">return</span> baseURI;
|
199
|
+
<a name="l00183"></a>00183 }
|
200
|
+
<a name="l00184"></a>00184
|
201
|
+
<a name="l00185"></a>00185 UPDATE_TRACE_POINT();
|
202
|
+
<a name="l00186"></a>00186 <span class="keywordflow">if</span> (shouldAutoDetectWSGI()
|
203
|
+
<a name="l00187"></a>00187 && <a class="code" href="group__Support.html#g8bfea2692733dfd80703707a120bce86" title="Check whether the specified directory is a valid WSGI application root directory...">verifyWSGIDir</a>(config->getAppRoot(ap_document_root(r)), mstat, throttleRate)) {
|
204
|
+
<a name="l00188"></a>00188 baseURIKnown = <span class="keyword">true</span>;
|
205
|
+
<a name="l00189"></a>00189 baseURI = <span class="stringliteral">"/"</span>;
|
206
|
+
<a name="l00190"></a>00190 appType = WSGI;
|
207
|
+
<a name="l00191"></a>00191 <span class="keywordflow">return</span> baseURI;
|
208
|
+
<a name="l00192"></a>00192 }
|
209
|
+
<a name="l00193"></a>00193
|
210
|
+
<a name="l00194"></a>00194 baseURIKnown = <span class="keyword">true</span>;
|
211
|
+
<a name="l00195"></a>00195 <span class="keywordflow">return</span> NULL;
|
212
|
+
<a name="l00196"></a>00196 }
|
213
|
+
<a name="l00197"></a>00197 <span class="comment"></span>
|
214
|
+
<a name="l00198"></a>00198 <span class="comment"> /**</span>
|
215
|
+
<a name="l00199"></a>00199 <span class="comment"> * Returns the filename of the 'public' directory of the Rails/Rack application</span>
|
216
|
+
<a name="l00200"></a>00200 <span class="comment"> * that's associated with the HTTP request.</span>
|
217
|
+
<a name="l00201"></a>00201 <span class="comment"> *</span>
|
218
|
+
<a name="l00202"></a>00202 <span class="comment"> * Returns an empty string if the document root of the HTTP request</span>
|
219
|
+
<a name="l00203"></a>00203 <span class="comment"> * cannot be determined, or if it isn't a valid folder.</span>
|
220
|
+
<a name="l00204"></a>00204 <span class="comment"> *</span>
|
221
|
+
<a name="l00205"></a>00205 <span class="comment"> * @throws FileSystemException An error occured while examening the filesystem.</span>
|
222
|
+
<a name="l00206"></a>00206 <span class="comment"> */</span>
|
223
|
+
<a name="l00207"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#ef969f27622fb215990a870076648aa1">00207</a> <span class="keywordtype">string</span> <a class="code" href="classPassenger_1_1DirectoryMapper.html#ef969f27622fb215990a870076648aa1" title="Returns the filename of the &#39;public&#39; directory of the Rails/Rack application...">getPublicDirectory</a>() {
|
224
|
+
<a name="l00208"></a>00208 <span class="keywordflow">if</span> (!baseURIKnown) {
|
225
|
+
<a name="l00209"></a>00209 <a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821" title="Determine whether the given HTTP request falls under one of the specified RailsBaseURIs...">getBaseURI</a>();
|
226
|
+
<a name="l00210"></a>00210 }
|
227
|
+
<a name="l00211"></a>00211 <span class="keywordflow">if</span> (baseURI == NULL) {
|
228
|
+
<a name="l00212"></a>00212 <span class="keywordflow">return</span> <span class="stringliteral">""</span>;
|
229
|
+
<a name="l00213"></a>00213 }
|
230
|
+
<a name="l00214"></a>00214
|
231
|
+
<a name="l00215"></a>00215 <span class="keyword">const</span> <span class="keywordtype">char</span> *docRoot = ap_document_root(r);
|
232
|
+
<a name="l00216"></a>00216 <span class="keywordtype">size_t</span> len = strlen(docRoot);
|
233
|
+
<a name="l00217"></a>00217 <span class="keywordflow">if</span> (len > 0) {
|
234
|
+
<a name="l00218"></a>00218 <span class="keywordtype">string</span> path;
|
235
|
+
<a name="l00219"></a>00219 <span class="keywordflow">if</span> (docRoot[len - 1] == <span class="charliteral">'/'</span>) {
|
236
|
+
<a name="l00220"></a>00220 path.assign(docRoot, len - 1);
|
237
|
+
<a name="l00221"></a>00221 } <span class="keywordflow">else</span> {
|
238
|
+
<a name="l00222"></a>00222 path.assign(docRoot, len);
|
239
|
+
<a name="l00223"></a>00223 }
|
240
|
+
<a name="l00224"></a>00224 <span class="keywordflow">if</span> (strcmp(baseURI, <span class="stringliteral">"/"</span>) != 0) {
|
241
|
+
<a name="l00225"></a>00225 path.append(baseURI);
|
242
|
+
<a name="l00226"></a>00226 }
|
243
|
+
<a name="l00227"></a>00227 <span class="keywordflow">return</span> path;
|
244
|
+
<a name="l00228"></a>00228 } <span class="keywordflow">else</span> {
|
245
|
+
<a name="l00229"></a>00229 <span class="keywordflow">return</span> <span class="stringliteral">""</span>;
|
246
|
+
<a name="l00230"></a>00230 }
|
247
|
+
<a name="l00231"></a>00231 }
|
248
|
+
<a name="l00232"></a>00232 <span class="comment"></span>
|
249
|
+
<a name="l00233"></a>00233 <span class="comment"> /**</span>
|
250
|
+
<a name="l00234"></a>00234 <span class="comment"> * Returns the application type that's associated with the HTTP request.</span>
|
251
|
+
<a name="l00235"></a>00235 <span class="comment"> *</span>
|
252
|
+
<a name="l00236"></a>00236 <span class="comment"> * @throws FileSystemException An error occured while examening the filesystem.</span>
|
253
|
+
<a name="l00237"></a>00237 <span class="comment"> */</span>
|
254
|
+
<a name="l00238"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#ba438d86ca263972a47540956bf11ec1">00238</a> ApplicationType <a class="code" href="classPassenger_1_1DirectoryMapper.html#ba438d86ca263972a47540956bf11ec1" title="Returns the application type that&#39;s associated with the HTTP request.">getApplicationType</a>() {
|
255
|
+
<a name="l00239"></a>00239 <span class="keywordflow">if</span> (!baseURIKnown) {
|
256
|
+
<a name="l00240"></a>00240 <a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821" title="Determine whether the given HTTP request falls under one of the specified RailsBaseURIs...">getBaseURI</a>();
|
257
|
+
<a name="l00241"></a>00241 }
|
258
|
+
<a name="l00242"></a>00242 <span class="keywordflow">return</span> appType;
|
259
|
+
<a name="l00243"></a>00243 }
|
260
|
+
<a name="l00244"></a>00244 <span class="comment"></span>
|
261
|
+
<a name="l00245"></a>00245 <span class="comment"> /**</span>
|
262
|
+
<a name="l00246"></a>00246 <span class="comment"> * Returns the application type (as a string) that's associated</span>
|
263
|
+
<a name="l00247"></a>00247 <span class="comment"> * with the HTTP request.</span>
|
264
|
+
<a name="l00248"></a>00248 <span class="comment"> *</span>
|
265
|
+
<a name="l00249"></a>00249 <span class="comment"> * @throws FileSystemException An error occured while examening the filesystem.</span>
|
266
|
+
<a name="l00250"></a>00250 <span class="comment"> */</span>
|
267
|
+
<a name="l00251"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#c46f0e74ffd05b7fe9924dd99a057cf7">00251</a> <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="classPassenger_1_1DirectoryMapper.html#c46f0e74ffd05b7fe9924dd99a057cf7" title="Returns the application type (as a string) that&#39;s associated with the HTTP request...">getApplicationTypeString</a>() {
|
268
|
+
<a name="l00252"></a>00252 <span class="keywordflow">if</span> (!baseURIKnown) {
|
269
|
+
<a name="l00253"></a>00253 <a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821" title="Determine whether the given HTTP request falls under one of the specified RailsBaseURIs...">getBaseURI</a>();
|
270
|
+
<a name="l00254"></a>00254 }
|
271
|
+
<a name="l00255"></a>00255 <span class="keywordflow">switch</span> (appType) {
|
272
|
+
<a name="l00256"></a>00256 <span class="keywordflow">case</span> RAILS:
|
273
|
+
<a name="l00257"></a>00257 <span class="keywordflow">return</span> <span class="stringliteral">"rails"</span>;
|
274
|
+
<a name="l00258"></a>00258 <span class="keywordflow">case</span> RACK:
|
275
|
+
<a name="l00259"></a>00259 <span class="keywordflow">return</span> <span class="stringliteral">"rack"</span>;
|
276
|
+
<a name="l00260"></a>00260 <span class="keywordflow">case</span> WSGI:
|
277
|
+
<a name="l00261"></a>00261 <span class="keywordflow">return</span> <span class="stringliteral">"wsgi"</span>;
|
278
|
+
<a name="l00262"></a>00262 <span class="keywordflow">default</span>:
|
279
|
+
<a name="l00263"></a>00263 <span class="keywordflow">return</span> NULL;
|
280
|
+
<a name="l00264"></a>00264 };
|
281
|
+
<a name="l00265"></a>00265 }
|
282
|
+
<a name="l00266"></a>00266 <span class="comment"></span>
|
283
|
+
<a name="l00267"></a>00267 <span class="comment"> /**</span>
|
284
|
+
<a name="l00268"></a>00268 <span class="comment"> * Returns the environment under which the application should be spawned.</span>
|
285
|
+
<a name="l00269"></a>00269 <span class="comment"> *</span>
|
286
|
+
<a name="l00270"></a>00270 <span class="comment"> * @throws FileSystemException An error occured while examening the filesystem.</span>
|
287
|
+
<a name="l00271"></a>00271 <span class="comment"> */</span>
|
288
|
+
<a name="l00272"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#f5091e3cef3878e160e5d3b2181d82fb">00272</a> <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="classPassenger_1_1DirectoryMapper.html#f5091e3cef3878e160e5d3b2181d82fb" title="Returns the environment under which the application should be spawned.">getEnvironment</a>() {
|
289
|
+
<a name="l00273"></a>00273 <span class="keywordflow">switch</span> (<a class="code" href="classPassenger_1_1DirectoryMapper.html#ba438d86ca263972a47540956bf11ec1" title="Returns the application type that&#39;s associated with the HTTP request.">getApplicationType</a>()) {
|
290
|
+
<a name="l00274"></a>00274 <span class="keywordflow">case</span> RAILS:
|
291
|
+
<a name="l00275"></a>00275 <span class="keywordflow">return</span> config->getRailsEnv();
|
292
|
+
<a name="l00276"></a>00276 <span class="keywordflow">case</span> RACK:
|
293
|
+
<a name="l00277"></a>00277 <span class="keywordflow">return</span> config->getRackEnv();
|
294
|
+
<a name="l00278"></a>00278 <span class="keywordflow">default</span>:
|
295
|
+
<a name="l00279"></a>00279 <span class="keywordflow">return</span> <span class="stringliteral">"production"</span>;
|
296
|
+
<a name="l00280"></a>00280 }
|
297
|
+
<a name="l00281"></a>00281 }
|
298
|
+
<a name="l00282"></a>00282 };
|
299
|
+
<a name="l00283"></a>00283
|
300
|
+
<a name="l00284"></a>00284 } <span class="comment">// namespace Passenger</span>
|
301
|
+
<a name="l00285"></a>00285
|
302
|
+
<a name="l00286"></a>00286 <span class="preprocessor">#endif </span><span class="comment">/* _PASSENGER_DIRECTORY_MAPPER_H_ */</span>
|
303
|
+
<a name="l00287"></a>00287
|
304
|
+
</pre></div></div>
|
305
|
+
<hr size="1"><address style="text-align: right;"><small>Generated on Fri Mar 13 19:24:32 2009 for Passenger by
|
306
|
+
<a href="http://www.doxygen.org/index.html">
|
307
|
+
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.5 </small></address>
|
308
|
+
</body>
|
309
|
+
</html>
|
@@ -10,7 +10,6 @@
|
|
10
10
|
<ul>
|
11
11
|
<li><a href="main.html"><span>Main Page</span></a></li>
|
12
12
|
<li><a href="modules.html"><span>Modules</span></a></li>
|
13
|
-
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
|
14
13
|
<li><a href="annotated.html"><span>Classes</span></a></li>
|
15
14
|
<li class="current"><a href="files.html"><span>Files</span></a></li>
|
16
15
|
</ul>
|
@@ -73,7 +72,7 @@
|
|
73
72
|
<a name="l00056"></a>00056 <span class="comment"> */</span>
|
74
73
|
<a name="l00057"></a><a class="code" href="classPassenger_1_1DummySpawnManager.html">00057</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1DummySpawnManager.html" title="A dummy SpawnManager replacement for testing/debugging purposes.">DummySpawnManager</a> {
|
75
74
|
<a name="l00058"></a>00058 <span class="keyword">public</span>:
|
76
|
-
<a name="l00059"></a>00059
|
75
|
+
<a name="l00059"></a>00059 ApplicationPtr spawn(<span class="keyword">const</span> <span class="keywordtype">string</span> &appRoot, <span class="keyword">const</span> <span class="keywordtype">string</span> &user = <span class="stringliteral">""</span>, <span class="keyword">const</span> <span class="keywordtype">string</span> &group = <span class="stringliteral">""</span>) {
|
77
76
|
<a name="l00060"></a>00060 <span class="keywordtype">int</span> fds[2];
|
78
77
|
<a name="l00061"></a>00061 pid_t pid;
|
79
78
|
<a name="l00062"></a>00062
|
@@ -106,7 +105,7 @@
|
|
106
105
|
<a name="l00089"></a>00089 } <span class="keywordflow">else</span> {
|
107
106
|
<a name="l00090"></a>00090 close(fds[0]);
|
108
107
|
<a name="l00091"></a>00091 waitpid(pid, NULL, 0);
|
109
|
-
<a name="l00092"></a>00092 <span class="keywordflow">return</span>
|
108
|
+
<a name="l00092"></a>00092 <span class="keywordflow">return</span> ApplicationPtr(<span class="keyword">new</span> <a class="code" href="classPassenger_1_1Application.html" title="Represents a single Ruby on Rails or Rack application instance.">Application</a>(appRoot, pid, fds[1]));
|
110
109
|
<a name="l00093"></a>00093 }
|
111
110
|
<a name="l00094"></a>00094 }
|
112
111
|
<a name="l00095"></a>00095
|
@@ -119,7 +118,7 @@
|
|
119
118
|
<a name="l00102"></a>00102
|
120
119
|
<a name="l00103"></a>00103 <span class="preprocessor">#endif </span><span class="comment">/* _PASSENGER_DUMMY_SPAWN_MANAGER_H_ */</span>
|
121
120
|
</pre></div></div>
|
122
|
-
<hr size="1"><address style="text-align: right;"><small>Generated on
|
121
|
+
<hr size="1"><address style="text-align: right;"><small>Generated on Fri Mar 13 19:24:32 2009 for Passenger by
|
123
122
|
<a href="http://www.doxygen.org/index.html">
|
124
123
|
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.5 </small></address>
|
125
124
|
</body>
|
@@ -10,7 +10,6 @@
|
|
10
10
|
<ul>
|
11
11
|
<li><a href="main.html"><span>Main Page</span></a></li>
|
12
12
|
<li><a href="modules.html"><span>Modules</span></a></li>
|
13
|
-
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
|
14
13
|
<li><a href="annotated.html"><span>Classes</span></a></li>
|
15
14
|
<li class="current"><a href="files.html"><span>Files</span></a></li>
|
16
15
|
</ul>
|
@@ -37,7 +36,7 @@
|
|
37
36
|
<a name="l00020"></a>00020 <span class="preprocessor">#ifndef _PASSENGER_EXCEPTIONS_H_</span>
|
38
37
|
<a name="l00021"></a>00021 <span class="preprocessor"></span><span class="preprocessor">#define _PASSENGER_EXCEPTIONS_H_</span>
|
39
38
|
<a name="l00022"></a>00022 <span class="preprocessor"></span>
|
40
|
-
<a name="l00023"></a>00023 <span class="preprocessor">#include <
|
39
|
+
<a name="l00023"></a>00023 <span class="preprocessor">#include <oxt/tracable_exception.hpp></span>
|
41
40
|
<a name="l00024"></a>00024 <span class="preprocessor">#include <string></span>
|
42
41
|
<a name="l00025"></a>00025 <span class="preprocessor">#include <sstream></span>
|
43
42
|
<a name="l00026"></a>00026 <span class="preprocessor">#include <cstring></span>
|
@@ -58,7 +57,7 @@
|
|
58
57
|
<a name="l00041"></a>00041 <span class="comment"> *</span>
|
59
58
|
<a name="l00042"></a>00042 <span class="comment"> * @ingroup Exceptions</span>
|
60
59
|
<a name="l00043"></a>00043 <span class="comment"> */</span>
|
61
|
-
<a name="l00044"></a><a class="code" href="classPassenger_1_1SystemException.html">00044</a> <span class="keyword">class </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="keyword">public</span>
|
60
|
+
<a name="l00044"></a><a class="code" href="classPassenger_1_1SystemException.html">00044</a> <span class="keyword">class </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="keyword">public</span> oxt::tracable_exception {
|
62
61
|
<a name="l00045"></a>00045 <span class="keyword">private</span>:
|
63
62
|
<a name="l00046"></a>00046 <span class="keywordtype">string</span> briefMessage;
|
64
63
|
<a name="l00047"></a>00047 <span class="keywordtype">string</span> systemMessage;
|
@@ -68,177 +67,195 @@
|
|
68
67
|
<a name="l00051"></a>00051 <span class="comment"> /**</span>
|
69
68
|
<a name="l00052"></a>00052 <span class="comment"> * Create a new SystemException.</span>
|
70
69
|
<a name="l00053"></a>00053 <span class="comment"> *</span>
|
71
|
-
<a name="l00054"></a>00054 <span class="comment"> * @param
|
70
|
+
<a name="l00054"></a>00054 <span class="comment"> * @param briefMessage A brief message describing the error.</span>
|
72
71
|
<a name="l00055"></a>00055 <span class="comment"> * @param errorCode The error code, i.e. the value of errno right after the error occured.</span>
|
73
72
|
<a name="l00056"></a>00056 <span class="comment"> * @note A system description of the error will be appended to the given message.</span>
|
74
|
-
<a name="l00057"></a>00057 <span class="comment"> * For example, if <tt>errorCode</tt> is <tt>EBADF</tt>, and <tt>
|
73
|
+
<a name="l00057"></a>00057 <span class="comment"> * For example, if <tt>errorCode</tt> is <tt>EBADF</tt>, and <tt>briefMessage</tt></span>
|
75
74
|
<a name="l00058"></a>00058 <span class="comment"> * is <em>"Something happened"</em>, then what() will return <em>"Something happened: Bad</span>
|
76
75
|
<a name="l00059"></a>00059 <span class="comment"> * file descriptor (10)"</em> (if 10 is the number for EBADF).</span>
|
77
76
|
<a name="l00060"></a>00060 <span class="comment"> * @post code() == errorCode</span>
|
78
|
-
<a name="l00061"></a>00061 <span class="comment"> * @post brief() ==
|
77
|
+
<a name="l00061"></a>00061 <span class="comment"> * @post brief() == briefMessage</span>
|
79
78
|
<a name="l00062"></a>00062 <span class="comment"> */</span>
|
80
|
-
<a name="l00063"></a><a class="code" href="classPassenger_1_1SystemException.html#
|
79
|
+
<a name="l00063"></a><a class="code" href="classPassenger_1_1SystemException.html#1f0f33c63934ee40c5cd9c338c8aa04b">00063</a> <a class="code" href="classPassenger_1_1SystemException.html#1f0f33c63934ee40c5cd9c338c8aa04b" title="Create a new SystemException.">SystemException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &briefMessage, <span class="keywordtype">int</span> errorCode) {
|
81
80
|
<a name="l00064"></a>00064 stringstream str;
|
82
81
|
<a name="l00065"></a>00065
|
83
|
-
<a name="l00066"></a>00066
|
84
|
-
<a name="l00067"></a>00067
|
85
|
-
<a name="l00068"></a>00068
|
86
|
-
<a name="l00069"></a>00069
|
87
|
-
<a name="l00070"></a>00070
|
88
|
-
<a name="l00071"></a>00071
|
89
|
-
<a name="l00072"></a>00072
|
90
|
-
<a name="l00073"></a>00073
|
91
|
-
<a name="l00074"></a>00074
|
92
|
-
<a name="l00075"></a>00075
|
93
|
-
<a name="l00076"></a>00076
|
94
|
-
<a name="l00077"></a>00077
|
95
|
-
<a name="l00078"></a>00078
|
96
|
-
<a name="l00079"></a>00079 <span class="
|
97
|
-
<a name="l00080"></a>00080
|
98
|
-
<a name="l00081"></a>00081 <span class="
|
99
|
-
<a name="l00082"></a>00082
|
100
|
-
<a name="l00083"></a
|
101
|
-
<a name="l00084"></a>00084
|
102
|
-
<a name="l00085"></a>00085
|
103
|
-
<a name="l00086"></a>00086
|
104
|
-
<a name="l00087"></a>00087 <span class="
|
105
|
-
<a name="l00088"></a>00088
|
106
|
-
<a name="l00089"></a>00089
|
107
|
-
<a name="l00090"></a>00090
|
108
|
-
<a name="l00091"></a>00091 <span class="comment">
|
109
|
-
<a name="l00092"></a
|
110
|
-
<a name="l00093"></a>00093
|
111
|
-
<a name="l00094"></a>00094
|
112
|
-
<a name="l00095"></a>00095
|
113
|
-
<a name="l00096"></a>00096 <span class="
|
114
|
-
<a name="l00097"></a>00097
|
115
|
-
<a name="l00098"></a>00098
|
116
|
-
<a name="l00099"></a>00099
|
117
|
-
<a name="l00100"></a
|
118
|
-
<a name="l00101"></a>00101
|
119
|
-
<a name="l00102"></a>00102
|
120
|
-
<a name="l00103"></a>00103
|
121
|
-
<a name="l00104"></a>00104 <span class="
|
122
|
-
<a name="l00105"></a>00105
|
123
|
-
<a name="l00106"></a>00106
|
124
|
-
<a name="l00107"></a>00107
|
125
|
-
<a name="l00108"></a>00108 <span class="comment"
|
126
|
-
<a name="l00109"></a>00109 <span class="comment"
|
127
|
-
<a name="l00110"></a>00110 <span class="comment">
|
128
|
-
<a name="l00111"></a
|
129
|
-
<a name="l00112"></a>00112 <span class="
|
130
|
-
<a name="l00113"></a>00113
|
131
|
-
<a name="l00114"></a>00114 <span class="
|
132
|
-
<a name="l00115"></a>00115
|
133
|
-
<a name="l00116"></a>00116
|
134
|
-
<a name="l00117"></a>00117
|
135
|
-
<a name="l00118"></a>00118
|
136
|
-
<a name="l00119"></a>00119
|
137
|
-
<a name="l00120"></a>00120
|
138
|
-
<a name="l00121"></a>00121
|
139
|
-
<a name="l00122"></a>00122
|
140
|
-
<a name="l00123"></a>00123
|
141
|
-
<a name="l00124"></a>00124 <span class="
|
142
|
-
<a name="l00125"></a
|
143
|
-
<a name="l00126"></a>00126
|
144
|
-
<a name="l00127"></a>00127
|
145
|
-
<a name="l00128"></a>00128
|
146
|
-
<a name="l00129"></a>00129 <span class="
|
147
|
-
<a name="l00130"></a>00130
|
148
|
-
<a name="l00131"></a>00131
|
149
|
-
<a name="l00132"></a>00132
|
150
|
-
<a name="l00133"></a>00133 <span class="comment"
|
151
|
-
<a name="l00134"></a>00134 <span class="comment"
|
152
|
-
<a name="l00135"></a
|
153
|
-
<a name="l00136"></a>00136 <span class="
|
154
|
-
<a name="l00137"></a>00137
|
155
|
-
<a name="l00138"></a>00138 <span class="
|
156
|
-
<a name="l00139"></a>00139
|
157
|
-
<a name="l00140"></a>00140
|
158
|
-
<a name="l00141"></a>00141 <span class="
|
159
|
-
<a name="l00142"></a>00142
|
160
|
-
<a name="l00143"></a>00143 <span class="
|
161
|
-
<a name="l00144"></a>00144 <span class="
|
162
|
-
<a name="l00145"></a>00145 <span class="
|
163
|
-
<a name="l00146"></a>00146
|
164
|
-
<a name="l00147"></a
|
165
|
-
<a name="l00148"></a>00148 <span class="
|
166
|
-
<a name="l00149"></a>00149
|
167
|
-
<a name="l00150"></a>00150
|
168
|
-
<a name="l00151"></a>00151
|
169
|
-
<a name="l00152"></a>00152 <span class="
|
170
|
-
<a name="l00153"></a>00153 <span class="
|
171
|
-
<a name="l00154"></a>00154
|
172
|
-
<a name="l00155"></a>00155
|
173
|
-
<a name="l00156"></a
|
174
|
-
<a name="l00157"></a>00157 <span class="
|
175
|
-
<a name="l00158"></a>00158
|
176
|
-
<a name="l00159"></a>00159 <span class="
|
177
|
-
<a name="l00160"></a>00160
|
178
|
-
<a name="l00161"></a>00161
|
179
|
-
<a name="l00162"></a>00162 <span class="
|
180
|
-
<a name="l00163"></a>00163
|
181
|
-
<a name="l00164"></a>00164 <span class="
|
182
|
-
<a name="l00165"></a>00165 <span class="
|
183
|
-
<a name="l00166"></a>00166 <span class="
|
184
|
-
<a name="l00167"></a>00167
|
185
|
-
<a name="l00168"></a>00168 <span class="comment"
|
186
|
-
<a name="l00169"></a>00169 <span class="comment"
|
187
|
-
<a name="l00170"></a
|
188
|
-
<a name="l00171"></a>00171 <span class="
|
189
|
-
<a name="l00172"></a>00172
|
190
|
-
<a name="l00173"></a>00173
|
191
|
-
<a name="l00174"></a>00174
|
192
|
-
<a name="l00175"></a>00175 <span class="keyword">
|
193
|
-
<a name="l00176"></a>00176 <
|
194
|
-
<a name="l00177"></a>00177
|
195
|
-
<a name="l00178"></a>00178
|
196
|
-
<a name="l00179"></a>00179
|
197
|
-
<a name="l00180"></a>00180
|
198
|
-
<a name="l00181"></a>00181
|
199
|
-
<a name="l00182"></a>00182
|
200
|
-
<a name="l00183"></a>00183
|
201
|
-
<a name="l00184"></a>00184
|
202
|
-
<a name="l00185"></a>00185
|
203
|
-
<a name="l00186"></a>00186
|
204
|
-
<a name="l00187"></a>00187
|
205
|
-
<a name="l00188"></a>00188
|
206
|
-
<a name="l00189"></a>00189
|
207
|
-
<a name="l00190"></a>00190
|
208
|
-
<a name="l00191"></a>00191 <span class="
|
209
|
-
<a name="l00192"></a
|
210
|
-
<a name="l00193"></a>00193
|
211
|
-
<a name="l00194"></a>00194
|
212
|
-
<a name="l00195"></a>00195
|
213
|
-
<a name="l00196"></a>00196 <span class="
|
214
|
-
<a name="l00197"></a>00197
|
215
|
-
<a name="l00198"></a>00198
|
216
|
-
<a name="l00199"></a>00199
|
217
|
-
<a name="l00200"></a>00200 <span class="comment">
|
218
|
-
<a name="l00201"></a
|
219
|
-
<a name="l00202"></a>00202
|
220
|
-
<a name="l00203"></a>00203
|
221
|
-
<a name="l00204"></a>00204
|
222
|
-
<a name="l00205"></a>00205 <span class="
|
223
|
-
<a name="l00206"></a>00206
|
224
|
-
<a name="l00207"></a>00207
|
225
|
-
<a name="l00208"></a>00208
|
226
|
-
<a name="l00209"></a>00209 <span class="comment"
|
227
|
-
<a name="l00210"></a>00210 <span class="comment"
|
228
|
-
<a name="l00211"></a
|
229
|
-
<a name="l00212"></a>00212 <span class="
|
230
|
-
<a name="l00213"></a>00213
|
231
|
-
<a name="l00214"></a>00214 <span class="
|
232
|
-
<a name="l00215"></a
|
233
|
-
<a name="l00216"></a>00216
|
234
|
-
<a name="l00217"></a>00217 <span class="
|
235
|
-
<a name="l00218"></a>00218
|
236
|
-
<a name="l00219"></a>00219
|
237
|
-
<a name="l00220"></a>00220
|
238
|
-
<a name="l00221"></a>00221
|
239
|
-
<a name="l00222"></a>00222
|
82
|
+
<a name="l00066"></a>00066 str << strerror(errorCode) << <span class="stringliteral">" ("</span> << errorCode << <span class="stringliteral">")"</span>;
|
83
|
+
<a name="l00067"></a>00067 systemMessage = str.str();
|
84
|
+
<a name="l00068"></a>00068
|
85
|
+
<a name="l00069"></a>00069 setBriefMessage(briefMessage);
|
86
|
+
<a name="l00070"></a>00070 m_code = errorCode;
|
87
|
+
<a name="l00071"></a>00071 }
|
88
|
+
<a name="l00072"></a>00072
|
89
|
+
<a name="l00073"></a>00073 <span class="keyword">virtual</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>() throw() {}
|
90
|
+
<a name="l00074"></a>00074
|
91
|
+
<a name="l00075"></a>00075 <span class="keyword">virtual</span> <span class="keyword">const</span> <span class="keywordtype">char</span> *what() <span class="keyword">const</span> throw() {
|
92
|
+
<a name="l00076"></a>00076 <span class="keywordflow">return</span> fullMessage.c_str();
|
93
|
+
<a name="l00077"></a>00077 }
|
94
|
+
<a name="l00078"></a>00078
|
95
|
+
<a name="l00079"></a>00079 <span class="keywordtype">void</span> setBriefMessage(<span class="keyword">const</span> <span class="keywordtype">string</span> &message) {
|
96
|
+
<a name="l00080"></a>00080 briefMessage = message;
|
97
|
+
<a name="l00081"></a>00081 fullMessage = briefMessage + <span class="stringliteral">": "</span> + systemMessage;
|
98
|
+
<a name="l00082"></a>00082 }
|
99
|
+
<a name="l00083"></a>00083 <span class="comment"></span>
|
100
|
+
<a name="l00084"></a>00084 <span class="comment"> /**</span>
|
101
|
+
<a name="l00085"></a>00085 <span class="comment"> * The value of <tt>errno</tt> at the time the error occured.</span>
|
102
|
+
<a name="l00086"></a>00086 <span class="comment"> */</span>
|
103
|
+
<a name="l00087"></a><a class="code" href="classPassenger_1_1SystemException.html#ee7a6672bf79b72a4c3ee70c57d6a47c">00087</a> <span class="keywordtype">int</span> <a class="code" href="classPassenger_1_1SystemException.html#ee7a6672bf79b72a4c3ee70c57d6a47c" title="The value of errno at the time the error occured.">code</a>() <span class="keyword">const</span> throw() {
|
104
|
+
<a name="l00088"></a>00088 <span class="keywordflow">return</span> m_code;
|
105
|
+
<a name="l00089"></a>00089 }
|
106
|
+
<a name="l00090"></a>00090 <span class="comment"></span>
|
107
|
+
<a name="l00091"></a>00091 <span class="comment"> /**</span>
|
108
|
+
<a name="l00092"></a>00092 <span class="comment"> * Returns a brief version of the exception message. This message does</span>
|
109
|
+
<a name="l00093"></a>00093 <span class="comment"> * not include the system error description, and is equivalent to the</span>
|
110
|
+
<a name="l00094"></a>00094 <span class="comment"> * value of the <tt>message</tt> parameter as passed to the constructor.</span>
|
111
|
+
<a name="l00095"></a>00095 <span class="comment"> */</span>
|
112
|
+
<a name="l00096"></a><a class="code" href="classPassenger_1_1SystemException.html#84fa2ab4f5b7b96704734fcdfdaa0269">00096</a> <span class="keywordtype">string</span> <a class="code" href="classPassenger_1_1SystemException.html#84fa2ab4f5b7b96704734fcdfdaa0269" title="Returns a brief version of the exception message.">brief</a>() <span class="keyword">const</span> throw() {
|
113
|
+
<a name="l00097"></a>00097 <span class="keywordflow">return</span> briefMessage;
|
114
|
+
<a name="l00098"></a>00098 }
|
115
|
+
<a name="l00099"></a>00099 <span class="comment"></span>
|
116
|
+
<a name="l00100"></a>00100 <span class="comment"> /**</span>
|
117
|
+
<a name="l00101"></a>00101 <span class="comment"> * Returns the system's error message. This message contains both the</span>
|
118
|
+
<a name="l00102"></a>00102 <span class="comment"> * content of <tt>strerror(errno)</tt> and the errno number itself.</span>
|
119
|
+
<a name="l00103"></a>00103 <span class="comment"> */</span>
|
120
|
+
<a name="l00104"></a><a class="code" href="classPassenger_1_1SystemException.html#0ef41d755fea2c9b1db2252e7c418dc8">00104</a> <span class="keywordtype">string</span> <a class="code" href="classPassenger_1_1SystemException.html#0ef41d755fea2c9b1db2252e7c418dc8" title="Returns the system&#39;s error message.">sys</a>() <span class="keyword">const</span> throw() {
|
121
|
+
<a name="l00105"></a>00105 <span class="keywordflow">return</span> systemMessage;
|
122
|
+
<a name="l00106"></a>00106 }
|
123
|
+
<a name="l00107"></a>00107 };
|
124
|
+
<a name="l00108"></a>00108 <span class="comment"></span>
|
125
|
+
<a name="l00109"></a>00109 <span class="comment">/**</span>
|
126
|
+
<a name="l00110"></a>00110 <span class="comment"> * A filesystem error, as returned by the operating system. This may include,</span>
|
127
|
+
<a name="l00111"></a>00111 <span class="comment"> * for example, permission errors.</span>
|
128
|
+
<a name="l00112"></a>00112 <span class="comment"> *</span>
|
129
|
+
<a name="l00113"></a>00113 <span class="comment"> * @ingroup Exceptions</span>
|
130
|
+
<a name="l00114"></a>00114 <span class="comment"> */</span>
|
131
|
+
<a name="l00115"></a><a class="code" href="classPassenger_1_1FileSystemException.html">00115</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1FileSystemException.html" title="A filesystem error, as returned by the operating system.">FileSystemException</a>: <span class="keyword">public</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> {
|
132
|
+
<a name="l00116"></a>00116 <span class="keyword">private</span>:
|
133
|
+
<a name="l00117"></a>00117 <span class="keywordtype">string</span> m_filename;
|
134
|
+
<a name="l00118"></a>00118 <span class="keyword">public</span>:
|
135
|
+
<a name="l00119"></a>00119 <a class="code" href="classPassenger_1_1FileSystemException.html" title="A filesystem error, as returned by the operating system.">FileSystemException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message, <span class="keywordtype">int</span> errorCode,
|
136
|
+
<a name="l00120"></a>00120 <span class="keyword">const</span> <span class="keywordtype">string</span> &<a class="code" href="classPassenger_1_1FileSystemException.html#7eef8fefd84a07efa9fe3a76129a4386" title="The filename that&#39;s associated to the error.">filename</a>)
|
137
|
+
<a name="l00121"></a>00121 : <a class="code" href="classPassenger_1_1SystemException.html#1f0f33c63934ee40c5cd9c338c8aa04b" title="Create a new SystemException.">SystemException</a>(message, errorCode),
|
138
|
+
<a name="l00122"></a>00122 m_filename(filename) {}
|
139
|
+
<a name="l00123"></a>00123
|
140
|
+
<a name="l00124"></a>00124 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1FileSystemException.html" title="A filesystem error, as returned by the operating system.">FileSystemException</a>() <span class="keywordflow">throw</span>() {}
|
141
|
+
<a name="l00125"></a>00125 <span class="comment"></span>
|
142
|
+
<a name="l00126"></a>00126 <span class="comment"> /**</span>
|
143
|
+
<a name="l00127"></a>00127 <span class="comment"> * The filename that's associated to the error.</span>
|
144
|
+
<a name="l00128"></a>00128 <span class="comment"> */</span>
|
145
|
+
<a name="l00129"></a><a class="code" href="classPassenger_1_1FileSystemException.html#7eef8fefd84a07efa9fe3a76129a4386">00129</a> <span class="keywordtype">string</span> <a class="code" href="classPassenger_1_1FileSystemException.html#7eef8fefd84a07efa9fe3a76129a4386" title="The filename that&#39;s associated to the error.">filename</a>() <span class="keyword">const</span> throw() {
|
146
|
+
<a name="l00130"></a>00130 <span class="keywordflow">return</span> m_filename;
|
147
|
+
<a name="l00131"></a>00131 }
|
148
|
+
<a name="l00132"></a>00132 };
|
149
|
+
<a name="l00133"></a>00133 <span class="comment"></span>
|
150
|
+
<a name="l00134"></a>00134 <span class="comment">/**</span>
|
151
|
+
<a name="l00135"></a>00135 <span class="comment"> * Represents an error that occured during an I/O operation.</span>
|
152
|
+
<a name="l00136"></a>00136 <span class="comment"> *</span>
|
153
|
+
<a name="l00137"></a>00137 <span class="comment"> * @ingroup Exceptions</span>
|
154
|
+
<a name="l00138"></a>00138 <span class="comment"> */</span>
|
155
|
+
<a name="l00139"></a><a class="code" href="classPassenger_1_1IOException.html">00139</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1IOException.html" title="Represents an error that occured during an I/O operation.">IOException</a>: <span class="keyword">public</span> oxt::tracable_exception {
|
156
|
+
<a name="l00140"></a>00140 <span class="keyword">private</span>:
|
157
|
+
<a name="l00141"></a>00141 <span class="keywordtype">string</span> msg;
|
158
|
+
<a name="l00142"></a>00142 <span class="keyword">public</span>:
|
159
|
+
<a name="l00143"></a>00143 <a class="code" href="classPassenger_1_1IOException.html" title="Represents an error that occured during an I/O operation.">IOException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): msg(message) {}
|
160
|
+
<a name="l00144"></a>00144 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1IOException.html" title="Represents an error that occured during an I/O operation.">IOException</a>() <span class="keywordflow">throw</span>() {}
|
161
|
+
<a name="l00145"></a>00145 <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(); }
|
162
|
+
<a name="l00146"></a>00146 };
|
163
|
+
<a name="l00147"></a>00147 <span class="comment"></span>
|
164
|
+
<a name="l00148"></a>00148 <span class="comment">/**</span>
|
165
|
+
<a name="l00149"></a>00149 <span class="comment"> * Thrown when a certain file cannot be found.</span>
|
166
|
+
<a name="l00150"></a>00150 <span class="comment"> */</span>
|
167
|
+
<a name="l00151"></a><a class="code" href="classPassenger_1_1FileNotFoundException.html">00151</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1FileNotFoundException.html" title="Thrown when a certain file cannot be found.">FileNotFoundException</a>: <span class="keyword">public</span> <a class="code" href="classPassenger_1_1IOException.html" title="Represents an error that occured during an I/O operation.">IOException</a> {
|
168
|
+
<a name="l00152"></a>00152 <span class="keyword">public</span>:
|
169
|
+
<a name="l00153"></a>00153 <a class="code" href="classPassenger_1_1FileNotFoundException.html" title="Thrown when a certain file cannot be found.">FileNotFoundException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): <a class="code" href="classPassenger_1_1IOException.html" title="Represents an error that occured during an I/O operation.">IOException</a>(message) {}
|
170
|
+
<a name="l00154"></a>00154 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1FileNotFoundException.html" title="Thrown when a certain file cannot be found.">FileNotFoundException</a>() <span class="keywordflow">throw</span>() {}
|
171
|
+
<a name="l00155"></a>00155 };
|
172
|
+
<a name="l00156"></a>00156 <span class="comment"></span>
|
173
|
+
<a name="l00157"></a>00157 <span class="comment">/**</span>
|
174
|
+
<a name="l00158"></a>00158 <span class="comment"> * Thrown when an invalid configuration is given.</span>
|
175
|
+
<a name="l00159"></a>00159 <span class="comment"> */</span>
|
176
|
+
<a name="l00160"></a><a class="code" href="classPassenger_1_1ConfigurationException.html">00160</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1ConfigurationException.html" title="Thrown when an invalid configuration is given.">ConfigurationException</a>: <span class="keyword">public</span> oxt::tracable_exception {
|
177
|
+
<a name="l00161"></a>00161 <span class="keyword">private</span>:
|
178
|
+
<a name="l00162"></a>00162 <span class="keywordtype">string</span> msg;
|
179
|
+
<a name="l00163"></a>00163 <span class="keyword">public</span>:
|
180
|
+
<a name="l00164"></a>00164 <a class="code" href="classPassenger_1_1ConfigurationException.html" title="Thrown when an invalid configuration is given.">ConfigurationException</a>(<span class="keyword">const</span> <span class="keywordtype">string</span> &message): msg(message) {}
|
181
|
+
<a name="l00165"></a>00165 <span class="keyword">virtual</span> ~<a class="code" href="classPassenger_1_1ConfigurationException.html" title="Thrown when an invalid configuration is given.">ConfigurationException</a>() <span class="keywordflow">throw</span>() {}
|
182
|
+
<a name="l00166"></a>00166 <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(); }
|
183
|
+
<a name="l00167"></a>00167 };
|
184
|
+
<a name="l00168"></a>00168 <span class="comment"></span>
|
185
|
+
<a name="l00169"></a>00169 <span class="comment">/**</span>
|
186
|
+
<a name="l00170"></a>00170 <span class="comment"> * Thrown when SpawnManager or ApplicationPool fails to spawn an application</span>
|
187
|
+
<a name="l00171"></a>00171 <span class="comment"> * instance. The exception may contain an error page, which is a user-friendly</span>
|
188
|
+
<a name="l00172"></a>00172 <span class="comment"> * HTML page with details about the error.</span>
|
189
|
+
<a name="l00173"></a>00173 <span class="comment"> */</span>
|
190
|
+
<a name="l00174"></a><a class="code" href="classPassenger_1_1SpawnException.html">00174</a> <span class="keyword">class </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="keyword">public</span> oxt::tracable_exception {
|
191
|
+
<a name="l00175"></a>00175 <span class="keyword">private</span>:
|
192
|
+
<a name="l00176"></a>00176 <span class="keywordtype">string</span> msg;
|
193
|
+
<a name="l00177"></a>00177 <span class="keywordtype">bool</span> m_hasErrorPage;
|
194
|
+
<a name="l00178"></a>00178 <span class="keywordtype">string</span> m_errorPage;
|
195
|
+
<a name="l00179"></a>00179 <span class="keyword">public</span>:
|
196
|
+
<a name="l00180"></a>00180 <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)
|
197
|
+
<a name="l00181"></a>00181 : msg(message) {
|
198
|
+
<a name="l00182"></a>00182 m_hasErrorPage = <span class="keyword">false</span>;
|
199
|
+
<a name="l00183"></a>00183 }
|
200
|
+
<a name="l00184"></a>00184
|
201
|
+
<a name="l00185"></a>00185 <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)
|
202
|
+
<a name="l00186"></a>00186 : msg(message), m_errorPage(errorPage) {
|
203
|
+
<a name="l00187"></a>00187 m_hasErrorPage = <span class="keyword">true</span>;
|
204
|
+
<a name="l00188"></a>00188 }
|
205
|
+
<a name="l00189"></a>00189
|
206
|
+
<a name="l00190"></a>00190 <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>() {}
|
207
|
+
<a name="l00191"></a>00191 <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(); }
|
208
|
+
<a name="l00192"></a>00192 <span class="comment"></span>
|
209
|
+
<a name="l00193"></a>00193 <span class="comment"> /**</span>
|
210
|
+
<a name="l00194"></a>00194 <span class="comment"> * Check whether an error page is available.</span>
|
211
|
+
<a name="l00195"></a>00195 <span class="comment"> */</span>
|
212
|
+
<a name="l00196"></a><a class="code" href="classPassenger_1_1SpawnException.html#e65dc272e183fd9e5637a4091cc6bbf4">00196</a> <span class="keywordtype">bool</span> <a class="code" href="classPassenger_1_1SpawnException.html#e65dc272e183fd9e5637a4091cc6bbf4" title="Check whether an error page is available.">hasErrorPage</a>()<span class="keyword"> const </span>{
|
213
|
+
<a name="l00197"></a>00197 <span class="keywordflow">return</span> m_hasErrorPage;
|
214
|
+
<a name="l00198"></a>00198 }
|
215
|
+
<a name="l00199"></a>00199 <span class="comment"></span>
|
216
|
+
<a name="l00200"></a>00200 <span class="comment"> /**</span>
|
217
|
+
<a name="l00201"></a>00201 <span class="comment"> * Return the error page content.</span>
|
218
|
+
<a name="l00202"></a>00202 <span class="comment"> *</span>
|
219
|
+
<a name="l00203"></a>00203 <span class="comment"> * @pre hasErrorPage()</span>
|
220
|
+
<a name="l00204"></a>00204 <span class="comment"> */</span>
|
221
|
+
<a name="l00205"></a><a class="code" href="classPassenger_1_1SpawnException.html#6f675a37edd7070875d0744e7dd010a1">00205</a> <span class="keyword">const</span> <span class="keywordtype">string</span> <a class="code" href="classPassenger_1_1SpawnException.html#6f675a37edd7070875d0744e7dd010a1" title="Return the error page content.">getErrorPage</a>()<span class="keyword"> const </span>{
|
222
|
+
<a name="l00206"></a>00206 <span class="keywordflow">return</span> m_errorPage;
|
223
|
+
<a name="l00207"></a>00207 }
|
224
|
+
<a name="l00208"></a>00208 };
|
225
|
+
<a name="l00209"></a>00209 <span class="comment"></span>
|
226
|
+
<a name="l00210"></a>00210 <span class="comment">/**</span>
|
227
|
+
<a name="l00211"></a>00211 <span class="comment"> * A generic runtime exception.</span>
|
228
|
+
<a name="l00212"></a>00212 <span class="comment"> *</span>
|
229
|
+
<a name="l00213"></a>00213 <span class="comment"> * @ingroup Exceptions</span>
|
230
|
+
<a name="l00214"></a>00214 <span class="comment"> */</span>
|
231
|
+
<a name="l00215"></a><a class="code" href="classPassenger_1_1RuntimeException.html">00215</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 {
|
232
|
+
<a name="l00216"></a>00216 <span class="keyword">private</span>:
|
233
|
+
<a name="l00217"></a>00217 <span class="keywordtype">string</span> msg;
|
234
|
+
<a name="l00218"></a>00218 <span class="keyword">public</span>:
|
235
|
+
<a name="l00219"></a>00219 <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) {}
|
236
|
+
<a name="l00220"></a>00220 <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>() {}
|
237
|
+
<a name="l00221"></a>00221 <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(); }
|
238
|
+
<a name="l00222"></a>00222 };
|
239
|
+
<a name="l00223"></a>00223 <span class="comment"></span>
|
240
|
+
<a name="l00224"></a>00224 <span class="comment">/**</span>
|
241
|
+
<a name="l00225"></a>00225 <span class="comment"> * The application pool is too busy and cannot fulfill a get() request.</span>
|
242
|
+
<a name="l00226"></a>00226 <span class="comment"> *</span>
|
243
|
+
<a name="l00227"></a>00227 <span class="comment"> * @ingroup Exceptions</span>
|
244
|
+
<a name="l00228"></a>00228 <span class="comment"> */</span>
|
245
|
+
<a name="l00229"></a><a class="code" href="classPassenger_1_1BusyException.html">00229</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 {
|
246
|
+
<a name="l00230"></a>00230 <span class="keyword">private</span>:
|
247
|
+
<a name="l00231"></a>00231 <span class="keywordtype">string</span> msg;
|
248
|
+
<a name="l00232"></a>00232 <span class="keyword">public</span>:
|
249
|
+
<a name="l00233"></a>00233 <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) {}
|
250
|
+
<a name="l00234"></a>00234 <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>() {}
|
251
|
+
<a name="l00235"></a>00235 <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(); }
|
252
|
+
<a name="l00236"></a>00236 };
|
253
|
+
<a name="l00237"></a>00237
|
254
|
+
<a name="l00238"></a>00238 } <span class="comment">// namespace Passenger</span>
|
255
|
+
<a name="l00239"></a>00239
|
256
|
+
<a name="l00240"></a>00240 <span class="preprocessor">#endif </span><span class="comment">/* _PASSENGER_EXCEPTIONS_H_ */</span>
|
240
257
|
</pre></div></div>
|
241
|
-
<hr size="1"><address style="text-align: right;"><small>Generated on
|
258
|
+
<hr size="1"><address style="text-align: right;"><small>Generated on Fri Mar 13 19:24:32 2009 for Passenger by
|
242
259
|
<a href="http://www.doxygen.org/index.html">
|
243
260
|
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.5 </small></address>
|
244
261
|
</body>
|