1f3e2b6e48
It's listed as an official, read-only repo mirror: https://gcc.gnu.org/wiki/GitMirror
185 lines
5.8 KiB
Ruby
185 lines
5.8 KiB
Ruby
class Gcc < Formula
|
|
desc "GNU compiler collection"
|
|
homepage "https://gcc.gnu.org/"
|
|
head "https://gcc.gnu.org/git/gcc.git"
|
|
|
|
stable do
|
|
url "https://ftp.gnu.org/gnu/gcc/gcc-8.2.0/gcc-8.2.0.tar.xz"
|
|
mirror "https://ftpmirror.gnu.org/gcc/gcc-8.2.0/gcc-8.2.0.tar.xz"
|
|
sha256 "196c3c04ba2613f893283977e6011b2345d1cd1af9abeac58e916b1aab3e0080"
|
|
|
|
# isl 0.20 compatibility
|
|
# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=86724
|
|
patch :DATA
|
|
end
|
|
|
|
bottle do
|
|
rebuild 1
|
|
sha256 "362ece7c7a43571fce42243890d7fd4df21c453e5997bf72165d7855aa48f254" => :mojave
|
|
sha256 "f65f583746746494db1b02bb8a8d53ef54089ff8564d88d886527148794e9eef" => :high_sierra
|
|
sha256 "0fa57f7f5dbbc6360c5894b987a37d829b4984dfe51a91ba26f48d6c97d1f370" => :sierra
|
|
sha256 "5a51d9f6ab8d14a0b2a37783225cc356f3d68a074f1b814124f00c739475c655" => :el_capitan
|
|
end
|
|
|
|
option "with-jit", "Build just-in-time compiler"
|
|
option "with-nls", "Build with native language support (localization)"
|
|
|
|
depends_on "gmp"
|
|
depends_on "isl"
|
|
depends_on "libmpc"
|
|
depends_on "mpfr"
|
|
|
|
# GCC bootstraps itself, so it is OK to have an incompatible C++ stdlib
|
|
cxxstdlib_check :skip
|
|
|
|
# The bottles are built on systems with the CLT installed, and do not work
|
|
# out of the box on Xcode-only systems due to an incorrect sysroot.
|
|
pour_bottle? do
|
|
reason "The bottle needs the Xcode CLT to be installed."
|
|
satisfy { MacOS::CLT.installed? }
|
|
end
|
|
|
|
def version_suffix
|
|
if build.head?
|
|
"HEAD"
|
|
else
|
|
version.to_s.slice(/\d/)
|
|
end
|
|
end
|
|
|
|
def install
|
|
# GCC will suffer build errors if forced to use a particular linker.
|
|
ENV.delete "LD"
|
|
|
|
# We avoiding building:
|
|
# - Ada, which requires a pre-existing GCC Ada compiler to bootstrap
|
|
# - Go, currently not supported on macOS
|
|
# - BRIG
|
|
languages = %w[c c++ objc obj-c++ fortran]
|
|
|
|
# JIT compiler is off by default, enabling it has performance cost
|
|
languages << "jit" if build.with? "jit"
|
|
|
|
osmajor = `uname -r`.chomp
|
|
|
|
args = [
|
|
"--build=x86_64-apple-darwin#{osmajor}",
|
|
"--prefix=#{prefix}",
|
|
"--libdir=#{lib}/gcc/#{version_suffix}",
|
|
"--enable-languages=#{languages.join(",")}",
|
|
# Make most executables versioned to avoid conflicts.
|
|
"--program-suffix=-#{version_suffix}",
|
|
"--with-gmp=#{Formula["gmp"].opt_prefix}",
|
|
"--with-mpfr=#{Formula["mpfr"].opt_prefix}",
|
|
"--with-mpc=#{Formula["libmpc"].opt_prefix}",
|
|
"--with-isl=#{Formula["isl"].opt_prefix}",
|
|
"--with-system-zlib",
|
|
"--enable-checking=release",
|
|
"--with-pkgversion=Homebrew GCC #{pkg_version} #{build.used_options*" "}".strip,
|
|
"--with-bugurl=https://github.com/Homebrew/homebrew-core/issues",
|
|
]
|
|
|
|
args << "--disable-nls" if build.without? "nls"
|
|
args << "--enable-host-shared" if build.with?("jit")
|
|
|
|
# Xcode 10 dropped 32-bit support
|
|
args << "--disable-multilib" if DevelopmentTools.clang_build_version >= 1000
|
|
|
|
# Ensure correct install names when linking against libgcc_s;
|
|
# see discussion in https://github.com/Homebrew/legacy-homebrew/pull/34303
|
|
inreplace "libgcc/config/t-slibgcc-darwin", "@shlib_slibdir@", "#{HOMEBREW_PREFIX}/lib/gcc/#{version_suffix}"
|
|
|
|
mkdir "build" do
|
|
if !MacOS::CLT.installed?
|
|
# For Xcode-only systems, we need to tell the sysroot path
|
|
args << "--with-native-system-header-dir=/usr/include"
|
|
args << "--with-sysroot=#{MacOS.sdk_path}"
|
|
elsif MacOS.version >= :mojave
|
|
# System headers are no longer located in /usr/include
|
|
args << "--with-native-system-header-dir=/usr/include"
|
|
args << "--with-sysroot=/Library/Developer/CommandLineTools/SDKs/MacOSX.sdk"
|
|
end
|
|
|
|
system "../configure", *args
|
|
|
|
make_args = []
|
|
# Use -headerpad_max_install_names in the build,
|
|
# otherwise updated load commands won't fit in the Mach-O header.
|
|
# This is needed because `gcc` avoids the superenv shim.
|
|
if build.bottle?
|
|
make_args << "BOOT_LDFLAGS=-Wl,-headerpad_max_install_names"
|
|
end
|
|
|
|
system "make", *make_args
|
|
system "make", "install"
|
|
|
|
bin.install_symlink bin/"gfortran-#{version_suffix}" => "gfortran"
|
|
end
|
|
|
|
# Handle conflicts between GCC formulae and avoid interfering
|
|
# with system compilers.
|
|
# Rename man7.
|
|
Dir.glob(man7/"*.7") { |file| add_suffix file, version_suffix }
|
|
# Even when we disable building info pages some are still installed.
|
|
info.rmtree
|
|
end
|
|
|
|
def add_suffix(file, suffix)
|
|
dir = File.dirname(file)
|
|
ext = File.extname(file)
|
|
base = File.basename(file, ext)
|
|
File.rename file, "#{dir}/#{base}-#{suffix}#{ext}"
|
|
end
|
|
|
|
test do
|
|
(testpath/"hello-c.c").write <<~EOS
|
|
#include <stdio.h>
|
|
int main()
|
|
{
|
|
puts("Hello, world!");
|
|
return 0;
|
|
}
|
|
EOS
|
|
system "#{bin}/gcc-#{version_suffix}", "-o", "hello-c", "hello-c.c"
|
|
assert_equal "Hello, world!\n", `./hello-c`
|
|
|
|
(testpath/"hello-cc.cc").write <<~EOS
|
|
#include <iostream>
|
|
int main()
|
|
{
|
|
std::cout << "Hello, world!" << std::endl;
|
|
return 0;
|
|
}
|
|
EOS
|
|
system "#{bin}/g++-#{version_suffix}", "-o", "hello-cc", "hello-cc.cc"
|
|
assert_equal "Hello, world!\n", `./hello-cc`
|
|
|
|
(testpath/"test.f90").write <<~EOS
|
|
integer,parameter::m=10000
|
|
real::a(m), b(m)
|
|
real::fact=0.5
|
|
|
|
do concurrent (i=1:m)
|
|
a(i) = a(i) + fact*b(i)
|
|
end do
|
|
write(*,"(A)") "Done"
|
|
end
|
|
EOS
|
|
system "#{bin}/gfortran", "-o", "test", "test.f90"
|
|
assert_equal "Done\n", `./test`
|
|
end
|
|
end
|
|
|
|
__END__
|
|
diff --git a/gcc/graphite.h b/gcc/graphite.h
|
|
index 4e0e58c..be0a22b 100644
|
|
--- a/gcc/graphite.h
|
|
+++ b/gcc/graphite.h
|
|
@@ -37,6 +37,8 @@ along with GCC; see the file COPYING3. If not see
|
|
#include <isl/schedule.h>
|
|
#include <isl/ast_build.h>
|
|
#include <isl/schedule_node.h>
|
|
+#include <isl/id.h>
|
|
+#include <isl/space.h>
|
|
|
|
typedef struct poly_dr *poly_dr_p;
|