diff --git a/bin/ruby-build b/bin/ruby-build index 59fcf556..015b9472 100755 --- a/bin/ruby-build +++ b/bin/ruby-build @@ -320,10 +320,12 @@ build_package_standard() { # Support YAML_CONFIGURE_OPTS, RUBY_CONFIGURE_OPTS, etc. local package_var_name="$(echo "${package_name%%-*}" | tr a-z A-Z)" + local PACKAGE_CONFIGURE="${package_var_name}_CONFIGURE" + local PACKAGE_PREFIX_PATH="${package_var_name}_PREFIX_PATH" local PACKAGE_CONFIGURE_OPTS="${package_var_name}_CONFIGURE_OPTS" local PACKAGE_MAKE_OPTS="${package_var_name}_MAKE_OPTS" - { ./configure --prefix="$PREFIX_PATH" $CONFIGURE_OPTS ${!PACKAGE_CONFIGURE_OPTS} + { ${!PACKAGE_CONFIGURE:-./configure} --prefix="${!PACKAGE_PREFIX_PATH:-$PREFIX_PATH}" $CONFIGURE_OPTS ${!PACKAGE_CONFIGURE_OPTS} "$MAKE" $MAKE_OPTS ${!PACKAGE_MAKE_OPTS} "$MAKE" install } >&4 2>&1 @@ -498,6 +500,51 @@ verify_gcc() { echo "$gcc" } +build_package_replace_osx_openssl() { + # Check for broken OpenSSL build shipped with OSX. + if [[ $(type sw_vers) ]] && + [[ "$(openssl version)" = "OpenSSL 0.9.8r 8 Feb 2011" ]] + then + # Install to a subdirectory since we don't want shims for bin/openssl. + OPENSSL_PREFIX_PATH="${PREFIX_PATH}/openssl" + + # Put openssl.conf, certs, etc in ~/.rbenv/versions/*/openssl/ssl + OPENSSLDIR="${OPENSSLDIR:-$OPENSSL_PREFIX_PATH/ssl}" + + # Tell Ruby to use this openssl for its extension. + RUBY_CONFIGURE_OPTS="--with-openssl-dir=$OPENSSL_PREFIX_PATH $RUBY_CONFIGURE_OPTS" + + # Normally, we'd use ./config to automatically guess our platform. But + # that doesn't work for 64-bit Darwin: it picks 32-bit by default and + # asks you to run ./Configure by hand if you want 64-bit. So, here we are: + OPENSSL_CONFIGURE="${OPENSSL_CONFIGURE:-perl ./Configure darwin64-x86_64-cc}" + + # Compile with zlib, no kerberos, and do a static build. + OPENSSL_CONFIGURE_OPTS="--openssldir=$OPENSSLDIR zlib no-krb5 no-shared" + + # Default MAKE_OPTS are -j 2 which can confuse the build. Thankfully, make + # gives precedence to the last -j option, so we can override that. + OPENSSL_MAKE_OPTS="-j 1" + + install_package "openssl-1.0.1c" "https://www.openssl.org/source/openssl-1.0.1c.tar.gz#ae412727c8c15b67880aef7bd2999b2e" standard install_cacerts_from_keychain + fi +} + +# Extract root certs from the system keychain if .pem format and rehash. +build_package_install_cacerts_from_keychain() { + security find-certificate -a -p /Library/Keychains/System.keychain > "$OPENSSLDIR/cacert.pem" + c_rehash "$OPENSSLDIR" >&4 2>&1 +} + +# Post-install check that the openssl extension was built. +build_package_verify_openssl() { + $PREFIX_PATH/bin/ruby -e 'begin + require "openssl" + rescue LoadError + abort "The Ruby openssl extension was not compiled. Missing the OpenSSL lib?" + end' >&4 2>&1 +} + version() { echo "ruby-build ${RUBY_BUILD_VERSION}" } diff --git a/share/ruby-build/2.0.0-dev b/share/ruby-build/2.0.0-dev index 99be2b95..8f08323f 100644 --- a/share/ruby-build/2.0.0-dev +++ b/share/ruby-build/2.0.0-dev @@ -1 +1 @@ -install_git "ruby-2.0.0-dev" "https://github.com/ruby/ruby.git" "trunk" autoconf standard +install_git "ruby-2.0.0-dev" "https://github.com/ruby/ruby.git" "trunk" replace_osx_openssl autoconf standard verify_openssl diff --git a/share/ruby-build/2.0.0-preview1 b/share/ruby-build/2.0.0-preview1 index 40b114cd..a61863c3 100644 --- a/share/ruby-build/2.0.0-preview1 +++ b/share/ruby-build/2.0.0-preview1 @@ -1,2 +1,2 @@ install_package "yaml-0.1.4" "http://pyyaml.org/download/libyaml/yaml-0.1.4.tar.gz#36c852831d02cf90508c29852361d01b" -install_package "ruby-2.0.0-preview1" "http://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-preview1.tar.gz#c7d73f3ddb6d25e7733626ddbad04158" +install_package "ruby-2.0.0-preview1" "http://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-preview1.tar.gz#c7d73f3ddb6d25e7733626ddbad04158" replace_osx_openssl standard verify_openssl diff --git a/share/ruby-build/2.0.0-preview2 b/share/ruby-build/2.0.0-preview2 index f2217a01..098c2d16 100644 --- a/share/ruby-build/2.0.0-preview2 +++ b/share/ruby-build/2.0.0-preview2 @@ -1 +1 @@ -install_package "ruby-2.0.0-preview2" "http://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-preview2.tar.gz#eaddcbf63dc775708de45c7a81ab54b9" +install_package "ruby-2.0.0-preview2" "http://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-preview2.tar.gz#eaddcbf63dc775708de45c7a81ab54b9" replace_osx_openssl standard verify_openssl diff --git a/share/ruby-build/2.0.0-rc1 b/share/ruby-build/2.0.0-rc1 index ca6dfa06..81f0b39d 100644 --- a/share/ruby-build/2.0.0-rc1 +++ b/share/ruby-build/2.0.0-rc1 @@ -1 +1 @@ -install_package "ruby-2.0.0-rc1" "http://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-rc1.tar.gz#7d587dde85e0edf7a2e4f6783e6c0e2e" +install_package "ruby-2.0.0-rc1" "http://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-rc1.tar.gz#7d587dde85e0edf7a2e4f6783e6c0e2e" replace_osx_openssl standard verify_openssl