class Postgresql < Formula desc "Object-relational database system" homepage "https://www.postgresql.org/" url "https://ftp.postgresql.org/pub/source/v9.5.4/postgresql-9.5.4.tar.bz2" sha256 "cf5e571164ad66028ecd7dd8819e3765470d45bcd440d258b686be7e69c76ed0" bottle do rebuild 1 sha256 "fa725a3e3daab0d4492f80af6e702807fa9c26572f8b7eccc91c8ecb10a1dbc3" => :sierra sha256 "4817d42e9cad63ece2e612f3b8f16931b1cfcf014e024d1f23e87ac815721eed" => :el_capitan sha256 "a1deb24ef12f78a8e95114542823eda19ecbab38db1c8d72dd383f5f91a0ec6f" => :yosemite sha256 "8dea71ddee4c7c05f9a4321bf60dbfdc88df1c53c6c12031593855c928bc2c53" => :mavericks end devel do url "https://ftp.postgresql.org/pub/source/v9.6rc1/postgresql-9.6rc1.tar.gz" sha256 "a202c0bfba27f4dd612c01a4a4f6de1f5b42ada27471f8cb6a59df150cfe71c9" end option "32-bit" option "without-perl", "Build without Perl support" option "without-tcl", "Build without Tcl support" option "with-dtrace", "Build with DTrace support" deprecated_option "no-perl" => "without-perl" deprecated_option "no-tcl" => "without-tcl" deprecated_option "enable-dtrace" => "with-dtrace" depends_on "openssl" depends_on "readline" depends_on "libxml2" if MacOS.version <= :leopard # Leopard libxml is too old option "with-python", "Enable PL/Python2" depends_on :python => :optional option "with-python3", "Enable PL/Python3 (incompatible with --with-python)" depends_on :python3 => :optional conflicts_with "postgres-xc", :because => "postgresql and postgres-xc install the same binaries." fails_with :clang do build 211 cause "Miscompilation resulting in segfault on queries" end def install ENV.libxml2 if MacOS.version >= :snow_leopard # 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"].opt_lib} -L#{Formula["readline"].opt_lib}" ENV.prepend "CPPFLAGS", "-I#{Formula["openssl"].opt_include} -I#{Formula["readline"].opt_include}" args = %W[ --disable-debug --prefix=#{prefix} --datadir=#{HOMEBREW_PREFIX}/share/postgresql --libdir=#{HOMEBREW_PREFIX}/lib --sysconfdir=#{etc} --docdir=#{doc} --enable-thread-safety --with-bonjour --with-gssapi --with-ldap --with-openssl --with-pam --with-libxml --with-libxslt ] args << "--with-perl" if build.with? "perl" which_python = nil if build.with?("python") && build.with?("python3") odie "Cannot provide both --with-python and --with-python3" elsif build.with?("python") || build.with?("python3") args << "--with-python" which_python = which(build.with?("python") ? "python" : "python3") end ENV["PYTHON"] = which_python # The CLT is required to build Tcl support on 10.7 and 10.8 because # tclConfig.sh is not part of the SDK if build.with?("tcl") && (MacOS.version >= :mavericks || MacOS::CLT.installed?) args << "--with-tcl" if File.exist?("#{MacOS.sdk_path}/usr/lib/tclConfig.sh") args << "--with-tclconfig=#{MacOS.sdk_path}/usr/lib" end end args << "--enable-dtrace" if build.with? "dtrace" args << "--with-uuid=e2fs" if build.build_32_bit? ENV.append %w[CFLAGS LDFLAGS], "-arch #{Hardware::CPU.arch_32_bit}" end system "./configure", *args system "make" system "make", "install-world", "datadir=#{pkgshare}", "libdir=#{lib}", "pkglibdir=#{lib}/postgresql" end def post_install (var/"log").mkpath (var/"postgres").mkpath unless File.exist? "#{var}/postgres/PG_VERSION" system "#{bin}/initdb", "#{var}/postgres" end end def caveats; <<-EOS.undent 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/homebrew/issues/2510 To migrate existing data from a previous major version (pre-9.0) of PostgreSQL, see: https://www.postgresql.org/docs/9.5/static/upgrading.html To migrate existing data from a previous minor version (9.0-9.4) of PostgreSQL, see: https://www.postgresql.org/docs/9.5/static/pgupgrade.html You will need your previous PostgreSQL installation from brew to perform `pg_upgrade`. Do not run `brew cleanup postgresql` until you have performed the migration. EOS end plist_options :manual => "postgres -D #{HOMEBREW_PREFIX}/var/postgres" def plist; <<-EOS.undent KeepAlive Label #{plist_name} ProgramArguments #{opt_bin}/postgres -D #{var}/postgres RunAtLoad WorkingDirectory #{HOMEBREW_PREFIX} StandardErrorPath #{var}/log/postgres.log EOS end test do system "#{bin}/initdb", testpath/"test" assert_equal "#{HOMEBREW_PREFIX}/share/postgresql", shell_output("#{bin}/pg_config --sharedir").chomp assert_equal "#{HOMEBREW_PREFIX}/lib", shell_output("#{bin}/pg_config --libdir").chomp assert_equal "#{HOMEBREW_PREFIX}/lib/postgresql", shell_output("#{bin}/pg_config --pkglibdir").chomp end end