passenger 4.0.20 → 4.0.21
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of passenger might be problematic. Click here for more details.
- checksums.yaml +8 -8
- checksums.yaml.gz.asc +7 -7
- data.tar.gz.asc +7 -7
- data/.gitignore +1 -0
- data/.travis.yml +1 -1
- data/NEWS +15 -0
- data/README.md +5 -3
- data/Rakefile +1 -0
- data/bin/passenger-config +1 -5
- data/bin/passenger-install-apache2-module +53 -5
- data/bin/passenger-install-nginx-module +19 -6
- data/bin/passenger-memory-stats +3 -3
- data/build/agents.rb +11 -8
- data/build/apache2.rb +9 -5
- data/build/basics.rb +15 -21
- data/build/common_library.rb +16 -6
- data/build/cplusplus_support.rb +5 -5
- data/build/cxx_tests.rb +3 -3
- data/build/documentation.rb +1 -1
- data/build/misc.rb +4 -37
- data/build/node_tests.rb +29 -0
- data/build/oxt_tests.rb +1 -1
- data/build/packaging.rb +29 -10
- data/build/preprocessor.rb +2 -1
- data/build/test_basics.rb +15 -6
- data/debian.template/locations.ini.template +1 -0
- data/debian.template/passenger.install.template +1 -0
- data/dev/copy_boost_headers.rb +7 -3
- data/dev/run_travis.sh +32 -16
- data/doc/Users guide Apache.idmap.txt +22 -34
- data/doc/Users guide Apache.txt +20 -234
- data/doc/Users guide Nginx.idmap.txt +84 -66
- data/doc/Users guide Nginx.txt +50 -1
- data/doc/Users guide Standalone.idmap.txt +74 -0
- data/doc/Users guide Standalone.txt +22 -9
- data/doc/Users guide.txt +51 -0
- data/doc/users_guide_snippets/environment_variables.txt +0 -3
- data/doc/users_guide_snippets/installation.txt +337 -380
- data/doc/users_guide_snippets/installation/run_installer.txt +58 -0
- data/doc/users_guide_snippets/installation/verify_running_epilogue.txt +6 -0
- data/doc/users_guide_snippets/support_information.txt +2 -9
- data/doc/users_guide_snippets/troubleshooting/default.txt +112 -0
- data/doc/users_guide_snippets/troubleshooting/rails.txt +56 -0
- data/doc/users_guide_snippets/where_to_get_support.txt +9 -0
- data/ext/apache2/Bucket.h +1 -1
- data/ext/apache2/Configuration.hpp +0 -44
- data/ext/apache2/CreateDirConfig.cpp +1 -1
- data/ext/apache2/CreateDirConfig.cpp.erb +1 -1
- data/ext/apache2/Hooks.cpp +28 -21
- data/ext/apache2/MergeDirConfig.cpp +1 -0
- data/ext/apache2/MergeDirConfig.cpp.erb +1 -1
- data/ext/apache2/SetHeaders.cpp +73 -0
- data/ext/apache2/SetHeaders.cpp.erb +88 -0
- data/ext/boost/algorithm/string/detail/find_format.hpp +5 -5
- data/ext/boost/algorithm/string/detail/find_format_all.hpp +5 -5
- data/ext/boost/algorithm/string/detail/finder.hpp +1 -1
- data/ext/boost/algorithm/string/formatter.hpp +2 -2
- data/ext/boost/assert.hpp +6 -1
- data/ext/boost/atomic.hpp +18 -0
- data/ext/boost/atomic/atomic.hpp +241 -0
- data/ext/boost/atomic/detail/base.hpp +585 -0
- data/ext/boost/atomic/detail/cas32strong.hpp +885 -0
- data/ext/boost/atomic/detail/cas32weak.hpp +947 -0
- data/ext/boost/atomic/detail/cas64strong.hpp +443 -0
- data/ext/boost/atomic/detail/config.hpp +54 -0
- data/ext/boost/atomic/detail/gcc-alpha.hpp +368 -0
- data/ext/boost/atomic/detail/gcc-armv6plus.hpp +252 -0
- data/ext/boost/atomic/detail/gcc-cas.hpp +157 -0
- data/ext/boost/atomic/detail/gcc-ppc.hpp +2850 -0
- data/ext/boost/atomic/detail/gcc-sparcv9.hpp +1259 -0
- data/ext/boost/atomic/detail/gcc-x86.hpp +1766 -0
- data/ext/boost/atomic/detail/generic-cas.hpp +206 -0
- data/ext/boost/atomic/detail/interlocked.hpp +200 -0
- data/ext/boost/atomic/detail/linux-arm.hpp +189 -0
- data/ext/boost/atomic/detail/lockpool.hpp +97 -0
- data/ext/boost/atomic/detail/platform.hpp +62 -0
- data/ext/boost/atomic/detail/type-classification.hpp +45 -0
- data/ext/boost/chrono/config.hpp +8 -3
- data/ext/boost/chrono/duration.hpp +9 -10
- data/ext/boost/chrono/system_clocks.hpp +1 -1
- data/ext/boost/chrono/time_point.hpp +4 -3
- data/ext/boost/config/auto_link.hpp +53 -52
- data/ext/boost/config/compiler/borland.hpp +1 -0
- data/ext/boost/config/compiler/clang.hpp +24 -1
- data/ext/boost/config/compiler/codegear.hpp +1 -0
- data/ext/boost/config/compiler/common_edg.hpp +1 -0
- data/ext/boost/config/compiler/cray.hpp +1 -0
- data/ext/boost/config/compiler/digitalmars.hpp +1 -0
- data/ext/boost/config/compiler/gcc.hpp +29 -3
- data/ext/boost/config/compiler/gcc_xml.hpp +2 -1
- data/ext/boost/config/compiler/hp_acc.hpp +1 -0
- data/ext/boost/config/compiler/intel.hpp +1 -1
- data/ext/boost/config/compiler/metrowerks.hpp +1 -0
- data/ext/boost/config/compiler/mpw.hpp +1 -0
- data/ext/boost/config/compiler/pathscale.hpp +1 -0
- data/ext/boost/config/compiler/pgi.hpp +1 -0
- data/ext/boost/config/compiler/sunpro_cc.hpp +1 -0
- data/ext/boost/config/compiler/vacpp.hpp +3 -2
- data/ext/boost/config/compiler/visualc.hpp +25 -11
- data/ext/boost/config/platform/vxworks.hpp +353 -15
- data/ext/boost/config/select_compiler_config.hpp +4 -4
- data/ext/boost/config/stdlib/dinkumware.hpp +10 -3
- data/ext/boost/config/stdlib/libstdcpp3.hpp +2 -1
- data/ext/boost/config/suffix.hpp +45 -19
- data/ext/boost/date_time/format_date_parser.hpp +1 -11
- data/ext/boost/date_time/strings_from_facet.hpp +5 -3
- data/ext/boost/detail/atomic_redef_macros.hpp +19 -0
- data/ext/boost/detail/atomic_undef_macros.hpp +39 -0
- data/ext/boost/detail/endian.hpp +52 -4
- data/ext/boost/detail/scoped_enum_emulation.hpp +10 -10
- data/ext/boost/detail/select_type.hpp +36 -0
- data/ext/boost/exception/current_exception_cast.hpp +1 -1
- data/ext/boost/exception/detail/error_info_impl.hpp +3 -5
- data/ext/boost/exception/detail/exception_ptr.hpp +3 -3
- data/ext/boost/exception/detail/is_output_streamable.hpp +1 -1
- data/ext/boost/exception/detail/object_hex_dump.hpp +1 -1
- data/ext/boost/exception/detail/type_info.hpp +1 -1
- data/ext/boost/exception/diagnostic_information.hpp +15 -14
- data/ext/boost/exception/exception.hpp +1 -1
- data/ext/boost/exception/get_error_info.hpp +1 -1
- data/ext/boost/exception/info.hpp +12 -13
- data/ext/boost/exception/to_string.hpp +6 -1
- data/ext/boost/exception/to_string_stub.hpp +9 -1
- data/ext/boost/foreach.hpp +5 -5
- data/ext/boost/function/function_template.hpp +6 -6
- data/ext/boost/functional/hash/detail/float_functions.hpp +90 -0
- data/ext/boost/functional/hash/detail/hash_float.hpp +11 -2
- data/ext/boost/functional/hash/extensions.hpp +14 -2
- data/ext/boost/functional/hash/hash.hpp +26 -5
- data/ext/boost/get_pointer.hpp +17 -2
- data/ext/boost/integer_traits.hpp +1 -1
- data/ext/boost/lexical_cast.hpp +615 -395
- data/ext/boost/libs/atomic/lockpool.cpp +24 -0
- data/ext/boost/libs/system/src/error_code.cpp +25 -18
- data/ext/boost/libs/thread/src/future.cpp +7 -5
- data/ext/boost/libs/thread/src/pthread/once.cpp +9 -3
- data/ext/boost/libs/thread/src/pthread/once_atomic.cpp +90 -0
- data/ext/boost/libs/thread/src/pthread/thread.cpp +129 -95
- data/ext/boost/libs/thread/src/pthread/timeconv.inl +20 -1
- data/ext/boost/limits.hpp +1 -1
- data/ext/boost/math/policies/policy.hpp +10 -0
- data/ext/boost/math/special_functions/detail/round_fwd.hpp +17 -4
- data/ext/boost/math/special_functions/fpclassify.hpp +114 -45
- data/ext/boost/math/special_functions/math_fwd.hpp +195 -83
- data/ext/boost/math/special_functions/sign.hpp +13 -8
- data/ext/boost/math/tools/config.hpp +38 -16
- data/ext/boost/move/algorithm.hpp +275 -0
- data/ext/boost/move/core.hpp +332 -0
- data/ext/boost/move/detail/config_begin.hpp +23 -0
- data/ext/boost/move/detail/config_end.hpp +20 -0
- data/ext/boost/move/detail/meta_utils.hpp +158 -0
- data/ext/boost/move/iterator.hpp +298 -0
- data/ext/boost/move/move.hpp +10 -1256
- data/ext/boost/move/traits.hpp +142 -0
- data/ext/boost/move/utility.hpp +194 -0
- data/ext/boost/mpl/assert.hpp +72 -4
- data/ext/boost/noncopyable.hpp +15 -3
- data/ext/boost/pointer_to_other.hpp +55 -0
- data/ext/boost/range/concepts.hpp +4 -4
- data/ext/boost/range/detail/extract_optional_type.hpp +1 -1
- data/ext/boost/range/empty.hpp +1 -1
- data/ext/boost/range/iterator_range_core.hpp +4 -1
- data/ext/boost/range/iterator_range_io.hpp +2 -2
- data/ext/boost/ratio/config.hpp +6 -0
- data/ext/boost/ratio/detail/overflow_helpers.hpp +2 -2
- data/ext/boost/smart_ptr/allocate_shared_array.hpp +250 -0
- data/ext/boost/smart_ptr/detail/allocate_array_helper.hpp +169 -0
- data/ext/boost/smart_ptr/detail/array_deleter.hpp +124 -0
- data/ext/boost/smart_ptr/detail/array_traits.hpp +53 -0
- data/ext/boost/smart_ptr/detail/array_utility.hpp +178 -0
- data/ext/boost/smart_ptr/detail/make_array_helper.hpp +157 -0
- data/ext/boost/smart_ptr/detail/operator_bool.hpp +16 -9
- data/ext/boost/smart_ptr/detail/shared_count.hpp +78 -7
- data/ext/boost/smart_ptr/detail/sp_convertible.hpp +15 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base.hpp +12 -6
- data/ext/boost/smart_ptr/detail/sp_counted_base_acc_ia64.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_aix.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_cw_ppc.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_cw_x86.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_ia64.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_mips.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_ppc.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_sparc.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_gcc_x86.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_nt.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_pt.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_snc_ps3.hpp +162 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_solaris.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_spin.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_sync.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_base_vacpp_ppc.hpp +1 -0
- data/ext/boost/smart_ptr/detail/sp_counted_impl.hpp +15 -0
- data/ext/boost/smart_ptr/detail/sp_forward.hpp +39 -0
- data/ext/boost/smart_ptr/detail/sp_has_sync.hpp +19 -3
- data/ext/boost/smart_ptr/detail/sp_if_array.hpp +31 -0
- data/ext/boost/smart_ptr/detail/sp_nullptr_t.hpp +45 -0
- data/ext/boost/smart_ptr/detail/spinlock_gcc_arm.hpp +5 -12
- data/ext/boost/smart_ptr/enable_shared_from_this.hpp +4 -4
- data/ext/boost/smart_ptr/make_shared.hpp +5 -1060
- data/ext/boost/smart_ptr/make_shared_array.hpp +247 -0
- data/ext/boost/smart_ptr/make_shared_object.hpp +1128 -0
- data/ext/boost/smart_ptr/scoped_array.hpp +32 -7
- data/ext/boost/smart_ptr/scoped_ptr.hpp +31 -5
- data/ext/boost/smart_ptr/shared_array.hpp +135 -20
- data/ext/boost/smart_ptr/shared_ptr.hpp +444 -126
- data/ext/boost/smart_ptr/weak_ptr.hpp +39 -28
- data/ext/boost/static_assert.hpp +74 -17
- data/ext/boost/system/error_code.hpp +76 -68
- data/ext/boost/system/system_error.hpp +5 -1
- data/ext/boost/thread/barrier.hpp +6 -2
- data/ext/boost/thread/completion_latch.hpp +233 -0
- data/ext/boost/thread/condition.hpp +6 -1
- data/ext/boost/thread/detail/async_func.hpp +571 -0
- data/ext/boost/thread/detail/config.hpp +248 -40
- data/ext/boost/thread/detail/counter.hpp +93 -0
- data/ext/boost/thread/detail/delete.hpp +12 -0
- data/ext/boost/thread/detail/invoke.hpp +1351 -0
- data/ext/boost/thread/detail/is_convertible.hpp +48 -0
- data/ext/boost/thread/detail/lockable_wrapper.hpp +45 -0
- data/ext/boost/thread/detail/log.hpp +83 -0
- data/ext/boost/thread/detail/make_tuple_indices.hpp +224 -0
- data/ext/boost/thread/detail/move.hpp +32 -16
- data/ext/boost/thread/detail/thread.hpp +236 -41
- data/ext/boost/thread/detail/thread_group.hpp +55 -9
- data/ext/boost/thread/detail/thread_interruption.hpp +4 -1
- data/ext/boost/thread/exceptions.hpp +2 -0
- data/ext/boost/thread/externally_locked.hpp +351 -0
- data/ext/boost/thread/externally_locked_stream.hpp +170 -0
- data/ext/boost/thread/future.hpp +2517 -455
- data/ext/boost/thread/future_error_code.hpp +61 -0
- data/ext/boost/thread/is_locked_by_this_thread.hpp +39 -0
- data/ext/boost/thread/latch.hpp +142 -0
- data/ext/boost/thread/lock_algorithms.hpp +468 -0
- data/ext/boost/thread/lock_concepts.hpp +197 -0
- data/ext/boost/thread/lock_factories.hpp +78 -0
- data/ext/boost/thread/lock_guard.hpp +88 -0
- data/ext/boost/thread/lock_options.hpp +31 -0
- data/ext/boost/thread/lock_traits.hpp +45 -0
- data/ext/boost/thread/lock_types.hpp +1226 -0
- data/ext/boost/thread/lockable_adapter.hpp +226 -0
- data/ext/boost/thread/lockable_concepts.hpp +157 -0
- data/ext/boost/thread/lockable_traits.hpp +207 -0
- data/ext/boost/thread/locks.hpp +5 -1816
- data/ext/boost/thread/mutex.hpp +33 -1
- data/ext/boost/thread/null_mutex.hpp +243 -0
- data/ext/boost/thread/once.hpp +10 -1
- data/ext/boost/thread/poly_lockable.hpp +68 -0
- data/ext/boost/thread/poly_lockable_adapter.hpp +89 -0
- data/ext/boost/thread/poly_shared_lockable.hpp +135 -0
- data/ext/boost/thread/poly_shared_lockable_adapter.hpp +170 -0
- data/ext/boost/thread/pthread/condition_variable.hpp +74 -26
- data/ext/boost/thread/pthread/condition_variable_fwd.hpp +54 -27
- data/ext/boost/thread/pthread/mutex.hpp +101 -38
- data/ext/boost/thread/pthread/once.hpp +459 -44
- data/ext/boost/thread/pthread/once_atomic.hpp +313 -0
- data/ext/boost/thread/pthread/recursive_mutex.hpp +19 -10
- data/ext/boost/thread/pthread/shared_mutex.hpp +226 -61
- data/ext/boost/thread/pthread/shared_mutex_assert.hpp +724 -0
- data/ext/boost/thread/pthread/thread_data.hpp +53 -50
- data/ext/boost/thread/pthread/timespec.hpp +96 -12
- data/ext/boost/thread/recursive_mutex.hpp +44 -1
- data/ext/boost/thread/reverse_lock.hpp +3 -2
- data/ext/boost/thread/scoped_thread.hpp +285 -0
- data/ext/boost/thread/shared_lock_guard.hpp +2 -1
- data/ext/boost/thread/shared_mutex.hpp +23 -0
- data/ext/boost/thread/strict_lock.hpp +235 -0
- data/ext/boost/thread/sync_bounded_queue.hpp +594 -0
- data/ext/boost/thread/sync_queue.hpp +516 -0
- data/ext/boost/thread/synchronized_value.hpp +1001 -0
- data/ext/boost/thread/testable_mutex.hpp +148 -0
- data/ext/boost/thread/thread.hpp +1 -13
- data/ext/boost/thread/thread_functors.hpp +57 -0
- data/ext/boost/thread/thread_guard.hpp +46 -0
- data/ext/boost/thread/thread_only.hpp +29 -0
- data/ext/boost/thread/v2/shared_mutex.hpp +1062 -0
- data/ext/boost/thread/v2/thread.hpp +37 -10
- data/ext/boost/thread/xtime.hpp +2 -1
- data/ext/boost/token_functions.hpp +16 -16
- data/ext/boost/type_traits/add_lvalue_reference.hpp +26 -0
- data/ext/boost/type_traits/add_reference.hpp +1 -1
- data/ext/boost/type_traits/add_rvalue_reference.hpp +4 -4
- data/ext/boost/type_traits/aligned_storage.hpp +13 -0
- data/ext/boost/type_traits/common_type.hpp +11 -12
- data/ext/boost/type_traits/config.hpp +1 -1
- data/ext/boost/type_traits/detail/common_type_imp.hpp +1 -1
- data/ext/boost/type_traits/detail/has_binary_operator.hpp +1 -1
- data/ext/boost/type_traits/detail/is_function_ptr_tester.hpp +1 -1
- data/ext/boost/type_traits/has_left_shift.hpp +49 -0
- data/ext/boost/type_traits/has_right_shift.hpp +49 -0
- data/ext/boost/type_traits/has_trivial_move_assign.hpp +57 -0
- data/ext/boost/type_traits/has_trivial_move_constructor.hpp +57 -0
- data/ext/boost/type_traits/intrinsics.hpp +18 -2
- data/ext/boost/type_traits/is_abstract.hpp +1 -1
- data/ext/boost/type_traits/is_array.hpp +1 -1
- data/ext/boost/type_traits/is_const.hpp +1 -1
- data/ext/boost/type_traits/is_convertible.hpp +78 -17
- data/ext/boost/type_traits/is_function.hpp +6 -1
- data/ext/boost/type_traits/is_integral.hpp +6 -1
- data/ext/boost/type_traits/is_nothrow_move_assignable.hpp +84 -0
- data/ext/boost/type_traits/is_nothrow_move_constructible.hpp +84 -0
- data/ext/boost/type_traits/is_pod.hpp +3 -1
- data/ext/boost/type_traits/is_rvalue_reference.hpp +1 -1
- data/ext/boost/type_traits/is_volatile.hpp +1 -1
- data/ext/boost/type_traits/make_signed.hpp +153 -0
- data/ext/boost/type_traits/make_unsigned.hpp +16 -0
- data/ext/boost/type_traits/remove_const.hpp +1 -1
- data/ext/boost/type_traits/remove_cv.hpp +1 -1
- data/ext/boost/type_traits/remove_reference.hpp +1 -1
- data/ext/boost/type_traits/remove_volatile.hpp +1 -1
- data/ext/boost/unordered/detail/allocate.hpp +1120 -0
- data/ext/boost/unordered/detail/buckets.hpp +876 -0
- data/ext/boost/unordered/detail/equivalent.hpp +680 -0
- data/ext/boost/unordered/detail/extract_key.hpp +183 -0
- data/ext/boost/unordered/detail/fwd.hpp +23 -0
- data/ext/boost/unordered/detail/table.hpp +861 -0
- data/ext/boost/unordered/detail/unique.hpp +622 -0
- data/ext/boost/unordered/detail/util.hpp +260 -0
- data/ext/boost/unordered/unordered_map.hpp +1652 -0
- data/ext/boost/unordered/unordered_map_fwd.hpp +65 -0
- data/ext/boost/unordered/unordered_set.hpp +1549 -0
- data/ext/boost/unordered/unordered_set_fwd.hpp +63 -0
- data/ext/boost/unordered_map.hpp +18 -0
- data/ext/boost/unordered_set.hpp +18 -0
- data/ext/boost/utility/addressof.hpp +2 -2
- data/ext/boost/utility/result_of.hpp +8 -1
- data/ext/boost/version.hpp +2 -2
- data/ext/common/Account.h +1 -1
- data/ext/common/AccountsDatabase.h +1 -1
- data/ext/common/AgentsStarter.cpp +3 -1
- data/ext/common/AgentsStarter.h +2 -2
- data/ext/common/ApplicationPool2/AppTypes.cpp +24 -6
- data/ext/common/ApplicationPool2/AppTypes.h +17 -8
- data/ext/common/ApplicationPool2/Common.h +12 -12
- data/ext/common/ApplicationPool2/DirectSpawner.h +2 -2
- data/ext/common/ApplicationPool2/DummySpawner.h +3 -3
- data/ext/common/ApplicationPool2/Group.h +6 -6
- data/ext/common/ApplicationPool2/Implementation.cpp +19 -19
- data/ext/common/ApplicationPool2/PipeWatcher.h +5 -5
- data/ext/common/ApplicationPool2/Pool.h +21 -21
- data/ext/common/ApplicationPool2/Process.h +6 -6
- data/ext/common/ApplicationPool2/Session.h +1 -1
- data/ext/common/ApplicationPool2/SmartSpawner.h +24 -12
- data/ext/common/ApplicationPool2/Socket.h +2 -2
- data/ext/common/ApplicationPool2/Spawner.h +64 -14
- data/ext/common/ApplicationPool2/SpawnerFactory.h +7 -7
- data/ext/common/ApplicationPool2/SuperGroup.h +5 -5
- data/ext/common/BackgroundEventLoop.cpp +4 -4
- data/ext/common/BackgroundEventLoop.h +1 -1
- data/ext/common/Constants.h +13 -1
- data/ext/common/EventedBufferedInput.h +8 -8
- data/ext/common/Exceptions.cpp +71 -0
- data/ext/common/Exceptions.h +60 -7
- data/ext/common/FileDescriptor.h +4 -4
- data/ext/common/MessageClient.h +1 -1
- data/ext/common/MessageServer.h +5 -5
- data/ext/common/MultiLibeio.cpp +3 -3
- data/ext/common/MultiLibeio.h +2 -2
- data/ext/common/RandomGenerator.h +11 -11
- data/ext/common/ResourceLocator.h +8 -1
- data/ext/common/SafeLibev.h +12 -12
- data/ext/common/ServerInstanceDir.h +11 -3
- data/ext/common/UnionStation.h +10 -10
- data/ext/common/Utils.cpp +11 -13
- data/ext/common/Utils.h +9 -9
- data/ext/common/Utils/BlockingQueue.h +10 -10
- data/ext/common/Utils/BufferedIO.h +1 -1
- data/ext/common/Utils/CachedFileStat.hpp +2 -2
- data/ext/common/Utils/FileChangeChecker.h +1 -1
- data/ext/common/Utils/HashMap.h +13 -4
- data/ext/common/Utils/IOUtils.cpp +33 -10
- data/ext/common/Utils/IniFile.h +3 -3
- data/ext/common/Utils/Lock.h +2 -2
- data/ext/common/Utils/MessagePassing.h +10 -10
- data/ext/common/Utils/ProcessMetricsCollector.h +24 -6
- data/ext/common/Utils/ScopeGuard.h +5 -5
- data/ext/common/Utils/jsoncpp.cpp +2 -0
- data/ext/common/agents/HelperAgent/FileBackedPipe.h +26 -26
- data/ext/common/agents/HelperAgent/Main.cpp +18 -18
- data/ext/common/agents/HelperAgent/RequestHandler.cpp +4 -4
- data/ext/common/agents/HelperAgent/RequestHandler.h +30 -21
- data/ext/common/agents/LoggingAgent/AdminController.h +1 -1
- data/ext/common/agents/LoggingAgent/FilterSupport.h +13 -11
- data/ext/common/agents/LoggingAgent/LoggingServer.h +11 -11
- data/ext/common/agents/LoggingAgent/Main.cpp +9 -9
- data/ext/common/agents/LoggingAgent/RemoteSender.h +3 -3
- data/ext/common/agents/SpawnPreparer.cpp +1 -0
- data/ext/common/agents/Watchdog/AgentWatcher.cpp +8 -7
- data/ext/common/agents/Watchdog/Main.cpp +81 -73
- data/ext/common/agents/Watchdog/ServerInstanceDirToucher.cpp +1 -1
- data/ext/libev/Changes +57 -0
- data/ext/libev/LICENSE +2 -1
- data/ext/libev/Makefile.in +110 -50
- data/ext/libev/README +8 -8
- data/ext/libev/aclocal.m4 +1503 -861
- data/ext/libev/config.guess +290 -304
- data/ext/libev/config.sub +77 -198
- data/ext/libev/configure +1735 -890
- data/ext/libev/configure.ac +3 -2
- data/ext/libev/ev++.h +6 -6
- data/ext/libev/ev.c +541 -214
- data/ext/libev/ev.h +106 -100
- data/ext/libev/ev_epoll.c +1 -1
- data/ext/libev/ev_kqueue.c +20 -4
- data/ext/libev/ev_vars.h +15 -16
- data/ext/libev/ev_win32.c +12 -2
- data/ext/libev/ev_wrap.h +162 -160
- data/ext/libev/event.c +29 -6
- data/ext/libev/event.h +9 -2
- data/ext/libev/ltmain.sh +2632 -1384
- data/ext/nginx/ConfigurationCommands.c +1 -1
- data/ext/nginx/ConfigurationCommands.c.erb +3 -1
- data/ext/nginx/ContentHandler.c +25 -2
- data/ext/nginx/CreateLocationConfig.c +1 -0
- data/ext/nginx/CreateLocationConfig.c.erb +1 -1
- data/ext/nginx/MergeLocationConfig.c +1 -0
- data/ext/nginx/MergeLocationConfig.c.erb +1 -1
- data/ext/nginx/config +12 -0
- data/ext/oxt/dynamic_thread_group.hpp +7 -4
- data/ext/oxt/system_calls.cpp +5 -1
- data/ext/oxt/system_calls.hpp +3 -0
- data/helper-scripts/node-loader.js +117 -249
- data/lib/phusion_passenger.rb +27 -5
- data/lib/phusion_passenger/abstract_installer.rb +104 -9
- data/lib/phusion_passenger/admin_tools/memory_stats.rb +10 -9
- data/lib/phusion_passenger/apache2/config_options.rb +6 -3
- data/lib/phusion_passenger/common_library.rb +7 -1
- data/lib/phusion_passenger/constants.rb +6 -0
- data/lib/phusion_passenger/loader_shared_helpers.rb +7 -4
- data/lib/phusion_passenger/nginx/config_options.rb +2 -1
- data/lib/phusion_passenger/packaging.rb +3 -0
- data/lib/phusion_passenger/platform_info/apache.rb +43 -6
- data/lib/phusion_passenger/platform_info/apache_detector.rb +15 -5
- data/lib/phusion_passenger/platform_info/compiler.rb +167 -32
- data/lib/phusion_passenger/platform_info/cxx_portability.rb +133 -77
- data/lib/phusion_passenger/platform_info/depcheck.rb +17 -7
- data/lib/phusion_passenger/platform_info/depcheck_specs/apache2.rb +3 -3
- data/lib/phusion_passenger/platform_info/depcheck_specs/compiler_toolchain.rb +4 -4
- data/lib/phusion_passenger/platform_info/depcheck_specs/ruby.rb +5 -6
- data/lib/phusion_passenger/platform_info/linux.rb +2 -1
- data/lib/phusion_passenger/platform_info/operating_system.rb +1 -1
- data/lib/phusion_passenger/platform_info/ruby.rb +18 -3
- data/lib/phusion_passenger/standalone/runtime_installer.rb +6 -2
- data/lib/phusion_passenger/standalone/start_command.rb +8 -2
- data/lib/phusion_passenger/utils/ansi_colors.rb +9 -0
- data/lib/phusion_passenger/utils/hosts_file_parser.rb +4 -2
- data/node_lib/phusion_passenger/httplib_emulation.js +141 -0
- data/node_lib/phusion_passenger/line_reader.js +154 -0
- data/node_lib/phusion_passenger/request_handler.js +65 -0
- data/node_lib/phusion_passenger/session_protocol_parser.js +113 -0
- data/resources/templates/apache2/deployment_example.txt.erb +2 -1
- data/resources/templates/apache2/installing_against_a_different_apache.txt.erb +14 -0
- data/resources/templates/apache2/multiple_apache_installations_detected.txt.erb +15 -0
- data/resources/templates/apache2/possible_solutions_for_compilation_and_installation_problems.txt.erb +4 -5
- data/resources/templates/general_error_with_html.html.template +1 -1
- data/resources/templates/installer_common/gem_install_permission_problems.txt.erb +17 -0
- data/resources/templates/installer_common/low_amount_of_memory_warning.txt.erb +6 -4
- data/resources/templates/installer_common/world_inaccessible_directories.txt.erb +16 -0
- data/resources/templates/nginx/deployment_example.txt.erb +2 -1
- data/resources/templates/nginx/possible_solutions_for_compilation_and_installation_problems.txt.erb +4 -5
- data/resources/templates/standalone/config.erb +1 -0
- data/test/cxx/ApplicationPool2/DirectSpawnerTest.cpp +3 -3
- data/test/cxx/ApplicationPool2/PoolTest.cpp +4 -4
- data/test/cxx/ApplicationPool2/ProcessTest.cpp +5 -5
- data/test/cxx/ApplicationPool2/SmartSpawnerTest.cpp +5 -5
- data/test/cxx/ApplicationPool2/SpawnerTestCases.cpp +1 -1
- data/test/cxx/EventedBufferedInputTest.cpp +6 -6
- data/test/cxx/FileBackedPipeTest.cpp +1 -1
- data/test/cxx/MessagePassingTest.cpp +1 -1
- data/test/cxx/MessageServerTest.cpp +4 -4
- data/test/cxx/RequestHandlerTest.cpp +7 -7
- data/test/cxx/UnionStationTest.cpp +2 -2
- data/test/node/line_reader_spec.js +338 -0
- data/test/node/spec_helper.js +27 -0
- data/test/ruby/standalone/runtime_installer_spec.rb +2 -1
- metadata +131 -22
- metadata.gz.asc +7 -7
- data/ext/boost/functional/hash/detail/container_fwd_0x.hpp +0 -29
- data/ext/boost/lambda/core.hpp +0 -79
- data/ext/boost/lambda/detail/actions.hpp +0 -174
- data/ext/boost/lambda/detail/arity_code.hpp +0 -110
- data/ext/boost/lambda/detail/function_adaptors.hpp +0 -789
- data/ext/boost/lambda/detail/is_instance_of.hpp +0 -104
- data/ext/boost/lambda/detail/lambda_config.hpp +0 -48
- data/ext/boost/lambda/detail/lambda_functor_base.hpp +0 -615
- data/ext/boost/lambda/detail/lambda_functors.hpp +0 -324
- data/ext/boost/lambda/detail/lambda_fwd.hpp +0 -74
- data/ext/boost/lambda/detail/lambda_traits.hpp +0 -578
- data/ext/boost/lambda/detail/member_ptr.hpp +0 -737
- data/ext/boost/lambda/detail/operator_actions.hpp +0 -139
- data/ext/boost/lambda/detail/operator_lambda_func_base.hpp +0 -271
- data/ext/boost/lambda/detail/operator_return_type_traits.hpp +0 -917
- data/ext/boost/lambda/detail/operators.hpp +0 -370
- data/ext/boost/lambda/detail/ret.hpp +0 -325
- data/ext/boost/lambda/detail/return_type_traits.hpp +0 -282
- data/ext/boost/lambda/detail/select_functions.hpp +0 -74
- data/ext/boost/lambda/lambda.hpp +0 -34
@@ -28,86 +28,160 @@ require 'phusion_passenger/platform_info/operating_system'
|
|
28
28
|
module PhusionPassenger
|
29
29
|
|
30
30
|
module PlatformInfo
|
31
|
-
#
|
31
|
+
# Linker flags that should be used for linking every C/C++ program,
|
32
32
|
# for portability reasons. These flags should be specified as last
|
33
|
-
# when invoking the
|
34
|
-
def self.
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
33
|
+
# when invoking the linker.
|
34
|
+
def self.portability_ldflags
|
35
|
+
if os_name =~ /solaris/
|
36
|
+
result = '-lxnet -lsocket -lnsl -lpthread'
|
37
|
+
else
|
38
|
+
result = '-lpthread'
|
39
|
+
end
|
40
|
+
result << ' -lrt' if has_rt_library?
|
41
|
+
result << ' -lmath' if has_math_library?
|
42
|
+
return result
|
43
|
+
end
|
44
|
+
memoize :portability_ldflags
|
45
|
+
|
46
|
+
# Extra compiler flags that should always be passed to the C compiler,
|
47
|
+
# last in the command string.
|
48
|
+
def self.default_extra_cflags
|
49
|
+
return default_extra_c_or_cxxflags(:cc)
|
50
|
+
end
|
51
|
+
memoize :default_extra_cflags, true
|
52
|
+
|
53
|
+
# Extra compiler flags that should always be passed to the C++ compiler,
|
54
|
+
# last in the command string.
|
55
|
+
def self.default_extra_cxxflags
|
56
|
+
return default_extra_c_or_cxxflags(:cxx)
|
57
|
+
end
|
58
|
+
memoize :default_extra_cxxflags, true
|
59
|
+
|
60
|
+
private
|
61
|
+
def self.check_unordered_map(flags, class_name, header_name, macro_name)
|
62
|
+
ok = try_compile("Checking for unordered_map", :cxx, %Q{
|
63
|
+
#include <#{header_name}>
|
41
64
|
int
|
42
65
|
main() {
|
43
|
-
|
66
|
+
#{class_name}<int, int> m;
|
44
67
|
return 0;
|
45
68
|
}
|
46
69
|
})
|
47
|
-
if ok
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
return 0;
|
60
|
-
}
|
61
|
-
})
|
62
|
-
if ok
|
63
|
-
hash_namespace = namespace
|
64
|
-
flags << "-DHASH_NAMESPACE=\"#{namespace}\""
|
65
|
-
flags << "-DHASH_MAP_HEADER=\"<#{hash_map_header}>\""
|
66
|
-
flags << "-DHASH_MAP_CLASS=\"hash_map\""
|
67
|
-
end
|
68
|
-
break if ok
|
69
|
-
end
|
70
|
-
break if ok
|
71
|
-
end
|
72
|
-
['ext/hash_fun.h', 'functional', 'tr1/functional',
|
73
|
-
'ext/stl_hash_fun.h', 'hash_fun.h', 'stl_hash_fun.h',
|
74
|
-
'stl/_hash_fun.h'].each do |hash_function_header|
|
75
|
-
ok = try_compile("Checking for #{hash_function_header}", :cxx, %Q{
|
76
|
-
#include <#{hash_function_header}>
|
70
|
+
flags << "-D#{macro_name}" if ok
|
71
|
+
return ok
|
72
|
+
end
|
73
|
+
private_class_method :check_unordered_map
|
74
|
+
|
75
|
+
def self.check_hash_map(flags)
|
76
|
+
hash_namespace = nil
|
77
|
+
ok = false
|
78
|
+
['__gnu_cxx', '', 'std', 'stdext'].each do |namespace|
|
79
|
+
['hash_map', 'ext/hash_map'].each do |hash_map_header|
|
80
|
+
ok = try_compile("Checking for #{hash_map_header}", :cxx, %Q{
|
81
|
+
#include <#{hash_map_header}>
|
77
82
|
int
|
78
83
|
main() {
|
79
|
-
#{
|
84
|
+
#{namespace}::hash_map<int, int> m;
|
80
85
|
return 0;
|
81
86
|
}
|
82
87
|
})
|
83
88
|
if ok
|
84
|
-
|
89
|
+
hash_namespace = namespace
|
90
|
+
flags << "-DHASH_NAMESPACE=\"#{namespace}\""
|
91
|
+
flags << "-DHASH_MAP_HEADER=\"<#{hash_map_header}>\""
|
92
|
+
flags << "-DHASH_MAP_CLASS=\"hash_map\""
|
85
93
|
break
|
86
94
|
end
|
87
95
|
end
|
96
|
+
break if ok
|
97
|
+
end
|
98
|
+
['ext/hash_fun.h', 'functional', 'tr1/functional',
|
99
|
+
'ext/stl_hash_fun.h', 'hash_fun.h', 'stl_hash_fun.h',
|
100
|
+
'stl/_hash_fun.h'].each do |hash_function_header|
|
101
|
+
ok = try_compile("Checking for #{hash_function_header}", :cxx, %Q{
|
102
|
+
#include <#{hash_function_header}>
|
103
|
+
int
|
104
|
+
main() {
|
105
|
+
#{hash_namespace}::hash<int>()(5);
|
106
|
+
return 0;
|
107
|
+
}
|
108
|
+
})
|
109
|
+
if ok
|
110
|
+
flags << "-DHASH_FUN_H=\"<#{hash_function_header}>\""
|
111
|
+
break
|
112
|
+
end
|
113
|
+
end
|
114
|
+
end
|
115
|
+
private_class_method :check_hash_map
|
116
|
+
|
117
|
+
def self.default_extra_c_or_cxxflags(cc_or_cxx)
|
118
|
+
flags = ["-D_REENTRANT", "-I/usr/local/include"]
|
119
|
+
|
120
|
+
if !send("#{cc_or_cxx}_is_sun_studio?")
|
121
|
+
flags << "-Wall -Wextra -Wno-unused-parameter -Wno-parentheses -Wpointer-arith -Wwrite-strings -Wno-long-long"
|
122
|
+
if send("#{cc_or_cxx}_supports_wno_missing_field_initializers_flag?")
|
123
|
+
flags << "-Wno-missing-field-initializers"
|
124
|
+
end
|
125
|
+
if requires_no_tls_direct_seg_refs? && send("#{cc_or_cxx}_supports_no_tls_direct_seg_refs_option?")
|
126
|
+
flags << "-mno-tls-direct-seg-refs"
|
127
|
+
end
|
128
|
+
# Work around Clang warnings in ev++.h.
|
129
|
+
if send("#{cc_or_cxx}_is_clang?")
|
130
|
+
flags << "-Wno-ambiguous-member-template"
|
131
|
+
end
|
88
132
|
end
|
89
133
|
|
90
|
-
|
91
|
-
|
92
|
-
#
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
134
|
+
if !send("#{cc_or_cxx}_is_sun_studio?")
|
135
|
+
flags << "-fcommon"
|
136
|
+
if send("#{cc_or_cxx}_supports_feliminate_unused_debug?")
|
137
|
+
flags << "-feliminate-unused-debug-symbols -feliminate-unused-debug-types"
|
138
|
+
end
|
139
|
+
if send("#{cc_or_cxx}_supports_visibility_flag?")
|
140
|
+
flags << "-fvisibility=hidden -DVISIBILITY_ATTRIBUTE_SUPPORTED"
|
141
|
+
if send("#{cc_or_cxx}_visibility_flag_generates_warnings?") &&
|
142
|
+
send("#{cc_or_cxx}_supports_wno_attributes_flag?")
|
143
|
+
flags << "-Wno-attributes"
|
144
|
+
end
|
145
|
+
end
|
146
|
+
end
|
147
|
+
|
148
|
+
flags << debugging_cflags
|
149
|
+
flags << '-DHAS_ALLOCA_H' if has_alloca_h?
|
150
|
+
flags << '-DHAVE_ACCEPT4' if has_accept4?
|
151
|
+
flags << '-DHAS_SFENCE' if supports_sfence_instruction?
|
152
|
+
flags << '-DHAS_LFENCE' if supports_lfence_instruction?
|
153
|
+
flags << "-DPASSENGER_DEBUG -DBOOST_DISABLE_ASSERTS"
|
154
|
+
|
155
|
+
if cc_or_cxx == :cxx
|
156
|
+
# There are too many implementations of of the hash map!
|
157
|
+
# Figure out the right one.
|
158
|
+
check_unordered_map(flags, "std::unordered_map", "unordered_map", "HAS_UNORDERED_MAP") ||
|
159
|
+
check_unordered_map(flags, "std::tr1::unordered_map", "unordered_map", "HAS_TR1_UNORDERED_MAP") ||
|
160
|
+
check_hash_map(flags)
|
161
|
+
end
|
162
|
+
|
163
|
+
if os_name =~ /solaris/
|
164
|
+
if send("#{cc_or_cxx}_is_sun_studio?")
|
165
|
+
flags << '-mt'
|
166
|
+
else
|
167
|
+
flags << '-pthreads'
|
168
|
+
end
|
169
|
+
if os_name =~ /solaris2\.11/
|
100
170
|
# skip the _XOPEN_SOURCE and _XPG4_2 definitions in later versions of Solaris / OpenIndiana
|
101
171
|
flags << '-D__EXTENSIONS__ -D__SOLARIS__ -D_FILE_OFFSET_BITS=64'
|
102
172
|
else
|
103
173
|
flags << '-D_XOPEN_SOURCE=500 -D_XPG4_2 -D__EXTENSIONS__ -D__SOLARIS__ -D_FILE_OFFSET_BITS=64'
|
104
|
-
flags << '-D__SOLARIS9__ -DBOOST__STDC_CONSTANT_MACROS_DEFINED' if
|
174
|
+
flags << '-D__SOLARIS9__ -DBOOST__STDC_CONSTANT_MACROS_DEFINED' if os_name =~ /solaris2\.9/
|
175
|
+
end
|
176
|
+
flags << '-DBOOST_HAS_STDINT_H' unless os_name =~ /solaris2\.9/
|
177
|
+
if send("#{cc_or_cxx}_is_sun_studio?")
|
178
|
+
flags << '-xtarget=ultra' if RUBY_PLATFORM =~ /sparc/
|
179
|
+
else
|
180
|
+
flags << '-mcpu=ultrasparc' if RUBY_PLATFORM =~ /sparc/
|
105
181
|
end
|
106
|
-
|
107
|
-
flags << '-mcpu=ultrasparc' if RUBY_PLATFORM =~ /sparc/
|
108
|
-
elsif RUBY_PLATFORM =~ /openbsd/
|
182
|
+
elsif os_name =~ /openbsd/
|
109
183
|
flags << '-DBOOST_HAS_STDINT_H -D_GLIBCPP__PTHREADS'
|
110
|
-
elsif
|
184
|
+
elsif os_name =~ /aix/
|
111
185
|
flags << '-pthread'
|
112
186
|
flags << '-DOXT_DISABLE_BACKTRACES'
|
113
187
|
elsif RUBY_PLATFORM =~ /(sparc-linux|arm-linux|^arm.*-linux|sh4-linux)/
|
@@ -116,28 +190,10 @@ module PlatformInfo
|
|
116
190
|
# http://groups.google.com/group/phusion-passenger/browse_thread/thread/aad4bd9d8d200561
|
117
191
|
flags << '-DBOOST_SP_USE_PTHREADS'
|
118
192
|
end
|
119
|
-
|
120
|
-
flags << '-DHAS_ALLOCA_H' if has_alloca_h?
|
121
|
-
flags << '-DHAS_SFENCE' if supports_sfence_instruction?
|
122
|
-
flags << '-DHAS_LFENCE' if supports_lfence_instruction?
|
123
|
-
|
124
|
-
return flags.compact.join(" ").strip
|
125
|
-
end
|
126
|
-
memoize :portability_cflags, true
|
127
193
|
|
128
|
-
|
129
|
-
# for portability reasons. These flags should be specified as last
|
130
|
-
# when invoking the linker.
|
131
|
-
def self.portability_ldflags
|
132
|
-
if RUBY_PLATFORM =~ /solaris/
|
133
|
-
result = '-lxnet -lrt -lsocket -lnsl -lpthread'
|
134
|
-
else
|
135
|
-
result = '-lpthread'
|
136
|
-
end
|
137
|
-
flags << ' -lmath' if has_math_library?
|
138
|
-
return result
|
194
|
+
return flags.compact.map{ |str| str.strip }.join(" ").strip
|
139
195
|
end
|
140
|
-
|
196
|
+
private_class_method :default_extra_c_or_cxxflags
|
141
197
|
end
|
142
198
|
|
143
199
|
end # module PhusionPassenger
|
@@ -243,8 +243,12 @@ module Depcheck
|
|
243
243
|
install_instructions("Please install it with <b>urpmi #{package_name}</b>")
|
244
244
|
end
|
245
245
|
|
246
|
-
def yum_install(package_name)
|
247
|
-
|
246
|
+
def yum_install(package_name, options = {})
|
247
|
+
if options[:epel]
|
248
|
+
install_instructions("Please enable <b>EPEL</b>, then install with <b>yum install #{package_name}</b>")
|
249
|
+
else
|
250
|
+
install_instructions("Please install it with <b>yum install #{package_name}</b>")
|
251
|
+
end
|
248
252
|
end
|
249
253
|
|
250
254
|
def emerge(package_name)
|
@@ -253,12 +257,18 @@ module Depcheck
|
|
253
257
|
|
254
258
|
def gem_install(package_name)
|
255
259
|
install_instructions("Please make sure RubyGems is installed, then run " +
|
256
|
-
"<b>#{gem_command
|
260
|
+
"<b>#{gem_command} install #{package_name}</b>")
|
257
261
|
end
|
258
262
|
|
259
|
-
def
|
260
|
-
|
261
|
-
|
263
|
+
def install_osx_command_line_tools
|
264
|
+
require 'phusion_passenger/platform_info/compiler'
|
265
|
+
if PlatformInfo.xcode_select_version.to_s >= "2333"
|
266
|
+
install_instructions "Please install the Xcode command line tools: " +
|
267
|
+
"<b>sudo xcode-select --install</b>"
|
268
|
+
else
|
269
|
+
install_instructions "Please install Xcode, then install the command line tools " +
|
270
|
+
"though the menu <b>Xcode -> Preferences -> Downloads -> Components</b>"
|
271
|
+
end
|
262
272
|
end
|
263
273
|
|
264
274
|
|
@@ -267,7 +277,7 @@ module Depcheck
|
|
267
277
|
end
|
268
278
|
|
269
279
|
def gem_command
|
270
|
-
PlatformInfo.gem_command
|
280
|
+
PlatformInfo.gem_command(:sudo => true) || 'gem'
|
271
281
|
end
|
272
282
|
|
273
283
|
def find_command(command, *args)
|
@@ -56,7 +56,7 @@ define 'apache2-dev' do
|
|
56
56
|
emerge "apache"
|
57
57
|
end
|
58
58
|
on :macosx do
|
59
|
-
|
59
|
+
install_osx_command_line_tools
|
60
60
|
end
|
61
61
|
end
|
62
62
|
|
@@ -89,7 +89,7 @@ define 'apr-dev' do
|
|
89
89
|
emerge "apr"
|
90
90
|
end
|
91
91
|
on :macosx do
|
92
|
-
|
92
|
+
install_osx_command_line_tools
|
93
93
|
end
|
94
94
|
end
|
95
95
|
|
@@ -119,6 +119,6 @@ define 'apu-dev' do
|
|
119
119
|
yum_install "apr-util-devel"
|
120
120
|
end
|
121
121
|
on :macosx do
|
122
|
-
|
122
|
+
install_osx_command_line_tools
|
123
123
|
end
|
124
124
|
end
|
@@ -19,7 +19,7 @@ define 'cc' do
|
|
19
19
|
emerge "gcc"
|
20
20
|
end
|
21
21
|
on :macosx do
|
22
|
-
|
22
|
+
install_osx_command_line_tools
|
23
23
|
end
|
24
24
|
end
|
25
25
|
|
@@ -44,7 +44,7 @@ define 'c++' do
|
|
44
44
|
emerge "gcc"
|
45
45
|
end
|
46
46
|
on :macosx do
|
47
|
-
|
47
|
+
install_osx_command_line_tools
|
48
48
|
end
|
49
49
|
end
|
50
50
|
|
@@ -65,7 +65,7 @@ define 'make' do
|
|
65
65
|
yum_install "make"
|
66
66
|
end
|
67
67
|
on :macosx do
|
68
|
-
|
68
|
+
install_osx_command_line_tools
|
69
69
|
end
|
70
70
|
on :other_platforms do
|
71
71
|
website "http://www.gnu.org/software/make/"
|
@@ -89,7 +89,7 @@ define 'gmake' do
|
|
89
89
|
yum_install "make"
|
90
90
|
end
|
91
91
|
on :macosx do
|
92
|
-
|
92
|
+
install_osx_command_line_tools
|
93
93
|
end
|
94
94
|
on :other_platforms do
|
95
95
|
website "http://www.gnu.org/software/make/"
|
@@ -24,7 +24,7 @@ define 'ruby-dev' do
|
|
24
24
|
end
|
25
25
|
end
|
26
26
|
|
27
|
-
if ruby_command =~ %r(^/usr/bin/ruby)
|
27
|
+
if ruby_command =~ %r(^/usr/bin/ruby) || ruby_command =~ %r(^/System/Library/Frameworks/Ruby.framework)
|
28
28
|
# Only tell user to install the headers with the system's package manager
|
29
29
|
# if Ruby itself was installed with the package manager.
|
30
30
|
on :debian do
|
@@ -36,6 +36,9 @@ define 'ruby-dev' do
|
|
36
36
|
on :redhat do
|
37
37
|
yum_install "ruby-devel"
|
38
38
|
end
|
39
|
+
on :macosx do
|
40
|
+
install_osx_command_line_tools
|
41
|
+
end
|
39
42
|
end
|
40
43
|
on :other_platforms do
|
41
44
|
install_instructions "Please (re)install Ruby by downloading it from <b>#{website}</b>"
|
@@ -127,12 +130,8 @@ define 'rake' do
|
|
127
130
|
on :mandriva do
|
128
131
|
urpmi "rake"
|
129
132
|
end
|
130
|
-
on :amazon do
|
131
|
-
# 'yum install rake' installs Ruby 1.9's Rake but Ruby 1.8 is the default -_-
|
132
|
-
gem_install 'rake'
|
133
|
-
end
|
134
133
|
on :redhat do
|
135
|
-
yum_install "rake"
|
134
|
+
yum_install "rubygem-rake", :epel => true
|
136
135
|
end
|
137
136
|
end
|
138
137
|
on :other_platforms do
|
@@ -22,6 +22,7 @@
|
|
22
22
|
# THE SOFTWARE.
|
23
23
|
|
24
24
|
require 'phusion_passenger/platform_info'
|
25
|
+
require 'phusion_passenger/platform_info/operating_system'
|
25
26
|
|
26
27
|
module PhusionPassenger
|
27
28
|
|
@@ -41,7 +42,7 @@ module PlatformInfo
|
|
41
42
|
# distributions it is likely compatible with.
|
42
43
|
# Returns nil if the operating system is not Linux.
|
43
44
|
def self.linux_distro_tags
|
44
|
-
if
|
45
|
+
if os_name != "linux"
|
45
46
|
return nil
|
46
47
|
end
|
47
48
|
lsb_release = read_file("/etc/lsb-release")
|
@@ -23,6 +23,7 @@
|
|
23
23
|
|
24
24
|
require 'rbconfig'
|
25
25
|
require 'phusion_passenger/platform_info'
|
26
|
+
require 'phusion_passenger/platform_info/operating_system'
|
26
27
|
|
27
28
|
module PhusionPassenger
|
28
29
|
|
@@ -139,10 +140,24 @@ module PlatformInfo
|
|
139
140
|
end
|
140
141
|
|
141
142
|
# Returns the correct 'gem' command for this Ruby interpreter.
|
142
|
-
|
143
|
-
|
143
|
+
# If `:sudo => true` is given, then the gem command is prefixed by a
|
144
|
+
# sudo command if filesystem permissions require this.
|
145
|
+
def self.gem_command(options = {})
|
146
|
+
command = locate_ruby_tool('gem')
|
147
|
+
if options[:sudo] && gem_install_requires_sudo?
|
148
|
+
command = "#{ruby_sudo_command} #{command}"
|
149
|
+
end
|
150
|
+
return command
|
144
151
|
end
|
145
152
|
memoize :gem_command
|
153
|
+
|
154
|
+
# Returns whether running 'gem install' as the current user requires sudo.
|
155
|
+
def self.gem_install_requires_sudo?
|
156
|
+
`#{gem_command} env` =~ /INSTALLATION DIRECTORY: (.+)/
|
157
|
+
install_dir = $1
|
158
|
+
return !File.writable?(install_dir)
|
159
|
+
end
|
160
|
+
memoize :gem_install_requires_sudo?
|
146
161
|
|
147
162
|
# Returns the absolute path to the Rake executable that
|
148
163
|
# belongs to the current Ruby interpreter. Returns nil if it
|
@@ -335,7 +350,7 @@ module PlatformInfo
|
|
335
350
|
|
336
351
|
private
|
337
352
|
def self.locate_ruby_tool_by_basename(name)
|
338
|
-
if
|
353
|
+
if os_name == "macosx" &&
|
339
354
|
ruby_command =~ %r(\A/System/Library/Frameworks/Ruby.framework/Versions/.*?/usr/bin/ruby\Z)
|
340
355
|
# On OS X we must look for Ruby binaries in /usr/bin.
|
341
356
|
# RubyGems puts executables (e.g. 'rake') in there, not in
|