[dev-db/postgresql] sync
This commit is contained in:
parent
c7ef7152b8
commit
cf35e3d9f3
@ -21,9 +21,8 @@ LICENSE="POSTGRESQL GPL-2"
|
||||
DESCRIPTION="PostgreSQL RDBMS"
|
||||
HOMEPAGE="https://www.postgresql.org/"
|
||||
|
||||
IUSE="debug doc icu kerberos ldap llvm lz4 nls pam
|
||||
perl python +readline selinux +server systemd ssl static-libs tcl
|
||||
threads uuid xml zlib zstd"
|
||||
IUSE="debug doc icu kerberos ldap llvm lz4 nls pam perl python +readline
|
||||
selinux +server systemd ssl static-libs tcl uuid xml zlib zstd"
|
||||
|
||||
REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )"
|
||||
|
||||
@ -142,7 +141,6 @@ src_configure() {
|
||||
--sysconfdir="${PO}/etc/postgresql-${SLOT}" \
|
||||
--with-system-tzdata="${PO}/usr/share/zoneinfo" \
|
||||
$(use_enable debug) \
|
||||
$(use_enable threads thread-safety) \
|
||||
$(use_with icu) \
|
||||
$(use_with kerberos gssapi) \
|
||||
$(use_with ldap) \
|
||||
|
@ -3,9 +3,10 @@
|
||||
|
||||
EAPI=8
|
||||
|
||||
PYTHON_COMPAT=( python3_{9,10,11} )
|
||||
PYTHON_COMPAT=( python3_{10,11,12} )
|
||||
|
||||
inherit flag-o-matic git-r3 linux-info pam python-single-r1 systemd tmpfiles
|
||||
inherit flag-o-matic git-r3 linux-info meson pam python-single-r1 \
|
||||
systemd tmpfiles
|
||||
|
||||
KEYWORDS=""
|
||||
|
||||
@ -17,9 +18,8 @@ LICENSE="POSTGRESQL GPL-2"
|
||||
DESCRIPTION="PostgreSQL RDBMS"
|
||||
HOMEPAGE="https://www.postgresql.org/"
|
||||
|
||||
IUSE="debug icu kerberos ldap llvm +lz4
|
||||
nls pam perl python +readline selinux server systemd
|
||||
ssl static-libs tcl threads uuid xml zlib zstd"
|
||||
IUSE="debug +icu kerberos ldap llvm +lz4 nls pam perl python +readline
|
||||
selinux server systemd ssl static-libs tcl uuid xml zlib zstd"
|
||||
|
||||
REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )"
|
||||
|
||||
@ -93,7 +93,7 @@ pkg_pretend() {
|
||||
if ! use server; then
|
||||
elog "You are using a live ebuild that uses the current source code as it is"
|
||||
elog "available from PostgreSQL's Git repository at emerge time. Given such,"
|
||||
elog "the GNU Makefiles may be altered by upstream without notice and the"
|
||||
elog "the Meson build files may be altered by upstream without notice and the"
|
||||
elog "documentation for this live version is not readily available"
|
||||
elog "online. Ergo, the ebuild maintainers will not support building a"
|
||||
elog "client-only and/or document-free version."
|
||||
@ -127,69 +127,76 @@ src_prepare() {
|
||||
}
|
||||
|
||||
src_configure() {
|
||||
local emesonargs=()
|
||||
|
||||
case ${CHOST} in
|
||||
*-darwin*|*-solaris*)
|
||||
use nls && append-libs intl
|
||||
;;
|
||||
esac
|
||||
|
||||
export LDFLAGS_SL="${LDFLAGS}"
|
||||
export LDFLAGS_EX="${LDFLAGS}"
|
||||
|
||||
local PO="${EPREFIX}"
|
||||
|
||||
local i uuid_config=""
|
||||
if use uuid; then
|
||||
for i in ${UTIL_LINUX_LIBC[@]}; do
|
||||
use ${i} && uuid_config="--with-uuid=e2fs"
|
||||
use ${i} && uuid_config="-Duuid=e2fs"
|
||||
done
|
||||
[[ -z $uuid_config ]] && uuid_config="--with-uuid=ossp"
|
||||
|
||||
emesonargs+=( ${uuid_config:-"-Duuid=ossp"} )
|
||||
fi
|
||||
|
||||
local myconf="\
|
||||
--prefix="${PO}/usr/$(get_libdir)/postgresql-${SLOT}" \
|
||||
--datadir="${PO}/usr/share/postgresql-${SLOT}" \
|
||||
--includedir="${PO}/usr/include/postgresql-${SLOT}" \
|
||||
--mandir="${PO}/usr/share/postgresql-${SLOT}/man" \
|
||||
--sysconfdir="${PO}/etc/postgresql-${SLOT}" \
|
||||
--with-system-tzdata="${PO}/usr/share/zoneinfo" \
|
||||
$(use_enable debug) \
|
||||
$(use_enable nls) \
|
||||
$(use_enable threads thread-safety) \
|
||||
$(use_with icu) \
|
||||
$(use_with kerberos gssapi) \
|
||||
$(use_with ldap) \
|
||||
$(use_with llvm) \
|
||||
$(use_with lz4) \
|
||||
$(use_with pam) \
|
||||
$(use_with perl) \
|
||||
$(use_with python) \
|
||||
$(use_with readline) \
|
||||
$(use_with ssl openssl) \
|
||||
$(use_with tcl) \
|
||||
$(use_with xml libxml) \
|
||||
$(use_with xml libxslt) \
|
||||
$(use_with zlib) \
|
||||
$(use_with zstd ) \
|
||||
$(use_with systemd) \
|
||||
${uuid_config}"
|
||||
if use alpha; then
|
||||
myconf+=" --disable-spinlocks"
|
||||
else
|
||||
# Should be the default but just in case
|
||||
myconf+=" --enable-spinlocks"
|
||||
fi
|
||||
econf ${myconf}
|
||||
use debug && emesonargs+=( "--debug" )
|
||||
|
||||
local PO="${EPREFIX}"
|
||||
emesonargs+=(
|
||||
--prefix="${PO}/usr/$(get_libdir)/postgresql-${SLOT}"
|
||||
--datadir="${PO}/usr/share/postgresql-${SLOT}"
|
||||
--includedir="${PO}/usr/include/postgresql-${SLOT}"
|
||||
--mandir="${PO}/usr/share/postgresql-${SLOT}/man"
|
||||
--sysconfdir="${PO}/etc/postgresql-${SLOT}"
|
||||
-Dsystem_tzdata="${PO}/usr/share/zoneinfo"
|
||||
$(meson_feature icu)
|
||||
$(meson_feature kerberos gssapi)
|
||||
$(meson_feature ldap)
|
||||
$(meson_feature llvm)
|
||||
$(meson_feature lz4)
|
||||
$(meson_feature nls)
|
||||
$(meson_feature pam)
|
||||
$(meson_feature perl plperl)
|
||||
$(meson_feature python plpython)
|
||||
$(meson_feature readline)
|
||||
$(meson_feature systemd)
|
||||
$(meson_feature tcl pltcl)
|
||||
$(meson_feature xml libxml)
|
||||
$(meson_feature xml libxslt)
|
||||
$(meson_feature zlib)
|
||||
$(meson_feature zstd)
|
||||
)
|
||||
|
||||
use ssl && emesonargs+=( "-Dssl=openssl" )
|
||||
use alpha && emesonargs+=( "-Dspinlocks=false" )
|
||||
|
||||
export LDFLAGS_SL="${LDFLAGS}"
|
||||
export LDFLAGS_EX="${LDFLAGS}"
|
||||
|
||||
meson_src_configure
|
||||
}
|
||||
|
||||
src_compile() {
|
||||
emake world
|
||||
meson_src_compile
|
||||
meson_src_compile {docs,man}
|
||||
}
|
||||
|
||||
src_install() {
|
||||
emake DESTDIR="${D}" install-world
|
||||
meson_src_install
|
||||
|
||||
dodoc README HISTORY doc/TODO
|
||||
dodoc -r "${BUILD_DIR}"/doc/src/sgml/html
|
||||
|
||||
# postgresql.eselect places the man files of the selected slot, which may
|
||||
# not be this ${SLOT}, hence doins instead of doman
|
||||
insinto /usr/share/postgresql-${SLOT}/man/
|
||||
doins -r "${BUILD_DIR}"/doc/src/sgml/man{1,3,7}
|
||||
docompress /usr/share/postgresql-${SLOT}/man/man{1,3,7}
|
||||
|
||||
insinto /etc/postgresql-${SLOT}
|
||||
newins src/bin/psql/psqlrc.sample psqlrc
|
||||
@ -222,11 +229,8 @@ src_install() {
|
||||
-mindepth 1 -maxdepth 1)
|
||||
do
|
||||
bn=$(basename "${f}")
|
||||
# Temporarily tack on tmp to workaround a file collision
|
||||
# issue. This is only necessary for 9.7 and earlier. 10 never
|
||||
# had this issue.
|
||||
dosym "../$(get_libdir)/postgresql-${SLOT}/bin/${bn}" \
|
||||
"/usr/bin/${bn}${SLOT/.}tmp"
|
||||
"/usr/bin/${bn}${SLOT/.}"
|
||||
done
|
||||
|
||||
# Create slot specific man pages
|
||||
@ -259,40 +263,6 @@ src_install() {
|
||||
fi
|
||||
}
|
||||
|
||||
pkg_preinst() {
|
||||
# Find all of the slot-specific symlinks, if any, in /usr/bin (e.g.,
|
||||
# /usr/bin/psql97). They may have been created by the
|
||||
# postgresql.eselect module, but they're handled within this ebuild
|
||||
# now. It's alright if we momentarily delete /usr/bin/psql as it
|
||||
# will be recreated by the eselect module in pkg_ppostinst(). We
|
||||
# only worry about the 9.7 slot as that's the last slot that had its
|
||||
# slot-specific links generated by eselect.
|
||||
#
|
||||
# This can be removed when 10 is the lowest slot in the tree.
|
||||
local canonicalise
|
||||
if type -p realpath > /dev/null; then
|
||||
canonicalise=realpath
|
||||
elif type -p readlink > /dev/null; then
|
||||
canonicalise='readlink -f'
|
||||
else
|
||||
# can't die, subshell
|
||||
die "No readlink nor realpath found, cannot canonicalise"
|
||||
fi
|
||||
|
||||
local l
|
||||
# First remove any symlinks in /usr/bin that may have been created
|
||||
# by the old eselect
|
||||
for l in $(find "${ROOT}/usr/bin" -mindepth 1 -maxdepth 1 -type l) ; do
|
||||
[[ $(${canonicalise} "${l}") == *postgresql-9.7* ]] && rm "${l}"
|
||||
done
|
||||
|
||||
# Then move the symlinks created by the ebuild to their proper place.
|
||||
for l in "${ED}"/usr/bin/*tmp ; do
|
||||
mv "${l}" "${l%tmp}" \
|
||||
|| ewarn "Couldn't rename $(basename ${l}) to $(basename ${l%tmp})"
|
||||
done
|
||||
}
|
||||
|
||||
pkg_postinst() {
|
||||
use systemd && tmpfiles_process ${PN}-${SLOT}.conf
|
||||
postgresql-config update
|
||||
@ -460,7 +430,7 @@ src_test() {
|
||||
# LC_CTYPE to be equal to LC_COLLATE since LC_COLLATE is set by Portage.
|
||||
local old_ctype=${LC_CTYPE}
|
||||
export LC_CTYPE=${LC_COLLATE}
|
||||
emake check
|
||||
meson_src_test
|
||||
export LC_CTYPE=${old_ctype}
|
||||
|
||||
einfo "If you think other tests besides the regression tests are necessary, please"
|
||||
|
Loading…
x
Reference in New Issue
Block a user