homebrew-core/Formula/disco.rb

83 lines
2.6 KiB
Ruby
Raw Normal View History

2014-07-21 02:24:23 +00:00
require "formula"
2011-03-10 05:11:03 +00:00
class Disco < Formula
desc "Distributed computing framework based on the MapReduce paradigm"
2014-07-21 02:24:23 +00:00
homepage "http://discoproject.org/"
2014-10-31 23:50:48 +00:00
url "https://github.com/discoproject/disco/archive/0.5.4.tar.gz"
sha1 "43bc8fac5d5d657a81a8d7b628d1f72f97470b6e"
2014-08-21 08:13:25 +00:00
bottle do
cellar :any
2014-11-01 01:50:18 +00:00
sha1 "f1a4e9775053971dac6ab3b183ebb13d6928c050" => :yosemite
sha1 "286325ec178e1bd06a78127333c835a1bf5a2763" => :mavericks
sha1 "da6e23c51a8ca6c353e83724746f0e11dba37a99" => :mountain_lion
2014-08-21 08:13:25 +00:00
end
depends_on :python if MacOS.version <= :snow_leopard
2014-07-21 02:24:23 +00:00
depends_on "erlang"
depends_on "simplejson" => :python if MacOS.version <= :leopard
depends_on "libcmph"
2014-03-18 17:13:31 +00:00
# Modifies config for single-node operation
patch :DATA
def install
ENV["PYTHONPATH"] = lib+"python2.7/site-packages"
2011-04-04 23:15:16 +00:00
inreplace "Makefile" do |s|
s.change_make_var! "prefix", prefix
s.change_make_var! "sysconfdir", etc
s.change_make_var! "localstatedir", var
2011-04-04 23:15:16 +00:00
end
2014-01-04 13:04:23 +00:00
# Disco's "rebar" build tool refuses to build unless it's in a git repo, so
# make a dummy one
system "git init && git add master/rebar && git commit -a -m 'dummy commit'"
2014-01-04 13:04:23 +00:00
system "make"
system "make install"
prefix.install %w[contrib doc examples]
2014-01-04 13:04:23 +00:00
# Fix the config file to point at the linked files, not in to cellar
# This isn't ideal - if there's a settings.py file left over from a previous disco
# installation, it'll issue a Warning
inreplace "#{etc}/disco/settings.py" do |s|
s.gsub!("Cellar/disco/"+version+"/", "")
end
2014-07-21 02:24:23 +00:00
bin.env_script_all_files(libexec+"bin", :PYTHONPATH => ENV["PYTHONPATH"])
end
2014-04-30 22:37:30 +00:00
test do
system "#{bin}/disco"
end
def caveats
2014-01-04 13:04:23 +00:00
<<-EOS.undent
Please copy #{etc}/disco/settings.py to ~/.disco and edit it if necessary.
The DDFS_*_REPLICA settings have been set to 1 assuming a single-machine install.
Please see http://discoproject.org/doc/disco/start/install.html for further instructions.
EOS
end
end
__END__
diff -rupN disco-0.4.5/conf/gen.settings.sh my-edits/disco-0.4.5/conf/gen.settings.sh
--- disco-0.4.5/conf/gen.settings.sh 2013-03-28 12:21:30.000000000 -0400
+++ my-edits/disco-0.4.5/conf/gen.settings.sh 2013-04-10 23:10:00.000000000 -0400
@@ -23,8 +23,11 @@ DISCO_PORT = 8989
# DISCO_PROXY_ENABLED = "on"
# DISCO_HTTPD = "/usr/sbin/varnishd -a 0.0.0.0:\$DISCO_PROXY_PORT -f \$DISCO_PROXY_CONFIG -P \$DISCO_PROXY_PID -n/tmp -smalloc"
-DDFS_TAG_MIN_REPLICAS = 3
-DDFS_TAG_REPLICAS = 3
-DDFS_BLOB_REPLICAS = 3
+# Settings appropriate for single-node operation
+DDFS_TAG_MIN_REPLICAS = 1
+DDFS_TAG_REPLICAS = 1
+DDFS_BLOB_REPLICAS = 1
+
+DISCO_MASTER_HOST = "localhost"
EOF