homebrew-core/Formula/sphinx.rb
2012-04-14 10:01:57 -07:00

96 lines
2.6 KiB
Ruby

require 'formula'
class Libstemmer < Formula
# upstream is constantly changing the tarball,
# so doing checksum verification here would require
# constant, rapid updates to this formula.
head 'http://snowball.tartarus.org/dist/libstemmer_c.tgz'
homepage 'http://snowball.tartarus.org/'
end
class Sphinx < Formula
homepage 'http://www.sphinxsearch.com'
url 'http://sphinxsearch.com/files/sphinx-2.0.4-release.tar.gz'
md5 '7da4df3df3decb24d8c6fb8f47de1d3d'
head 'http://sphinxsearch.googlecode.com/svn/trunk/'
fails_with :llvm do
build 2334
cause "ld: rel32 out of range in _GetPrivateProfileString from /usr/lib/libodbc.a(SQLGetPrivateProfileString.o)"
end
fails_with :clang do
build 318
cause <<-EOS.undent
configure: error: Gcc version error. Minspec is 3.4
http://sphinxsearch.com/bugs/view.php?id=1123
sphinxexpr.cpp:1799:11: error: use of undeclared identifier 'ExprEval'
https://github.com/mxcl/homebrew/issues/10016
https://github.com/mxcl/homebrew/pull/10698
EOS
end
def options
[
['--mysql', 'Force compiling against MySQL.'],
['--pgsql', 'Force compiling against PostgreSQL.'],
]
end
def install
lstem = Pathname.pwd+'libstemmer_c'
Libstemmer.new.brew { lstem.install Dir['*'] }
args = ["--prefix=#{prefix}",
"--disable-debug",
"--disable-dependency-tracking",
"--localstatedir=#{var}"]
# always build with libstemmer support
args << "--with-libstemmer"
# configure script won't auto-select PostgreSQL
args << "--with-pgsql" if ARGV.include?('--pgsql') or which 'pg_config'
args << "--without-mysql" unless ARGV.include?('--mysql') or which 'mysql_config'
system "./configure", *args
system "make install"
end
def caveats; <<-EOS.undent
Sphinx has been compiled with libstemmer support.
Sphinx depends on either MySQL or PostreSQL as a datasource.
You can install these with Homebrew with:
brew install mysql
For MySQL server.
brew install mysql-connector-c
For MySQL client libraries only.
brew install postgresql
For PostgreSQL server.
We don't install these for you when you install this formula, as
we don't know which datasource you intend to use.
EOS
end
end
__END__
diff --git a/configure b/configure
index aebac75..82d6d05 100755
--- a/configure
+++ b/configure
@@ -4361,7 +4361,7 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext
#ifdef __GNUC__
#if __GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ > 3)
-void main() {}
+int main() {}
#else
syntax error
#endif