passenger_dudemeister 3.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1565) hide show
  1. data/DEVELOPERS.TXT +113 -0
  2. data/INSTALL +6 -0
  3. data/LICENSE +19 -0
  4. data/NEWS +429 -0
  5. data/PACKAGING.TXT +25 -0
  6. data/README +45 -0
  7. data/Rakefile +56 -0
  8. data/bin/passenger +32 -0
  9. data/bin/passenger-config +46 -0
  10. data/bin/passenger-install-apache2-module +237 -0
  11. data/bin/passenger-install-nginx-module +476 -0
  12. data/bin/passenger-make-enterprisey +82 -0
  13. data/bin/passenger-memory-stats +171 -0
  14. data/bin/passenger-status +211 -0
  15. data/build/agents.rb +80 -0
  16. data/build/apache2.rb +168 -0
  17. data/build/basics.rb +105 -0
  18. data/build/common_library.rb +268 -0
  19. data/build/config.rb +42 -0
  20. data/build/cplusplus_support.rb +61 -0
  21. data/build/cxx_tests.rb +219 -0
  22. data/build/documentation.rb +84 -0
  23. data/build/gempackagetask.rb +99 -0
  24. data/build/integration_tests.rb +64 -0
  25. data/build/misc.rb +153 -0
  26. data/build/nginx.rb +72 -0
  27. data/build/oxt_tests.rb +59 -0
  28. data/build/packagetask.rb +186 -0
  29. data/build/packaging.rb +194 -0
  30. data/build/rake_extensions.rb +182 -0
  31. data/build/rdoctask.rb +209 -0
  32. data/build/rpm.rb +98 -0
  33. data/build/ruby_extension.rb +52 -0
  34. data/build/ruby_tests.rb +49 -0
  35. data/build/test_basics.rb +43 -0
  36. data/debian/README.Debian +15 -0
  37. data/debian/changelog +185 -0
  38. data/debian/compat +1 -0
  39. data/debian/control +49 -0
  40. data/debian/copyright +20 -0
  41. data/debian/libapache2-mod-passenger.install +1 -0
  42. data/debian/libapache2-mod-passenger.postinst +36 -0
  43. data/debian/libapache2-mod-passenger.prerm +15 -0
  44. data/debian/passenger-common.install +4 -0
  45. data/debian/passenger.conf +4 -0
  46. data/debian/passenger.load +1 -0
  47. data/debian/prerm +2 -0
  48. data/debian/rules +37 -0
  49. data/debian/watch +3 -0
  50. data/dev/copy_boost_headers.rb +155 -0
  51. data/dev/find_owner_pipe_leaks.rb +128 -0
  52. data/dev/render_error_pages.rb +116 -0
  53. data/doc/ApplicationPool algorithm.txt +615 -0
  54. data/doc/Architectural overview.html +1 -0
  55. data/doc/Architectural overview.txt +334 -0
  56. data/doc/Doxyfile +241 -0
  57. data/doc/Security of user switching support.html +1 -0
  58. data/doc/Security of user switching support.txt +197 -0
  59. data/doc/Users guide Apache.html +1 -0
  60. data/doc/Users guide Apache.txt +2208 -0
  61. data/doc/Users guide Nginx.html +1 -0
  62. data/doc/Users guide Nginx.txt +1394 -0
  63. data/doc/Users guide Standalone.html +1 -0
  64. data/doc/Users guide Standalone.txt +40 -0
  65. data/doc/definitions.h +5 -0
  66. data/doc/images/by_sa.png +0 -0
  67. data/doc/images/conservative_spawning.png +0 -0
  68. data/doc/images/conservative_spawning.svg +248 -0
  69. data/doc/images/icons/README +5 -0
  70. data/doc/images/icons/callouts/1.png +0 -0
  71. data/doc/images/icons/callouts/10.png +0 -0
  72. data/doc/images/icons/callouts/11.png +0 -0
  73. data/doc/images/icons/callouts/12.png +0 -0
  74. data/doc/images/icons/callouts/13.png +0 -0
  75. data/doc/images/icons/callouts/14.png +0 -0
  76. data/doc/images/icons/callouts/15.png +0 -0
  77. data/doc/images/icons/callouts/2.png +0 -0
  78. data/doc/images/icons/callouts/3.png +0 -0
  79. data/doc/images/icons/callouts/4.png +0 -0
  80. data/doc/images/icons/callouts/5.png +0 -0
  81. data/doc/images/icons/callouts/6.png +0 -0
  82. data/doc/images/icons/callouts/7.png +0 -0
  83. data/doc/images/icons/callouts/8.png +0 -0
  84. data/doc/images/icons/callouts/9.png +0 -0
  85. data/doc/images/icons/caution.png +0 -0
  86. data/doc/images/icons/example.png +0 -0
  87. data/doc/images/icons/home.png +0 -0
  88. data/doc/images/icons/important.png +0 -0
  89. data/doc/images/icons/next.png +0 -0
  90. data/doc/images/icons/note.png +0 -0
  91. data/doc/images/icons/prev.png +0 -0
  92. data/doc/images/icons/tip.png +0 -0
  93. data/doc/images/icons/up.png +0 -0
  94. data/doc/images/icons/warning.png +0 -0
  95. data/doc/images/passenger_architecture.png +0 -0
  96. data/doc/images/passenger_architecture.svg +401 -0
  97. data/doc/images/phusion_banner.png +0 -0
  98. data/doc/images/smart-lv2.png +0 -0
  99. data/doc/images/smart-lv2.svg +320 -0
  100. data/doc/images/spawn_server_architecture.png +0 -0
  101. data/doc/images/spawn_server_architecture.svg +655 -0
  102. data/doc/images/typical_isolated_web_application.png +0 -0
  103. data/doc/images/typical_isolated_web_application.svg +213 -0
  104. data/doc/rdoc/classes/ConditionVariable.html +215 -0
  105. data/doc/rdoc/classes/Exception.html +120 -0
  106. data/doc/rdoc/classes/GC.html +113 -0
  107. data/doc/rdoc/classes/IO.html +221 -0
  108. data/doc/rdoc/classes/PhusionPassenger.html +397 -0
  109. data/doc/rdoc/classes/PhusionPassenger/AbstractInstaller.html +180 -0
  110. data/doc/rdoc/classes/PhusionPassenger/AbstractRequestHandler.html +647 -0
  111. data/doc/rdoc/classes/PhusionPassenger/AbstractServer.html +654 -0
  112. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/InvalidPassword.html +92 -0
  113. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerAlreadyStarted.html +97 -0
  114. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerError.html +96 -0
  115. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/ServerNotStarted.html +97 -0
  116. data/doc/rdoc/classes/PhusionPassenger/AbstractServer/UnknownMessage.html +96 -0
  117. data/doc/rdoc/classes/PhusionPassenger/AbstractServerCollection.html +619 -0
  118. data/doc/rdoc/classes/PhusionPassenger/AdminTools.html +142 -0
  119. data/doc/rdoc/classes/PhusionPassenger/AdminTools/MemoryStats.html +368 -0
  120. data/doc/rdoc/classes/PhusionPassenger/AdminTools/MemoryStats/Process.html +231 -0
  121. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance.html +588 -0
  122. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/CorruptedDirectoryError.html +92 -0
  123. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/GenerationsAbsentError.html +92 -0
  124. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Group.html +147 -0
  125. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Process.html +279 -0
  126. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/RoleDeniedError.html +92 -0
  127. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/StaleDirectoryError.html +92 -0
  128. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/Stats.html +123 -0
  129. data/doc/rdoc/classes/PhusionPassenger/AdminTools/ServerInstance/UnsupportedGenerationStructureVersionError.html +92 -0
  130. data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger.html +341 -0
  131. data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/Log.html +294 -0
  132. data/doc/rdoc/classes/PhusionPassenger/AnalyticsLogger/SharedData.html +199 -0
  133. data/doc/rdoc/classes/PhusionPassenger/AppInitError.html +155 -0
  134. data/doc/rdoc/classes/PhusionPassenger/AppProcess.html +367 -0
  135. data/doc/rdoc/classes/PhusionPassenger/ClassicRails.html +95 -0
  136. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/ApplicationSpawner.html +351 -0
  137. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/ApplicationSpawner/Error.html +98 -0
  138. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/CGIFixed.html +200 -0
  139. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/FrameworkSpawner.html +410 -0
  140. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/FrameworkSpawner/Error.html +98 -0
  141. data/doc/rdoc/classes/PhusionPassenger/ClassicRails/RequestHandler.html +156 -0
  142. data/doc/rdoc/classes/PhusionPassenger/ClassicRailsExtensions.html +115 -0
  143. data/doc/rdoc/classes/PhusionPassenger/ClassicRailsExtensions/AnalyticsLogging.html +202 -0
  144. data/doc/rdoc/classes/PhusionPassenger/ConsoleTextTemplate.html +172 -0
  145. data/doc/rdoc/classes/PhusionPassenger/DebugLogging.html +273 -0
  146. data/doc/rdoc/classes/PhusionPassenger/FrameworkInitError.html +145 -0
  147. data/doc/rdoc/classes/PhusionPassenger/HTMLTemplate.html +162 -0
  148. data/doc/rdoc/classes/PhusionPassenger/InitializationError.html +141 -0
  149. data/doc/rdoc/classes/PhusionPassenger/InvalidPath.html +92 -0
  150. data/doc/rdoc/classes/PhusionPassenger/MessageChannel.html +673 -0
  151. data/doc/rdoc/classes/PhusionPassenger/MessageChannel/InvalidHashError.html +92 -0
  152. data/doc/rdoc/classes/PhusionPassenger/MessageClient.html +415 -0
  153. data/doc/rdoc/classes/PhusionPassenger/NativeSupportLoader.html +134 -0
  154. data/doc/rdoc/classes/PhusionPassenger/Packaging.html +129 -0
  155. data/doc/rdoc/classes/PhusionPassenger/PlatformInfo.html +1972 -0
  156. data/doc/rdoc/classes/PhusionPassenger/Plugin.html +237 -0
  157. data/doc/rdoc/classes/PhusionPassenger/Rack.html +91 -0
  158. data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner.html +312 -0
  159. data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner/Error.html +98 -0
  160. data/doc/rdoc/classes/PhusionPassenger/Rack/RequestHandler.html +218 -0
  161. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions.html +114 -0
  162. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging.html +259 -0
  163. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ACExtension.html +139 -0
  164. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ASBenchmarkableExtension.html +118 -0
  165. data/doc/rdoc/classes/PhusionPassenger/Rails3Extensions/AnalyticsLogging/ExceptionLogger.html +135 -0
  166. data/doc/rdoc/classes/PhusionPassenger/SpawnManager.html +378 -0
  167. data/doc/rdoc/classes/PhusionPassenger/Standalone.html +111 -0
  168. data/doc/rdoc/classes/PhusionPassenger/Standalone/AppFinder.html +252 -0
  169. data/doc/rdoc/classes/PhusionPassenger/Standalone/Command.html +161 -0
  170. data/doc/rdoc/classes/PhusionPassenger/Standalone/ConfigFile.html +368 -0
  171. data/doc/rdoc/classes/PhusionPassenger/Standalone/ConfigFile/DisallowedContextError.html +132 -0
  172. data/doc/rdoc/classes/PhusionPassenger/Standalone/HelpCommand.html +151 -0
  173. data/doc/rdoc/classes/PhusionPassenger/Standalone/Main.html +189 -0
  174. data/doc/rdoc/classes/PhusionPassenger/Standalone/PackageRuntimeCommand.html +177 -0
  175. data/doc/rdoc/classes/PhusionPassenger/Standalone/RuntimeInstaller.html +341 -0
  176. data/doc/rdoc/classes/PhusionPassenger/Standalone/StartCommand.html +203 -0
  177. data/doc/rdoc/classes/PhusionPassenger/Standalone/StatusCommand.html +156 -0
  178. data/doc/rdoc/classes/PhusionPassenger/Standalone/StopCommand.html +168 -0
  179. data/doc/rdoc/classes/PhusionPassenger/Standalone/Utils.html +86 -0
  180. data/doc/rdoc/classes/PhusionPassenger/Standalone/VersionCommand.html +135 -0
  181. data/doc/rdoc/classes/PhusionPassenger/UnknownError.html +125 -0
  182. data/doc/rdoc/classes/PhusionPassenger/Utils.html +1543 -0
  183. data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher.html +204 -0
  184. data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher/DirInfo.html +171 -0
  185. data/doc/rdoc/classes/PhusionPassenger/Utils/FileSystemWatcher/FileInfo.html +140 -0
  186. data/doc/rdoc/classes/PhusionPassenger/Utils/HostsFileParser.html +260 -0
  187. data/doc/rdoc/classes/PhusionPassenger/Utils/PseudoIO.html +169 -0
  188. data/doc/rdoc/classes/PhusionPassenger/Utils/RewindableInput.html +265 -0
  189. data/doc/rdoc/classes/PhusionPassenger/Utils/RewindableInput/Tempfile.html +120 -0
  190. data/doc/rdoc/classes/PhusionPassenger/Utils/UnseekableSocket.html +561 -0
  191. data/doc/rdoc/classes/PhusionPassenger/VersionNotFound.html +140 -0
  192. data/doc/rdoc/classes/PhusionPassenger/WSGI.html +89 -0
  193. data/doc/rdoc/classes/PhusionPassenger/WSGI/ApplicationSpawner.html +182 -0
  194. data/doc/rdoc/classes/Process.html +115 -0
  195. data/doc/rdoc/classes/Signal.html +139 -0
  196. data/doc/rdoc/created.rid +1 -0
  197. data/doc/rdoc/files/DEVELOPERS_TXT.html +280 -0
  198. data/doc/rdoc/files/README.html +157 -0
  199. data/doc/rdoc/files/lib/phusion_passenger/abstract_installer_rb.html +130 -0
  200. data/doc/rdoc/files/lib/phusion_passenger/abstract_request_handler_rb.html +135 -0
  201. data/doc/rdoc/files/lib/phusion_passenger/abstract_server_collection_rb.html +126 -0
  202. data/doc/rdoc/files/lib/phusion_passenger/abstract_server_rb.html +128 -0
  203. data/doc/rdoc/files/lib/phusion_passenger/admin_tools/memory_stats_rb.html +126 -0
  204. data/doc/rdoc/files/lib/phusion_passenger/admin_tools/server_instance_rb.html +132 -0
  205. data/doc/rdoc/files/lib/phusion_passenger/admin_tools_rb.html +122 -0
  206. data/doc/rdoc/files/lib/phusion_passenger/analytics_logger_rb.html +129 -0
  207. data/doc/rdoc/files/lib/phusion_passenger/app_process_rb.html +127 -0
  208. data/doc/rdoc/files/lib/phusion_passenger/classic_rails/application_spawner_rb.html +141 -0
  209. data/doc/rdoc/files/lib/phusion_passenger/classic_rails/cgi_fixed_rb.html +126 -0
  210. data/doc/rdoc/files/lib/phusion_passenger/classic_rails/framework_spawner_rb.html +146 -0
  211. data/doc/rdoc/files/lib/phusion_passenger/classic_rails/request_handler_rb.html +125 -0
  212. data/doc/rdoc/files/lib/phusion_passenger/classic_rails_extensions/init_rb.html +132 -0
  213. data/doc/rdoc/files/lib/phusion_passenger/console_text_template_rb.html +126 -0
  214. data/doc/rdoc/files/lib/phusion_passenger/constants_rb.html +122 -0
  215. data/doc/rdoc/files/lib/phusion_passenger/debug_logging_rb.html +122 -0
  216. data/doc/rdoc/files/lib/phusion_passenger/dependencies_rb.html +147 -0
  217. data/doc/rdoc/files/lib/phusion_passenger/exceptions_rb.html +122 -0
  218. data/doc/rdoc/files/lib/phusion_passenger/html_template_rb.html +127 -0
  219. data/doc/rdoc/files/lib/phusion_passenger/message_channel_rb.html +120 -0
  220. data/doc/rdoc/files/lib/phusion_passenger/message_client_rb.html +127 -0
  221. data/doc/rdoc/files/lib/phusion_passenger/native_support_rb.html +132 -0
  222. data/doc/rdoc/files/lib/phusion_passenger/packaging_rb.html +122 -0
  223. data/doc/rdoc/files/lib/phusion_passenger/platform_info/apache_rb.html +127 -0
  224. data/doc/rdoc/files/lib/phusion_passenger/platform_info/binary_compatibility_rb.html +129 -0
  225. data/doc/rdoc/files/lib/phusion_passenger/platform_info/compiler_rb.html +127 -0
  226. data/doc/rdoc/files/lib/phusion_passenger/platform_info/curl_rb.html +126 -0
  227. data/doc/rdoc/files/lib/phusion_passenger/platform_info/documentation_tools_rb.html +126 -0
  228. data/doc/rdoc/files/lib/phusion_passenger/platform_info/linux_rb.html +126 -0
  229. data/doc/rdoc/files/lib/phusion_passenger/platform_info/operating_system_rb.html +127 -0
  230. data/doc/rdoc/files/lib/phusion_passenger/platform_info/ruby_rb.html +128 -0
  231. data/doc/rdoc/files/lib/phusion_passenger/platform_info/zlib_rb.html +126 -0
  232. data/doc/rdoc/files/lib/phusion_passenger/platform_info_rb.html +122 -0
  233. data/doc/rdoc/files/lib/phusion_passenger/plugin_rb.html +127 -0
  234. data/doc/rdoc/files/lib/phusion_passenger/public_api_rb.html +127 -0
  235. data/doc/rdoc/files/lib/phusion_passenger/rack/application_spawner_rb.html +137 -0
  236. data/doc/rdoc/files/lib/phusion_passenger/rack/request_handler_rb.html +125 -0
  237. data/doc/rdoc/files/lib/phusion_passenger/rails3_extensions/init_rb.html +127 -0
  238. data/doc/rdoc/files/lib/phusion_passenger/simple_benchmarking_rb.html +122 -0
  239. data/doc/rdoc/files/lib/phusion_passenger/spawn_manager_rb.html +160 -0
  240. data/doc/rdoc/files/lib/phusion_passenger/standalone/app_finder_rb.html +127 -0
  241. data/doc/rdoc/files/lib/phusion_passenger/standalone/command_rb.html +136 -0
  242. data/doc/rdoc/files/lib/phusion_passenger/standalone/config_file_rb.html +126 -0
  243. data/doc/rdoc/files/lib/phusion_passenger/standalone/help_command_rb.html +126 -0
  244. data/doc/rdoc/files/lib/phusion_passenger/standalone/main_rb.html +126 -0
  245. data/doc/rdoc/files/lib/phusion_passenger/standalone/package_runtime_command_rb.html +127 -0
  246. data/doc/rdoc/files/lib/phusion_passenger/standalone/runtime_installer_rb.html +133 -0
  247. data/doc/rdoc/files/lib/phusion_passenger/standalone/start_command_rb.html +136 -0
  248. data/doc/rdoc/files/lib/phusion_passenger/standalone/status_command_rb.html +126 -0
  249. data/doc/rdoc/files/lib/phusion_passenger/standalone/stop_command_rb.html +126 -0
  250. data/doc/rdoc/files/lib/phusion_passenger/standalone/utils_rb.html +126 -0
  251. data/doc/rdoc/files/lib/phusion_passenger/standalone/version_command_rb.html +127 -0
  252. data/doc/rdoc/files/lib/phusion_passenger/utils/file_system_watcher_rb.html +126 -0
  253. data/doc/rdoc/files/lib/phusion_passenger/utils/hosts_file_parser_rb.html +120 -0
  254. data/doc/rdoc/files/lib/phusion_passenger/utils/rewindable_input_rb.html +100 -0
  255. data/doc/rdoc/files/lib/phusion_passenger/utils/tmpdir_rb.html +122 -0
  256. data/doc/rdoc/files/lib/phusion_passenger/utils/unseekable_socket_rb.html +126 -0
  257. data/doc/rdoc/files/lib/phusion_passenger/utils_rb.html +179 -0
  258. data/doc/rdoc/files/lib/phusion_passenger/wsgi/application_spawner_rb.html +132 -0
  259. data/doc/rdoc/fr_class_index.html +138 -0
  260. data/doc/rdoc/fr_file_index.html +108 -0
  261. data/doc/rdoc/fr_method_index.html +433 -0
  262. data/doc/rdoc/index.html +26 -0
  263. data/doc/rdoc/rdoc-style.css +187 -0
  264. data/doc/template/horo.rb +613 -0
  265. data/doc/users_guide_snippets/analysis_and_system_maintenance.txt +201 -0
  266. data/doc/users_guide_snippets/appendix_a_about.txt +13 -0
  267. data/doc/users_guide_snippets/appendix_b_terminology.txt +63 -0
  268. data/doc/users_guide_snippets/appendix_c_spawning_methods.txt +303 -0
  269. data/doc/users_guide_snippets/global_queueing_explained.txt +74 -0
  270. data/doc/users_guide_snippets/passenger_spawn_method.txt +49 -0
  271. data/doc/users_guide_snippets/rackup_specifications.txt +71 -0
  272. data/doc/users_guide_snippets/tips.txt +207 -0
  273. data/doc/users_guide_snippets/under_the_hood/page_caching_support.txt +22 -0
  274. data/ext/apache2/Bucket.cpp +190 -0
  275. data/ext/apache2/Bucket.h +87 -0
  276. data/ext/apache2/Configuration.cpp +717 -0
  277. data/ext/apache2/Configuration.h +51 -0
  278. data/ext/apache2/Configuration.hpp +462 -0
  279. data/ext/apache2/DirectoryMapper.h +280 -0
  280. data/ext/apache2/HelperAgent.cpp +365 -0
  281. data/ext/apache2/Hooks.cpp +1757 -0
  282. data/ext/apache2/Hooks.h +45 -0
  283. data/ext/apache2/mod_passenger.c +44 -0
  284. data/ext/boost/algorithm/string/case_conv.hpp +176 -0
  285. data/ext/boost/algorithm/string/compare.hpp +199 -0
  286. data/ext/boost/algorithm/string/concept.hpp +83 -0
  287. data/ext/boost/algorithm/string/config.hpp +28 -0
  288. data/ext/boost/algorithm/string/constants.hpp +36 -0
  289. data/ext/boost/algorithm/string/detail/case_conv.hpp +121 -0
  290. data/ext/boost/algorithm/string/detail/find_format.hpp +204 -0
  291. data/ext/boost/algorithm/string/detail/find_format_all.hpp +273 -0
  292. data/ext/boost/algorithm/string/detail/find_format_store.hpp +89 -0
  293. data/ext/boost/algorithm/string/detail/finder.hpp +646 -0
  294. data/ext/boost/algorithm/string/detail/formatter.hpp +94 -0
  295. data/ext/boost/algorithm/string/detail/replace_storage.hpp +159 -0
  296. data/ext/boost/algorithm/string/detail/sequence.hpp +200 -0
  297. data/ext/boost/algorithm/string/detail/util.hpp +106 -0
  298. data/ext/boost/algorithm/string/erase.hpp +844 -0
  299. data/ext/boost/algorithm/string/find_format.hpp +287 -0
  300. data/ext/boost/algorithm/string/finder.hpp +270 -0
  301. data/ext/boost/algorithm/string/formatter.hpp +103 -0
  302. data/ext/boost/algorithm/string/replace.hpp +928 -0
  303. data/ext/boost/algorithm/string/sequence_traits.hpp +193 -0
  304. data/ext/boost/algorithm/string/yes_no_type.hpp +33 -0
  305. data/ext/boost/assert.hpp +50 -0
  306. data/ext/boost/bind.hpp +24 -0
  307. data/ext/boost/bind/arg.hpp +62 -0
  308. data/ext/boost/bind/bind.hpp +1751 -0
  309. data/ext/boost/bind/bind_cc.hpp +117 -0
  310. data/ext/boost/bind/bind_mf2_cc.hpp +228 -0
  311. data/ext/boost/bind/bind_mf_cc.hpp +227 -0
  312. data/ext/boost/bind/bind_template.hpp +345 -0
  313. data/ext/boost/bind/mem_fn.hpp +389 -0
  314. data/ext/boost/bind/mem_fn_cc.hpp +103 -0
  315. data/ext/boost/bind/mem_fn_template.hpp +1047 -0
  316. data/ext/boost/bind/placeholders.hpp +69 -0
  317. data/ext/boost/bind/storage.hpp +475 -0
  318. data/ext/boost/call_traits.hpp +24 -0
  319. data/ext/boost/checked_delete.hpp +69 -0
  320. data/ext/boost/concept/assert.hpp +46 -0
  321. data/ext/boost/concept/detail/backward_compatibility.hpp +16 -0
  322. data/ext/boost/concept/detail/concept_def.hpp +51 -0
  323. data/ext/boost/concept/detail/concept_undef.hpp +5 -0
  324. data/ext/boost/concept/detail/general.hpp +75 -0
  325. data/ext/boost/concept/detail/has_constraints.hpp +50 -0
  326. data/ext/boost/concept/usage.hpp +44 -0
  327. data/ext/boost/concept_check.hpp +1007 -0
  328. data/ext/boost/config.hpp +70 -0
  329. data/ext/boost/config/abi/borland_prefix.hpp +27 -0
  330. data/ext/boost/config/abi/borland_suffix.hpp +12 -0
  331. data/ext/boost/config/abi/msvc_prefix.hpp +22 -0
  332. data/ext/boost/config/abi/msvc_suffix.hpp +8 -0
  333. data/ext/boost/config/abi_prefix.hpp +25 -0
  334. data/ext/boost/config/abi_suffix.hpp +27 -0
  335. data/ext/boost/config/auto_link.hpp +420 -0
  336. data/ext/boost/config/compiler/borland.hpp +275 -0
  337. data/ext/boost/config/compiler/clang.hpp +62 -0
  338. data/ext/boost/config/compiler/codegear.hpp +177 -0
  339. data/ext/boost/config/compiler/comeau.hpp +59 -0
  340. data/ext/boost/config/compiler/common_edg.hpp +99 -0
  341. data/ext/boost/config/compiler/compaq_cxx.hpp +19 -0
  342. data/ext/boost/config/compiler/digitalmars.hpp +93 -0
  343. data/ext/boost/config/compiler/gcc.hpp +243 -0
  344. data/ext/boost/config/compiler/gcc_xml.hpp +55 -0
  345. data/ext/boost/config/compiler/greenhills.hpp +28 -0
  346. data/ext/boost/config/compiler/hp_acc.hpp +127 -0
  347. data/ext/boost/config/compiler/intel.hpp +196 -0
  348. data/ext/boost/config/compiler/kai.hpp +33 -0
  349. data/ext/boost/config/compiler/metrowerks.hpp +139 -0
  350. data/ext/boost/config/compiler/mpw.hpp +81 -0
  351. data/ext/boost/config/compiler/nvcc.hpp +86 -0
  352. data/ext/boost/config/compiler/pgi.hpp +77 -0
  353. data/ext/boost/config/compiler/sgi_mipspro.hpp +29 -0
  354. data/ext/boost/config/compiler/sunpro_cc.hpp +144 -0
  355. data/ext/boost/config/compiler/vacpp.hpp +96 -0
  356. data/ext/boost/config/compiler/visualc.hpp +274 -0
  357. data/ext/boost/config/no_tr1/cmath.hpp +28 -0
  358. data/ext/boost/config/no_tr1/complex.hpp +28 -0
  359. data/ext/boost/config/no_tr1/functional.hpp +28 -0
  360. data/ext/boost/config/no_tr1/memory.hpp +28 -0
  361. data/ext/boost/config/no_tr1/utility.hpp +28 -0
  362. data/ext/boost/config/platform/aix.hpp +33 -0
  363. data/ext/boost/config/platform/amigaos.hpp +15 -0
  364. data/ext/boost/config/platform/beos.hpp +26 -0
  365. data/ext/boost/config/platform/bsd.hpp +86 -0
  366. data/ext/boost/config/platform/cygwin.hpp +48 -0
  367. data/ext/boost/config/platform/hpux.hpp +87 -0
  368. data/ext/boost/config/platform/irix.hpp +31 -0
  369. data/ext/boost/config/platform/linux.hpp +98 -0
  370. data/ext/boost/config/platform/macos.hpp +86 -0
  371. data/ext/boost/config/platform/qnxnto.hpp +31 -0
  372. data/ext/boost/config/platform/solaris.hpp +28 -0
  373. data/ext/boost/config/platform/symbian.hpp +94 -0
  374. data/ext/boost/config/platform/vxworks.hpp +31 -0
  375. data/ext/boost/config/platform/win32.hpp +65 -0
  376. data/ext/boost/config/posix_features.hpp +95 -0
  377. data/ext/boost/config/requires_threads.hpp +92 -0
  378. data/ext/boost/config/select_compiler_config.hpp +129 -0
  379. data/ext/boost/config/select_platform_config.hpp +98 -0
  380. data/ext/boost/config/select_stdlib_config.hpp +77 -0
  381. data/ext/boost/config/stdlib/dinkumware.hpp +148 -0
  382. data/ext/boost/config/stdlib/libcomo.hpp +72 -0
  383. data/ext/boost/config/stdlib/libstdcpp3.hpp +128 -0
  384. data/ext/boost/config/stdlib/modena.hpp +56 -0
  385. data/ext/boost/config/stdlib/msl.hpp +84 -0
  386. data/ext/boost/config/stdlib/roguewave.hpp +180 -0
  387. data/ext/boost/config/stdlib/sgi.hpp +137 -0
  388. data/ext/boost/config/stdlib/stlport.hpp +237 -0
  389. data/ext/boost/config/stdlib/vacpp.hpp +44 -0
  390. data/ext/boost/config/suffix.hpp +639 -0
  391. data/ext/boost/config/user.hpp +124 -0
  392. data/ext/boost/config/warning_disable.hpp +47 -0
  393. data/ext/boost/cstdint.hpp +504 -0
  394. data/ext/boost/current_function.hpp +67 -0
  395. data/ext/boost/date_time/adjust_functors.hpp +178 -0
  396. data/ext/boost/date_time/c_time.hpp +107 -0
  397. data/ext/boost/date_time/compiler_config.hpp +171 -0
  398. data/ext/boost/date_time/constrained_value.hpp +121 -0
  399. data/ext/boost/date_time/date.hpp +208 -0
  400. data/ext/boost/date_time/date_clock_device.hpp +77 -0
  401. data/ext/boost/date_time/date_defs.hpp +26 -0
  402. data/ext/boost/date_time/date_duration.hpp +146 -0
  403. data/ext/boost/date_time/date_duration_types.hpp +269 -0
  404. data/ext/boost/date_time/date_facet.hpp +764 -0
  405. data/ext/boost/date_time/date_format_simple.hpp +159 -0
  406. data/ext/boost/date_time/date_formatting.hpp +127 -0
  407. data/ext/boost/date_time/date_formatting_limited.hpp +121 -0
  408. data/ext/boost/date_time/date_formatting_locales.hpp +233 -0
  409. data/ext/boost/date_time/date_generator_formatter.hpp +265 -0
  410. data/ext/boost/date_time/date_generator_parser.hpp +330 -0
  411. data/ext/boost/date_time/date_generators.hpp +509 -0
  412. data/ext/boost/date_time/date_iterator.hpp +101 -0
  413. data/ext/boost/date_time/date_names_put.hpp +320 -0
  414. data/ext/boost/date_time/date_parsing.hpp +316 -0
  415. data/ext/boost/date_time/dst_rules.hpp +391 -0
  416. data/ext/boost/date_time/filetime_functions.hpp +170 -0
  417. data/ext/boost/date_time/format_date_parser.hpp +743 -0
  418. data/ext/boost/date_time/gregorian/conversion.hpp +68 -0
  419. data/ext/boost/date_time/gregorian/formatters.hpp +162 -0
  420. data/ext/boost/date_time/gregorian/formatters_limited.hpp +81 -0
  421. data/ext/boost/date_time/gregorian/greg_calendar.hpp +48 -0
  422. data/ext/boost/date_time/gregorian/greg_date.hpp +136 -0
  423. data/ext/boost/date_time/gregorian/greg_day.hpp +57 -0
  424. data/ext/boost/date_time/gregorian/greg_day_of_year.hpp +38 -0
  425. data/ext/boost/date_time/gregorian/greg_duration.hpp +134 -0
  426. data/ext/boost/date_time/gregorian/greg_duration_types.hpp +43 -0
  427. data/ext/boost/date_time/gregorian/greg_month.hpp +105 -0
  428. data/ext/boost/date_time/gregorian/greg_weekday.hpp +66 -0
  429. data/ext/boost/date_time/gregorian/greg_year.hpp +53 -0
  430. data/ext/boost/date_time/gregorian/greg_ymd.hpp +33 -0
  431. data/ext/boost/date_time/gregorian/gregorian.hpp +38 -0
  432. data/ext/boost/date_time/gregorian/gregorian_io.hpp +784 -0
  433. data/ext/boost/date_time/gregorian/gregorian_types.hpp +109 -0
  434. data/ext/boost/date_time/gregorian/parsers.hpp +91 -0
  435. data/ext/boost/date_time/gregorian_calendar.hpp +70 -0
  436. data/ext/boost/date_time/gregorian_calendar.ipp +219 -0
  437. data/ext/boost/date_time/int_adapter.hpp +509 -0
  438. data/ext/boost/date_time/iso_format.hpp +303 -0
  439. data/ext/boost/date_time/locale_config.hpp +31 -0
  440. data/ext/boost/date_time/microsec_time_clock.hpp +127 -0
  441. data/ext/boost/date_time/parse_format_base.hpp +29 -0
  442. data/ext/boost/date_time/period.hpp +377 -0
  443. data/ext/boost/date_time/period_formatter.hpp +196 -0
  444. data/ext/boost/date_time/period_parser.hpp +198 -0
  445. data/ext/boost/date_time/posix_time/conversion.hpp +94 -0
  446. data/ext/boost/date_time/posix_time/date_duration_operators.hpp +114 -0
  447. data/ext/boost/date_time/posix_time/posix_time.hpp +39 -0
  448. data/ext/boost/date_time/posix_time/posix_time_config.hpp +178 -0
  449. data/ext/boost/date_time/posix_time/posix_time_duration.hpp +82 -0
  450. data/ext/boost/date_time/posix_time/posix_time_io.hpp +239 -0
  451. data/ext/boost/date_time/posix_time/posix_time_system.hpp +68 -0
  452. data/ext/boost/date_time/posix_time/posix_time_types.hpp +55 -0
  453. data/ext/boost/date_time/posix_time/ptime.hpp +65 -0
  454. data/ext/boost/date_time/posix_time/time_formatters.hpp +289 -0
  455. data/ext/boost/date_time/posix_time/time_parsers.hpp +44 -0
  456. data/ext/boost/date_time/posix_time/time_period.hpp +29 -0
  457. data/ext/boost/date_time/special_defs.hpp +25 -0
  458. data/ext/boost/date_time/special_values_formatter.hpp +96 -0
  459. data/ext/boost/date_time/special_values_parser.hpp +159 -0
  460. data/ext/boost/date_time/string_convert.hpp +33 -0
  461. data/ext/boost/date_time/string_parse_tree.hpp +278 -0
  462. data/ext/boost/date_time/strings_from_facet.hpp +125 -0
  463. data/ext/boost/date_time/time.hpp +191 -0
  464. data/ext/boost/date_time/time_clock.hpp +83 -0
  465. data/ext/boost/date_time/time_defs.hpp +43 -0
  466. data/ext/boost/date_time/time_duration.hpp +282 -0
  467. data/ext/boost/date_time/time_facet.hpp +1367 -0
  468. data/ext/boost/date_time/time_formatting_streams.hpp +122 -0
  469. data/ext/boost/date_time/time_iterator.hpp +52 -0
  470. data/ext/boost/date_time/time_parsing.hpp +321 -0
  471. data/ext/boost/date_time/time_resolution_traits.hpp +144 -0
  472. data/ext/boost/date_time/time_system_counted.hpp +254 -0
  473. data/ext/boost/date_time/time_system_split.hpp +207 -0
  474. data/ext/boost/date_time/wrapping_int.hpp +169 -0
  475. data/ext/boost/date_time/year_month_day.hpp +45 -0
  476. data/ext/boost/detail/call_traits.hpp +164 -0
  477. data/ext/boost/detail/endian.hpp +76 -0
  478. data/ext/boost/detail/indirect_traits.hpp +487 -0
  479. data/ext/boost/detail/iterator.hpp +494 -0
  480. data/ext/boost/detail/lcast_precision.hpp +184 -0
  481. data/ext/boost/detail/limits.hpp +449 -0
  482. data/ext/boost/detail/no_exceptions_support.hpp +87 -0
  483. data/ext/boost/detail/reference_content.hpp +141 -0
  484. data/ext/boost/detail/sp_typeinfo.hpp +129 -0
  485. data/ext/boost/detail/workaround.hpp +267 -0
  486. data/ext/boost/enable_shared_from_this.hpp +18 -0
  487. data/ext/boost/exception/current_exception_cast.hpp +43 -0
  488. data/ext/boost/exception/detail/attribute_noreturn.hpp +17 -0
  489. data/ext/boost/exception/detail/error_info_impl.hpp +75 -0
  490. data/ext/boost/exception/detail/exception_ptr.hpp +431 -0
  491. data/ext/boost/exception/detail/is_output_streamable.hpp +60 -0
  492. data/ext/boost/exception/detail/object_hex_dump.hpp +50 -0
  493. data/ext/boost/exception/detail/type_info.hpp +83 -0
  494. data/ext/boost/exception/diagnostic_information.hpp +184 -0
  495. data/ext/boost/exception/exception.hpp +436 -0
  496. data/ext/boost/exception/get_error_info.hpp +130 -0
  497. data/ext/boost/exception/info.hpp +200 -0
  498. data/ext/boost/exception/to_string.hpp +83 -0
  499. data/ext/boost/exception/to_string_stub.hpp +109 -0
  500. data/ext/boost/exception_ptr.hpp +11 -0
  501. data/ext/boost/function.hpp +66 -0
  502. data/ext/boost/function/detail/function_iterate.hpp +16 -0
  503. data/ext/boost/function/detail/maybe_include.hpp +267 -0
  504. data/ext/boost/function/detail/prologue.hpp +26 -0
  505. data/ext/boost/function/function_base.hpp +904 -0
  506. data/ext/boost/function/function_fwd.hpp +70 -0
  507. data/ext/boost/function/function_template.hpp +1158 -0
  508. data/ext/boost/function_equal.hpp +28 -0
  509. data/ext/boost/get_pointer.hpp +33 -0
  510. data/ext/boost/implicit_cast.hpp +29 -0
  511. data/ext/boost/integer.hpp +257 -0
  512. data/ext/boost/integer_fwd.hpp +180 -0
  513. data/ext/boost/integer_traits.hpp +261 -0
  514. data/ext/boost/io/ios_state.hpp +439 -0
  515. data/ext/boost/io_fwd.hpp +67 -0
  516. data/ext/boost/is_placeholder.hpp +31 -0
  517. data/ext/boost/iterator.hpp +59 -0
  518. data/ext/boost/iterator/detail/config_def.hpp +137 -0
  519. data/ext/boost/iterator/detail/config_undef.hpp +25 -0
  520. data/ext/boost/iterator/detail/enable_if.hpp +86 -0
  521. data/ext/boost/iterator/detail/facade_iterator_category.hpp +200 -0
  522. data/ext/boost/iterator/detail/minimum_category.hpp +116 -0
  523. data/ext/boost/iterator/interoperable.hpp +50 -0
  524. data/ext/boost/iterator/iterator_adaptor.hpp +371 -0
  525. data/ext/boost/iterator/iterator_categories.hpp +188 -0
  526. data/ext/boost/iterator/iterator_concepts.hpp +284 -0
  527. data/ext/boost/iterator/iterator_facade.hpp +878 -0
  528. data/ext/boost/iterator/iterator_traits.hpp +92 -0
  529. data/ext/boost/iterator/reverse_iterator.hpp +69 -0
  530. data/ext/boost/iterator/transform_iterator.hpp +187 -0
  531. data/ext/boost/lexical_cast.hpp +1213 -0
  532. data/ext/boost/limits.hpp +146 -0
  533. data/ext/boost/make_shared.hpp +17 -0
  534. data/ext/boost/mem_fn.hpp +24 -0
  535. data/ext/boost/memory_order.hpp +53 -0
  536. data/ext/boost/mpl/always.hpp +39 -0
  537. data/ext/boost/mpl/and.hpp +60 -0
  538. data/ext/boost/mpl/apply.hpp +229 -0
  539. data/ext/boost/mpl/apply_fwd.hpp +107 -0
  540. data/ext/boost/mpl/apply_wrap.hpp +234 -0
  541. data/ext/boost/mpl/arg.hpp +131 -0
  542. data/ext/boost/mpl/arg_fwd.hpp +28 -0
  543. data/ext/boost/mpl/assert.hpp +370 -0
  544. data/ext/boost/mpl/aux_/adl_barrier.hpp +48 -0
  545. data/ext/boost/mpl/aux_/arg_typedef.hpp +31 -0
  546. data/ext/boost/mpl/aux_/arity.hpp +39 -0
  547. data/ext/boost/mpl/aux_/arity_spec.hpp +67 -0
  548. data/ext/boost/mpl/aux_/common_name_wknd.hpp +34 -0
  549. data/ext/boost/mpl/aux_/config/adl.hpp +40 -0
  550. data/ext/boost/mpl/aux_/config/arrays.hpp +30 -0
  551. data/ext/boost/mpl/aux_/config/bcc.hpp +28 -0
  552. data/ext/boost/mpl/aux_/config/bind.hpp +33 -0
  553. data/ext/boost/mpl/aux_/config/compiler.hpp +66 -0
  554. data/ext/boost/mpl/aux_/config/ctps.hpp +30 -0
  555. data/ext/boost/mpl/aux_/config/dtp.hpp +46 -0
  556. data/ext/boost/mpl/aux_/config/eti.hpp +47 -0
  557. data/ext/boost/mpl/aux_/config/gcc.hpp +23 -0
  558. data/ext/boost/mpl/aux_/config/has_apply.hpp +32 -0
  559. data/ext/boost/mpl/aux_/config/has_xxx.hpp +34 -0
  560. data/ext/boost/mpl/aux_/config/integral.hpp +38 -0
  561. data/ext/boost/mpl/aux_/config/intel.hpp +21 -0
  562. data/ext/boost/mpl/aux_/config/lambda.hpp +32 -0
  563. data/ext/boost/mpl/aux_/config/msvc.hpp +21 -0
  564. data/ext/boost/mpl/aux_/config/msvc_typename.hpp +26 -0
  565. data/ext/boost/mpl/aux_/config/nttp.hpp +41 -0
  566. data/ext/boost/mpl/aux_/config/overload_resolution.hpp +29 -0
  567. data/ext/boost/mpl/aux_/config/pp_counter.hpp +26 -0
  568. data/ext/boost/mpl/aux_/config/preprocessor.hpp +39 -0
  569. data/ext/boost/mpl/aux_/config/static_constant.hpp +25 -0
  570. data/ext/boost/mpl/aux_/config/ttp.hpp +41 -0
  571. data/ext/boost/mpl/aux_/config/use_preprocessed.hpp +19 -0
  572. data/ext/boost/mpl/aux_/config/workaround.hpp +19 -0
  573. data/ext/boost/mpl/aux_/full_lambda.hpp +354 -0
  574. data/ext/boost/mpl/aux_/has_apply.hpp +32 -0
  575. data/ext/boost/mpl/aux_/has_type.hpp +23 -0
  576. data/ext/boost/mpl/aux_/include_preprocessed.hpp +42 -0
  577. data/ext/boost/mpl/aux_/integral_wrapper.hpp +93 -0
  578. data/ext/boost/mpl/aux_/lambda_arity_param.hpp +25 -0
  579. data/ext/boost/mpl/aux_/lambda_support.hpp +169 -0
  580. data/ext/boost/mpl/aux_/msvc_never_true.hpp +34 -0
  581. data/ext/boost/mpl/aux_/na.hpp +95 -0
  582. data/ext/boost/mpl/aux_/na_assert.hpp +34 -0
  583. data/ext/boost/mpl/aux_/na_fwd.hpp +31 -0
  584. data/ext/boost/mpl/aux_/na_spec.hpp +175 -0
  585. data/ext/boost/mpl/aux_/nested_type_wknd.hpp +48 -0
  586. data/ext/boost/mpl/aux_/nttp_decl.hpp +35 -0
  587. data/ext/boost/mpl/aux_/preprocessed/gcc/and.hpp +69 -0
  588. data/ext/boost/mpl/aux_/preprocessed/gcc/apply.hpp +169 -0
  589. data/ext/boost/mpl/aux_/preprocessed/gcc/apply_fwd.hpp +52 -0
  590. data/ext/boost/mpl/aux_/preprocessed/gcc/apply_wrap.hpp +84 -0
  591. data/ext/boost/mpl/aux_/preprocessed/gcc/arg.hpp +123 -0
  592. data/ext/boost/mpl/aux_/preprocessed/gcc/bind.hpp +561 -0
  593. data/ext/boost/mpl/aux_/preprocessed/gcc/bind_fwd.hpp +52 -0
  594. data/ext/boost/mpl/aux_/preprocessed/gcc/full_lambda.hpp +558 -0
  595. data/ext/boost/mpl/aux_/preprocessed/gcc/or.hpp +69 -0
  596. data/ext/boost/mpl/aux_/preprocessed/gcc/placeholders.hpp +105 -0
  597. data/ext/boost/mpl/aux_/preprocessed/gcc/quote.hpp +123 -0
  598. data/ext/boost/mpl/aux_/preprocessed/gcc/template_arity.hpp +97 -0
  599. data/ext/boost/mpl/aux_/preprocessor/def_params_tail.hpp +105 -0
  600. data/ext/boost/mpl/aux_/preprocessor/enum.hpp +62 -0
  601. data/ext/boost/mpl/aux_/preprocessor/filter_params.hpp +28 -0
  602. data/ext/boost/mpl/aux_/preprocessor/params.hpp +65 -0
  603. data/ext/boost/mpl/aux_/preprocessor/sub.hpp +65 -0
  604. data/ext/boost/mpl/aux_/static_cast.hpp +27 -0
  605. data/ext/boost/mpl/aux_/template_arity.hpp +189 -0
  606. data/ext/boost/mpl/aux_/template_arity_fwd.hpp +23 -0
  607. data/ext/boost/mpl/aux_/type_wrapper.hpp +47 -0
  608. data/ext/boost/mpl/aux_/value_wknd.hpp +89 -0
  609. data/ext/boost/mpl/aux_/yes_no.hpp +58 -0
  610. data/ext/boost/mpl/bind.hpp +551 -0
  611. data/ext/boost/mpl/bind_fwd.hpp +99 -0
  612. data/ext/boost/mpl/bool.hpp +39 -0
  613. data/ext/boost/mpl/bool_fwd.hpp +33 -0
  614. data/ext/boost/mpl/eval_if.hpp +71 -0
  615. data/ext/boost/mpl/has_xxx.hpp +640 -0
  616. data/ext/boost/mpl/identity.hpp +45 -0
  617. data/ext/boost/mpl/if.hpp +135 -0
  618. data/ext/boost/mpl/int.hpp +22 -0
  619. data/ext/boost/mpl/int_fwd.hpp +27 -0
  620. data/ext/boost/mpl/integral_c.hpp +51 -0
  621. data/ext/boost/mpl/integral_c_fwd.hpp +32 -0
  622. data/ext/boost/mpl/integral_c_tag.hpp +26 -0
  623. data/ext/boost/mpl/lambda.hpp +29 -0
  624. data/ext/boost/mpl/lambda_fwd.hpp +57 -0
  625. data/ext/boost/mpl/limits/arity.hpp +21 -0
  626. data/ext/boost/mpl/logical.hpp +21 -0
  627. data/ext/boost/mpl/next.hpp +19 -0
  628. data/ext/boost/mpl/next_prior.hpp +49 -0
  629. data/ext/boost/mpl/not.hpp +51 -0
  630. data/ext/boost/mpl/or.hpp +61 -0
  631. data/ext/boost/mpl/placeholders.hpp +100 -0
  632. data/ext/boost/mpl/protect.hpp +55 -0
  633. data/ext/boost/mpl/quote.hpp +151 -0
  634. data/ext/boost/mpl/size_t.hpp +25 -0
  635. data/ext/boost/mpl/size_t_fwd.hpp +28 -0
  636. data/ext/boost/mpl/void.hpp +76 -0
  637. data/ext/boost/mpl/void_fwd.hpp +26 -0
  638. data/ext/boost/next_prior.hpp +51 -0
  639. data/ext/boost/non_type.hpp +27 -0
  640. data/ext/boost/noncopyable.hpp +36 -0
  641. data/ext/boost/none.hpp +28 -0
  642. data/ext/boost/none_t.hpp +24 -0
  643. data/ext/boost/operators.hpp +976 -0
  644. data/ext/boost/optional.hpp +18 -0
  645. data/ext/boost/optional/optional.hpp +924 -0
  646. data/ext/boost/optional/optional_fwd.hpp +22 -0
  647. data/ext/boost/preprocessor/arithmetic/add.hpp +51 -0
  648. data/ext/boost/preprocessor/arithmetic/dec.hpp +288 -0
  649. data/ext/boost/preprocessor/arithmetic/detail/div_base.hpp +61 -0
  650. data/ext/boost/preprocessor/arithmetic/inc.hpp +288 -0
  651. data/ext/boost/preprocessor/arithmetic/mod.hpp +39 -0
  652. data/ext/boost/preprocessor/arithmetic/sub.hpp +50 -0
  653. data/ext/boost/preprocessor/array/data.hpp +28 -0
  654. data/ext/boost/preprocessor/array/elem.hpp +29 -0
  655. data/ext/boost/preprocessor/array/size.hpp +28 -0
  656. data/ext/boost/preprocessor/cat.hpp +35 -0
  657. data/ext/boost/preprocessor/comma_if.hpp +17 -0
  658. data/ext/boost/preprocessor/comparison/less_equal.hpp +39 -0
  659. data/ext/boost/preprocessor/config/config.hpp +70 -0
  660. data/ext/boost/preprocessor/control/deduce_d.hpp +22 -0
  661. data/ext/boost/preprocessor/control/detail/while.hpp +536 -0
  662. data/ext/boost/preprocessor/control/expr_iif.hpp +31 -0
  663. data/ext/boost/preprocessor/control/if.hpp +30 -0
  664. data/ext/boost/preprocessor/control/iif.hpp +34 -0
  665. data/ext/boost/preprocessor/control/while.hpp +312 -0
  666. data/ext/boost/preprocessor/debug/error.hpp +33 -0
  667. data/ext/boost/preprocessor/detail/auto_rec.hpp +293 -0
  668. data/ext/boost/preprocessor/detail/check.hpp +48 -0
  669. data/ext/boost/preprocessor/detail/is_binary.hpp +30 -0
  670. data/ext/boost/preprocessor/empty.hpp +17 -0
  671. data/ext/boost/preprocessor/enum.hpp +17 -0
  672. data/ext/boost/preprocessor/enum_params.hpp +17 -0
  673. data/ext/boost/preprocessor/facilities/empty.hpp +21 -0
  674. data/ext/boost/preprocessor/facilities/identity.hpp +23 -0
  675. data/ext/boost/preprocessor/identity.hpp +17 -0
  676. data/ext/boost/preprocessor/inc.hpp +17 -0
  677. data/ext/boost/preprocessor/iterate.hpp +17 -0
  678. data/ext/boost/preprocessor/iteration/detail/bounds/lower1.hpp +99 -0
  679. data/ext/boost/preprocessor/iteration/detail/bounds/upper1.hpp +99 -0
  680. data/ext/boost/preprocessor/iteration/detail/iter/forward1.hpp +1342 -0
  681. data/ext/boost/preprocessor/iteration/iterate.hpp +82 -0
  682. data/ext/boost/preprocessor/list/adt.hpp +73 -0
  683. data/ext/boost/preprocessor/list/append.hpp +40 -0
  684. data/ext/boost/preprocessor/list/detail/fold_left.hpp +279 -0
  685. data/ext/boost/preprocessor/list/detail/fold_right.hpp +277 -0
  686. data/ext/boost/preprocessor/list/fold_left.hpp +303 -0
  687. data/ext/boost/preprocessor/list/fold_right.hpp +40 -0
  688. data/ext/boost/preprocessor/list/for_each_i.hpp +65 -0
  689. data/ext/boost/preprocessor/list/reverse.hpp +40 -0
  690. data/ext/boost/preprocessor/list/transform.hpp +49 -0
  691. data/ext/boost/preprocessor/logical/and.hpp +30 -0
  692. data/ext/boost/preprocessor/logical/bitand.hpp +38 -0
  693. data/ext/boost/preprocessor/logical/bool.hpp +288 -0
  694. data/ext/boost/preprocessor/logical/compl.hpp +36 -0
  695. data/ext/boost/preprocessor/logical/not.hpp +30 -0
  696. data/ext/boost/preprocessor/punctuation/comma.hpp +21 -0
  697. data/ext/boost/preprocessor/punctuation/comma_if.hpp +31 -0
  698. data/ext/boost/preprocessor/repeat.hpp +17 -0
  699. data/ext/boost/preprocessor/repetition/detail/for.hpp +536 -0
  700. data/ext/boost/preprocessor/repetition/enum.hpp +66 -0
  701. data/ext/boost/preprocessor/repetition/enum_binary_params.hpp +54 -0
  702. data/ext/boost/preprocessor/repetition/enum_params.hpp +41 -0
  703. data/ext/boost/preprocessor/repetition/enum_trailing_params.hpp +38 -0
  704. data/ext/boost/preprocessor/repetition/for.hpp +306 -0
  705. data/ext/boost/preprocessor/repetition/repeat.hpp +825 -0
  706. data/ext/boost/preprocessor/repetition/repeat_from_to.hpp +87 -0
  707. data/ext/boost/preprocessor/seq/cat.hpp +48 -0
  708. data/ext/boost/preprocessor/seq/elem.hpp +304 -0
  709. data/ext/boost/preprocessor/seq/enum.hpp +288 -0
  710. data/ext/boost/preprocessor/seq/fold_left.hpp +1070 -0
  711. data/ext/boost/preprocessor/seq/for_each_i.hpp +61 -0
  712. data/ext/boost/preprocessor/seq/seq.hpp +44 -0
  713. data/ext/boost/preprocessor/seq/size.hpp +548 -0
  714. data/ext/boost/preprocessor/seq/transform.hpp +48 -0
  715. data/ext/boost/preprocessor/slot/detail/def.hpp +49 -0
  716. data/ext/boost/preprocessor/slot/detail/shared.hpp +247 -0
  717. data/ext/boost/preprocessor/slot/slot.hpp +32 -0
  718. data/ext/boost/preprocessor/stringize.hpp +33 -0
  719. data/ext/boost/preprocessor/tuple/eat.hpp +57 -0
  720. data/ext/boost/preprocessor/tuple/elem.hpp +385 -0
  721. data/ext/boost/preprocessor/tuple/rem.hpp +72 -0
  722. data/ext/boost/preprocessor/tuple/to_list.hpp +62 -0
  723. data/ext/boost/range/algorithm/equal.hpp +188 -0
  724. data/ext/boost/range/as_literal.hpp +127 -0
  725. data/ext/boost/range/begin.hpp +132 -0
  726. data/ext/boost/range/concepts.hpp +331 -0
  727. data/ext/boost/range/config.hpp +54 -0
  728. data/ext/boost/range/const_iterator.hpp +67 -0
  729. data/ext/boost/range/detail/common.hpp +117 -0
  730. data/ext/boost/range/detail/extract_optional_type.hpp +52 -0
  731. data/ext/boost/range/detail/implementation_help.hpp +103 -0
  732. data/ext/boost/range/detail/misc_concept.hpp +33 -0
  733. data/ext/boost/range/detail/sfinae.hpp +77 -0
  734. data/ext/boost/range/detail/str_types.hpp +38 -0
  735. data/ext/boost/range/difference_type.hpp +29 -0
  736. data/ext/boost/range/distance.hpp +34 -0
  737. data/ext/boost/range/empty.hpp +34 -0
  738. data/ext/boost/range/end.hpp +131 -0
  739. data/ext/boost/range/functions.hpp +27 -0
  740. data/ext/boost/range/iterator.hpp +72 -0
  741. data/ext/boost/range/iterator_range.hpp +16 -0
  742. data/ext/boost/range/iterator_range_core.hpp +542 -0
  743. data/ext/boost/range/iterator_range_io.hpp +93 -0
  744. data/ext/boost/range/mutable_iterator.hpp +67 -0
  745. data/ext/boost/range/rbegin.hpp +65 -0
  746. data/ext/boost/range/rend.hpp +65 -0
  747. data/ext/boost/range/reverse_iterator.hpp +40 -0
  748. data/ext/boost/range/size.hpp +36 -0
  749. data/ext/boost/range/size_type.hpp +79 -0
  750. data/ext/boost/range/value_type.hpp +34 -0
  751. data/ext/boost/ref.hpp +189 -0
  752. data/ext/boost/scoped_array.hpp +16 -0
  753. data/ext/boost/scoped_ptr.hpp +16 -0
  754. data/ext/boost/shared_array.hpp +19 -0
  755. data/ext/boost/shared_ptr.hpp +19 -0
  756. data/ext/boost/smart_ptr/bad_weak_ptr.hpp +59 -0
  757. data/ext/boost/smart_ptr/detail/atomic_count.hpp +119 -0
  758. data/ext/boost/smart_ptr/detail/atomic_count_gcc.hpp +72 -0
  759. data/ext/boost/smart_ptr/detail/atomic_count_gcc_x86.hpp +77 -0
  760. data/ext/boost/smart_ptr/detail/atomic_count_pthreads.hpp +96 -0
  761. data/ext/boost/smart_ptr/detail/atomic_count_solaris.hpp +59 -0
  762. data/ext/boost/smart_ptr/detail/atomic_count_sync.hpp +61 -0
  763. data/ext/boost/smart_ptr/detail/atomic_count_win32.hpp +63 -0
  764. data/ext/boost/smart_ptr/detail/operator_bool.hpp +56 -0
  765. data/ext/boost/smart_ptr/detail/shared_count.hpp +444 -0
  766. data/ext/boost/smart_ptr/detail/sp_convertible.hpp +76 -0
  767. data/ext/boost/smart_ptr/detail/sp_counted_base.hpp +70 -0
  768. data/ext/boost/smart_ptr/detail/sp_counted_base_acc_ia64.hpp +150 -0
  769. data/ext/boost/smart_ptr/detail/sp_counted_base_cw_ppc.hpp +170 -0
  770. data/ext/boost/smart_ptr/detail/sp_counted_base_cw_x86.hpp +158 -0
  771. data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_ia64.hpp +157 -0
  772. data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_mips.hpp +172 -0
  773. data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_ppc.hpp +181 -0
  774. data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_sparc.hpp +166 -0
  775. data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_x86.hpp +173 -0
  776. data/ext/boost/smart_ptr/detail/sp_counted_base_nt.hpp +107 -0
  777. data/ext/boost/smart_ptr/detail/sp_counted_base_pt.hpp +135 -0
  778. data/ext/boost/smart_ptr/detail/sp_counted_base_solaris.hpp +113 -0
  779. data/ext/boost/smart_ptr/detail/sp_counted_base_spin.hpp +131 -0
  780. data/ext/boost/smart_ptr/detail/sp_counted_base_sync.hpp +155 -0
  781. data/ext/boost/smart_ptr/detail/sp_counted_base_w32.hpp +130 -0
  782. data/ext/boost/smart_ptr/detail/sp_counted_impl.hpp +231 -0
  783. data/ext/boost/smart_ptr/detail/sp_has_sync.hpp +49 -0
  784. data/ext/boost/smart_ptr/detail/spinlock.hpp +53 -0
  785. data/ext/boost/smart_ptr/detail/spinlock_gcc_arm.hpp +85 -0
  786. data/ext/boost/smart_ptr/detail/spinlock_nt.hpp +89 -0
  787. data/ext/boost/smart_ptr/detail/spinlock_pool.hpp +87 -0
  788. data/ext/boost/smart_ptr/detail/spinlock_pt.hpp +79 -0
  789. data/ext/boost/smart_ptr/detail/spinlock_sync.hpp +87 -0
  790. data/ext/boost/smart_ptr/detail/yield_k.hpp +149 -0
  791. data/ext/boost/smart_ptr/enable_shared_from_this.hpp +79 -0
  792. data/ext/boost/smart_ptr/make_shared.hpp +508 -0
  793. data/ext/boost/smart_ptr/scoped_array.hpp +107 -0
  794. data/ext/boost/smart_ptr/scoped_ptr.hpp +131 -0
  795. data/ext/boost/smart_ptr/shared_array.hpp +147 -0
  796. data/ext/boost/smart_ptr/shared_ptr.hpp +701 -0
  797. data/ext/boost/smart_ptr/weak_ptr.hpp +230 -0
  798. data/ext/boost/src/pthread/once.cpp +51 -0
  799. data/ext/boost/src/pthread/thread.cpp +616 -0
  800. data/ext/boost/src/pthread/timeconv.inl +133 -0
  801. data/ext/boost/src/tss_null.cpp +34 -0
  802. data/ext/boost/static_assert.hpp +132 -0
  803. data/ext/boost/thread.hpp +26 -0
  804. data/ext/boost/thread/barrier.hpp +64 -0
  805. data/ext/boost/thread/condition.hpp +16 -0
  806. data/ext/boost/thread/condition_variable.hpp +21 -0
  807. data/ext/boost/thread/detail/config.hpp +100 -0
  808. data/ext/boost/thread/detail/force_cast.hpp +39 -0
  809. data/ext/boost/thread/detail/move.hpp +60 -0
  810. data/ext/boost/thread/detail/platform.hpp +71 -0
  811. data/ext/boost/thread/detail/singleton.hpp +59 -0
  812. data/ext/boost/thread/detail/thread.hpp +540 -0
  813. data/ext/boost/thread/detail/thread_group.hpp +108 -0
  814. data/ext/boost/thread/detail/thread_heap_alloc.hpp +23 -0
  815. data/ext/boost/thread/detail/thread_interruption.hpp +35 -0
  816. data/ext/boost/thread/detail/tss_hooks.hpp +65 -0
  817. data/ext/boost/thread/exceptions.hpp +223 -0
  818. data/ext/boost/thread/future.hpp +1375 -0
  819. data/ext/boost/thread/locks.hpp +1585 -0
  820. data/ext/boost/thread/mutex.hpp +21 -0
  821. data/ext/boost/thread/once.hpp +33 -0
  822. data/ext/boost/thread/pthread/condition_variable.hpp +179 -0
  823. data/ext/boost/thread/pthread/condition_variable_fwd.hpp +102 -0
  824. data/ext/boost/thread/pthread/mutex.hpp +236 -0
  825. data/ext/boost/thread/pthread/once.hpp +95 -0
  826. data/ext/boost/thread/pthread/pthread_mutex_scoped_lock.hpp +54 -0
  827. data/ext/boost/thread/pthread/recursive_mutex.hpp +345 -0
  828. data/ext/boost/thread/pthread/shared_mutex.hpp +303 -0
  829. data/ext/boost/thread/pthread/thread_data.hpp +129 -0
  830. data/ext/boost/thread/pthread/thread_heap_alloc.hpp +242 -0
  831. data/ext/boost/thread/pthread/timespec.hpp +36 -0
  832. data/ext/boost/thread/recursive_mutex.hpp +21 -0
  833. data/ext/boost/thread/shared_mutex.hpp +21 -0
  834. data/ext/boost/thread/thread.hpp +27 -0
  835. data/ext/boost/thread/thread_time.hpp +50 -0
  836. data/ext/boost/thread/tss.hpp +113 -0
  837. data/ext/boost/thread/xtime.hpp +92 -0
  838. data/ext/boost/throw_exception.hpp +91 -0
  839. data/ext/boost/token_functions.hpp +641 -0
  840. data/ext/boost/token_iterator.hpp +128 -0
  841. data/ext/boost/tokenizer.hpp +98 -0
  842. data/ext/boost/type.hpp +18 -0
  843. data/ext/boost/type_traits/add_const.hpp +47 -0
  844. data/ext/boost/type_traits/add_pointer.hpp +72 -0
  845. data/ext/boost/type_traits/add_reference.hpp +107 -0
  846. data/ext/boost/type_traits/add_volatile.hpp +47 -0
  847. data/ext/boost/type_traits/alignment_of.hpp +128 -0
  848. data/ext/boost/type_traits/broken_compiler_spec.hpp +117 -0
  849. data/ext/boost/type_traits/composite_traits.hpp +29 -0
  850. data/ext/boost/type_traits/config.hpp +76 -0
  851. data/ext/boost/type_traits/conversion_traits.hpp +17 -0
  852. data/ext/boost/type_traits/detail/bool_trait_def.hpp +173 -0
  853. data/ext/boost/type_traits/detail/bool_trait_undef.hpp +27 -0
  854. data/ext/boost/type_traits/detail/cv_traits_impl.hpp +97 -0
  855. data/ext/boost/type_traits/detail/false_result.hpp +28 -0
  856. data/ext/boost/type_traits/detail/ice_and.hpp +35 -0
  857. data/ext/boost/type_traits/detail/ice_eq.hpp +36 -0
  858. data/ext/boost/type_traits/detail/ice_not.hpp +31 -0
  859. data/ext/boost/type_traits/detail/ice_or.hpp +34 -0
  860. data/ext/boost/type_traits/detail/is_function_ptr_helper.hpp +220 -0
  861. data/ext/boost/type_traits/detail/is_mem_fun_pointer_impl.hpp +817 -0
  862. data/ext/boost/type_traits/detail/size_t_trait_def.hpp +58 -0
  863. data/ext/boost/type_traits/detail/size_t_trait_undef.hpp +16 -0
  864. data/ext/boost/type_traits/detail/template_arity_spec.hpp +31 -0
  865. data/ext/boost/type_traits/detail/type_trait_def.hpp +61 -0
  866. data/ext/boost/type_traits/detail/type_trait_undef.hpp +19 -0
  867. data/ext/boost/type_traits/detail/yes_no_type.hpp +26 -0
  868. data/ext/boost/type_traits/function_traits.hpp +236 -0
  869. data/ext/boost/type_traits/has_nothrow_copy.hpp +39 -0
  870. data/ext/boost/type_traits/has_trivial_copy.hpp +49 -0
  871. data/ext/boost/type_traits/has_trivial_destructor.hpp +42 -0
  872. data/ext/boost/type_traits/ice.hpp +20 -0
  873. data/ext/boost/type_traits/integral_constant.hpp +53 -0
  874. data/ext/boost/type_traits/intrinsics.hpp +240 -0
  875. data/ext/boost/type_traits/is_abstract.hpp +153 -0
  876. data/ext/boost/type_traits/is_arithmetic.hpp +51 -0
  877. data/ext/boost/type_traits/is_array.hpp +91 -0
  878. data/ext/boost/type_traits/is_base_and_derived.hpp +254 -0
  879. data/ext/boost/type_traits/is_base_of.hpp +51 -0
  880. data/ext/boost/type_traits/is_class.hpp +140 -0
  881. data/ext/boost/type_traits/is_const.hpp +165 -0
  882. data/ext/boost/type_traits/is_convertible.hpp +430 -0
  883. data/ext/boost/type_traits/is_enum.hpp +189 -0
  884. data/ext/boost/type_traits/is_float.hpp +27 -0
  885. data/ext/boost/type_traits/is_function.hpp +106 -0
  886. data/ext/boost/type_traits/is_fundamental.hpp +45 -0
  887. data/ext/boost/type_traits/is_integral.hpp +78 -0
  888. data/ext/boost/type_traits/is_lvalue_reference.hpp +118 -0
  889. data/ext/boost/type_traits/is_member_function_pointer.hpp +136 -0
  890. data/ext/boost/type_traits/is_member_pointer.hpp +116 -0
  891. data/ext/boost/type_traits/is_pod.hpp +135 -0
  892. data/ext/boost/type_traits/is_pointer.hpp +162 -0
  893. data/ext/boost/type_traits/is_reference.hpp +45 -0
  894. data/ext/boost/type_traits/is_rvalue_reference.hpp +29 -0
  895. data/ext/boost/type_traits/is_same.hpp +103 -0
  896. data/ext/boost/type_traits/is_scalar.hpp +55 -0
  897. data/ext/boost/type_traits/is_signed.hpp +135 -0
  898. data/ext/boost/type_traits/is_union.hpp +49 -0
  899. data/ext/boost/type_traits/is_unsigned.hpp +130 -0
  900. data/ext/boost/type_traits/is_void.hpp +38 -0
  901. data/ext/boost/type_traits/is_volatile.hpp +152 -0
  902. data/ext/boost/type_traits/make_unsigned.hpp +137 -0
  903. data/ext/boost/type_traits/remove_const.hpp +90 -0
  904. data/ext/boost/type_traits/remove_cv.hpp +83 -0
  905. data/ext/boost/type_traits/remove_pointer.hpp +43 -0
  906. data/ext/boost/type_traits/remove_reference.hpp +70 -0
  907. data/ext/boost/type_traits/type_with_alignment.hpp +393 -0
  908. data/ext/boost/units/detail/utility.hpp +104 -0
  909. data/ext/boost/utility.hpp +20 -0
  910. data/ext/boost/utility/addressof.hpp +102 -0
  911. data/ext/boost/utility/base_from_member.hpp +87 -0
  912. data/ext/boost/utility/binary.hpp +708 -0
  913. data/ext/boost/utility/compare_pointees.hpp +68 -0
  914. data/ext/boost/utility/enable_if.hpp +119 -0
  915. data/ext/boost/visit_each.hpp +29 -0
  916. data/ext/boost/weak_ptr.hpp +18 -0
  917. data/ext/common/AbstractSpawnManager.h +110 -0
  918. data/ext/common/Account.h +175 -0
  919. data/ext/common/AccountsDatabase.cpp +81 -0
  920. data/ext/common/AccountsDatabase.h +130 -0
  921. data/ext/common/AgentBase.cpp +323 -0
  922. data/ext/common/AgentBase.h +39 -0
  923. data/ext/common/AgentsStarter.cpp +154 -0
  924. data/ext/common/AgentsStarter.h +81 -0
  925. data/ext/common/AgentsStarter.hpp +646 -0
  926. data/ext/common/ApplicationPool/Client.h +796 -0
  927. data/ext/common/ApplicationPool/Interface.h +295 -0
  928. data/ext/common/ApplicationPool/Pool.h +1327 -0
  929. data/ext/common/ApplicationPool/Server.h +475 -0
  930. data/ext/common/BCrypt.cpp +343 -0
  931. data/ext/common/BCrypt.h +73 -0
  932. data/ext/common/Blowfish.c +685 -0
  933. data/ext/common/Blowfish.h +103 -0
  934. data/ext/common/Constants.h +48 -0
  935. data/ext/common/EventedClient.h +702 -0
  936. data/ext/common/EventedMessageServer.h +327 -0
  937. data/ext/common/EventedServer.h +295 -0
  938. data/ext/common/Exceptions.h +348 -0
  939. data/ext/common/FileDescriptor.h +293 -0
  940. data/ext/common/HelperAgent/BacktracesServer.h +59 -0
  941. data/ext/common/IniFile.h +488 -0
  942. data/ext/common/Logging.cpp +64 -0
  943. data/ext/common/Logging.h +695 -0
  944. data/ext/common/LoggingAgent/ChangeNotifier.h +63 -0
  945. data/ext/common/LoggingAgent/DataStoreId.h +177 -0
  946. data/ext/common/LoggingAgent/LoggingServer.h +1343 -0
  947. data/ext/common/LoggingAgent/Main.cpp +278 -0
  948. data/ext/common/LoggingAgent/RemoteSender.h +468 -0
  949. data/ext/common/MessageChannel.h +737 -0
  950. data/ext/common/MessageClient.h +297 -0
  951. data/ext/common/MessageReadersWriters.h +508 -0
  952. data/ext/common/MessageServer.h +581 -0
  953. data/ext/common/PoolOptions.h +518 -0
  954. data/ext/common/Process.h +255 -0
  955. data/ext/common/RandomGenerator.h +160 -0
  956. data/ext/common/ResourceLocator.h +134 -0
  957. data/ext/common/SafeLibev.h +149 -0
  958. data/ext/common/ServerInstanceDir.h +347 -0
  959. data/ext/common/Session.h +470 -0
  960. data/ext/common/SpawnManager.h +616 -0
  961. data/ext/common/StaticString.h +298 -0
  962. data/ext/common/StringListCreator.h +83 -0
  963. data/ext/common/Utils.cpp +972 -0
  964. data/ext/common/Utils.h +428 -0
  965. data/ext/common/Utils/Base64.cpp +143 -0
  966. data/ext/common/Utils/Base64.h +83 -0
  967. data/ext/common/Utils/BlockingQueue.h +136 -0
  968. data/ext/common/Utils/BufferedIO.h +196 -0
  969. data/ext/common/Utils/CachedFileStat.cpp +62 -0
  970. data/ext/common/Utils/CachedFileStat.h +51 -0
  971. data/ext/common/Utils/CachedFileStat.hpp +243 -0
  972. data/ext/common/Utils/FileChangeChecker.h +209 -0
  973. data/ext/common/Utils/IOUtils.cpp +913 -0
  974. data/ext/common/Utils/IOUtils.h +370 -0
  975. data/ext/common/Utils/MD5.cpp +406 -0
  976. data/ext/common/Utils/MD5.h +98 -0
  977. data/ext/common/Utils/MemZeroGuard.h +103 -0
  978. data/ext/common/Utils/ProcessMetricsCollector.h +590 -0
  979. data/ext/common/Utils/ScopeGuard.h +72 -0
  980. data/ext/common/Utils/StrIntUtils.cpp +363 -0
  981. data/ext/common/Utils/StrIntUtils.h +231 -0
  982. data/ext/common/Utils/SystemTime.cpp +37 -0
  983. data/ext/common/Utils/SystemTime.h +201 -0
  984. data/ext/common/Utils/Timer.h +152 -0
  985. data/ext/common/Utils/VariantMap.h +363 -0
  986. data/ext/common/Utils/utf8.h +35 -0
  987. data/ext/common/Utils/utf8/checked.h +324 -0
  988. data/ext/common/Utils/utf8/core.h +359 -0
  989. data/ext/common/Utils/utf8/unchecked.h +229 -0
  990. data/ext/common/Watchdog.cpp +1001 -0
  991. data/ext/google/COPYING +28 -0
  992. data/ext/google/ChangeLog +167 -0
  993. data/ext/google/dense_hash_map +310 -0
  994. data/ext/google/dense_hash_set +287 -0
  995. data/ext/google/sparse_hash_map +294 -0
  996. data/ext/google/sparse_hash_set +275 -0
  997. data/ext/google/sparsehash/densehashtable.h +1062 -0
  998. data/ext/google/sparsehash/sparseconfig.h +55 -0
  999. data/ext/google/sparsehash/sparsehashtable.h +1015 -0
  1000. data/ext/google/sparsetable +1468 -0
  1001. data/ext/google/type_traits.h +250 -0
  1002. data/ext/libev/Changes +302 -0
  1003. data/ext/libev/LICENSE +36 -0
  1004. data/ext/libev/Makefile.am +18 -0
  1005. data/ext/libev/Makefile.in +685 -0
  1006. data/ext/libev/README +58 -0
  1007. data/ext/libev/aclocal.m4 +7549 -0
  1008. data/ext/libev/autogen.sh +6 -0
  1009. data/ext/libev/config.guess +1526 -0
  1010. data/ext/libev/config.h.in +121 -0
  1011. data/ext/libev/config.sub +1658 -0
  1012. data/ext/libev/configure +22156 -0
  1013. data/ext/libev/configure.ac +18 -0
  1014. data/ext/libev/ev++.h +800 -0
  1015. data/ext/libev/ev.c +3694 -0
  1016. data/ext/libev/ev.h +705 -0
  1017. data/ext/libev/ev_epoll.c +228 -0
  1018. data/ext/libev/ev_kqueue.c +196 -0
  1019. data/ext/libev/ev_poll.c +144 -0
  1020. data/ext/libev/ev_port.c +165 -0
  1021. data/ext/libev/ev_select.c +308 -0
  1022. data/ext/libev/ev_vars.h +187 -0
  1023. data/ext/libev/ev_win32.c +153 -0
  1024. data/ext/libev/ev_wrap.h +178 -0
  1025. data/ext/libev/event.c +401 -0
  1026. data/ext/libev/event.h +158 -0
  1027. data/ext/libev/install-sh +294 -0
  1028. data/ext/libev/libev.m4 +38 -0
  1029. data/ext/libev/ltmain.sh +6871 -0
  1030. data/ext/libev/missing +336 -0
  1031. data/ext/libev/mkinstalldirs +111 -0
  1032. data/ext/nginx/Configuration.c +1454 -0
  1033. data/ext/nginx/Configuration.h +94 -0
  1034. data/ext/nginx/ContentHandler.c +1360 -0
  1035. data/ext/nginx/ContentHandler.h +64 -0
  1036. data/ext/nginx/HelperAgent.cpp +988 -0
  1037. data/ext/nginx/HttpStatusExtractor.h +351 -0
  1038. data/ext/nginx/ScgiRequestParser.h +375 -0
  1039. data/ext/nginx/StaticContentHandler.c +256 -0
  1040. data/ext/nginx/StaticContentHandler.h +37 -0
  1041. data/ext/nginx/config +56 -0
  1042. data/ext/nginx/ngx_http_passenger_module.c +499 -0
  1043. data/ext/nginx/ngx_http_passenger_module.h +63 -0
  1044. data/ext/oxt/backtrace.cpp +185 -0
  1045. data/ext/oxt/backtrace.hpp +135 -0
  1046. data/ext/oxt/detail/backtrace_disabled.hpp +39 -0
  1047. data/ext/oxt/detail/backtrace_enabled.hpp +156 -0
  1048. data/ext/oxt/detail/spin_lock_darwin.hpp +69 -0
  1049. data/ext/oxt/detail/spin_lock_gcc_x86.hpp +81 -0
  1050. data/ext/oxt/detail/spin_lock_portable.hpp +38 -0
  1051. data/ext/oxt/detail/spin_lock_pthreads.hpp +97 -0
  1052. data/ext/oxt/detail/tracable_exception_disabled.hpp +46 -0
  1053. data/ext/oxt/detail/tracable_exception_enabled.hpp +48 -0
  1054. data/ext/oxt/dynamic_thread_group.hpp +195 -0
  1055. data/ext/oxt/macros.hpp +58 -0
  1056. data/ext/oxt/spin_lock.hpp +57 -0
  1057. data/ext/oxt/system_calls.cpp +477 -0
  1058. data/ext/oxt/system_calls.hpp +260 -0
  1059. data/ext/oxt/thread.cpp +32 -0
  1060. data/ext/oxt/thread.hpp +370 -0
  1061. data/ext/oxt/tracable_exception.cpp +87 -0
  1062. data/ext/oxt/tracable_exception.hpp +35 -0
  1063. data/ext/ruby/extconf.rb +41 -0
  1064. data/ext/ruby/passenger_native_support.c +1037 -0
  1065. data/helper-scripts/passenger-spawn-server +106 -0
  1066. data/helper-scripts/prespawn +63 -0
  1067. data/lib/phusion_passenger.rb +107 -0
  1068. data/lib/phusion_passenger/abstract_installer.rb +234 -0
  1069. data/lib/phusion_passenger/abstract_request_handler.rb +738 -0
  1070. data/lib/phusion_passenger/abstract_server.rb +372 -0
  1071. data/lib/phusion_passenger/abstract_server_collection.rb +335 -0
  1072. data/lib/phusion_passenger/admin_tools.rb +48 -0
  1073. data/lib/phusion_passenger/admin_tools/memory_stats.rb +299 -0
  1074. data/lib/phusion_passenger/admin_tools/server_instance.rb +334 -0
  1075. data/lib/phusion_passenger/analytics_logger.rb +342 -0
  1076. data/lib/phusion_passenger/app_process.rb +162 -0
  1077. data/lib/phusion_passenger/classic_rails/application_spawner.rb +344 -0
  1078. data/lib/phusion_passenger/classic_rails/cgi_fixed.rb +68 -0
  1079. data/lib/phusion_passenger/classic_rails/framework_spawner.rb +311 -0
  1080. data/lib/phusion_passenger/classic_rails/request_handler.rb +75 -0
  1081. data/lib/phusion_passenger/classic_rails_extensions/analytics_logging/ac_base_extension.rb +65 -0
  1082. data/lib/phusion_passenger/classic_rails_extensions/analytics_logging/ac_benchmarking_extension.rb +48 -0
  1083. data/lib/phusion_passenger/classic_rails_extensions/analytics_logging/ac_rescue_extension.rb +59 -0
  1084. data/lib/phusion_passenger/classic_rails_extensions/analytics_logging/ar_abstract_adapter_extension.rb +54 -0
  1085. data/lib/phusion_passenger/classic_rails_extensions/analytics_logging/as_cache_extension.rb +130 -0
  1086. data/lib/phusion_passenger/classic_rails_extensions/analytics_logging/av_benchmark_helper_extension.rb +47 -0
  1087. data/lib/phusion_passenger/classic_rails_extensions/init.rb +123 -0
  1088. data/lib/phusion_passenger/console_text_template.rb +66 -0
  1089. data/lib/phusion_passenger/constants.rb +35 -0
  1090. data/lib/phusion_passenger/debug_logging.rb +104 -0
  1091. data/lib/phusion_passenger/dependencies.rb +633 -0
  1092. data/lib/phusion_passenger/exceptions.rb +103 -0
  1093. data/lib/phusion_passenger/html_template.rb +107 -0
  1094. data/lib/phusion_passenger/message_channel.rb +387 -0
  1095. data/lib/phusion_passenger/message_client.rb +173 -0
  1096. data/lib/phusion_passenger/native_support.rb +166 -0
  1097. data/lib/phusion_passenger/packaging.rb +108 -0
  1098. data/lib/phusion_passenger/platform_info.rb +248 -0
  1099. data/lib/phusion_passenger/platform_info/apache.rb +332 -0
  1100. data/lib/phusion_passenger/platform_info/binary_compatibility.rb +175 -0
  1101. data/lib/phusion_passenger/platform_info/compiler.rb +183 -0
  1102. data/lib/phusion_passenger/platform_info/curl.rb +61 -0
  1103. data/lib/phusion_passenger/platform_info/documentation_tools.rb +35 -0
  1104. data/lib/phusion_passenger/platform_info/linux.rb +77 -0
  1105. data/lib/phusion_passenger/platform_info/operating_system.rb +158 -0
  1106. data/lib/phusion_passenger/platform_info/ruby.rb +338 -0
  1107. data/lib/phusion_passenger/platform_info/zlib.rb +38 -0
  1108. data/lib/phusion_passenger/plugin.rb +96 -0
  1109. data/lib/phusion_passenger/public_api.rb +112 -0
  1110. data/lib/phusion_passenger/rack/application_spawner.rb +227 -0
  1111. data/lib/phusion_passenger/rack/request_handler.rb +145 -0
  1112. data/lib/phusion_passenger/rails3_extensions/init.rb +207 -0
  1113. data/lib/phusion_passenger/simple_benchmarking.rb +52 -0
  1114. data/lib/phusion_passenger/spawn_manager.rb +359 -0
  1115. data/lib/phusion_passenger/standalone/app_finder.rb +153 -0
  1116. data/lib/phusion_passenger/standalone/command.rb +241 -0
  1117. data/lib/phusion_passenger/standalone/config_file.rb +119 -0
  1118. data/lib/phusion_passenger/standalone/help_command.rb +57 -0
  1119. data/lib/phusion_passenger/standalone/main.rb +101 -0
  1120. data/lib/phusion_passenger/standalone/package_runtime_command.rb +92 -0
  1121. data/lib/phusion_passenger/standalone/runtime_installer.rb +479 -0
  1122. data/lib/phusion_passenger/standalone/start_command.rb +514 -0
  1123. data/lib/phusion_passenger/standalone/status_command.rb +62 -0
  1124. data/lib/phusion_passenger/standalone/stop_command.rb +74 -0
  1125. data/lib/phusion_passenger/standalone/utils.rb +46 -0
  1126. data/lib/phusion_passenger/standalone/version_command.rb +42 -0
  1127. data/lib/phusion_passenger/templates/apache2/apache_must_be_compiled_with_compatible_mpm.txt.erb +9 -0
  1128. data/lib/phusion_passenger/templates/apache2/config_snippets.txt.erb +13 -0
  1129. data/lib/phusion_passenger/templates/apache2/deployment_example.txt.erb +23 -0
  1130. data/lib/phusion_passenger/templates/apache2/no_write_permission_to_passenger_root.txt.erb +9 -0
  1131. data/lib/phusion_passenger/templates/apache2/possible_solutions_for_compilation_and_installation_problems.txt.erb +11 -0
  1132. data/lib/phusion_passenger/templates/apache2/run_installer_as_root.txt.erb +8 -0
  1133. data/lib/phusion_passenger/templates/apache2/welcome.txt.erb +15 -0
  1134. data/lib/phusion_passenger/templates/app_exited_during_initialization.html.erb +38 -0
  1135. data/lib/phusion_passenger/templates/app_init_error.html.erb +64 -0
  1136. data/lib/phusion_passenger/templates/database_error.html.erb +66 -0
  1137. data/lib/phusion_passenger/templates/error_layout.css +97 -0
  1138. data/lib/phusion_passenger/templates/error_layout.html.erb +39 -0
  1139. data/lib/phusion_passenger/templates/framework_init_error.html.erb +39 -0
  1140. data/lib/phusion_passenger/templates/general_error.html.erb +22 -0
  1141. data/lib/phusion_passenger/templates/load_error.html.erb +46 -0
  1142. data/lib/phusion_passenger/templates/nginx/ask_for_extra_configure_flags.txt.erb +8 -0
  1143. data/lib/phusion_passenger/templates/nginx/cannot_write_to_dir.txt.erb +11 -0
  1144. data/lib/phusion_passenger/templates/nginx/config_snippets.txt.erb +17 -0
  1145. data/lib/phusion_passenger/templates/nginx/config_snippets_inserted.txt.erb +20 -0
  1146. data/lib/phusion_passenger/templates/nginx/confirm_extra_configure_flags.txt.erb +5 -0
  1147. data/lib/phusion_passenger/templates/nginx/deployment_example.txt.erb +22 -0
  1148. data/lib/phusion_passenger/templates/nginx/pcre_could_not_be_downloaded.txt.erb +11 -0
  1149. data/lib/phusion_passenger/templates/nginx/pcre_could_not_be_extracted.txt.erb +11 -0
  1150. data/lib/phusion_passenger/templates/nginx/possible_solutions_for_compilation_and_installation_problems.txt.erb +11 -0
  1151. data/lib/phusion_passenger/templates/nginx/possible_solutions_for_download_and_extraction_problems.txt.erb +20 -0
  1152. data/lib/phusion_passenger/templates/nginx/query_download_and_install.txt.erb +21 -0
  1153. data/lib/phusion_passenger/templates/nginx/run_installer_as_root.txt.erb +8 -0
  1154. data/lib/phusion_passenger/templates/nginx/welcome.txt.erb +15 -0
  1155. data/lib/phusion_passenger/templates/standalone/cannot_write_to_dir.txt.erb +11 -0
  1156. data/lib/phusion_passenger/templates/standalone/config.erb +94 -0
  1157. data/lib/phusion_passenger/templates/standalone/possible_solutions_for_download_and_extraction_problems.txt.erb +17 -0
  1158. data/lib/phusion_passenger/templates/standalone/run_installer_as_root.txt.erb +8 -0
  1159. data/lib/phusion_passenger/templates/standalone/welcome.txt.erb +8 -0
  1160. data/lib/phusion_passenger/templates/standalone_default_root/index.html +1 -0
  1161. data/lib/phusion_passenger/templates/version_not_found.html.erb +34 -0
  1162. data/lib/phusion_passenger/utils.rb +1080 -0
  1163. data/lib/phusion_passenger/utils/file_system_watcher.rb +186 -0
  1164. data/lib/phusion_passenger/utils/hosts_file_parser.rb +130 -0
  1165. data/lib/phusion_passenger/utils/rewindable_input.rb +125 -0
  1166. data/lib/phusion_passenger/utils/tmpdir.rb +70 -0
  1167. data/lib/phusion_passenger/utils/unseekable_socket.rb +196 -0
  1168. data/lib/phusion_passenger/wsgi/application_spawner.rb +108 -0
  1169. data/lib/phusion_passenger/wsgi/request_handler.py +199 -0
  1170. data/man/passenger-config.1 +29 -0
  1171. data/man/passenger-make-enterprisey.8 +23 -0
  1172. data/man/passenger-memory-stats.8 +33 -0
  1173. data/man/passenger-status.8 +43 -0
  1174. data/man/passenger-stress-test.1 +43 -0
  1175. data/resources/mime.types +73 -0
  1176. data/resources/union_station_gateway.crt +32 -0
  1177. data/test/config.yml.example +41 -0
  1178. data/test/cxx/ApplicationPool_PoolTest.cpp +33 -0
  1179. data/test/cxx/ApplicationPool_PoolTestCases.cpp +1029 -0
  1180. data/test/cxx/ApplicationPool_ServerTest.cpp +308 -0
  1181. data/test/cxx/ApplicationPool_Server_PoolTest.cpp +80 -0
  1182. data/test/cxx/Base64Test.cpp +50 -0
  1183. data/test/cxx/BufferedIOTest.cpp +364 -0
  1184. data/test/cxx/CachedFileStatTest.cpp +402 -0
  1185. data/test/cxx/CxxTestMain.cpp +122 -0
  1186. data/test/cxx/EventedClientTest.cpp +523 -0
  1187. data/test/cxx/FileChangeCheckerTest.cpp +329 -0
  1188. data/test/cxx/FileDescriptorTest.cpp +69 -0
  1189. data/test/cxx/HttpStatusExtractorTest.cpp +198 -0
  1190. data/test/cxx/IOUtilsTest.cpp +796 -0
  1191. data/test/cxx/LoggingTest.cpp +914 -0
  1192. data/test/cxx/MessageChannelTest.cpp +557 -0
  1193. data/test/cxx/MessageReadersWritersTest.cpp +574 -0
  1194. data/test/cxx/MessageServerTest.cpp +383 -0
  1195. data/test/cxx/PoolOptionsTest.cpp +116 -0
  1196. data/test/cxx/ProcessMetricsCollectorTest.cpp +121 -0
  1197. data/test/cxx/ScgiRequestParserTest.cpp +389 -0
  1198. data/test/cxx/ServerInstanceDirTest.cpp +186 -0
  1199. data/test/cxx/SpawnManagerTest.cpp +161 -0
  1200. data/test/cxx/StaticStringTest.cpp +220 -0
  1201. data/test/cxx/SystemTimeTest.cpp +37 -0
  1202. data/test/cxx/TestSupport.cpp +166 -0
  1203. data/test/cxx/TestSupport.h +254 -0
  1204. data/test/cxx/UtilsTest.cpp +491 -0
  1205. data/test/cxx/VariantMapTest.cpp +179 -0
  1206. data/test/integration_tests/apache2_tests.rb +666 -0
  1207. data/test/integration_tests/cgi_environment_spec.rb +26 -0
  1208. data/test/integration_tests/hello_world_rack_spec.rb +36 -0
  1209. data/test/integration_tests/hello_world_wsgi_spec.rb +41 -0
  1210. data/test/integration_tests/mycook_spec.rb +166 -0
  1211. data/test/integration_tests/nginx_tests.rb +260 -0
  1212. data/test/integration_tests/spec_helper.rb +19 -0
  1213. data/test/oxt/backtrace_test.cpp +88 -0
  1214. data/test/oxt/counter.hpp +55 -0
  1215. data/test/oxt/dynamic_thread_group_test.cpp +131 -0
  1216. data/test/oxt/oxt_test_main.cpp +25 -0
  1217. data/test/oxt/spin_lock_test.cpp +59 -0
  1218. data/test/oxt/syscall_interruption_test.cpp +38 -0
  1219. data/test/ruby/abstract_request_handler_spec.rb +406 -0
  1220. data/test/ruby/abstract_server_collection_spec.rb +247 -0
  1221. data/test/ruby/abstract_server_spec.rb +61 -0
  1222. data/test/ruby/admin_tools_spec.rb +362 -0
  1223. data/test/ruby/analytics_logger_spec.rb +253 -0
  1224. data/test/ruby/app_process_spec.rb +43 -0
  1225. data/test/ruby/classic_rails/application_spawner_spec.rb +89 -0
  1226. data/test/ruby/classic_rails/framework_spawner_spec.rb +92 -0
  1227. data/test/ruby/debug_logging_spec.rb +141 -0
  1228. data/test/ruby/message_channel_spec.rb +196 -0
  1229. data/test/ruby/rack/application_spawner_spec.rb +116 -0
  1230. data/test/ruby/shared/abstract_server_spec.rb +23 -0
  1231. data/test/ruby/shared/rails/analytics_logging_extensions_spec.rb +375 -0
  1232. data/test/ruby/shared/spawners/classic_rails/framework_spawner_spec.rb +38 -0
  1233. data/test/ruby/shared/spawners/classic_rails/lack_of_rails_gem_version_spec.rb +19 -0
  1234. data/test/ruby/shared/spawners/classic_rails/spawner_spec.rb +15 -0
  1235. data/test/ruby/shared/spawners/non_preloading_spawner_spec.rb +27 -0
  1236. data/test/ruby/shared/spawners/preloading_spawner_spec.rb +29 -0
  1237. data/test/ruby/shared/spawners/reload_all_spec.rb +36 -0
  1238. data/test/ruby/shared/spawners/reload_single_spec.rb +52 -0
  1239. data/test/ruby/shared/spawners/spawn_server_spec.rb +28 -0
  1240. data/test/ruby/shared/spawners/spawner_spec.rb +273 -0
  1241. data/test/ruby/shared/utils/pseudo_io_spec.rb +60 -0
  1242. data/test/ruby/spawn_manager_spec.rb +134 -0
  1243. data/test/ruby/spec_helper.rb +104 -0
  1244. data/test/ruby/utils/file_system_watcher_spec.rb +221 -0
  1245. data/test/ruby/utils/hosts_file_parser.rb +258 -0
  1246. data/test/ruby/utils/unseekable_socket_spec.rb +66 -0
  1247. data/test/ruby/utils_spec.rb +748 -0
  1248. data/test/ruby/wsgi/application_spawner_spec.rb +50 -0
  1249. data/test/stub/apache2/httpd.conf.erb +86 -0
  1250. data/test/stub/apache2/mime.types +748 -0
  1251. data/test/stub/garbage1.dat +0 -0
  1252. data/test/stub/garbage2.dat +0 -0
  1253. data/test/stub/garbage3.dat +0 -0
  1254. data/test/stub/http_request.yml +23 -0
  1255. data/test/stub/message_channel.rb +11 -0
  1256. data/test/stub/message_channel_2.rb +12 -0
  1257. data/test/stub/message_channel_3.rb +19 -0
  1258. data/test/stub/nginx/koi-utf +109 -0
  1259. data/test/stub/nginx/koi-win +103 -0
  1260. data/test/stub/nginx/mime.types +70 -0
  1261. data/test/stub/nginx/nginx.conf.erb +58 -0
  1262. data/test/stub/nginx/win-utf +126 -0
  1263. data/test/stub/rack/config.ru +4 -0
  1264. data/test/stub/rack/public/rack.jpg +0 -0
  1265. data/test/stub/rails_apps/1.2/empty/Rakefile +10 -0
  1266. data/test/stub/rails_apps/1.2/empty/app/controllers/application.rb +7 -0
  1267. data/test/stub/rails_apps/1.2/empty/app/helpers/application_helper.rb +3 -0
  1268. data/test/stub/rails_apps/1.2/empty/config/boot.rb +108 -0
  1269. data/test/stub/rails_apps/1.2/empty/config/database.yml +31 -0
  1270. data/test/stub/rails_apps/1.2/empty/config/environment.rb +66 -0
  1271. data/test/stub/rails_apps/1.2/empty/config/environments/development.rb +21 -0
  1272. data/test/stub/rails_apps/1.2/empty/config/environments/production.rb +18 -0
  1273. data/test/stub/rails_apps/1.2/empty/config/environments/staging.rb +18 -0
  1274. data/test/stub/rails_apps/1.2/empty/config/environments/test.rb +19 -0
  1275. data/test/stub/rails_apps/1.2/empty/config/routes.rb +23 -0
  1276. data/test/stub/rails_apps/1.2/empty/doc/README_FOR_APP +2 -0
  1277. data/test/stub/rails_apps/1.2/empty/public/404.html +30 -0
  1278. data/test/stub/rails_apps/1.2/empty/public/500.html +30 -0
  1279. data/test/stub/rails_apps/1.2/empty/public/dispatch.cgi +10 -0
  1280. data/test/stub/rails_apps/1.2/empty/public/dispatch.fcgi +24 -0
  1281. data/test/stub/rails_apps/1.2/empty/public/dispatch.rb +10 -0
  1282. data/test/stub/rails_apps/1.2/empty/public/favicon.ico +0 -0
  1283. data/test/stub/rails_apps/1.2/empty/public/images/rails.png +0 -0
  1284. data/test/stub/rails_apps/1.2/empty/public/robots.txt +1 -0
  1285. data/test/stub/rails_apps/1.2/empty/script/about +3 -0
  1286. data/test/stub/rails_apps/1.2/empty/script/breakpointer +3 -0
  1287. data/test/stub/rails_apps/1.2/empty/script/console +3 -0
  1288. data/test/stub/rails_apps/1.2/empty/script/destroy +3 -0
  1289. data/test/stub/rails_apps/1.2/empty/script/generate +3 -0
  1290. data/test/stub/rails_apps/1.2/empty/script/performance/benchmarker +3 -0
  1291. data/test/stub/rails_apps/1.2/empty/script/performance/profiler +3 -0
  1292. data/test/stub/rails_apps/1.2/empty/script/plugin +3 -0
  1293. data/test/stub/rails_apps/1.2/empty/script/process/inspector +3 -0
  1294. data/test/stub/rails_apps/1.2/empty/script/process/reaper +3 -0
  1295. data/test/stub/rails_apps/1.2/empty/script/process/spawner +3 -0
  1296. data/test/stub/rails_apps/1.2/empty/script/runner +3 -0
  1297. data/test/stub/rails_apps/1.2/empty/script/server +3 -0
  1298. data/test/stub/rails_apps/1.2/empty/test/test_helper.rb +28 -0
  1299. data/test/stub/rails_apps/2.0/empty/Rakefile +10 -0
  1300. data/test/stub/rails_apps/2.0/empty/app/controllers/application.rb +10 -0
  1301. data/test/stub/rails_apps/2.0/empty/app/helpers/application_helper.rb +3 -0
  1302. data/test/stub/rails_apps/2.0/empty/config/boot.rb +108 -0
  1303. data/test/stub/rails_apps/2.0/empty/config/database.yml +31 -0
  1304. data/test/stub/rails_apps/2.0/empty/config/environment.rb +59 -0
  1305. data/test/stub/rails_apps/2.0/empty/config/environments/development.rb +18 -0
  1306. data/test/stub/rails_apps/2.0/empty/config/environments/production.rb +18 -0
  1307. data/test/stub/rails_apps/2.0/empty/config/environments/staging.rb +18 -0
  1308. data/test/stub/rails_apps/2.0/empty/config/environments/test.rb +22 -0
  1309. data/test/stub/rails_apps/2.0/empty/config/initializers/inflections.rb +10 -0
  1310. data/test/stub/rails_apps/2.0/empty/config/initializers/mime_types.rb +5 -0
  1311. data/test/stub/rails_apps/2.0/empty/config/routes.rb +35 -0
  1312. data/test/stub/rails_apps/2.0/empty/doc/README_FOR_APP +2 -0
  1313. data/test/stub/rails_apps/2.0/empty/public/404.html +30 -0
  1314. data/test/stub/rails_apps/2.0/empty/public/422.html +30 -0
  1315. data/test/stub/rails_apps/2.0/empty/public/500.html +30 -0
  1316. data/test/stub/rails_apps/2.0/empty/public/dispatch.cgi +10 -0
  1317. data/test/stub/rails_apps/2.0/empty/public/dispatch.fcgi +24 -0
  1318. data/test/stub/rails_apps/2.0/empty/public/dispatch.rb +10 -0
  1319. data/test/stub/rails_apps/2.0/empty/public/favicon.ico +0 -0
  1320. data/test/stub/rails_apps/2.0/empty/public/images/rails.png +0 -0
  1321. data/test/stub/rails_apps/2.0/empty/public/robots.txt +5 -0
  1322. data/test/stub/rails_apps/2.0/empty/script/about +3 -0
  1323. data/test/stub/rails_apps/2.0/empty/script/console +3 -0
  1324. data/test/stub/rails_apps/2.0/empty/script/destroy +3 -0
  1325. data/test/stub/rails_apps/2.0/empty/script/generate +3 -0
  1326. data/test/stub/rails_apps/2.0/empty/script/performance/benchmarker +3 -0
  1327. data/test/stub/rails_apps/2.0/empty/script/performance/profiler +3 -0
  1328. data/test/stub/rails_apps/2.0/empty/script/performance/request +3 -0
  1329. data/test/stub/rails_apps/2.0/empty/script/plugin +3 -0
  1330. data/test/stub/rails_apps/2.0/empty/script/process/inspector +3 -0
  1331. data/test/stub/rails_apps/2.0/empty/script/process/reaper +3 -0
  1332. data/test/stub/rails_apps/2.0/empty/script/process/spawner +3 -0
  1333. data/test/stub/rails_apps/2.0/empty/script/runner +3 -0
  1334. data/test/stub/rails_apps/2.0/empty/script/server +3 -0
  1335. data/test/stub/rails_apps/2.0/empty/test/test_helper.rb +38 -0
  1336. data/test/stub/rails_apps/2.2/empty/Rakefile +10 -0
  1337. data/test/stub/rails_apps/2.2/empty/app/controllers/application.rb +15 -0
  1338. data/test/stub/rails_apps/2.2/empty/app/helpers/application_helper.rb +3 -0
  1339. data/test/stub/rails_apps/2.2/empty/config/boot.rb +109 -0
  1340. data/test/stub/rails_apps/2.2/empty/config/database.yml +31 -0
  1341. data/test/stub/rails_apps/2.2/empty/config/environment.rb +75 -0
  1342. data/test/stub/rails_apps/2.2/empty/config/environments/development.rb +17 -0
  1343. data/test/stub/rails_apps/2.2/empty/config/environments/production.rb +24 -0
  1344. data/test/stub/rails_apps/2.2/empty/config/environments/staging.rb +24 -0
  1345. data/test/stub/rails_apps/2.2/empty/config/environments/test.rb +22 -0
  1346. data/test/stub/rails_apps/2.2/empty/config/initializers/inflections.rb +10 -0
  1347. data/test/stub/rails_apps/2.2/empty/config/initializers/mime_types.rb +5 -0
  1348. data/test/stub/rails_apps/2.2/empty/config/initializers/new_rails_defaults.rb +17 -0
  1349. data/test/stub/rails_apps/2.2/empty/config/locales/en.yml +5 -0
  1350. data/test/stub/rails_apps/2.2/empty/config/routes.rb +43 -0
  1351. data/test/stub/rails_apps/2.2/empty/doc/README_FOR_APP +5 -0
  1352. data/test/stub/rails_apps/2.2/empty/public/404.html +30 -0
  1353. data/test/stub/rails_apps/2.2/empty/public/422.html +30 -0
  1354. data/test/stub/rails_apps/2.2/empty/public/500.html +33 -0
  1355. data/test/stub/rails_apps/2.2/empty/public/dispatch.cgi +10 -0
  1356. data/test/stub/rails_apps/2.2/empty/public/dispatch.fcgi +24 -0
  1357. data/test/stub/rails_apps/2.2/empty/public/dispatch.rb +10 -0
  1358. data/test/stub/rails_apps/2.2/empty/public/favicon.ico +0 -0
  1359. data/test/stub/rails_apps/2.2/empty/public/images/rails.png +0 -0
  1360. data/test/stub/rails_apps/2.2/empty/public/robots.txt +5 -0
  1361. data/test/stub/rails_apps/2.2/empty/script/about +4 -0
  1362. data/test/stub/rails_apps/2.2/empty/script/console +3 -0
  1363. data/test/stub/rails_apps/2.2/empty/script/dbconsole +3 -0
  1364. data/test/stub/rails_apps/2.2/empty/script/destroy +3 -0
  1365. data/test/stub/rails_apps/2.2/empty/script/generate +3 -0
  1366. data/test/stub/rails_apps/2.2/empty/script/performance/benchmarker +3 -0
  1367. data/test/stub/rails_apps/2.2/empty/script/performance/profiler +3 -0
  1368. data/test/stub/rails_apps/2.2/empty/script/performance/request +3 -0
  1369. data/test/stub/rails_apps/2.2/empty/script/plugin +3 -0
  1370. data/test/stub/rails_apps/2.2/empty/script/process/inspector +3 -0
  1371. data/test/stub/rails_apps/2.2/empty/script/process/reaper +3 -0
  1372. data/test/stub/rails_apps/2.2/empty/script/process/spawner +3 -0
  1373. data/test/stub/rails_apps/2.2/empty/script/runner +3 -0
  1374. data/test/stub/rails_apps/2.2/empty/script/server +3 -0
  1375. data/test/stub/rails_apps/2.2/empty/test/performance/browsing_test.rb +9 -0
  1376. data/test/stub/rails_apps/2.2/empty/test/test_helper.rb +38 -0
  1377. data/test/stub/rails_apps/2.3/empty/Rakefile +10 -0
  1378. data/test/stub/rails_apps/2.3/empty/app/controllers/application_controller.rb +10 -0
  1379. data/test/stub/rails_apps/2.3/empty/app/helpers/application_helper.rb +3 -0
  1380. data/test/stub/rails_apps/2.3/empty/config/boot.rb +110 -0
  1381. data/test/stub/rails_apps/2.3/empty/config/database.yml +31 -0
  1382. data/test/stub/rails_apps/2.3/empty/config/environment.rb +41 -0
  1383. data/test/stub/rails_apps/2.3/empty/config/environments/development.rb +17 -0
  1384. data/test/stub/rails_apps/2.3/empty/config/environments/production.rb +28 -0
  1385. data/test/stub/rails_apps/2.3/empty/config/environments/staging.rb +28 -0
  1386. data/test/stub/rails_apps/2.3/empty/config/environments/test.rb +28 -0
  1387. data/test/stub/rails_apps/2.3/empty/config/initializers/backtrace_silencers.rb +7 -0
  1388. data/test/stub/rails_apps/2.3/empty/config/initializers/inflections.rb +10 -0
  1389. data/test/stub/rails_apps/2.3/empty/config/initializers/mime_types.rb +5 -0
  1390. data/test/stub/rails_apps/2.3/empty/config/initializers/new_rails_defaults.rb +21 -0
  1391. data/test/stub/rails_apps/2.3/empty/config/initializers/session_store.rb +15 -0
  1392. data/test/stub/rails_apps/2.3/empty/config/locales/en.yml +5 -0
  1393. data/test/stub/rails_apps/2.3/empty/config/routes.rb +43 -0
  1394. data/test/stub/rails_apps/2.3/empty/db/seeds.rb +7 -0
  1395. data/test/stub/rails_apps/2.3/empty/doc/README_FOR_APP +2 -0
  1396. data/test/stub/rails_apps/2.3/empty/public/404.html +30 -0
  1397. data/test/stub/rails_apps/2.3/empty/public/422.html +30 -0
  1398. data/test/stub/rails_apps/2.3/empty/public/500.html +30 -0
  1399. data/test/stub/rails_apps/2.3/empty/public/favicon.ico +0 -0
  1400. data/test/stub/rails_apps/2.3/empty/public/images/rails.png +0 -0
  1401. data/test/stub/rails_apps/2.3/empty/public/robots.txt +5 -0
  1402. data/test/stub/rails_apps/2.3/empty/script/about +4 -0
  1403. data/test/stub/rails_apps/2.3/empty/script/console +3 -0
  1404. data/test/stub/rails_apps/2.3/empty/script/dbconsole +3 -0
  1405. data/test/stub/rails_apps/2.3/empty/script/destroy +3 -0
  1406. data/test/stub/rails_apps/2.3/empty/script/generate +3 -0
  1407. data/test/stub/rails_apps/2.3/empty/script/performance/benchmarker +3 -0
  1408. data/test/stub/rails_apps/2.3/empty/script/performance/profiler +3 -0
  1409. data/test/stub/rails_apps/2.3/empty/script/plugin +3 -0
  1410. data/test/stub/rails_apps/2.3/empty/script/runner +3 -0
  1411. data/test/stub/rails_apps/2.3/empty/script/server +3 -0
  1412. data/test/stub/rails_apps/2.3/empty/test/performance/browsing_test.rb +9 -0
  1413. data/test/stub/rails_apps/2.3/empty/test/test_helper.rb +38 -0
  1414. data/test/stub/rails_apps/2.3/foobar/Rakefile +10 -0
  1415. data/test/stub/rails_apps/2.3/foobar/app/controllers/application_controller.rb +12 -0
  1416. data/test/stub/rails_apps/2.3/foobar/app/controllers/bar_controller_1.rb +5 -0
  1417. data/test/stub/rails_apps/2.3/foobar/app/controllers/bar_controller_2.rb +5 -0
  1418. data/test/stub/rails_apps/2.3/foobar/app/controllers/foo_controller.rb +21 -0
  1419. data/test/stub/rails_apps/2.3/foobar/app/helpers/application_helper.rb +3 -0
  1420. data/test/stub/rails_apps/2.3/foobar/config/boot.rb +110 -0
  1421. data/test/stub/rails_apps/2.3/foobar/config/database.yml +19 -0
  1422. data/test/stub/rails_apps/2.3/foobar/config/environment.rb +59 -0
  1423. data/test/stub/rails_apps/2.3/foobar/config/environments/development.rb +17 -0
  1424. data/test/stub/rails_apps/2.3/foobar/config/environments/production.rb +18 -0
  1425. data/test/stub/rails_apps/2.3/foobar/config/environments/staging.rb +18 -0
  1426. data/test/stub/rails_apps/2.3/foobar/config/initializers/inflections.rb +10 -0
  1427. data/test/stub/rails_apps/2.3/foobar/config/initializers/mime_types.rb +5 -0
  1428. data/test/stub/rails_apps/2.3/foobar/config/routes.rb +35 -0
  1429. data/test/stub/rails_apps/2.3/foobar/script/about +3 -0
  1430. data/test/stub/rails_apps/2.3/foobar/script/console +3 -0
  1431. data/test/stub/rails_apps/2.3/foobar/script/dbconsole +3 -0
  1432. data/test/stub/rails_apps/2.3/foobar/script/destroy +3 -0
  1433. data/test/stub/rails_apps/2.3/foobar/script/generate +3 -0
  1434. data/test/stub/rails_apps/2.3/foobar/script/performance/benchmarker +3 -0
  1435. data/test/stub/rails_apps/2.3/foobar/script/performance/profiler +3 -0
  1436. data/test/stub/rails_apps/2.3/foobar/script/performance/request +3 -0
  1437. data/test/stub/rails_apps/2.3/foobar/script/plugin +3 -0
  1438. data/test/stub/rails_apps/2.3/foobar/script/process/inspector +3 -0
  1439. data/test/stub/rails_apps/2.3/foobar/script/process/reaper +3 -0
  1440. data/test/stub/rails_apps/2.3/foobar/script/process/spawner +3 -0
  1441. data/test/stub/rails_apps/2.3/foobar/script/runner +3 -0
  1442. data/test/stub/rails_apps/2.3/foobar/script/server +3 -0
  1443. data/test/stub/rails_apps/2.3/mycook/Rakefile +10 -0
  1444. data/test/stub/rails_apps/2.3/mycook/app/controllers/application_controller.rb +12 -0
  1445. data/test/stub/rails_apps/2.3/mycook/app/controllers/recipes_controller.rb +5 -0
  1446. data/test/stub/rails_apps/2.3/mycook/app/controllers/uploads_controller.rb +15 -0
  1447. data/test/stub/rails_apps/2.3/mycook/app/controllers/welcome_controller.rb +71 -0
  1448. data/test/stub/rails_apps/2.3/mycook/app/helpers/application_helper.rb +3 -0
  1449. data/test/stub/rails_apps/2.3/mycook/app/views/layouts/default.rhtml +26 -0
  1450. data/test/stub/rails_apps/2.3/mycook/app/views/recipes/create.rhtml +13 -0
  1451. data/test/stub/rails_apps/2.3/mycook/app/views/recipes/index.rhtml +3 -0
  1452. data/test/stub/rails_apps/2.3/mycook/app/views/recipes/new.rhtml +8 -0
  1453. data/test/stub/rails_apps/2.3/mycook/app/views/uploads/index.rhtml +1 -0
  1454. data/test/stub/rails_apps/2.3/mycook/app/views/uploads/new.html.erb +8 -0
  1455. data/test/stub/rails_apps/2.3/mycook/app/views/welcome/cached.rhtml +1 -0
  1456. data/test/stub/rails_apps/2.3/mycook/app/views/welcome/index.rhtml +20 -0
  1457. data/test/stub/rails_apps/2.3/mycook/config/boot.rb +110 -0
  1458. data/test/stub/rails_apps/2.3/mycook/config/database.yml +19 -0
  1459. data/test/stub/rails_apps/2.3/mycook/config/environment.rb +61 -0
  1460. data/test/stub/rails_apps/2.3/mycook/config/environments/development.rb +18 -0
  1461. data/test/stub/rails_apps/2.3/mycook/config/environments/production.rb +19 -0
  1462. data/test/stub/rails_apps/2.3/mycook/config/initializers/inflections.rb +10 -0
  1463. data/test/stub/rails_apps/2.3/mycook/config/initializers/mime_types.rb +5 -0
  1464. data/test/stub/rails_apps/2.3/mycook/config/routes.rb +38 -0
  1465. data/test/stub/rails_apps/2.3/mycook/log/useless.txt +1 -0
  1466. data/test/stub/rails_apps/2.3/mycook/public/404.html +30 -0
  1467. data/test/stub/rails_apps/2.3/mycook/public/422.html +30 -0
  1468. data/test/stub/rails_apps/2.3/mycook/public/500.html +30 -0
  1469. data/test/stub/rails_apps/2.3/mycook/public/dispatch.cgi +10 -0
  1470. data/test/stub/rails_apps/2.3/mycook/public/dispatch.fcgi +24 -0
  1471. data/test/stub/rails_apps/2.3/mycook/public/dispatch.rb +10 -0
  1472. data/test/stub/rails_apps/2.3/mycook/public/favicon.ico +0 -0
  1473. data/test/stub/rails_apps/2.3/mycook/public/images/angrywizard.gif +0 -0
  1474. data/test/stub/rails_apps/2.3/mycook/public/images/cookbook.gif +0 -0
  1475. data/test/stub/rails_apps/2.3/mycook/public/images/header.png +0 -0
  1476. data/test/stub/rails_apps/2.3/mycook/public/images/rails.png +0 -0
  1477. data/test/stub/rails_apps/2.3/mycook/public/javascripts/application.js +2 -0
  1478. data/test/stub/rails_apps/2.3/mycook/public/javascripts/controls.js +963 -0
  1479. data/test/stub/rails_apps/2.3/mycook/public/javascripts/dragdrop.js +973 -0
  1480. data/test/stub/rails_apps/2.3/mycook/public/javascripts/effects.js +1128 -0
  1481. data/test/stub/rails_apps/2.3/mycook/public/javascripts/prototype.js +4320 -0
  1482. data/test/stub/rails_apps/2.3/mycook/public/robots.txt +5 -0
  1483. data/test/stub/rails_apps/2.3/mycook/public/uploads.html +26 -0
  1484. data/test/stub/rails_apps/2.3/mycook/public/welcome/cached.html +26 -0
  1485. data/test/stub/rails_apps/2.3/mycook/script/about +3 -0
  1486. data/test/stub/rails_apps/2.3/mycook/script/console +3 -0
  1487. data/test/stub/rails_apps/2.3/mycook/script/dbconsole +3 -0
  1488. data/test/stub/rails_apps/2.3/mycook/script/destroy +3 -0
  1489. data/test/stub/rails_apps/2.3/mycook/script/generate +3 -0
  1490. data/test/stub/rails_apps/2.3/mycook/script/performance/benchmarker +3 -0
  1491. data/test/stub/rails_apps/2.3/mycook/script/performance/profiler +3 -0
  1492. data/test/stub/rails_apps/2.3/mycook/script/performance/request +3 -0
  1493. data/test/stub/rails_apps/2.3/mycook/script/plugin +3 -0
  1494. data/test/stub/rails_apps/2.3/mycook/script/process/inspector +3 -0
  1495. data/test/stub/rails_apps/2.3/mycook/script/process/reaper +3 -0
  1496. data/test/stub/rails_apps/2.3/mycook/script/process/spawner +3 -0
  1497. data/test/stub/rails_apps/2.3/mycook/script/runner +3 -0
  1498. data/test/stub/rails_apps/2.3/mycook/script/server +3 -0
  1499. data/test/stub/rails_apps/2.3/mycook/sites/some.site/public/uploads.html +26 -0
  1500. data/test/stub/rails_apps/2.3/mycook/sites/some.site/public/welcome/cached.html +26 -0
  1501. data/test/stub/rails_apps/2.3/mycook/tmp/cache/useless.txt +1 -0
  1502. data/test/stub/rails_apps/2.3/mycook/tmp/pids/useless.txt +1 -0
  1503. data/test/stub/rails_apps/2.3/mycook/tmp/sessions/useless.txt +1 -0
  1504. data/test/stub/rails_apps/2.3/mycook/tmp/sockets/useless.txt +1 -0
  1505. data/test/stub/rails_apps/3.0/empty/Gemfile +22 -0
  1506. data/test/stub/rails_apps/3.0/empty/Gemfile.lock +73 -0
  1507. data/test/stub/rails_apps/3.0/empty/Rakefile +10 -0
  1508. data/test/stub/rails_apps/3.0/empty/app/controllers/application_controller.rb +4 -0
  1509. data/test/stub/rails_apps/3.0/empty/app/helpers/application_helper.rb +2 -0
  1510. data/test/stub/rails_apps/3.0/empty/app/views/layouts/application.html.erb +14 -0
  1511. data/test/stub/rails_apps/3.0/empty/config.ru +4 -0
  1512. data/test/stub/rails_apps/3.0/empty/config/application.rb +48 -0
  1513. data/test/stub/rails_apps/3.0/empty/config/boot.rb +13 -0
  1514. data/test/stub/rails_apps/3.0/empty/config/database.yml +22 -0
  1515. data/test/stub/rails_apps/3.0/empty/config/environment.rb +5 -0
  1516. data/test/stub/rails_apps/3.0/empty/config/environments/development.rb +19 -0
  1517. data/test/stub/rails_apps/3.0/empty/config/environments/production.rb +48 -0
  1518. data/test/stub/rails_apps/3.0/empty/config/environments/test.rb +32 -0
  1519. data/test/stub/rails_apps/3.0/empty/config/initializers/backtrace_silencers.rb +7 -0
  1520. data/test/stub/rails_apps/3.0/empty/config/initializers/inflections.rb +10 -0
  1521. data/test/stub/rails_apps/3.0/empty/config/initializers/mime_types.rb +5 -0
  1522. data/test/stub/rails_apps/3.0/empty/config/initializers/passenger.rb +1 -0
  1523. data/test/stub/rails_apps/3.0/empty/config/initializers/secret_token.rb +7 -0
  1524. data/test/stub/rails_apps/3.0/empty/config/initializers/session_store.rb +8 -0
  1525. data/test/stub/rails_apps/3.0/empty/config/locales/en.yml +5 -0
  1526. data/test/stub/rails_apps/3.0/empty/config/routes.rb +58 -0
  1527. data/test/stub/rails_apps/3.0/empty/db/seeds.rb +7 -0
  1528. data/test/stub/rails_apps/3.0/empty/doc/README_FOR_APP +2 -0
  1529. data/test/stub/rails_apps/3.0/empty/public/404.html +26 -0
  1530. data/test/stub/rails_apps/3.0/empty/public/422.html +26 -0
  1531. data/test/stub/rails_apps/3.0/empty/public/500.html +26 -0
  1532. data/test/stub/rails_apps/3.0/empty/public/favicon.ico +0 -0
  1533. data/test/stub/rails_apps/3.0/empty/public/index.html +279 -0
  1534. data/test/stub/rails_apps/3.0/empty/public/robots.txt +5 -0
  1535. data/test/stub/rails_apps/3.0/empty/script/rails +9 -0
  1536. data/test/stub/rails_apps/3.0/empty/test/performance/browsing_test.rb +9 -0
  1537. data/test/stub/rails_apps/3.0/empty/test/test_helper.rb +13 -0
  1538. data/test/stub/spawn_server.rb +22 -0
  1539. data/test/stub/upload_data.txt +494 -0
  1540. data/test/stub/vendor_rails/minimal/README +1 -0
  1541. data/test/stub/vendor_rails/minimal/actionmailer/lib/action_mailer.rb +0 -0
  1542. data/test/stub/vendor_rails/minimal/actionpack/lib/action_controller.rb +22 -0
  1543. data/test/stub/vendor_rails/minimal/actionpack/lib/action_pack.rb +0 -0
  1544. data/test/stub/vendor_rails/minimal/actionpack/lib/action_view.rb +0 -0
  1545. data/test/stub/vendor_rails/minimal/activerecord/lib/active_record.rb +7 -0
  1546. data/test/stub/vendor_rails/minimal/activeresource/lib/active_resource.rb +0 -0
  1547. data/test/stub/vendor_rails/minimal/activesupport/lib/active_support.rb +17 -0
  1548. data/test/stub/vendor_rails/minimal/activesupport/lib/active_support/whiny_nil.rb +0 -0
  1549. data/test/stub/vendor_rails/minimal/railties/lib/dispatcher.rb +0 -0
  1550. data/test/stub/vendor_rails/minimal/railties/lib/initializer.rb +57 -0
  1551. data/test/stub/vendor_rails/minimal/railties/lib/ruby_version_check.rb +1 -0
  1552. data/test/stub/wsgi/passenger_wsgi.py +3 -0
  1553. data/test/stub/wsgi/public/wsgi-snake.jpg +0 -0
  1554. data/test/stub/zsfa/header.png +0 -0
  1555. data/test/stub/zsfa/index.html +14 -0
  1556. data/test/stub/zsfa/zsfa.png +0 -0
  1557. data/test/support/allocate_memory.c +14 -0
  1558. data/test/support/apache2_controller.rb +258 -0
  1559. data/test/support/multipart.rb +62 -0
  1560. data/test/support/nginx_controller.rb +99 -0
  1561. data/test/support/test_helper.rb +448 -0
  1562. data/test/support/valgrind.h +2539 -0
  1563. data/test/tut/tut.h +1240 -0
  1564. data/test/tut/tut_reporter.h +256 -0
  1565. metadata +1703 -0
