class Hadoop < Formula homepage "https://hadoop.apache.org/" url "https://www.apache.org/dyn/closer.cgi?path=hadoop/common/hadoop-2.7.0/hadoop-2.7.0.tar.gz" mirror "https://archive.apache.org/dist/hadoop/common/hadoop-2.7.0/hadoop-2.7.0.tar.gz" sha1 "ed5a19a54f878dde96a8655290d624b15e280d96" depends_on :java def install rm_f Dir["bin/*.cmd", "sbin/*.cmd", "libexec/*.cmd", "etc/hadoop/*.cmd"] libexec.install %w[bin sbin libexec share etc] bin.write_exec_script Dir["#{libexec}/bin/*"] sbin.write_exec_script Dir["#{libexec}/sbin/*"] # But don't make rcc visible, it conflicts with Qt (bin/"rcc").unlink inreplace "#{libexec}/etc/hadoop/hadoop-env.sh", "export JAVA_HOME=${JAVA_HOME}", "export JAVA_HOME=\"$(/usr/libexec/java_home)\"" inreplace "#{libexec}/etc/hadoop/yarn-env.sh", "# export JAVA_HOME=/home/y/libexec/jdk1.6.0/", "export JAVA_HOME=\"$(/usr/libexec/java_home)\"" inreplace "#{libexec}/etc/hadoop/mapred-env.sh", "# export JAVA_HOME=/home/y/libexec/jdk1.6.0/", "export JAVA_HOME=\"$(/usr/libexec/java_home)\"" end def caveats; <<-EOS.undent In Hadoop's config file: #{libexec}/etc/hadoop/hadoop-env.sh, #{libexec}/etc/hadoop/mapred-env.sh and #{libexec}/etc/hadoop/yarn-env.sh $JAVA_HOME has been set to be the output of: /usr/libexec/java_home EOS end test do system bin/"hadoop", "fs", "-ls" end end