class PostgresqlAT96 < Formula desc "Object-relational database system" homepage "https://www.postgresql.org/" url "https://ftp.postgresql.org/pub/source/v9.6.15/postgresql-9.6.15.tar.bz2" sha256 "3cd9fe9af247167f863030842c1a57f58bdf3e5d50a94997d34a802b6032170a" revision 1 bottle do sha256 "661fa3a54e1e9fdbf445a0bbc0b91faddea6b2b023811e05b1902402be62d600" => :catalina sha256 "92c545b9724c68be7b4598b16bd43b24bddd30c98a72548ba657bfb662026305" => :mojave sha256 "263bef3e3927121a8e1a9c5f17a3d17ae44c64beff509db1d3d239d065faf20f" => :high_sierra sha256 "3007b300d69bedcb20276093929c2687f7bebdaed40e86cb3fd27d90dcc0a157" => :sierra end keg_only :versioned_formula depends_on "openssl@1.1" depends_on "readline" def install # avoid adding the SDK library directory to the linker search path ENV["XML2_CONFIG"] = "xml2-config --exec-prefix=/usr" ENV.prepend "LDFLAGS", "-L#{Formula["openssl@1.1"].opt_lib} -L#{Formula["readline"].opt_lib}" ENV.prepend "CPPFLAGS", "-I#{Formula["openssl@1.1"].opt_include} -I#{Formula["readline"].opt_include}" args = %W[ --disable-debug --prefix=#{prefix} --datadir=#{pkgshare} --libdir=#{lib} --sysconfdir=#{prefix}/etc --docdir=#{doc} --enable-thread-safety --with-bonjour --with-gssapi --with-ldap --with-openssl --with-pam --with-libxml --with-libxslt --with-perl --with-uuid=e2fs ] # The CLT is required to build Tcl support on 10.7 and 10.8 because # tclConfig.sh is not part of the SDK args << "--with-tcl" if File.exist?("#{MacOS.sdk_path}/System/Library/Frameworks/Tcl.framework/tclConfig.sh") args << "--with-tclconfig=#{MacOS.sdk_path}/System/Library/Frameworks/Tcl.framework" end # As of Xcode/CLT 10.x the Perl headers were moved from /System # to inside the SDK, so we need to use `-iwithsysroot` instead # of `-I` to point to the correct location. # https://www.postgresql.org/message-id/153558865647.1483.573481613491501077%40wrigleys.postgresql.org if DevelopmentTools.clang_build_version >= 1000 inreplace "configure", "-I$perl_archlibexp/CORE", "-iwithsysroot $perl_archlibexp/CORE" inreplace "contrib/hstore_plperl/Makefile", "$(perl_archlibexp)/CORE", "-iwithsysroot $(perl_archlibexp)/CORE" inreplace "src/pl/plperl/GNUmakefile", "$(perl_archlibexp)/CORE", "-iwithsysroot $(perl_archlibexp)/CORE" end system "./configure", *args system "make" dirs = %W[datadir=#{pkgshare} libdir=#{lib} pkglibdir=#{lib}] # Temporarily disable building/installing the documentation. # Postgresql seems to "know" the build system has been altered and # tries to regenerate the documentation when using `install-world`. # This results in the build failing: # `ERROR: `osx' is missing on your system.` # Attempting to fix that by adding a dependency on `open-sp` doesn't # work and the build errors out on generating the documentation, so # for now let's simply omit it so we can package Postgresql for Mojave. if DevelopmentTools.clang_build_version >= 1000 system "make", "all" system "make", "-C", "contrib", "install", "all", *dirs system "make", "install", "all", *dirs else system "make", "install-world", *dirs end end def post_install (var/"log").mkpath (var/name).mkpath unless File.exist? "#{var}/#{name}/PG_VERSION" system "#{bin}/initdb", "#{var}/#{name}" end end def caveats; <<~EOS If builds of PostgreSQL 9 are failing and you have version 8.x installed, you may need to remove the previous version first. See: https://github.com/Homebrew/legacy-homebrew/issues/2510 To migrate existing data from a previous major version (pre-9.0) of PostgreSQL, see: https://www.postgresql.org/docs/9.6/static/upgrading.html To migrate existing data from a previous minor version (9.0-9.5) of PostgreSQL, see: https://www.postgresql.org/docs/9.6/static/pgupgrade.html You will need your previous PostgreSQL installation from brew to perform `pg_upgrade`. Do not run `brew cleanup postgresql@9.6` until you have performed the migration. EOS end plist_options :manual => "pg_ctl -D #{HOMEBREW_PREFIX}/var/postgresql@9.6 start" def plist; <<~EOS KeepAlive Label #{plist_name} ProgramArguments #{opt_bin}/postgres -D #{var}/#{name} RunAtLoad WorkingDirectory #{HOMEBREW_PREFIX} StandardErrorPath #{var}/log/#{name}.log EOS end test do system "#{bin}/initdb", testpath/"test" assert_equal pkgshare.to_s, shell_output("#{bin}/pg_config --sharedir").chomp assert_equal lib.to_s, shell_output("#{bin}/pg_config --libdir").chomp assert_equal lib.to_s, shell_output("#{bin}/pg_config --pkglibdir").chomp end end