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 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 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 #include #include +#include +#include typedef struct poly_dr *poly_dr_p;