82 lines
2.6 KiB
Ruby
82 lines
2.6 KiB
Ruby
require "formula"
|
|
|
|
class Disco < Formula
|
|
desc "Distributed computing framework based on the MapReduce paradigm"
|
|
homepage "http://discoproject.org/"
|
|
url "https://github.com/discoproject/disco/archive/0.5.4.tar.gz"
|
|
sha1 "43bc8fac5d5d657a81a8d7b628d1f72f97470b6e"
|
|
|
|
bottle do
|
|
cellar :any
|
|
sha1 "f1a4e9775053971dac6ab3b183ebb13d6928c050" => :yosemite
|
|
sha1 "286325ec178e1bd06a78127333c835a1bf5a2763" => :mavericks
|
|
sha1 "da6e23c51a8ca6c353e83724746f0e11dba37a99" => :mountain_lion
|
|
end
|
|
|
|
depends_on :python if MacOS.version <= :snow_leopard
|
|
depends_on "erlang"
|
|
depends_on "simplejson" => :python if MacOS.version <= :leopard
|
|
depends_on "libcmph"
|
|
|
|
# Modifies config for single-node operation
|
|
patch :DATA
|
|
|
|
def install
|
|
ENV["PYTHONPATH"] = lib+"python2.7/site-packages"
|
|
|
|
inreplace "Makefile" do |s|
|
|
s.change_make_var! "prefix", prefix
|
|
s.change_make_var! "sysconfdir", etc
|
|
s.change_make_var! "localstatedir", var
|
|
end
|
|
|
|
# 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'"
|
|
|
|
system "make"
|
|
system "make install"
|
|
prefix.install %w[contrib doc examples]
|
|
|
|
# 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
|
|
|
|
bin.env_script_all_files(libexec+"bin", :PYTHONPATH => ENV["PYTHONPATH"])
|
|
end
|
|
|
|
test do
|
|
system "#{bin}/disco"
|
|
end
|
|
|
|
def caveats
|
|
<<-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
|