class Root < Formula desc "Object oriented framework for large scale data analysis" homepage "https://root.cern.ch" url "https://root.cern.ch/download/root_v6.14.00.source.tar.gz" version "6.14.00" sha256 "7946430373489310c2791ff7a3520e393dc059db1371272bcd9d9cf0df347a0b" head "http://root.cern.ch/git/root.git" bottle do sha256 "f61a6854f0b2fdefd692390d10721cd35aad69c696628e0a378468986de9a4c3" => :high_sierra sha256 "ca54c9feda676eb4a51fa636e89e488341a25a53bcf446680e86baadf524fe57" => :sierra sha256 "a4214d56d0f8854106eb887ff44093444e39d1ce1b9d9466f226bf62ff27088b" => :el_capitan end depends_on "cmake" => :build depends_on "davix" depends_on "fftw" depends_on "gcc" # for gfortran. depends_on "graphviz" depends_on "gsl" depends_on "lz4" depends_on "openssl" depends_on "pcre" depends_on "tbb" depends_on "xrootd" depends_on "xz" # For LZMA. depends_on "python" => :recommended depends_on "python@2" => :optional needs :cxx11 skip_clean "bin" def install # Work around "error: no member named 'signbit' in the global namespace" ENV.delete("SDKROOT") if DevelopmentTools.clang_build_version >= 900 # Freetype/afterimage/gl2ps/lz4 are vendored in the tarball, so are fine. # However, this is still permitting the build process to make remote # connections. As a hack, since upstream support it, we inreplace # this file to "encourage" the connection over HTTPS rather than HTTP. inreplace "cmake/modules/SearchInstalledSoftware.cmake", "http://lcgpackages", "https://lcgpackages" args = std_cmake_args + %W[ -Dgnuinstall=ON -DCMAKE_INSTALL_ELISPDIR=#{elisp} -Dbuiltin_freetype=ON -Ddavix=ON -Dfftw3=ON -Dfortran=ON -Dgdml=ON -Dmathmore=ON -Dminuit2=ON -Dmysql=OFF -Droofit=ON -Dssl=ON -Dimt=ON -Dxrootd=ON ] if build.with?("python") && build.with?("python@2") odie "Root: Does not support building both python 2 and 3 wrappers" elsif build.with?("python") || build.with?("python@2") if build.with? "python@2" ENV.prepend_path "PATH", Formula["python@2"].opt_libexec/"bin" python_executable = Utils.popen_read("which python").strip python_version = Language::Python.major_minor_version("python") elsif build.with? "python" python_executable = Utils.popen_read("which python3").strip python_version = Language::Python.major_minor_version("python3") end python_prefix = Utils.popen_read("#{python_executable} -c 'import sys;print(sys.prefix)'").chomp python_include = Utils.popen_read("#{python_executable} -c 'from distutils import sysconfig;print(sysconfig.get_python_inc(True))'").chomp args << "-Dpython=ON" # cmake picks up the system's python dylib, even if we have a brewed one if File.exist? "#{python_prefix}/Python" python_library = "#{python_prefix}/Python" elsif File.exist? "#{python_prefix}/lib/lib#{python_version}.a" python_library = "#{python_prefix}/lib/lib#{python_version}.a" elsif File.exist? "#{python_prefix}/lib/lib#{python_version}.dylib" python_library = "#{python_prefix}/lib/lib#{python_version}.dylib" else odie "No libpythonX.Y.{a,dylib} file found!" end args << "-DPYTHON_EXECUTABLE='#{python_executable}'" args << "-DPYTHON_INCLUDE_DIR='#{python_include}'" args << "-DPYTHON_LIBRARY='#{python_library}'" else args << "-Dpython=OFF" end mkdir "builddir" do system "cmake", "..", *args # Work around superenv stripping out isysroot leading to errors with # libsystem_symptoms.dylib (only available on >= 10.12) and # libsystem_darwin.dylib (only available on >= 10.13) if MacOS.version < :high_sierra system "xcrun", "make", "install" else system "make", "install" end chmod 0755, Dir[bin/"*.*sh"] end end def caveats; <<~EOS Because ROOT depends on several installation-dependent environment variables to function properly, you should add the following commands to your shell initialization script (.bashrc/.profile/etc.), or call them directly before using ROOT. For bash users: . #{HOMEBREW_PREFIX}/bin/thisroot.sh For zsh users: pushd #{HOMEBREW_PREFIX} >/dev/null; . bin/thisroot.sh; popd >/dev/null For csh/tcsh users: source #{HOMEBREW_PREFIX}/bin/thisroot.csh EOS end test do (testpath/"test.C").write <<~EOS #include void test() { std::cout << "Hello, world!" << std::endl; } EOS (testpath/"test.bash").write <<~EOS . #{bin}/thisroot.sh root -l -b -n -q test.C EOS assert_equal "\nProcessing test.C...\nHello, world!\n", shell_output("/bin/bash test.bash") if build.with? "python" ENV["PYTHONPATH"] = lib/"root" system "python3", "-c", "import ROOT" end end end