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 2 sha256 "5d0b4c4bd26b4fe71f4a67fd25a740e9627684b01af9a87807fd5697c804e5ab" => :mojave sha256 "436ea3d1fa051a99129eb8bebae429bfb7a217af871c580cdaf4099b4688151b" => :high_sierra sha256 "3925eaf2b53b52d4f2a63477167519bdc58f79348500b108517e0e88e8eff0c1" => :sierra end # 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 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 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] # D will be included in GCC 9 languages << "d" if build.head? osmajor = `uname -r`.chomp pkgversion = "Homebrew GCC #{pkg_version} #{build.used_options*" "}".strip args = %W[ --build=x86_64-apple-darwin#{osmajor} --prefix=#{prefix} --libdir=#{lib}/gcc/#{version_suffix} --disable-nls --enable-checking=release --enable-languages=#{languages.join(",")} --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 --with-pkgversion=#{pkgversion} --with-bugurl=https://github.com/Homebrew/homebrew-core/issues ] # 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;