postgresql 14.0
parent
00b27f3504
commit
1f35bc50c2
|
@ -1,8 +1,8 @@
|
|||
class Postgresql < Formula
|
||||
desc "Object-relational database system"
|
||||
homepage "https://www.postgresql.org/"
|
||||
url "https://ftp.postgresql.org/pub/source/v13.4/postgresql-13.4.tar.bz2"
|
||||
sha256 "ea93e10390245f1ce461a54eb5f99a48d8cabd3a08ce4d652ec2169a357bc0cd"
|
||||
url "https://ftp.postgresql.org/pub/source/v14.0/postgresql-14.0.tar.bz2"
|
||||
sha256 "ee2ad79126a7375e9102c4db77c4acae6ae6ffe3e082403b88826d96d927a122"
|
||||
license "PostgreSQL"
|
||||
head "https://github.com/postgres/postgres.git", branch: "master"
|
||||
|
||||
|
|
|
@ -0,0 +1,191 @@
|
|||
class PostgresqlAT13 < Formula
|
||||
desc "Object-relational database system"
|
||||
homepage "https://www.postgresql.org/"
|
||||
url "https://ftp.postgresql.org/pub/source/v13.4/postgresql-13.4.tar.bz2"
|
||||
sha256 "ea93e10390245f1ce461a54eb5f99a48d8cabd3a08ce4d652ec2169a357bc0cd"
|
||||
license "PostgreSQL"
|
||||
|
||||
livecheck do
|
||||
url "https://ftp.postgresql.org/pub/source/"
|
||||
regex(%r{href=["']?v?(13(?:\.\d+)+)/?["' >]}i)
|
||||
end
|
||||
|
||||
keg_only :versioned_formula
|
||||
|
||||
# https://www.postgresql.org/support/versioning/
|
||||
deprecate! date: "2024-11-13", because: :unsupported
|
||||
|
||||
depends_on "pkg-config" => :build
|
||||
depends_on "icu4c"
|
||||
|
||||
# GSSAPI provided by Kerberos.framework crashes when forked.
|
||||
# See https://github.com/Homebrew/homebrew-core/issues/47494.
|
||||
depends_on "krb5"
|
||||
|
||||
depends_on "openssl@1.1"
|
||||
depends_on "readline"
|
||||
|
||||
uses_from_macos "libxml2"
|
||||
uses_from_macos "libxslt"
|
||||
uses_from_macos "openldap"
|
||||
uses_from_macos "perl"
|
||||
|
||||
on_linux do
|
||||
depends_on "linux-pam"
|
||||
depends_on "util-linux"
|
||||
end
|
||||
|
||||
def install
|
||||
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=#{opt_pkgshare}
|
||||
--libdir=#{opt_lib}
|
||||
--includedir=#{opt_include}
|
||||
--sysconfdir=#{etc}
|
||||
--docdir=#{doc}
|
||||
--enable-thread-safety
|
||||
--with-gssapi
|
||||
--with-icu
|
||||
--with-ldap
|
||||
--with-libxml
|
||||
--with-libxslt
|
||||
--with-openssl
|
||||
--with-pam
|
||||
--with-perl
|
||||
--with-uuid=e2fs
|
||||
]
|
||||
if OS.mac?
|
||||
args += %w[
|
||||
--with-bonjour
|
||||
--with-tcl
|
||||
]
|
||||
end
|
||||
|
||||
# PostgreSQL by default uses xcodebuild internally to determine this,
|
||||
# which does not work on CLT-only installs.
|
||||
args << "PG_SYSROOT=#{MacOS.sdk_path}" if MacOS.sdk_root_needed?
|
||||
|
||||
system "./configure", *args
|
||||
|
||||
# Work around busted path magic in Makefile.global.in. This can't be specified
|
||||
# in ./configure, but needs to be set here otherwise install prefixes containing
|
||||
# the string "postgres" will get an incorrect pkglibdir.
|
||||
# See https://github.com/Homebrew/homebrew-core/issues/62930#issuecomment-709411789
|
||||
system "make", "pkglibdir=#{lib}/postgresql"
|
||||
system "make", "install-world", "datadir=#{pkgshare}",
|
||||
"libdir=#{lib}",
|
||||
"pkglibdir=#{lib}/postgresql",
|
||||
"includedir=#{include}",
|
||||
"pkgincludedir=#{include}/postgresql",
|
||||
"includedir_server=#{include}/postgresql/server",
|
||||
"includedir_internal=#{include}/postgresql/internal"
|
||||
|
||||
if OS.linux?
|
||||
inreplace lib/"postgresql/pgxs/src/Makefile.global",
|
||||
"LD = #{HOMEBREW_PREFIX}/Homebrew/Library/Homebrew/shims/linux/super/ld",
|
||||
"LD = #{HOMEBREW_PREFIX}/bin/ld"
|
||||
end
|
||||
end
|
||||
|
||||
def post_install
|
||||
(var/"log").mkpath
|
||||
postgresql_datadir.mkpath
|
||||
|
||||
# Don't initialize database, it clashes when testing other PostgreSQL versions.
|
||||
return if ENV["HOMEBREW_GITHUB_ACTIONS"]
|
||||
|
||||
system "#{bin}/initdb", "--locale=C", "-E", "UTF-8", postgresql_datadir unless pg_version_exists?
|
||||
end
|
||||
|
||||
def postgresql_datadir
|
||||
var/name
|
||||
end
|
||||
|
||||
def postgresql_log_path
|
||||
var/"log/#{name}.log"
|
||||
end
|
||||
|
||||
def pg_version_exists?
|
||||
(postgresql_datadir/"PG_VERSION").exist?
|
||||
end
|
||||
|
||||
def old_postgres_data_dir
|
||||
var/"postgres"
|
||||
end
|
||||
|
||||
def postgresql_formula_present?
|
||||
Formula["postgresql"].any_version_installed?
|
||||
end
|
||||
|
||||
# Figure out what version of PostgreSQL the old data dir is
|
||||
# using
|
||||
def old_postgresql_datadir_version
|
||||
pg_version = old_postgres_data_dir/"PG_VERSION"
|
||||
pg_version.exist? && pg_version.read.chomp
|
||||
end
|
||||
|
||||
def caveats
|
||||
caveats = ""
|
||||
|
||||
# Extract the version from the formula name
|
||||
pg_formula_version = name.split("@", 2).last
|
||||
# ... and check it against the old data dir postgres version number
|
||||
# to see if we need to print a warning re: data dir
|
||||
if old_postgresql_datadir_version == pg_formula_version
|
||||
caveats += if postgresql_formula_present?
|
||||
# Both PostgreSQL and PostgreSQL@13 are installed
|
||||
<<~EOS
|
||||
Previous versions of this formula used the same data directory as
|
||||
the regular PostgreSQL formula. This causes a conflict if you
|
||||
try to use both at the same time.
|
||||
|
||||
In order to avoid this conflict, you should make sure that the
|
||||
#{name} data directory is located at:
|
||||
#{postgresql_datadir}
|
||||
|
||||
EOS
|
||||
else
|
||||
# Only PostgreSQL@13 is installed, not PostgreSQL
|
||||
<<~EOS
|
||||
Previous versions of #{name} used the same data directory as
|
||||
the postgresql formula. This will cause a conflict if you
|
||||
try to use both at the same time.
|
||||
|
||||
You can migrate to a versioned data directory by running:
|
||||
mv -v "#{old_postgres_data_dir}" "#{postgresql_datadir}"
|
||||
|
||||
(Make sure PostgreSQL is stopped before executing this command)
|
||||
|
||||
EOS
|
||||
end
|
||||
end
|
||||
|
||||
caveats += <<~EOS
|
||||
This formula has created a default database cluster with:
|
||||
initdb --locale=C -E UTF-8 #{postgresql_datadir}
|
||||
For more details, read:
|
||||
https://www.postgresql.org/docs/#{version.major}/app-initdb.html
|
||||
EOS
|
||||
|
||||
caveats
|
||||
end
|
||||
|
||||
service do
|
||||
run [opt_bin/"postgres", "-D", var/"postgresql@13"]
|
||||
keep_alive true
|
||||
log_path var/"log/postgresql@13.log"
|
||||
error_log_path var/"log/postgresql@13.log"
|
||||
working_dir HOMEBREW_PREFIX
|
||||
end
|
||||
|
||||
test do
|
||||
system "#{bin}/initdb", testpath/"test" unless ENV["HOMEBREW_GITHUB_ACTIONS"]
|
||||
assert_equal opt_pkgshare.to_s, shell_output("#{bin}/pg_config --sharedir").chomp
|
||||
assert_equal opt_lib.to_s, shell_output("#{bin}/pg_config --libdir").chomp
|
||||
assert_equal "#{lib}/postgresql", shell_output("#{bin}/pg_config --pkglibdir").chomp
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue