require "language/haskell" class GhcAT80 < Formula include Language::Haskell::Cabal desc "Glorious Glasgow Haskell Compilation System" homepage "https://haskell.org/ghc/" url "https://downloads.haskell.org/~ghc/8.0.2/ghc-8.0.2-src.tar.xz" sha256 "11625453e1d0686b3fa6739988f70ecac836cadc30b9f0c8b49ef9091d6118b1" bottle do sha256 "f2a42cd1cef4c212cae841513039bd280457ea8f58b696707c16dbc90c829a88" => :high_sierra sha256 "9184f9147b526c425fd14498dca9fa1550c563857291c3c5ad616c6e5e521e47" => :sierra sha256 "be71492dc8783027300be80d8554bf0a239ba53991002094dc11c5d982f7294f" => :el_capitan sha256 "715e6fd851a5044e1ccaa812b12db136cfa96c9b6e118893f93d92c625040e95" => :yosemite end keg_only :versioned_formula option "with-test", "Verify the build using the testsuite" option "without-docs", "Do not build documentation (including man page)" deprecated_option "tests" => "with-test" deprecated_option "with-tests" => "with-test" depends_on :macos => :lion depends_on "sphinx-doc" => :build if build.with? "docs" resource "gmp" do url "https://ftp.gnu.org/gnu/gmp/gmp-6.1.2.tar.xz" mirror "https://gmplib.org/download/gmp/gmp-6.1.2.tar.xz" mirror "https://ftpmirror.gnu.org/gmp/gmp-6.1.2.tar.xz" sha256 "87b565e89a9a684fe4ebeeddb8399dce2599f9c9049854ca8c0dfbdea0e21912" end if MacOS.version <= :lion fails_with :clang do cause <<-EOS.undent Fails to bootstrap ghc-cabal. Error is: libraries/Cabal/Cabal/Distribution/Compat/Binary/Class.hs:398:14: The last statement in a 'do' block must be an expression n <- get :: Get Int getMany n EOS end end # https://www.haskell.org/ghc/download_ghc_8_0_1#macosx_x86_64 # "This is a distribution for Mac OS X, 10.7 or later." resource "binary" do url "https://downloads.haskell.org/~ghc/8.0.2/ghc-8.0.2-x86_64-apple-darwin.tar.xz" sha256 "ff50a2df9f002f33b9f09717ebf5ec5a47906b9b65cc57b1f9849f8b2e06788d" end resource "testsuite" do url "https://downloads.haskell.org/~ghc/8.0.2/ghc-8.0.2-testsuite.tar.xz" sha256 "52235d299eb56292f2c273dc490792788b8ba11f4dc600035d050c8a4c1f4cf2" end def install # Setting -march=native, which is what --build-from-source does, fails # on Skylake (and possibly other architectures as well) with the error # "Segmentation fault: 11" for at least the following files: # utils/haddock/dist/build/Haddock/Backends/Hyperlinker/Types.dyn_o # utils/haddock/dist/build/Documentation/Haddock/Types.dyn_o # utils/haddock/dist/build/Haddock/GhcUtils.dyn_o # utils/haddock/dist/build/Paths_haddock.dyn_o # utils/haddock/dist/build/ResponseFile.dyn_o # Setting -march=core2 works around the bug. # Reported 22 May 2016: https://ghc.haskell.org/trac/ghc/ticket/12100 # Note that `unless build.bottle?` avoids overriding --bottle-arch=[...]. ENV["HOMEBREW_OPTFLAGS"] = "-march=#{Hardware.oldest_cpu}" unless build.bottle? # Build a static gmp rather than in-tree gmp, otherwise it links to brew's. gmp = libexec/"integer-gmp" # MPN_PATH: The lowest common denominator asm paths that work on Darwin, # corresponding to Yonah and Merom. Obviates --disable-assembly. ENV["MPN_PATH"] = "x86_64/fastsse x86_64/core2 x86_64 generic" if build.bottle? # GMP *does not* use PIC by default without shared libs so --with-pic # is mandatory or else you'll get "illegal text relocs" errors. resource("gmp").stage do system "./configure", "--prefix=#{gmp}", "--with-pic", "--disable-shared" system "make" system "make", "check" ENV.deparallelize { system "make", "install" } end args = ["--with-gmp-includes=#{gmp}/include", "--with-gmp-libraries=#{gmp}/lib", "--with-ld=ld", # Avoid hardcoding superenv's ld. "--with-gcc=#{ENV.cc}"] # Always. args << "--with-clang=#{ENV.cc}" if ENV.compiler == :clang # As of Xcode 7.3 (and the corresponding CLT) `nm` is a symlink to `llvm-nm` # and the old `nm` is renamed `nm-classic`. Building with the new `nm`, a # segfault occurs with the following error: # make[1]: * [compiler/stage2/dll-split.stamp] Segmentation fault: 11 # Upstream is aware of the issue and is recommending the use of nm-classic # until Apple restores POSIX compliance: # https://ghc.haskell.org/trac/ghc/ticket/11744 # https://ghc.haskell.org/trac/ghc/ticket/11823 # https://mail.haskell.org/pipermail/ghc-devs/2016-April/011862.html # LLVM itself has already fixed the bug: llvm-mirror/llvm@ae7cf585 # rdar://25311883 and rdar://25299678 if DevelopmentTools.clang_build_version >= 703 && DevelopmentTools.clang_build_version < 800 args << "--with-nm=#{`xcrun --find nm-classic`.chomp}" end resource("binary").stage do binary = buildpath/"binary" system "./configure", "--prefix=#{binary}", *args ENV.deparallelize { system "make", "install" } ENV.prepend_path "PATH", binary/"bin" end system "./configure", "--prefix=#{prefix}", *args system "make" if build.bottle? || build.with?("test") resource("testsuite").stage { buildpath.install Dir["*"] } cd "testsuite" do system "make", "clean" system "make", "CLEANUP=1", "THREADS=#{ENV.make_jobs}", "fast" end end ENV.deparallelize { system "make", "install" } Dir.glob(lib/"*/package.conf.d/package.cache") { |f| rm f } end def post_install system "#{bin}/ghc-pkg", "recache" end test do (testpath/"hello.hs").write('main = putStrLn "Hello Homebrew"') system "#{bin}/runghc", testpath/"hello.hs" end end