class Couchdb < Formula
desc "Document database server"
homepage "https://couchdb.apache.org/"
revision 13
stable do
url "https://www.apache.org/dyn/closer.cgi?path=/couchdb/source/1.6.1/apache-couchdb-1.6.1.tar.gz"
sha256 "5a601b173733ce3ed31b654805c793aa907131cd70b06d03825f169aa48c8627"
# Support Erlang/OTP 18.0+ compatibility, see upstream #95cb436
# It will be in the next CouchDB point release, likely 1.6.2.
# https://github.com/apache/couchdb/pull/431
patch :DATA
end
bottle do
sha256 "e8ee8e78cfdccbcb03fb672b0189354553e920fe49a82ed48e7308375a61c3b6" => :high_sierra
sha256 "e762e24878c9354a8316c83cd9c0453d44c2ba2402cb1f79da76bf54f1dffb9a" => :sierra
sha256 "7561fda33e55d676787f456a83edf1322b506715171188dc478ff508f5dde19c" => :el_capitan
sha256 "1b828b7df1f1eb8feccc278e8eb1cf138784fdb77cd805eaf29a322e144bbb07" => :yosemite
end
head do
url "https://github.com/apache/couchdb.git"
depends_on "autoconf" => :build
depends_on "automake" => :build
depends_on "libtool" => :build
depends_on "autoconf-archive" => :build
depends_on "pkg-config" => :build
depends_on "help2man" => :build
end
option "with-geocouch", "Build with GeoCouch spatial index extension"
depends_on "spidermonkey"
depends_on "icu4c"
# Incompatible with Erlang/OTP 20.0
# See upstream issue from 23 Jun 2017 https://github.com/apache/couchdb/issues/611
depends_on "erlang@19"
resource "geocouch" do
url "https://github.com/couchbase/geocouch/archive/couchdb1.3.x.tar.gz"
sha256 "1bad2275756e2f03151d7b2706c089b3059736130612de279d879db91d4b21e7"
end
def install
# CouchDB >=1.3.0 supports vendor names and versioning
# in the welcome message
inreplace "etc/couchdb/default.ini.tpl.in" do |s|
s.gsub! "%package_author_name%", "Homebrew"
s.gsub! "%version%", pkg_version
end
unless build.stable?
# workaround for the auto-generation of THANKS file which assumes
# a developer build environment incl access to git sha
touch "THANKS"
system "./bootstrap"
end
system "./configure", "--prefix=#{prefix}",
"--localstatedir=#{var}",
"--sysconfdir=#{etc}",
"--disable-init",
"--with-erlang=#{Formula["erlang@19"].opt_lib}/erlang/usr/include",
"--with-js-include=#{HOMEBREW_PREFIX}/include/js",
"--with-js-lib=#{HOMEBREW_PREFIX}/lib"
system "make"
system "make", "install"
install_geocouch if build.with? "geocouch"
# Use our plist instead to avoid faffing with a new system user.
(prefix/"Library/LaunchDaemons/org.apache.couchdb.plist").delete
(lib/"couchdb/bin/couchjs").chmod 0755
end
def geocouch_share
share/"couchdb-geocouch"
end
def install_geocouch
resource("geocouch").stage(buildpath/"geocouch")
ENV["COUCH_SRC"] = "#{buildpath}/src/couchdb"
cd "geocouch" do
system "make"
linked_geocouch_share = (HOMEBREW_PREFIX/"share/couchdb-geocouch")
geocouch_share.mkpath
geocouch_share.install "ebin"
# Install geocouch.plist for launchctl support.
geocouch_plist = geocouch_share/"geocouch.plist"
cp buildpath/"etc/launchd/org.apache.couchdb.plist.tpl.in", geocouch_plist
geocouch_plist.chmod 0644
inreplace geocouch_plist, "org.apache.couchdb", \
"geocouch"
inreplace geocouch_plist, "HOME", <<-EOS.lstrip.chop
ERL_FLAGS
-pa #{linked_geocouch_share}/ebin
HOME
EOS
inreplace geocouch_plist, "%bindir%/%couchdb_command_name%", \
HOMEBREW_PREFIX/"bin/couchdb"
# Turn off RunAtLoad and KeepAlive (to simplify experience for first-timers)
inreplace geocouch_plist, "RunAtLoad\n ",
"RunAtLoad\n "
inreplace geocouch_plist, "KeepAlive\n ",
"KeepAlive\n "
# Install geocouch.ini into couchdb.
(etc/"couchdb/default.d").install "etc/couchdb/default.d/geocouch.ini"
# Install tests into couchdb.
test_files = Dir["share/www/script/test/*.js"]
(pkgshare/"www/script/test").install test_files
# Complete the install by referencing the geocouch tests in couch_tests.js
# (which runs the tests).
test_lines = ["// GeoCouch Tests..."]
test_lines.concat(test_files.map { |file| file.gsub(%r{^.*\/(.*)$}, 'loadTest("\1");') })
test_lines << "// ...GeoCouch Tests"
(pkgshare/"www/script/couch_tests.js").append_lines test_lines
end
end
def post_install
(var/"lib/couchdb").mkpath
(var/"log/couchdb").mkpath
(var/"run/couchdb").mkpath
# default.ini is owned by CouchDB and marked not user-editable
# and must be overwritten to ensure correct operation.
if (etc/"couchdb/default.ini.default").exist?
# but take a backup just in case the user didn't read the warning.
mv etc/"couchdb/default.ini", etc/"couchdb/default.ini.old"
mv etc/"couchdb/default.ini.default", etc/"couchdb/default.ini"
end
end
def caveats
str = <<-EOS.undent
To test CouchDB run:
curl http://127.0.0.1:5984/
The reply should look like:
{"couchdb":"Welcome","uuid":"....","version":"#{version}","vendor":{"version":"#{version}-1","name":"Homebrew"}}
EOS
str += "\n#{geocouch_caveats}" if build.with? "geocouch"
str
end
def geocouch_caveats; <<-EOS.undent
GeoCouch Caveats:
FYI: geocouch installs as an extension of couchdb, so couchdb effectively
becomes geocouch. However, you can use couchdb normally (using geocouch
extensions optionally). NB: one exception: the couchdb test suite now
includes several geocouch tests.
To start geocouch manually and verify any geocouch version information (-V),
ERL_FLAGS="-pa #{geocouch_share}/ebin" couchdb -V
For general convenience, export your ERL_FLAGS (erlang flags, above) in
your login shell, and then start geocouch:
export ERL_FLAGS="-pa #{geocouch_share}/ebin"
couchdb
Alternately, prepare launchctl to start/stop geocouch as follows:
cp #{geocouch_share}/geocouch.plist ~/Library/LaunchAgents
chmod 0644 ~/Library/LaunchAgents/geocouch.plist
launchctl load ~/Library/LaunchAgents/geocouch.plist
Then start, check status of, and stop geocouch with the following three
commands.
launchctl start geocouch
launchctl list geocouch
launchctl stop geocouch
Finally, access, test, and configure your new geocouch with:
http://127.0.0.1:5984
http://127.0.0.1:5984/_utils/couch_tests.html?script/couch_tests.js
http://127.0.0.1:5984/_utils
And... relax.
-=-
To uninstall geocouch from your couchdb installation, uninstall couchdb
and re-install it without the '--with-geocouch' option.
brew uninstall couchdb
brew install couchdb
To see these instructions again, just run 'brew info couchdb'.
EOS
end
plist_options :manual => "couchdb"
def plist; <<-EOS.undent
KeepAlive
Label
#{plist_name}
ProgramArguments
#{opt_bin}/couchdb
RunAtLoad
EOS
end
test do
# ensure couchdb embedded spidermonkey vm works
system "#{bin}/couchjs", "-h"
(testpath/"var/lib/couchdb").mkpath
(testpath/"var/log/couchdb").mkpath
(testpath/"var/run/couchdb").mkpath
cp_r etc/"couchdb", testpath
inreplace "#{testpath}/couchdb/default.ini", "/usr/local/var", testpath/"var"
pid = fork do
ENV["ERL_LIBS"] = geocouch_share if build.with? "geocouch"
exec "#{bin}/couchdb -A #{testpath}/couchdb"
end
sleep 2
begin
assert_match "Homebrew", shell_output("curl -# localhost:5984")
ensure
Process.kill("SIGINT", pid)
Process.wait(pid)
end
end
end
__END__
commit 95cb436be30305efa091809813b64ef31af968c8
Author: Dave Cottlehuber
Date: Fri Jun 26 10:31:27 2015 +0200
build: support OTP-19.0
diff --git a/INSTALL.Unix b/INSTALL.Unix
index f66f98c..4c63bc8 100644
--- a/INSTALL.Unix
+++ b/INSTALL.Unix
@@ -39,7 +39,7 @@ Dependencies
You should have the following installed:
- * Erlang OTP (>=R14B01, ==R14B01, ==14B01, =14B01, =4.*) (http://icu-project.org/)
* OpenSSL (>=0.9.8r) (http://www.openssl.org/)
* Mozilla SpiderMonkey (=1.8.5) (http://www.mozilla.org/js/spidermonkey/)
diff --git a/configure.ac b/configure.ac
index 103f029..bf9ffc4 100644
--- a/configure.ac
+++ b/configure.ac
@@ -411,7 +411,7 @@ esac
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking Erlang version compatibility" >&5
$as_echo_n "checking Erlang version compatibility... " >&6; }
-erlang_version_error="The installed Erlang version must be >= R14B (erts-5.8.1) and =< 17 (erts-6.0)"
+erlang_version_error="The installed Erlang version must be >= R14B (erts-5.8.1) and =< 19 (erts-8.0.1)"
version="`${ERL} -version 2>&1 | ${SED} 's/[[^0-9]]/ /g'` 0 0 0"
major_version=`echo $version | ${AWK} "{print \\$1}"`
@@ -419,7 +419,7 @@ minor_version=`echo $version | ${AWK} "{print \\$2}"`
patch_version=`echo $version | ${AWK} "{print \\$3}"`
echo -n "detected Erlang version: $major_version.$minor_version.$patch_version..."
-if test $major_version -lt 5 -o $major_version -gt 6; then
+if test $major_version -lt 5 -o $major_version -gt 8; then
as_fn_error $? "$erlang_version_error major_version does not match" "$LINENO" 5
fi
@@ -438,9 +438,9 @@ otp_release="`\
AC_SUBST(otp_release)
AM_CONDITIONAL([USE_OTP_NIFS],
- [can_use_nifs=$(echo $otp_release | grep -E "^(R14B|R15|R16|17)")])
+ [can_use_nifs=$(echo $otp_release | grep -E "^(R14B|R15|R16|17|18|19)")])
AM_CONDITIONAL([USE_EJSON_COMPARE_NIF],
- [can_use_ejson=$(echo $otp_release | grep -E "^(R14B03|R15|R16|17)")])
+ [can_use_ejson=$(echo $otp_release | grep -E "^(R14B03|R15|R16|17|18|19)")])
has_crypto=`\
${ERL} -eval "\
diff --git a/share/doc/src/install/unix.rst b/share/doc/src/install/unix.rst
index 76fe922..904c128 100644
--- a/share/doc/src/install/unix.rst
+++ b/share/doc/src/install/unix.rst
@@ -52,7 +52,7 @@ Dependencies
You should have the following installed:
-* `Erlang OTP (>=R14B01, =`_
+* `Erlang OTP (>=R14B01, =`_
* `ICU `_
* `OpenSSL `_
* `Mozilla SpiderMonkey (1.8.5) `_
diff --git a/share/doc/src/install/windows.rst b/share/doc/src/install/windows.rst
index b7b66af..494ef65 100644
--- a/share/doc/src/install/windows.rst
+++ b/share/doc/src/install/windows.rst
@@ -90,7 +90,7 @@ Dependencies
You should have the following installed:
-* `Erlang OTP (>=14B01, `_
+* `Erlang OTP (>=14B01, `_
* `ICU (>=4.*) `_
* `OpenSSL (>0.9.8r) `_
* `Mozilla SpiderMonkey (=1.8.5) `_
--- a/configure 2015-06-27 12:56:30.000000000 +0200
+++ b/configure 2015-06-27 12:58:38.000000000 +0200
@@ -18532,7 +18532,7 @@
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking Erlang version compatibility" >&5
$as_echo_n "checking Erlang version compatibility... " >&6; }
-erlang_version_error="The installed Erlang version must be >= R14B (erts-5.8.1) and =< 17 (erts-6.0)"
+erlang_version_error="The installed Erlang version must be >= R14B (erts-5.8.1) and =< 19 (erts-8.0.1)"
version="`${ERL} -version 2>&1 | ${SED} 's/[^0-9]/ /g'` 0 0 0"
major_version=`echo $version | ${AWK} "{print \\$1}"`
@@ -18540,7 +18540,7 @@
patch_version=`echo $version | ${AWK} "{print \\$3}"`
echo -n "detected Erlang version: $major_version.$minor_version.$patch_version..."
-if test $major_version -lt 5 -o $major_version -gt 6; then
+if test $major_version -lt 5 -o $major_version -gt 8; then
as_fn_error $? "$erlang_version_error major_version does not match" "$LINENO" 5
fi
@@ -18559,7 +18559,7 @@
- if can_use_nifs=$(echo $otp_release | grep -E "^(R14B|R15|R16|17)"); then
+ if can_use_nifs=$(echo $otp_release | grep -E "^(R14B|R15|R16|17|18|19)"); then
USE_OTP_NIFS_TRUE=
USE_OTP_NIFS_FALSE='#'
else
@@ -18567,7 +18567,7 @@
USE_OTP_NIFS_FALSE=
fi
- if can_use_ejson=$(echo $otp_release | grep -E "^(R14B03|R15|R16|17)"); then
+ if can_use_ejson=$(echo $otp_release | grep -E "^(R14B03|R15|R16|17|18|19)"); then
USE_EJSON_COMPARE_NIF_TRUE=
USE_EJSON_COMPARE_NIF_FALSE='#'
else