@@ -0,0 +1,63 @@
1
+ /*
2
+ * Phusion Passenger - http://www.modrails.com/
3
+ * Copyright (c) 2010 Phusion
4
+ *
5
+ * "Phusion Passenger" is a trademark of Hongli Lai & Ninh Bui.
6
+ *
7
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
8
+ * of this software and associated documentation files (the "Software"), to deal
9
+ * in the Software without restriction, including without limitation the rights
10
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
+ * copies of the Software, and to permit persons to whom the Software is
12
+ * furnished to do so, subject to the following conditions:
13
+ *
14
+ * The above copyright notice and this permission notice shall be included in
15
+ * all copies or substantial portions of the Software.
16
+ *
17
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
+ * THE SOFTWARE.
24
+ */
25
+ #ifndef _PASSENGER_CHANGE_NOTIFIER_H_
26
+ #define _PASSENGER_CHANGE_NOTIFIER_H_
27
+
28
+ #include <boost/function.hpp>
29
+ #include <boost/shared_ptr.hpp>
30
+ #include <string>
31
+ #include <ev++.h>
32
+ #include "DataStoreId.h"
33
+ #include "../EventedClient.h"
34
+ #include "../FileDescriptor.h"
35
+ #include "../StaticString.h"
36
+
37
+ namespace Passenger {
38
+
39
+ using namespace std;
40
+ using namespace boost;
41
+
42
+
43
+ class ChangeNotifier {
44
+ public:
45
+ typedef function<string (const StaticString &groupName, const StaticString &nodeName,
46
+ const StaticString &category)> GetLastPosFunction;
47
+
48
+ GetLastPosFunction getLastPos;
49
+
50
+ ChangeNotifier(struct ev_loop *_loop) { }
51
+ virtual ~ChangeNotifier() { }
52
+
53
+ virtual void addClient(const FileDescriptor &fd) { }
54
+
55
+ virtual void changed(const DataStoreId &dataStoreId) { }
56
+ };
57
+
58
+ typedef shared_ptr<ChangeNotifier> ChangeNotifierPtr;
59
+
60
+
61
+ } // namespace Passenger
62
+
63
+ #endif /* _PASSENGER_CHANGE_NOTIFIER_H_ */
@@ -0,0 +1,177 @@
1
+ /*
2
+ * Phusion Passenger - http://www.modrails.com/
3
+ * Copyright (c) 2010 Phusion
4
+ *
5
+ * "Phusion Passenger" is a trademark of Hongli Lai & Ninh Bui.
6
+ *
7
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
8
+ * of this software and associated documentation files (the "Software"), to deal
9
+ * in the Software without restriction, including without limitation the rights
10
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
+ * copies of the Software, and to permit persons to whom the Software is
12
+ * furnished to do so, subject to the following conditions:
13
+ *
14
+ * The above copyright notice and this permission notice shall be included in
15
+ * all copies or substantial portions of the Software.
16
+ *
17
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
+ * THE SOFTWARE.
24
+ */
25
+ #ifndef _PASSENGER_DATA_STORE_ID_H_
26
+ #define _PASSENGER_DATA_STORE_ID_H_
27
+
28
+ #include <cstring>
29
+ #include <climits>
30
+ #include <cassert>
31
+ #include "StaticString.h"
32
+
33
+ namespace Passenger {
34
+
35
+
36
+ /**
37
+ * Efficient representation for a (groupName, nodeName, category) tuple.
38
+ */
39
+ class DataStoreId {
40
+ private:
41
+ char *id;
42
+ unsigned short groupNameSize;
43
+ unsigned short nodeNameSize;
44
+ unsigned short categorySize;
45
+
46
+ size_t totalSize() const {
47
+ return groupNameSize + nodeNameSize + categorySize + 3;
48
+ }
49
+
50
+ StaticString toStaticString() const {
51
+ if (id == NULL) {
52
+ return StaticString();
53
+ } else {
54
+ return StaticString(id, totalSize());
55
+ }
56
+ }
57
+
58
+ public:
59
+ DataStoreId(const StaticString &groupName, const StaticString &nodeName,
60
+ const StaticString &category)
61
+ {
62
+ assert(groupName.size() <= USHRT_MAX);
63
+ assert(nodeName.size() <= USHRT_MAX);
64
+ assert(category.size() <= USHRT_MAX);
65
+
66
+ char *end;
67
+
68
+ id = new char[groupName.size() + nodeName.size() +
69
+ category.size() + 3];
70
+ end = id;
71
+
72
+ memcpy(end, groupName.c_str(), groupName.size());
73
+ groupNameSize = groupName.size();
74
+ end += groupName.size();
75
+ *end = '\0';
76
+ end++;
77
+
78
+ memcpy(end, nodeName.c_str(), nodeName.size());
79
+ nodeNameSize = nodeName.size();
80
+ end += nodeName.size();
81
+ *end = '\0';
82
+ end++;
83
+
84
+ memcpy(end, category.c_str(), category.size());
85
+ categorySize = category.size();
86
+ end += category.size();
87
+ *end = '\0';
88
+ }
89
+
90
+ DataStoreId() {
91
+ id = NULL;
92
+ }
93
+
94
+ DataStoreId(const DataStoreId &other) {
95
+ if (other.id == NULL) {
96
+ id = NULL;
97
+ } else {
98
+ id = new char[other.totalSize()];
99
+ memcpy(id, other.id, other.totalSize());
100
+ groupNameSize = other.groupNameSize;
101
+ nodeNameSize = other.nodeNameSize;
102
+ categorySize = other.categorySize;
103
+ }
104
+ }
105
+
106
+ ~DataStoreId() {
107
+ delete id;
108
+ }
109
+
110
+ DataStoreId &operator=(const DataStoreId &other) {
111
+ if (other.id == NULL) {
112
+ delete id;
113
+ id = NULL;
114
+ return *this;
115
+ } else {
116
+ if (totalSize() != other.totalSize()) {
117
+ delete id;
118
+ id = NULL;
119
+ }
120
+ if (id == NULL) {
121
+ id = new char[other.totalSize()];
122
+ }
123
+ memcpy(id, other.id, other.totalSize());
124
+ groupNameSize = other.groupNameSize;
125
+ nodeNameSize = other.nodeNameSize;
126
+ categorySize = other.categorySize;
127
+ return *this;
128
+ }
129
+ }
130
+
131
+ bool operator<(const DataStoreId &other) const {
132
+ return toStaticString() < other.toStaticString();
133
+ }
134
+
135
+ bool operator==(const DataStoreId &other) const {
136
+ if (id == NULL) {
137
+ return other.id == NULL;
138
+ } else {
139
+ if (other.id == NULL) {
140
+ return false;
141
+ } else {
142
+ return toStaticString() == other.toStaticString();
143
+ }
144
+ }
145
+ }
146
+
147
+ StaticString getGroupName() const {
148
+ if (id != NULL) {
149
+ return StaticString(id, groupNameSize);
150
+ } else {
151
+ return StaticString();
152
+ }
153
+ }
154
+
155
+ StaticString getNodeName() const {
156
+ if (id != NULL) {
157
+ return StaticString(id + groupNameSize + 1,
158
+ nodeNameSize);
159
+ } else {
160
+ return StaticString();
161
+ }
162
+ }
163
+
164
+ StaticString getCategory() const {
165
+ if (id != NULL) {
166
+ return StaticString(id + groupNameSize + 1 + nodeNameSize + 1,
167
+ categorySize);
168
+ } else {
169
+ return StaticString();
170
+ }
171
+ }
172
+ };
173
+
174
+
175
+ } // namespace Passenger
176
+
177
+ #endif /* _PASSENGER_DATA_STORE_ID_H_ */
@@ -0,0 +1,1343 @@
1
+ /*
2
+ * Phusion Passenger - http://www.modrails.com/
3
+ * Copyright (c) 2010 Phusion
4
+ *
5
+ * "Phusion Passenger" is a trademark of Hongli Lai & Ninh Bui.
6
+ *
7
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
8
+ * of this software and associated documentation files (the "Software"), to deal
9
+ * in the Software without restriction, including without limitation the rights
10
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
+ * copies of the Software, and to permit persons to whom the Software is
12
+ * furnished to do so, subject to the following conditions:
13
+ *
14
+ * The above copyright notice and this permission notice shall be included in
15
+ * all copies or substantial portions of the Software.
16
+ *
17
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
+ * THE SOFTWARE.
24
+ */
25
+ #ifndef _PASSENGER_LOGGING_SERVER_H_
26
+ #define _PASSENGER_LOGGING_SERVER_H_
27
+
28
+ #include <oxt/system_calls.hpp>
29
+ #include <oxt/macros.hpp>
30
+ #include <boost/shared_ptr.hpp>
31
+ #include <string>
32
+ #include <ostream>
33
+ #include <sstream>
34
+ #include <map>
35
+ #include <ev++.h>
36
+
37
+ #include <sys/types.h>
38
+ #include <sys/time.h>
39
+ #include <sys/stat.h>
40
+ #include <grp.h>
41
+ #include <cstring>
42
+ #include <ctime>
43
+ #include <cassert>
44
+
45
+ #include "DataStoreId.h"
46
+ #include "RemoteSender.h"
47
+ #include "ChangeNotifier.h"
48
+ #include "../EventedMessageServer.h"
49
+ #include "../MessageReadersWriters.h"
50
+ #include "../StaticString.h"
51
+ #include "../Exceptions.h"
52
+ #include "../MessageChannel.h"
53
+ #include "../Constants.h"
54
+ #include "../Utils.h"
55
+ #include "../Utils/MD5.h"
56
+ #include "../Utils/IOUtils.h"
57
+ #include "../Utils/StrIntUtils.h"
58
+
59
+
60
+ namespace Passenger {
61
+
62
+ using namespace std;
63
+ using namespace boost;
64
+ using namespace oxt;
65
+
66
+
67
+ class LoggingServer: public EventedMessageServer {
68
+ private:
69
+ static const int MAX_LOG_SINK_CACHE_SIZE = 512;
70
+ static const int GARBAGE_COLLECTION_TIMEOUT = (int) (1.25 * 60 * 60); // 1 hour 15 minutes
71
+
72
+ struct LogSink;
73
+ typedef shared_ptr<LogSink> LogSinkPtr;
74
+ typedef map<string, LogSinkPtr> LogSinkCache;
75
+
76
+ struct LogSink {
77
+ LoggingServer *server;
78
+
79
+ /**
80
+ * Marks how many times this LogSink is currently opened, i.e. the
81
+ * number of Transaction objects currently referencing this LogSink.
82
+ * @invariant
83
+ * (opened == 0) == (this LogSink is in LoggingServer.inactiveLogSinks)
84
+ */
85
+ int opened;
86
+
87
+ /** Last time this LogSink hit an open count of 0. */
88
+ ev_tstamp lastUsed;
89
+
90
+ /** Last time data was actually written to the underlying storage device. */
91
+ ev_tstamp lastFlushed;
92
+
93
+ /**
94
+ * This LogSink's iterator inside LoggingServer.logSinkCache.
95
+ */
96
+ LogSinkCache::iterator cacheIterator;
97
+
98
+ /**
99
+ * This LogSink's iterator inside LoggingServer.inactiveLogSinks.
100
+ * Only valid when opened == 0.
101
+ */
102
+ list<LogSinkPtr>::iterator inactiveLogSinksIterator;
103
+
104
+ LogSink(LoggingServer *_server) {
105
+ server = _server;
106
+ opened = 0;
107
+ lastUsed = ev_now(server->getLoop());
108
+ lastFlushed = 0;
109
+ }
110
+
111
+ virtual ~LogSink() {
112
+ // We really want to flush() here but can't call virtual
113
+ // functions in destructor. :(
114
+ }
115
+
116
+ virtual bool isRemote() const {
117
+ return false;
118
+ }
119
+
120
+ virtual void append(const DataStoreId &dataStoreId,
121
+ const StaticString &data) = 0;
122
+ virtual void flush() { }
123
+ virtual void dump(ostream &stream) const { }
124
+ };
125
+
126
+ struct LogFile: public LogSink {
127
+ static const unsigned int BUFFER_CAPACITY = 8 * 1024;
128
+
129
+ string filename;
130
+ FileDescriptor fd;
131
+ char buffer[BUFFER_CAPACITY];
132
+ unsigned int bufferSize;
133
+
134
+ /**
135
+ * Contains every (groupName, nodeName, category) tuple for
136
+ * which their data is currently buffered in this sink.
137
+ */
138
+ set<DataStoreId> dataStoreIds;
139
+
140
+ LogFile(LoggingServer *server, const string &filename, mode_t filePermissions)
141
+ : LogSink(server)
142
+ {
143
+ int ret;
144
+
145
+ bufferSize = 0;
146
+
147
+ this->filename = filename;
148
+ fd = syscalls::open(filename.c_str(),
149
+ O_CREAT | O_WRONLY | O_APPEND,
150
+ filePermissions);
151
+ if (fd == -1) {
152
+ int e = errno;
153
+ throw FileSystemException("Cannnot open file", e, filename);
154
+ }
155
+ do {
156
+ ret = fchmod(fd, filePermissions);
157
+ } while (ret == -1 && errno == EINTR);
158
+ }
159
+
160
+ virtual ~LogFile() {
161
+ flush();
162
+ }
163
+
164
+ void notifyChanges() {
165
+ if (server->changeNotifier != NULL) {
166
+ set<DataStoreId>::const_iterator it;
167
+ set<DataStoreId>::const_iterator end = dataStoreIds.end();
168
+
169
+ for (it = dataStoreIds.begin(); it != dataStoreIds.end(); it++) {
170
+ server->changeNotifier->changed(*it);
171
+ }
172
+ }
173
+ dataStoreIds.clear();
174
+ }
175
+
176
+ virtual void append(const DataStoreId &dataStoreId, const StaticString &data) {
177
+ if (server->changeNotifier != NULL) {
178
+ dataStoreIds.insert(dataStoreId);
179
+ }
180
+ if (bufferSize + data.size() > BUFFER_CAPACITY) {
181
+ StaticString data2[2];
182
+ data2[0] = StaticString(buffer, bufferSize);
183
+ data2[1] = data;
184
+
185
+ gatheredWrite(fd, data2, 2);
186
+ lastFlushed = ev_now(server->getLoop());
187
+ bufferSize = 0;
188
+ notifyChanges();
189
+ } else {
190
+ memcpy(buffer + bufferSize, data.data(), data.size());
191
+ bufferSize += data.size();
192
+ }
193
+ }
194
+
195
+ virtual void flush() {
196
+ if (bufferSize > 0) {
197
+ lastFlushed = ev_now(server->getLoop());
198
+ writeExact(fd, buffer, bufferSize);
199
+ bufferSize = 0;
200
+ notifyChanges();
201
+ }
202
+ }
203
+
204
+ virtual void dump(ostream &stream) const {
205
+ stream << " Log file: file=" << filename << ", "
206
+ "opened=" << opened << ", "
207
+ "age=" << long(ev_now(server->getLoop()) - lastUsed) << "\n";
208
+ }
209
+ };
210
+
211
+ typedef shared_ptr<LogFile> LogFilePtr;
212
+
213
+ struct RemoteSink: public LogSink {
214
+ /* RemoteSender compresses the data with zlib before sending it
215
+ * to the server. Even including Base64 and URL encoding overhead,
216
+ * this compresses the data to about 25% of its original size.
217
+ * Therefore we set a buffer capacity of a little less than 4 times
218
+ * the TCP maximum segment size so that we can send as much
219
+ * data as possible to the server in a single TCP segment.
220
+ * With the "little less" we take into account:
221
+ * - HTTPS overhead. This can be as high as 2 KB.
222
+ * - The fact that RemoteSink.append() might try to flush the
223
+ * current buffer the current data. Empirical evidence has
224
+ * shown that the data for a request transaction is usually
225
+ * less than 5 KB.
226
+ */
227
+ static const unsigned int BUFFER_CAPACITY =
228
+ 4 * 64 * 1024 -
229
+ 16 * 1024;
230
+
231
+ string unionStationKey;
232
+ string nodeName;
233
+ string category;
234
+ char buffer[BUFFER_CAPACITY];
235
+ unsigned int bufferSize;
236
+
237
+ RemoteSink(LoggingServer *server, const string &unionStationKey,
238
+ const string &nodeName, const string &category)
239
+ : LogSink(server)
240
+ {
241
+ this->unionStationKey = unionStationKey;
242
+ this->nodeName = nodeName;
243
+ this->category = category;
244
+ this->bufferSize = 0;
245
+ }
246
+
247
+ virtual ~RemoteSink() {
248
+ flush();
249
+ }
250
+
251
+ virtual bool isRemote() const {
252
+ return true;
253
+ }
254
+
255
+ virtual void append(const DataStoreId &dataStoreId, const StaticString &data) {
256
+ if (bufferSize + data.size() > BUFFER_CAPACITY) {
257
+ StaticString data2[2];
258
+ data2[0] = StaticString(buffer, bufferSize);
259
+ data2[1] = data;
260
+
261
+ server->remoteSender.schedule(unionStationKey, nodeName,
262
+ category, data2, 2);
263
+ lastFlushed = ev_now(server->getLoop());
264
+ bufferSize = 0;
265
+ } else {
266
+ memcpy(buffer + bufferSize, data.data(), data.size());
267
+ bufferSize += data.size();
268
+ }
269
+ }
270
+
271
+ virtual void flush() {
272
+ if (bufferSize > 0) {
273
+ lastFlushed = ev_now(server->getLoop());
274
+ StaticString data(buffer, bufferSize);
275
+ server->remoteSender.schedule(unionStationKey, nodeName,
276
+ category, &data, 1);
277
+ bufferSize = 0;
278
+ }
279
+ }
280
+
281
+ virtual void dump(ostream &stream) const {
282
+ stream << " Remote sink: "
283
+ "key=" << unionStationKey << ", "
284
+ "node=" << nodeName << ", "
285
+ "category=" << category << ", "
286
+ "opened=" << opened << ", "
287
+ "age=" << long(ev_now(server->getLoop()) - lastUsed) << ", "
288
+ "bufferSize=" << bufferSize <<
289
+ "\n";
290
+ }
291
+ };
292
+
293
+ struct Transaction {
294
+ LoggingServer *server;
295
+ LogSinkPtr logSink;
296
+ string txnId;
297
+ DataStoreId dataStoreId;
298
+ unsigned int writeCount;
299
+ int refcount;
300
+ bool crashProtect, discarded;
301
+ string data;
302
+
303
+ Transaction(LoggingServer *server) {
304
+ this->server = server;
305
+ data.reserve(8 * 1024);
306
+ }
307
+
308
+ ~Transaction() {
309
+ if (logSink != NULL) {
310
+ if (!discarded) {
311
+ logSink->append(dataStoreId, data);
312
+ }
313
+ server->closeLogSink(logSink);
314
+ }
315
+ }
316
+
317
+ StaticString getGroupName() const {
318
+ return dataStoreId.getGroupName();
319
+ }
320
+
321
+ StaticString getNodeName() const {
322
+ return dataStoreId.getNodeName();
323
+ }
324
+
325
+ StaticString getCategory() const {
326
+ return dataStoreId.getCategory();
327
+ }
328
+
329
+ void discard() {
330
+ data.clear();
331
+ discarded = true;
332
+ }
333
+
334
+ void dump(ostream &stream) const {
335
+ stream << " Transaction " << txnId << ":\n";
336
+ stream << " Group : " << getGroupName() << "\n";
337
+ stream << " Node : " << getNodeName() << "\n";
338
+ stream << " Category: " << getCategory() << "\n";
339
+ stream << " Refcount: " << refcount << "\n";
340
+ }
341
+ };
342
+
343
+ typedef shared_ptr<Transaction> TransactionPtr;
344
+
345
+ enum ClientType {
346
+ UNINITIALIZED,
347
+ LOGGER,
348
+ WATCHER
349
+ };
350
+
351
+ struct Client: public EventedMessageClient {
352
+ string nodeName;
353
+ ClientType type;
354
+ char nodeId[MD5_HEX_SIZE];
355
+ /**
356
+ * Set of transaction IDs opened by this client.
357
+ * @invariant This is a subset of the transaction IDs in the 'transactions' member.
358
+ */
359
+ set<string> openTransactions;
360
+ ScalarMessage dataReader;
361
+ TransactionPtr currentTransaction;
362
+ string currentTimestamp;
363
+
364
+ Client(struct ev_loop *loop, const FileDescriptor &fd)
365
+ : EventedMessageClient(loop, fd)
366
+ {
367
+ type = UNINITIALIZED;
368
+ dataReader.setMaxSize(1024 * 128);
369
+ }
370
+ };
371
+
372
+ typedef shared_ptr<Client> ClientPtr;
373
+ typedef map<string, TransactionPtr> TransactionMap;
374
+
375
+ string dir;
376
+ gid_t gid;
377
+ string dirPermissions;
378
+ mode_t filePermissions;
379
+ RemoteSender remoteSender;
380
+ ChangeNotifierPtr changeNotifier;
381
+ ev::timer garbageCollectionTimer;
382
+ ev::timer sinkFlushingTimer;
383
+ ev::timer exitTimer;
384
+ TransactionMap transactions;
385
+ LogSinkCache logSinkCache;
386
+ /**
387
+ * @invariant
388
+ * inactiveLogSinks is sorted from oldest to youngest (by lastTime member).
389
+ * for all s in inactiveLogSinks:
390
+ * s.opened == 0
391
+ * inactiveLogSinks.size() == inactiveLogSinksCount
392
+ */
393
+ list<LogSinkPtr> inactiveLogSinks;
394
+ int inactiveLogSinksCount;
395
+ RandomGenerator randomGenerator;
396
+ bool refuseNewConnections;
397
+ bool exitRequested;
398
+ unsigned long long exitBeginTime;
399
+
400
+ void sendErrorToClient(Client *client, const string &message) {
401
+ client->writeArrayMessage("error", message.c_str(), NULL);
402
+ logError(client, message);
403
+ }
404
+
405
+ bool expectingArgumentsCount(Client *client, const vector<StaticString> &args, unsigned int size) {
406
+ if (args.size() == size) {
407
+ return true;
408
+ } else {
409
+ sendErrorToClient(client, "Invalid number of arguments");
410
+ client->disconnect();
411
+ return false;
412
+ }
413
+ }
414
+
415
+ bool expectingLoggerType(Client *client) {
416
+ if (client->type == LOGGER) {
417
+ return true;
418
+ } else {
419
+ sendErrorToClient(client, "Client not initialized as logger");
420
+ client->disconnect();
421
+ return false;
422
+ }
423
+ }
424
+
425
+ bool checkWhetherConnectionAreAcceptable(Client *client) {
426
+ if (refuseNewConnections) {
427
+ client->writeArrayMessage("server shutting down", NULL);
428
+ client->disconnect();
429
+ return false;
430
+ } else {
431
+ return true;
432
+ }
433
+ }
434
+
435
+ bool validTxnId(const StaticString &txnId) const {
436
+ // must contain timestamp
437
+ // must contain separator
438
+ // must contain random id
439
+ // must not be too large
440
+ return !txnId.empty();
441
+ }
442
+
443
+ bool validUnionStationKey(const StaticString &key) const {
444
+ // must be hexadecimal
445
+ // must not be too large
446
+ return !key.empty();
447
+ }
448
+
449
+ bool validLogContent(const StaticString &data) const {
450
+ const char *current = data.c_str();
451
+ const char *end = current + data.size();
452
+ while (current < end) {
453
+ char c = *current;
454
+ if ((c < 1 && c > 126) || c == '\n' || c == '\r') {
455
+ return false;
456
+ }
457
+ current++;
458
+ }
459
+ return true;
460
+ }
461
+
462
+ bool validTimestamp(const StaticString &timestamp) const {
463
+ // must be hexadecimal
464
+ // must not be too large
465
+ return true;
466
+ }
467
+
468
+ bool supportedCategory(const StaticString &category) const {
469
+ return category == "requests" || category == "processes" || category == "exceptions";
470
+ }
471
+
472
+ time_t extractTimestamp(const StaticString &txnId) const {
473
+ const char *timestampEnd = (const char *) memchr(txnId.c_str(), '-', txnId.size());
474
+ if (timestampEnd == NULL) {
475
+ return 0;
476
+ } else {
477
+ time_t timestamp = hexatriToULL(
478
+ StaticString(txnId.c_str(), timestampEnd - txnId.c_str())
479
+ );
480
+ return timestamp * 60;
481
+ }
482
+ }
483
+
484
+ void appendVersionAndGroupId(string &output, const StaticString &groupName) const {
485
+ md5_state_t state;
486
+ md5_byte_t digest[MD5_SIZE];
487
+ char checksum[MD5_HEX_SIZE];
488
+
489
+ output.append("/1/", 3);
490
+
491
+ md5_init(&state);
492
+ md5_append(&state, (const md5_byte_t *) groupName.data(), groupName.size());
493
+ md5_finish(&state, digest);
494
+ toHex(StaticString((const char *) digest, MD5_SIZE), checksum);
495
+ output.append(checksum, MD5_HEX_SIZE);
496
+ }
497
+
498
+ string determineFilename(const StaticString &groupName, const char *nodeId,
499
+ const StaticString &category, const StaticString &txnId = "") const
500
+ {
501
+ time_t timestamp;
502
+ struct tm tm;
503
+ char time_str[14];
504
+
505
+ if (!txnId.empty()) {
506
+ timestamp = extractTimestamp(txnId);
507
+ gmtime_r(&timestamp, &tm);
508
+ strftime(time_str, sizeof(time_str), "%Y/%m/%d/%H", &tm);
509
+ }
510
+
511
+ string filename;
512
+ filename.reserve(dir.size()
513
+ + (3 + MD5_HEX_SIZE) // version and group ID
514
+ + 1 // "/"
515
+ + MD5_HEX_SIZE // node ID
516
+ + 1 // "/"
517
+ + category.size()
518
+ + 1 // "/"
519
+ + sizeof(time_str) // including null terminator, which we use as space for "/"
520
+ + sizeof("log.txt")
521
+ );
522
+ filename.append(dir);
523
+ appendVersionAndGroupId(filename, groupName);
524
+ filename.append(1, '/');
525
+ filename.append(nodeId, MD5_HEX_SIZE);
526
+ filename.append(1, '/');
527
+ filename.append(category.c_str(), category.size());
528
+ if (!txnId.empty()) {
529
+ filename.append(1, '/');
530
+ filename.append(time_str);
531
+ filename.append("/log.txt");
532
+ }
533
+ return filename;
534
+ }
535
+
536
+ void setupGroupAndNodeDir(const StaticString &groupName, const StaticString &nodeName,
537
+ const char *nodeId)
538
+ {
539
+ string filename, groupDir, nodeDir;
540
+
541
+ filename.append(dir);
542
+ appendVersionAndGroupId(filename, groupName);
543
+ groupDir = filename;
544
+
545
+ filename.append("/");
546
+ filename.append(nodeId, MD5_HEX_SIZE);
547
+ nodeDir = filename;
548
+
549
+ createFile(groupDir + "/group_name.txt", groupName,
550
+ filePermissions, USER_NOT_GIVEN, GROUP_NOT_GIVEN,
551
+ false);
552
+ if (getFileType(groupDir + "/uuid.txt") == FT_NONEXISTANT) {
553
+ createFile(groupDir + "/uuid.txt",
554
+ randomGenerator.generateAsciiString(24),
555
+ filePermissions, USER_NOT_GIVEN, GROUP_NOT_GIVEN,
556
+ false);
557
+ }
558
+
559
+ createFile(nodeDir + "/node_name.txt", nodeName,
560
+ filePermissions, USER_NOT_GIVEN, GROUP_NOT_GIVEN,
561
+ false);
562
+ if (getFileType(nodeDir + "/uuid.txt") == FT_NONEXISTANT) {
563
+ createFile(nodeDir + "/uuid.txt",
564
+ randomGenerator.generateAsciiString(24),
565
+ filePermissions, USER_NOT_GIVEN, GROUP_NOT_GIVEN,
566
+ false);
567
+ }
568
+ }
569
+
570
+ bool openLogFileWithCache(const string &filename, LogSinkPtr &theLogSink) {
571
+ string cacheKey = "file:" + filename;
572
+ LogSinkCache::iterator it = logSinkCache.find(cacheKey);
573
+ if (it == logSinkCache.end()) {
574
+ trimLogSinkCache(MAX_LOG_SINK_CACHE_SIZE - 1);
575
+ makeDirTree(extractDirName(filename), dirPermissions,
576
+ USER_NOT_GIVEN, gid);
577
+ theLogSink.reset(new LogFile(this, filename, filePermissions));
578
+ pair<LogSinkCache::iterator, bool> p =
579
+ logSinkCache.insert(make_pair(cacheKey, theLogSink));
580
+ theLogSink->cacheIterator = p.first;
581
+ theLogSink->opened = 1;
582
+ return false;
583
+ } else {
584
+ theLogSink = it->second;
585
+ theLogSink->opened++;
586
+ if (theLogSink->opened == 1) {
587
+ inactiveLogSinks.erase(theLogSink->inactiveLogSinksIterator);
588
+ inactiveLogSinksCount--;
589
+ }
590
+ return true;
591
+ }
592
+ }
593
+
594
+ void openRemoteSink(const StaticString &unionStationKey, const string &nodeName,
595
+ const string &category, LogSinkPtr &theLogSink)
596
+ {
597
+ string cacheKey = "remote:";
598
+ cacheKey.append(unionStationKey.c_str(), unionStationKey.size());
599
+ cacheKey.append(1, '\0');
600
+ cacheKey.append(nodeName);
601
+ cacheKey.append(1, '\0');
602
+ cacheKey.append(category);
603
+
604
+ LogSinkCache::iterator it = logSinkCache.find(cacheKey);
605
+ if (it == logSinkCache.end()) {
606
+ trimLogSinkCache(MAX_LOG_SINK_CACHE_SIZE - 1);
607
+ theLogSink.reset(new RemoteSink(this, unionStationKey,
608
+ nodeName, category));
609
+ pair<LogSinkCache::iterator, bool> p =
610
+ logSinkCache.insert(make_pair(cacheKey, theLogSink));
611
+ theLogSink->cacheIterator = p.first;
612
+ theLogSink->opened = 1;
613
+ } else {
614
+ theLogSink = it->second;
615
+ theLogSink->opened++;
616
+ if (theLogSink->opened == 1) {
617
+ inactiveLogSinks.erase(theLogSink->inactiveLogSinksIterator);
618
+ inactiveLogSinksCount--;
619
+ }
620
+ }
621
+ }
622
+
623
+ /**
624
+ * 'Closes' the given log sink. It's not actually deleted from memory;
625
+ * instead it's marked as inactive and cached for later use. May be
626
+ * deleted later when resources are low.
627
+ *
628
+ * No need to call this manually. Automatically called by Transaction's
629
+ * destructor.
630
+ */
631
+ void closeLogSink(const LogSinkPtr &logSink) {
632
+ logSink->opened--;
633
+ assert(logSink->opened >= 0);
634
+ logSink->lastUsed = ev_now(getLoop());
635
+ if (logSink->opened == 0) {
636
+ inactiveLogSinks.push_back(logSink);
637
+ logSink->inactiveLogSinksIterator = inactiveLogSinks.end();
638
+ logSink->inactiveLogSinksIterator--;
639
+ inactiveLogSinksCount++;
640
+ trimLogSinkCache(MAX_LOG_SINK_CACHE_SIZE);
641
+ }
642
+ }
643
+
644
+ /** Try to reduce the log sink cache size to the given size. */
645
+ void trimLogSinkCache(unsigned int size) {
646
+ while (!inactiveLogSinks.empty() && logSinkCache.size() > size) {
647
+ const LogSinkPtr logSink = inactiveLogSinks.front();
648
+ inactiveLogSinks.pop_front();
649
+ inactiveLogSinksCount--;
650
+ logSinkCache.erase(logSink->cacheIterator);
651
+ }
652
+ }
653
+
654
+ bool writeLogEntry(Client *client, const TransactionPtr &transaction,
655
+ const StaticString &timestamp, const StaticString &data)
656
+ {
657
+ if (transaction->discarded) {
658
+ return true;
659
+ }
660
+ if (OXT_UNLIKELY( !validLogContent(data) )) {
661
+ if (client != NULL) {
662
+ sendErrorToClient(client, "Log entry data contains an invalid character.");
663
+ client->disconnect();
664
+ }
665
+ return false;
666
+ }
667
+ if (OXT_UNLIKELY( !validTimestamp(timestamp) )) {
668
+ if (client != NULL) {
669
+ sendErrorToClient(client, "Log entry timestamp is invalid.");
670
+ client->disconnect();
671
+ }
672
+ return false;
673
+ }
674
+
675
+ char writeCountStr[sizeof(unsigned int) * 2 + 1];
676
+ integerToHexatri(transaction->writeCount, writeCountStr);
677
+ transaction->writeCount++;
678
+ transaction->data.reserve(transaction->data.size() +
679
+ transaction->txnId.size() +
680
+ 1 +
681
+ timestamp.size() +
682
+ 1 +
683
+ strlen(writeCountStr) +
684
+ 1 +
685
+ data.size() +
686
+ 1);
687
+ transaction->data.append(transaction->txnId);
688
+ transaction->data.append(" ");
689
+ transaction->data.append(timestamp);
690
+ transaction->data.append(" ");
691
+ transaction->data.append(writeCountStr);
692
+ transaction->data.append(" ");
693
+ transaction->data.append(data);
694
+ transaction->data.append("\n");
695
+ return true;
696
+ }
697
+
698
+ void writeDetachEntry(Client *client, const TransactionPtr &transaction) {
699
+ char timestamp[2 * sizeof(unsigned long long) + 1];
700
+ // Must use System::getUsec() here instead of ev_now() because the
701
+ // precision of the time is very important.
702
+ integerToHexatri<unsigned long long>(SystemTime::getUsec(), timestamp);
703
+ writeDetachEntry(client, transaction, timestamp);
704
+ }
705
+
706
+ void writeDetachEntry(Client *client, const TransactionPtr &transaction,
707
+ const StaticString &timestamp)
708
+ {
709
+ writeLogEntry(client, transaction, timestamp, "DETACH");
710
+ }
711
+
712
+ bool requireRights(Client *client, Account::Rights rights) {
713
+ if (client->messageServer.account->hasRights(rights)) {
714
+ return true;
715
+ } else {
716
+ P_TRACE(2, "Security error: insufficient rights to execute this command.");
717
+ client->writeArrayMessage("SecurityException",
718
+ "Insufficient rights to execute this command.",
719
+ NULL);
720
+ client->disconnect();
721
+ return false;
722
+ }
723
+ }
724
+
725
+ bool isDirectory(const string &dir, struct dirent *entry) const {
726
+ #ifdef __sun__
727
+ string path = dir;
728
+ path.append("/");
729
+ path.append(entry->d_name);
730
+ return getFileType(path) == FT_DIRECTORY;
731
+ #else
732
+ return entry->d_type == DT_DIR;
733
+ #endif
734
+ }
735
+
736
+ bool looksLikeNumber(const char *str) const {
737
+ const char *current = str;
738
+ while (*current != '\0') {
739
+ char c = *current;
740
+ if (!(c >= '0' && c <= '9')) {
741
+ return false;
742
+ }
743
+ current++;
744
+ }
745
+ return true;
746
+ }
747
+
748
+ bool getLastEntryInDirectory(const string &path, string &result) const {
749
+ DIR *dir = opendir(path.c_str());
750
+ struct dirent *entry;
751
+ vector<string> subdirs;
752
+
753
+ if (dir == NULL) {
754
+ int e = errno;
755
+ throw FileSystemException("Cannot open directory " + path,
756
+ e, path);
757
+ }
758
+ while ((entry = readdir(dir)) != NULL) {
759
+ if (isDirectory(path, entry) && looksLikeNumber(entry->d_name)) {
760
+ subdirs.push_back(entry->d_name);
761
+ }
762
+ }
763
+ closedir(dir);
764
+
765
+ if (subdirs.empty()) {
766
+ return false;
767
+ }
768
+
769
+ vector<string>::const_iterator it = subdirs.begin();
770
+ vector<string>::const_iterator end = subdirs.end();
771
+ vector<string>::const_iterator largest_it = subdirs.begin();
772
+ int largest = atoi(subdirs[0]);
773
+ for (it++; it != end; it++) {
774
+ const string &subdir = *it;
775
+ int number = atoi(subdir.c_str());
776
+ if (number > largest) {
777
+ largest_it = it;
778
+ largest = number;
779
+ }
780
+ }
781
+ result = *largest_it;
782
+ return true;
783
+ }
784
+
785
+ static void pendingDataFlushed(EventedClient *_client) {
786
+ Client *client = (Client *) _client;
787
+ LoggingServer *self = (LoggingServer *) client->userData;
788
+
789
+ client->onPendingDataFlushed = NULL;
790
+ if (OXT_UNLIKELY( client->type != WATCHER )) {
791
+ P_WARN("BUG: pendingDataFlushed() called even though client type is not WATCHER.");
792
+ client->disconnect();
793
+ } else if (self->changeNotifier != NULL) {
794
+ self->changeNotifier->addClient(client->detach());
795
+ } else {
796
+ client->disconnect();
797
+ }
798
+ }
799
+
800
+ /* Release all inactive log sinks that have been inactive for more than
801
+ * GARBAGE_COLLECTION_TIMEOUT seconds.
802
+ */
803
+ void releaseInactiveLogSinks(ev_tstamp now) {
804
+ bool done = false;
805
+
806
+ while (!done && !inactiveLogSinks.empty()) {
807
+ const LogSinkPtr logSink = inactiveLogSinks.front();
808
+ if (now - logSink->lastUsed >= GARBAGE_COLLECTION_TIMEOUT) {
809
+ inactiveLogSinks.pop_front();
810
+ inactiveLogSinksCount--;
811
+ logSinkCache.erase(logSink->cacheIterator);
812
+ } else {
813
+ done = true;
814
+ }
815
+ }
816
+ }
817
+
818
+ void garbageCollect(ev::timer &timer, int revents) {
819
+ P_DEBUG("Garbage collection time");
820
+ releaseInactiveLogSinks(ev_now(getLoop()));
821
+ }
822
+
823
+ void sinkFlushTimeout(ev::timer &timer, int revents) {
824
+ P_TRACE(2, "Flushing all sinks (periodic action)");
825
+ LogSinkCache::iterator it;
826
+ LogSinkCache::iterator end = logSinkCache.end();
827
+ ev_tstamp now = ev_now(getLoop());
828
+
829
+ for (it = logSinkCache.begin(); it != end; it++) {
830
+ LogSink *sink = it->second.get();
831
+
832
+ // Flush log file sinks every 15 seconds,
833
+ // remote sinks every 60 seconds.
834
+ if (sink->isRemote()) {
835
+ if (now - sink->lastFlushed >= 60) {
836
+ sink->flush();
837
+ }
838
+ } else {
839
+ sink->flush();
840
+ }
841
+ }
842
+ }
843
+
844
+ void flushAllSinks() {
845
+ P_TRACE(2, "Flushing all sinks");
846
+ LogSinkCache::iterator it;
847
+ LogSinkCache::iterator end = logSinkCache.end();
848
+
849
+ for (it = logSinkCache.begin(); it != end; it++) {
850
+ LogSink *sink = it->second.get();
851
+ sink->flush();
852
+ }
853
+ }
854
+
855
+ void exitTimerTimeout(ev::timer &timer, int revents) {
856
+ if (SystemTime::getMsec() >= exitBeginTime + 5000) {
857
+ exitTimer.stop();
858
+ exitRequested = false;
859
+ refuseNewConnections = false;
860
+ ev_unloop(getLoop(), EVUNLOOP_ONE);
861
+ }
862
+ }
863
+
864
+ protected:
865
+ virtual EventedClient *createClient(const FileDescriptor &fd) {
866
+ return new Client(getLoop(), fd);
867
+ }
868
+
869
+ virtual bool onMessageReceived(EventedMessageClient *_client, const vector<StaticString> &args) {
870
+ Client *client = (Client *) _client;
871
+
872
+ if (args[0] == "log") {
873
+ if (OXT_UNLIKELY( !expectingArgumentsCount(client, args, 3)
874
+ || !expectingLoggerType(client) )) {
875
+ return true;
876
+ }
877
+
878
+ string txnId = args[1];
879
+ string timestamp = args[2];
880
+
881
+ TransactionMap::iterator it = transactions.find(txnId);
882
+ if (OXT_UNLIKELY( it == transactions.end() )) {
883
+ sendErrorToClient(client, "Cannot log data: transaction does not exist");
884
+ client->disconnect();
885
+ } else {
886
+ set<string>::iterator sit = client->openTransactions.find(txnId);
887
+ if (OXT_UNLIKELY( sit == client->openTransactions.end() )) {
888
+ sendErrorToClient(client,
889
+ "Cannot log data: transaction not opened in this connection");
890
+ client->disconnect();
891
+ return true;
892
+ }
893
+ // Expecting the log data in a scalar message.
894
+ client->currentTransaction = it->second;
895
+ client->currentTimestamp = timestamp;
896
+ return false;
897
+ }
898
+
899
+ } else if (args[0] == "openTransaction") {
900
+ if (OXT_UNLIKELY( !expectingArgumentsCount(client, args, 8)
901
+ || !expectingLoggerType(client) )) {
902
+ return true;
903
+ }
904
+
905
+ string txnId = args[1];
906
+ StaticString groupName = args[2];
907
+ StaticString nodeName = args[3];
908
+ StaticString category = args[4];
909
+ StaticString timestamp = args[5];
910
+ StaticString unionStationKey = args[6];
911
+ bool crashProtect = args[7] == "true";
912
+
913
+ if (OXT_UNLIKELY( !validTxnId(txnId) )) {
914
+ sendErrorToClient(client, "Invalid transaction ID format");
915
+ client->disconnect();
916
+ return true;
917
+ }
918
+ if (!unionStationKey.empty()
919
+ && OXT_UNLIKELY( !validUnionStationKey(unionStationKey) )) {
920
+ sendErrorToClient(client, "Invalid Union Station key format");
921
+ client->disconnect();
922
+ return true;
923
+ }
924
+ if (OXT_UNLIKELY( client->openTransactions.find(txnId) !=
925
+ client->openTransactions.end() ))
926
+ {
927
+ sendErrorToClient(client, "Cannot open transaction: transaction already opened in this connection");
928
+ client->disconnect();
929
+ return true;
930
+ }
931
+
932
+ const char *nodeId;
933
+
934
+ if (nodeName.empty()) {
935
+ nodeName = client->nodeName;
936
+ nodeId = client->nodeId;
937
+ } else {
938
+ nodeId = NULL;
939
+ }
940
+
941
+ TransactionMap::iterator it = transactions.find(txnId);
942
+ TransactionPtr transaction;
943
+ if (it == transactions.end()) {
944
+ if (OXT_UNLIKELY( !supportedCategory(category) )) {
945
+ sendErrorToClient(client, "Unsupported category");
946
+ client->disconnect();
947
+ return true;
948
+ }
949
+
950
+ transaction.reset(new Transaction(this));
951
+ if (unionStationKey.empty()) {
952
+ char tempNodeId[MD5_HEX_SIZE];
953
+
954
+ if (nodeId == NULL) {
955
+ md5_state_t state;
956
+ md5_byte_t digest[MD5_SIZE];
957
+
958
+ md5_init(&state);
959
+ md5_append(&state,
960
+ (const md5_byte_t *) nodeName.data(),
961
+ nodeName.size());
962
+ md5_finish(&state, digest);
963
+ toHex(StaticString((const char *) digest, MD5_SIZE),
964
+ tempNodeId);
965
+ nodeId = tempNodeId;
966
+ }
967
+
968
+ string filename = determineFilename(groupName, nodeId,
969
+ category, txnId);
970
+ if (!openLogFileWithCache(filename, transaction->logSink)) {
971
+ setupGroupAndNodeDir(groupName, nodeName, nodeId);
972
+ }
973
+ } else {
974
+ openRemoteSink(unionStationKey, client->nodeName,
975
+ category, transaction->logSink);
976
+ }
977
+ transaction->txnId = txnId;
978
+ transaction->dataStoreId = DataStoreId(groupName,
979
+ nodeName, category);
980
+ transaction->writeCount = 0;
981
+ transaction->refcount = 0;
982
+ transaction->crashProtect = crashProtect;
983
+ transaction->discarded = false;
984
+ transactions.insert(make_pair(txnId, transaction));
985
+ } else {
986
+ transaction = it->second;
987
+ if (OXT_UNLIKELY( transaction->getGroupName() != groupName )) {
988
+ sendErrorToClient(client,
989
+ "Cannot open transaction: transaction already opened with a different group name");
990
+ client->disconnect();
991
+ return true;
992
+ }
993
+ if (OXT_UNLIKELY( transaction->getNodeName() != nodeName )) {
994
+ sendErrorToClient(client,
995
+ "Cannot open transaction: transaction already opened with a different node name");
996
+ client->disconnect();
997
+ return true;
998
+ }
999
+ if (OXT_UNLIKELY( transaction->getCategory() != category )) {
1000
+ sendErrorToClient(client,
1001
+ "Cannot open transaction: transaction already opened with a different category name");
1002
+ client->disconnect();
1003
+ return true;
1004
+ }
1005
+ }
1006
+
1007
+ client->openTransactions.insert(txnId);
1008
+ transaction->refcount++;
1009
+ writeLogEntry(client, transaction, timestamp, "ATTACH");
1010
+
1011
+ } else if (args[0] == "closeTransaction") {
1012
+ if (OXT_UNLIKELY( !expectingArgumentsCount(client, args, 3)
1013
+ || !expectingLoggerType(client) )) {
1014
+ return true;
1015
+ }
1016
+
1017
+ string txnId = args[1];
1018
+ StaticString timestamp = args[2];
1019
+
1020
+ TransactionMap::iterator it = transactions.find(txnId);
1021
+ if (OXT_UNLIKELY( it == transactions.end() )) {
1022
+ sendErrorToClient(client,
1023
+ "Cannot close transaction " + txnId +
1024
+ ": transaction does not exist");
1025
+ client->disconnect();
1026
+ } else {
1027
+ TransactionPtr &transaction = it->second;
1028
+
1029
+ set<string>::const_iterator sit = client->openTransactions.find(txnId);
1030
+ if (OXT_UNLIKELY( sit == client->openTransactions.end() )) {
1031
+ sendErrorToClient(client,
1032
+ "Cannot close transaction " + txnId +
1033
+ ": transaction not opened in this connection");
1034
+ client->disconnect();
1035
+ return true;
1036
+ } else {
1037
+ client->openTransactions.erase(sit);
1038
+ }
1039
+
1040
+ writeDetachEntry(client, transaction, timestamp);
1041
+ transaction->refcount--;
1042
+ assert(transaction->refcount >= 0);
1043
+ if (transaction->refcount == 0) {
1044
+ transactions.erase(it);
1045
+ }
1046
+ }
1047
+
1048
+ } else if (args[0] == "init") {
1049
+ if (OXT_UNLIKELY( client->type != UNINITIALIZED )) {
1050
+ sendErrorToClient(client, "Already initialized");
1051
+ client->disconnect();
1052
+ return true;
1053
+ }
1054
+ if (OXT_UNLIKELY( !expectingArgumentsCount(client, args, 2) )) {
1055
+ return true;
1056
+ }
1057
+ if (OXT_UNLIKELY( !checkWhetherConnectionAreAcceptable(client) )) {
1058
+ return true;
1059
+ }
1060
+
1061
+ StaticString nodeName = args[1];
1062
+ client->nodeName = nodeName;
1063
+
1064
+ md5_state_t state;
1065
+ md5_byte_t digest[MD5_SIZE];
1066
+ md5_init(&state);
1067
+ md5_append(&state, (const md5_byte_t *) nodeName.data(), nodeName.size());
1068
+ md5_finish(&state, digest);
1069
+ toHex(StaticString((const char *) digest, MD5_SIZE), client->nodeId);
1070
+
1071
+ client->type = LOGGER;
1072
+ client->writeArrayMessage("ok", NULL);
1073
+
1074
+ } else if (args[0] == "watchChanges") {
1075
+ if (OXT_UNLIKELY( !checkWhetherConnectionAreAcceptable(client) )) {
1076
+ return true;
1077
+ }
1078
+ if (OXT_UNLIKELY( client->type != UNINITIALIZED )) {
1079
+ sendErrorToClient(client, "This command cannot be invoked "
1080
+ "if the 'init' command is already invoked.");
1081
+ client->disconnect();
1082
+ return true;
1083
+ }
1084
+
1085
+ client->type = WATCHER;
1086
+ client->notifyReads(false);
1087
+ discardReadData();
1088
+
1089
+ // Add to the change notifier after all pending data
1090
+ // has been written out.
1091
+ client->onPendingDataFlushed = pendingDataFlushed;
1092
+ client->writeArrayMessage("ok", NULL);
1093
+
1094
+ } else if (args[0] == "flush") {
1095
+ flushAllSinks();
1096
+ client->writeArrayMessage("ok", NULL);
1097
+
1098
+ } else if (args[0] == "info") {
1099
+ stringstream stream;
1100
+ dump(stream);
1101
+ client->writeArrayMessage("info", stream.str().c_str(), NULL);
1102
+
1103
+ } else if (args[0] == "ping") {
1104
+ client->writeArrayMessage("pong", NULL);
1105
+
1106
+ } else if (args[0] == "exit") {
1107
+ if (!requireRights(client, Account::EXIT)) {
1108
+ client->disconnect();
1109
+ return true;
1110
+ }
1111
+ if (args.size() == 2 && args[1] == "immediately") {
1112
+ // Immediate exit.
1113
+ ev_unloop(getLoop(), EVUNLOOP_ONE);
1114
+ } else if (args.size() == 2 && args[1] == "semi-gracefully") {
1115
+ // Semi-graceful exit: refuse new connections, shut down
1116
+ // a few seconds after the last client has disconnected.
1117
+ refuseNewConnections = true;
1118
+ exitRequested = true;
1119
+ } else {
1120
+ // Graceful exit: shut down a few seconds after the
1121
+ // last client has disconnected.
1122
+ client->writeArrayMessage("Passed security", NULL);
1123
+ client->writeArrayMessage("exit command received", NULL);
1124
+ exitRequested = true;
1125
+ }
1126
+ client->disconnect();
1127
+
1128
+ } else {
1129
+ sendErrorToClient(client, "Unknown command '" + args[0] + "'");
1130
+ client->disconnect();
1131
+ }
1132
+
1133
+ return true;
1134
+ }
1135
+
1136
+ virtual pair<size_t, bool> onOtherDataReceived(EventedMessageClient *_client,
1137
+ const char *data, size_t size)
1138
+ {
1139
+ // In here we read the scalar message that's expected to come
1140
+ // after the "log" command.
1141
+ Client *client = (Client *) _client;
1142
+ size_t consumed = client->dataReader.feed(data, size);
1143
+ if (client->dataReader.done()) {
1144
+ writeLogEntry(client,
1145
+ client->currentTransaction,
1146
+ client->currentTimestamp,
1147
+ client->dataReader.value());
1148
+ client->currentTransaction.reset();
1149
+ client->dataReader.reset();
1150
+ return make_pair(consumed, true);
1151
+ } else {
1152
+ return make_pair(consumed, false);
1153
+ }
1154
+ }
1155
+
1156
+ virtual void onNewClient(EventedClient *client) {
1157
+ if (exitRequested && exitTimer.is_active()) {
1158
+ exitTimer.stop();
1159
+ }
1160
+ EventedMessageServer::onNewClient(client);
1161
+ }
1162
+
1163
+ virtual void onClientDisconnected(EventedClient *_client) {
1164
+ EventedMessageServer::onClientDisconnected(_client);
1165
+ Client *client = (Client *) _client;
1166
+ set<string>::const_iterator sit;
1167
+ set<string>::const_iterator send = client->openTransactions.end();
1168
+
1169
+ // Close any transactions that this client had opened.
1170
+ for (sit = client->openTransactions.begin(); sit != send; sit++) {
1171
+ const string &txnId = *sit;
1172
+ TransactionMap::iterator it = transactions.find(txnId);
1173
+ if (OXT_UNLIKELY( it == transactions.end() )) {
1174
+ P_ERROR("Bug: client->openTransactions is not a subset of this->transactions!");
1175
+ abort();
1176
+ }
1177
+
1178
+ TransactionPtr &transaction = it->second;
1179
+ if (transaction->crashProtect) {
1180
+ writeDetachEntry(client, transaction);
1181
+ } else {
1182
+ transaction->discard();
1183
+ }
1184
+ transaction->refcount--;
1185
+ assert(transaction->refcount >= 0);
1186
+ if (transaction->refcount == 0) {
1187
+ transactions.erase(it);
1188
+ }
1189
+ }
1190
+ client->openTransactions.clear();
1191
+
1192
+ // Possibly start exit timer.
1193
+ if (exitRequested && getClients().empty()) {
1194
+ exitTimer.start();
1195
+ /* Using SystemTime here instead of setting a correct
1196
+ * timeout directly on the timer, so that we can
1197
+ * manipulate the clock in LoggingServer unit tests.
1198
+ */
1199
+ exitBeginTime = SystemTime::getMsec();
1200
+ }
1201
+ }
1202
+
1203
+ public:
1204
+ LoggingServer(struct ev_loop *loop,
1205
+ FileDescriptor fd,
1206
+ const AccountsDatabasePtr &accountsDatabase,
1207
+ const string &dir,
1208
+ const string &permissions = DEFAULT_ANALYTICS_LOG_PERMISSIONS,
1209
+ gid_t gid = GROUP_NOT_GIVEN,
1210
+ const string &unionStationGatewayAddress = DEFAULT_UNION_STATION_GATEWAY_ADDRESS,
1211
+ unsigned short unionStationGatewayPort = DEFAULT_UNION_STATION_GATEWAY_PORT,
1212
+ const string &unionStationGatewayCert = "")
1213
+ : EventedMessageServer(loop, fd, accountsDatabase),
1214
+ remoteSender(unionStationGatewayAddress,
1215
+ unionStationGatewayPort,
1216
+ unionStationGatewayCert),
1217
+ garbageCollectionTimer(loop),
1218
+ sinkFlushingTimer(loop),
1219
+ exitTimer(loop)
1220
+ {
1221
+ this->dir = dir;
1222
+ this->gid = gid;
1223
+ dirPermissions = permissions;
1224
+ filePermissions = parseModeString(permissions) & ~(S_IXUSR | S_IXGRP | S_IXOTH);
1225
+ garbageCollectionTimer.set<LoggingServer, &LoggingServer::garbageCollect>(this);
1226
+ garbageCollectionTimer.start(GARBAGE_COLLECTION_TIMEOUT, GARBAGE_COLLECTION_TIMEOUT);
1227
+ sinkFlushingTimer.set<LoggingServer, &LoggingServer::sinkFlushTimeout>(this);
1228
+ sinkFlushingTimer.start(15, 15);
1229
+ exitTimer.set<LoggingServer, &LoggingServer::exitTimerTimeout>(this);
1230
+ exitTimer.set(0.05, 0.05);
1231
+ refuseNewConnections = false;
1232
+ exitRequested = false;
1233
+ inactiveLogSinksCount = 0;
1234
+ }
1235
+
1236
+ ~LoggingServer() {
1237
+ TransactionMap::iterator it, end = transactions.end();
1238
+ for (it = transactions.begin(); it != end; it++) {
1239
+ TransactionPtr &transaction = it->second;
1240
+ if (transaction->crashProtect) {
1241
+ writeDetachEntry(NULL, transaction);
1242
+ } else {
1243
+ transaction->discard();
1244
+ }
1245
+ }
1246
+
1247
+ // Invoke destructors, causing all transactions and log sinks to
1248
+ // be flushed before RemoteSender and ChangeNotifier are being
1249
+ // destroyed.
1250
+ transactions.clear();
1251
+ logSinkCache.clear();
1252
+ inactiveLogSinks.clear();
1253
+ }
1254
+
1255
+ void setChangeNotifier(const ChangeNotifierPtr &_changeNotifier) {
1256
+ changeNotifier = _changeNotifier;
1257
+ changeNotifier->getLastPos = boost::bind(&LoggingServer::getLastPos,
1258
+ this, _1, _2, _3);
1259
+ }
1260
+
1261
+ string getLastPos(const StaticString &groupName, const StaticString &nodeName,
1262
+ const StaticString &category) const
1263
+ {
1264
+ md5_state_t state;
1265
+ md5_byte_t digest[MD5_SIZE];
1266
+ char nodeId[MD5_HEX_SIZE];
1267
+ md5_init(&state);
1268
+ md5_append(&state, (const md5_byte_t *) nodeName.data(), nodeName.size());
1269
+ md5_finish(&state, digest);
1270
+ toHex(StaticString((const char *) digest, MD5_SIZE), nodeId);
1271
+
1272
+ string dir = determineFilename(groupName, nodeId, category);
1273
+ string subdir, component;
1274
+ subdir.reserve(13); // It's a string that looks like: "2010/06/24/12"
1275
+
1276
+ try {
1277
+ // Loop 4 times to process year, month, day, hour.
1278
+ for (int i = 0; i < 4; i++) {
1279
+ bool found = getLastEntryInDirectory(dir, component);
1280
+ if (!found) {
1281
+ return string();
1282
+ }
1283
+ dir.append("/");
1284
+ dir.append(component);
1285
+ if (i != 0) {
1286
+ subdir.append("/");
1287
+ }
1288
+ subdir.append(component);
1289
+ }
1290
+ // After the loop, new dir == old dir + "/" + subdir
1291
+ } catch (const SystemException &e) {
1292
+ if (e.code() == ENOENT) {
1293
+ return string();
1294
+ } else {
1295
+ throw;
1296
+ }
1297
+ }
1298
+
1299
+ string &filename = dir;
1300
+ filename.append("/log.txt");
1301
+
1302
+ struct stat buf;
1303
+ if (stat(filename.c_str(), &buf) == -1) {
1304
+ if (errno == ENOENT) {
1305
+ return string();
1306
+ } else {
1307
+ int e = errno;
1308
+ throw FileSystemException("Cannot stat() " + filename, e,
1309
+ filename);
1310
+ }
1311
+ } else {
1312
+ return subdir + "/" + toString(buf.st_size);
1313
+ }
1314
+ }
1315
+
1316
+ void dump(ostream &stream) const {
1317
+ TransactionMap::const_iterator it;
1318
+ TransactionMap::const_iterator end = transactions.end();
1319
+
1320
+ stream << "Number of clients: " << getClients().size() << "\n";
1321
+ stream << "Open transactions: " << transactions.size() << "\n";
1322
+ for (it = transactions.begin(); it != end; it++) {
1323
+ const TransactionPtr &transaction = it->second;
1324
+ transaction->dump(stream);
1325
+ }
1326
+
1327
+ LogSinkCache::const_iterator sit;
1328
+ LogSinkCache::const_iterator send = logSinkCache.end();
1329
+ stream << "Log sinks: " << logSinkCache.size() <<
1330
+ " (" << inactiveLogSinksCount << " inactive)\n";
1331
+ for (sit = logSinkCache.begin(); sit != send; sit++) {
1332
+ const LogSinkPtr &logSink = sit->second;
1333
+ logSink->dump(stream);
1334
+ }
1335
+ }
1336
+ };
1337
+
1338
+ typedef shared_ptr<LoggingServer> LoggingServerPtr;
1339
+
1340
+
1341
+ } // namespace Passenger
1342
+
1343
+ #endif /* _PASSENGER_LOGGING_SERVER_H_ */