2024-09-19 14:19:46 +00:00
|
|
|
{
|
|
|
|
fetchurl,
|
|
|
|
lib,
|
|
|
|
stdenv,
|
|
|
|
perl,
|
|
|
|
libxml2,
|
|
|
|
postgresql,
|
|
|
|
postgresqlTestHook,
|
|
|
|
geos,
|
|
|
|
proj,
|
|
|
|
gdalMinimal,
|
|
|
|
json_c,
|
|
|
|
pkg-config,
|
|
|
|
file,
|
|
|
|
protobufc,
|
|
|
|
libiconv,
|
|
|
|
libxslt,
|
|
|
|
docbook_xml_dtd_45,
|
|
|
|
cunit,
|
|
|
|
pcre2,
|
|
|
|
nixosTests,
|
|
|
|
jitSupport,
|
|
|
|
llvm,
|
2020-04-24 23:36:52 +00:00
|
|
|
}:
|
2024-01-25 14:12:00 +00:00
|
|
|
|
|
|
|
let
|
|
|
|
gdal = gdalMinimal;
|
|
|
|
in
|
2020-04-24 23:36:52 +00:00
|
|
|
stdenv.mkDerivation rec {
|
|
|
|
pname = "postgis";
|
2024-02-29 20:09:43 +00:00
|
|
|
version = "3.4.2";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
outputs = [
|
|
|
|
"out"
|
|
|
|
"doc"
|
|
|
|
];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
src = fetchurl {
|
|
|
|
url = "https://download.osgeo.org/postgis/source/postgis-${version}.tar.gz";
|
2024-09-19 14:19:46 +00:00
|
|
|
hash = "sha256-yMh0wAukqYSocDCva/lUSCFQIGCtRz1clvHU0INcWJI=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
buildInputs = [
|
|
|
|
libxml2
|
|
|
|
postgresql
|
|
|
|
geos
|
|
|
|
proj
|
|
|
|
gdal
|
|
|
|
json_c
|
|
|
|
protobufc
|
|
|
|
pcre2.dev
|
|
|
|
] ++ lib.optional stdenv.isDarwin libiconv;
|
|
|
|
nativeBuildInputs = [
|
|
|
|
perl
|
|
|
|
pkg-config
|
|
|
|
] ++ lib.optional jitSupport llvm;
|
2020-04-24 23:36:52 +00:00
|
|
|
dontDisableStatic = true;
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
nativeCheckInputs = [
|
|
|
|
postgresqlTestHook
|
|
|
|
cunit
|
|
|
|
libxslt
|
|
|
|
];
|
|
|
|
|
|
|
|
postgresqlTestUserOptions = "LOGIN SUPERUSER";
|
|
|
|
failureHook = "postgresqlStop";
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
# postgis config directory assumes /include /lib from the same root for json-c library
|
2024-04-21 15:54:59 +00:00
|
|
|
env.NIX_LDFLAGS = "-L${lib.getLib json_c}/lib";
|
2024-01-02 11:29:13 +00:00
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
preConfigure = ''
|
|
|
|
sed -i 's@/usr/bin/file@${file}/bin/file@' configure
|
2023-10-09 19:29:22 +00:00
|
|
|
configureFlags="--datadir=$out/share/postgresql --datarootdir=$out/share/postgresql --bindir=$out/bin --docdir=$doc/share/doc/${pname} --with-gdalconfig=${gdal}/bin/gdal-config --with-jsondir=${json_c.dev} --disable-extension-upgrades-install"
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2023-08-04 22:07:22 +00:00
|
|
|
makeFlags="PERL=${perl}/bin/perl datadir=$out/share/postgresql pkglibdir=$out/lib bindir=$out/bin docdir=$doc/share/doc/${pname}"
|
2020-04-24 23:36:52 +00:00
|
|
|
'';
|
|
|
|
postConfigure = ''
|
|
|
|
sed -i "s|@mkdir -p \$(DESTDIR)\$(PGSQL_BINDIR)||g ;
|
|
|
|
s|\$(DESTDIR)\$(PGSQL_BINDIR)|$prefix/bin|g
|
|
|
|
" \
|
|
|
|
"raster/loader/Makefile";
|
|
|
|
sed -i "s|\$(DESTDIR)\$(PGSQL_BINDIR)|$prefix/bin|g
|
|
|
|
" \
|
|
|
|
"raster/scripts/python/Makefile";
|
|
|
|
mkdir -p $out/bin
|
|
|
|
|
|
|
|
# postgis' build system assumes it is being installed to the same place as postgresql, and looks
|
|
|
|
# for the postgres binary relative to $PREFIX. We gently support this system using an illusion.
|
|
|
|
ln -s ${postgresql}/bin/postgres $out/bin/postgres
|
|
|
|
'';
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
doCheck = stdenv.isLinux;
|
|
|
|
|
|
|
|
preCheck = ''
|
|
|
|
substituteInPlace regress/run_test.pl --replace-fail "/share/contrib/postgis" "$out/share/postgresql/contrib/postgis"
|
|
|
|
substituteInPlace regress/Makefile --replace-fail 's,\$$libdir,$(REGRESS_INSTALLDIR)/lib,g' "s,\\$\$libdir,$PWD/regress/00-regress-install$out/lib,g" \
|
|
|
|
--replace-fail '$(REGRESS_INSTALLDIR)/share/contrib/postgis/*.sql' "$PWD/regress/00-regress-install$out/share/postgresql/contrib/postgis/*.sql"
|
|
|
|
substituteInPlace doc/postgis-out.xml --replace-fail "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" "${docbook_xml_dtd_45}/xml/dtd/docbook/docbookx.dtd"
|
|
|
|
# The test suite hardcodes it to use /tmp.
|
|
|
|
export PGIS_REG_TMPDIR="$TMPDIR/pgis_reg"
|
|
|
|
'';
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
# create aliases for all commands adding version information
|
|
|
|
postInstall = ''
|
|
|
|
# Teardown the illusory postgres used for building; see postConfigure.
|
|
|
|
rm $out/bin/postgres
|
|
|
|
|
|
|
|
for prog in $out/bin/*; do # */
|
|
|
|
ln -s $prog $prog-${version}
|
|
|
|
done
|
|
|
|
|
|
|
|
mkdir -p $doc/share/doc/postgis
|
|
|
|
mv doc/* $doc/share/doc/postgis/
|
|
|
|
'';
|
|
|
|
|
2020-11-24 20:58:05 +00:00
|
|
|
passthru.tests.postgis = nixosTests.postgis;
|
|
|
|
|
2021-01-15 22:18:51 +00:00
|
|
|
meta = with lib; {
|
2020-04-24 23:36:52 +00:00
|
|
|
description = "Geographic Objects for PostgreSQL";
|
|
|
|
homepage = "https://postgis.net/";
|
|
|
|
changelog = "https://git.osgeo.org/gitea/postgis/postgis/raw/tag/${version}/NEWS";
|
2024-06-05 15:53:02 +00:00
|
|
|
license = licenses.gpl2Plus;
|
2024-09-19 14:19:46 +00:00
|
|
|
maintainers =
|
|
|
|
with maintainers;
|
|
|
|
teams.geospatial.members
|
|
|
|
++ [
|
|
|
|
marcweber
|
|
|
|
wolfgangwalther
|
|
|
|
];
|
2020-04-24 23:36:52 +00:00
|
|
|
inherit (postgresql.meta) platforms;
|
|
|
|
};
|
|
|
|
}
|