2011-03-10 05:11:03 +00:00
|
|
|
class Curl < Formula
|
2015-05-19 00:00:59 +00:00
|
|
|
desc "Get a file from an HTTP, HTTPS or FTP server"
|
2014-11-27 13:49:49 +00:00
|
|
|
homepage "http://curl.haxx.se/"
|
2015-08-12 08:20:47 +00:00
|
|
|
url "https://github.com/bagder/curl/releases/download/curl-7_44_0/curl-7.44.0.tar.bz2"
|
|
|
|
mirror "http://curl.haxx.se/download/curl-7.44.0.tar.bz2"
|
|
|
|
sha256 "1e2541bae6582bb697c0fbae49e1d3e6fad5d05d5aa80dbd6f072e0a44341814"
|
2009-12-17 19:55:27 +00:00
|
|
|
|
2014-03-29 14:48:24 +00:00
|
|
|
bottle do
|
2014-11-06 19:26:54 +00:00
|
|
|
cellar :any
|
2015-09-12 23:18:40 +00:00
|
|
|
sha256 "7da0892cfe70151dbc4a8d94adc9e28a81e315fa601643682c2b3396fb070ea6" => :el_capitan
|
2015-08-12 09:24:02 +00:00
|
|
|
sha256 "24083f2d66cbb4248b7464dc79da9f600ff84eee2b7b0107a04556ad05609eb0" => :yosemite
|
|
|
|
sha256 "39b9b2b3a5b66e7d3e9ec3326d109776753f19f271e55259bf36e97cae269372" => :mavericks
|
|
|
|
sha256 "a4204db8c6013ce91f3dd4d3595f7e1fd5aa399801efb1044090408221946e31" => :mountain_lion
|
2014-03-29 14:48:24 +00:00
|
|
|
end
|
|
|
|
|
2013-12-11 19:27:13 +00:00
|
|
|
keg_only :provided_by_osx
|
2010-11-09 21:20:56 +00:00
|
|
|
|
2014-11-27 13:49:49 +00:00
|
|
|
option "with-libidn", "Build with support for Internationalized Domain Names"
|
|
|
|
option "with-rtmpdump", "Build with RTMP support"
|
|
|
|
option "with-libssh2", "Build with scp and sftp support"
|
|
|
|
option "with-c-ares", "Build with C-Ares async DNS support"
|
|
|
|
option "with-gssapi", "Build with GSSAPI/Kerberos authentication support."
|
|
|
|
option "with-libmetalink", "Build with libmetalink support."
|
|
|
|
option "with-libressl", "Build with LibreSSL instead of Secure Transport or OpenSSL"
|
2015-03-23 23:42:09 +00:00
|
|
|
option "with-nghttp2", "Build with HTTP/2 support (requires OpenSSL or LibreSSL)"
|
2012-08-28 00:31:15 +00:00
|
|
|
|
2014-11-14 20:35:07 +00:00
|
|
|
deprecated_option "with-idn" => "with-libidn"
|
|
|
|
deprecated_option "with-rtmp" => "with-rtmpdump"
|
|
|
|
deprecated_option "with-ssh" => "with-libssh2"
|
|
|
|
deprecated_option "with-ares" => "with-c-ares"
|
|
|
|
|
2015-03-23 23:42:09 +00:00
|
|
|
# HTTP/2 support requires OpenSSL 1.0.2+ or LibreSSL 2.1.3+ for ALPN Support
|
|
|
|
# which is currently not supported by Secure Transport (DarwinSSL).
|
|
|
|
if MacOS.version < :mountain_lion || (build.with?("nghttp2") && build.without?("libressl"))
|
|
|
|
depends_on "openssl"
|
|
|
|
else
|
2014-11-27 13:49:49 +00:00
|
|
|
option "with-openssl", "Build with OpenSSL instead of Secure Transport"
|
|
|
|
depends_on "openssl" => :optional
|
2014-01-14 03:06:13 +00:00
|
|
|
end
|
|
|
|
|
2014-11-27 13:49:49 +00:00
|
|
|
depends_on "pkg-config" => :build
|
|
|
|
depends_on "libidn" => :optional
|
|
|
|
depends_on "rtmpdump" => :optional
|
2014-12-03 17:19:11 +00:00
|
|
|
depends_on "libssh2" => :optional
|
|
|
|
depends_on "c-ares" => :optional
|
|
|
|
depends_on "libmetalink" => :optional
|
2014-11-27 13:49:49 +00:00
|
|
|
depends_on "libressl" => :optional
|
2015-03-23 23:42:09 +00:00
|
|
|
depends_on "nghttp2" => :optional
|
2012-04-04 06:28:44 +00:00
|
|
|
|
2009-12-17 19:55:27 +00:00
|
|
|
def install
|
2014-11-27 13:49:49 +00:00
|
|
|
# Throw an error if someone actually tries to rock both SSL choices.
|
|
|
|
# Long-term, make this singular-ssl-option-only a requirement.
|
2015-01-09 03:05:53 +00:00
|
|
|
if build.with?("libressl") && build.with?("openssl")
|
2014-11-27 13:49:49 +00:00
|
|
|
ohai <<-EOS.undent
|
|
|
|
--with-openssl and --with-libressl are both specified and
|
2015-03-23 23:42:09 +00:00
|
|
|
curl can only use one at a time; proceeding with libressl.
|
2014-11-27 13:49:49 +00:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
|
2012-04-04 06:28:44 +00:00
|
|
|
args = %W[
|
2012-08-28 00:31:15 +00:00
|
|
|
--disable-debug
|
|
|
|
--disable-dependency-tracking
|
2015-01-09 02:33:48 +00:00
|
|
|
--disable-silent-rules
|
2012-08-28 00:31:15 +00:00
|
|
|
--prefix=#{prefix}
|
|
|
|
]
|
2012-04-04 06:28:44 +00:00
|
|
|
|
2015-01-09 02:33:48 +00:00
|
|
|
# cURL has a new firm desire to find ssl with PKG_CONFIG_PATH instead of using
|
|
|
|
# "--with-ssl" any more. "when possible, set the PKG_CONFIG_PATH environment
|
|
|
|
# variable instead of using this option". Multi-SSL choice breaks w/o using it.
|
2015-03-23 23:42:09 +00:00
|
|
|
if build.with? "libressl"
|
2015-01-09 02:33:48 +00:00
|
|
|
ENV.prepend_path "PKG_CONFIG_PATH", "#{Formula["libressl"].opt_prefix}/lib/pkgconfig"
|
2014-11-27 13:49:49 +00:00
|
|
|
args << "--with-ssl=#{Formula["libressl"].opt_prefix}"
|
|
|
|
args << "--with-ca-bundle=#{etc}/libressl/cert.pem"
|
2015-03-23 23:42:09 +00:00
|
|
|
elsif MacOS.version < :mountain_lion || build.with?("openssl") || build.with?("nghttp2")
|
|
|
|
ENV.prepend_path "PKG_CONFIG_PATH", "#{Formula["openssl"].opt_prefix}/lib/pkgconfig"
|
|
|
|
args << "--with-ssl=#{Formula["openssl"].opt_prefix}"
|
|
|
|
args << "--with-ca-bundle=#{etc}/openssl/cert.pem"
|
2014-01-14 03:06:13 +00:00
|
|
|
else
|
|
|
|
args << "--with-darwinssl"
|
|
|
|
end
|
|
|
|
|
2014-11-14 20:35:07 +00:00
|
|
|
args << (build.with?("libssh2") ? "--with-libssh2" : "--without-libssh2")
|
|
|
|
args << (build.with?("libidn") ? "--with-libidn" : "--without-libidn")
|
2014-03-27 15:46:06 +00:00
|
|
|
args << (build.with?("libmetalink") ? "--with-libmetalink" : "--without-libmetalink")
|
|
|
|
args << (build.with?("gssapi") ? "--with-gssapi" : "--without-gssapi")
|
2014-11-14 20:35:07 +00:00
|
|
|
args << (build.with?("rtmpdump") ? "--with-librtmp" : "--without-librtmp")
|
2014-03-27 15:46:06 +00:00
|
|
|
|
2014-11-14 20:35:07 +00:00
|
|
|
if build.with? "c-ares"
|
2014-03-27 15:46:06 +00:00
|
|
|
args << "--enable-ares=#{Formula["c-ares"].opt_prefix}"
|
|
|
|
else
|
|
|
|
args << "--disable-ares"
|
|
|
|
end
|
2012-04-04 06:28:44 +00:00
|
|
|
|
|
|
|
system "./configure", *args
|
2014-11-27 13:49:49 +00:00
|
|
|
system "make", "install"
|
2009-12-17 19:55:27 +00:00
|
|
|
end
|
2014-04-01 21:38:06 +00:00
|
|
|
|
|
|
|
test do
|
|
|
|
# Fetch the curl tarball and see that the checksum matches.
|
|
|
|
# This requires a network connection, but so does Homebrew in general.
|
|
|
|
filename = (testpath/"test.tar.gz")
|
2015-06-30 22:25:43 +00:00
|
|
|
system "#{bin}/curl", "-L", stable.url, "-o", filename
|
2014-04-01 21:38:06 +00:00
|
|
|
filename.verify_checksum stable.checksum
|
|
|
|
end
|
2009-12-17 19:55:27 +00:00
|
|
|
end
|