class Postgresql < Formula desc "Object-relational database system" homepage "https://www.postgresql.org/" url "https://ftp.postgresql.org/pub/source/v11.3/postgresql-11.3.tar.bz2" sha256 "2a85e082fc225944821dfd23990e32dfcd2284c19060864b0ad4ca537d30522d" head "https://github.com/postgres/postgres.git" bottle do sha256 "f25a87e028236bda624af6f7cc0d6ad5de35266fe3bda0c64720e0fc4b103376" => :mojave sha256 "791e0d014207c4195d1553a7e0bf9a5e89ccac89b6e35f06ddbdffae8a91f578" => :high_sierra sha256 "cdd0a002a0d8a06a09a61520fabdf1fd7e7ba937264bc7c4c9fa03e3f1d87c91" => :sierra end depends_on "pkg-config" => :build depends_on "icu4c" depends_on "openssl" depends_on "readline" conflicts_with "postgres-xc", :because => "postgresql and postgres-xc install the same binaries." 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"].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-icu --with-ldap --with-libxml --with-libxslt --with-openssl --with-pam --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 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", "--locale=C", "-E", "UTF-8", "#{var}/postgres" end end def caveats; <<~EOS To migrate existing data from a previous major version of PostgreSQL run: brew postgresql-upgrade-database EOS end plist_options :manual => "pg_ctl -D #{HOMEBREW_PREFIX}/var/postgres start" def plist; <<~EOS KeepAlive Label #{plist_name} ProgramArguments #{opt_bin}/postgres -D #{var}/postgres RunAtLoad WorkingDirectory #{HOMEBREW_PREFIX} StandardOutPath #{var}/log/postgres.log 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