mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-06-11 04:05:40 +03:00

Previously, the user of postgresqlTestHook would have needed to set failureHook accordingly. However, this was not a clean solution, because postgresqlStop would also run for configure or build failures, before the server was even started. This gave odd errors from a failed shutdown in the log. Now postgresqlStop is only called when it makes sense - and whenever postgresqlTestHook is used.
180 lines
4.2 KiB
Nix
180 lines
4.2 KiB
Nix
{
|
|
autoconf,
|
|
automake,
|
|
cunit,
|
|
docbook5,
|
|
fetchFromGitHub,
|
|
fetchpatch,
|
|
gdalMinimal,
|
|
geos,
|
|
jitSupport,
|
|
json_c,
|
|
lib,
|
|
libiconv,
|
|
libtool,
|
|
libxml2,
|
|
libxslt,
|
|
llvm,
|
|
pcre2,
|
|
perl,
|
|
pkg-config,
|
|
postgresql,
|
|
postgresqlBuildExtension,
|
|
postgresqlTestExtension,
|
|
postgresqlTestHook,
|
|
proj,
|
|
protobufc,
|
|
stdenv,
|
|
which,
|
|
|
|
withSfcgal ? false,
|
|
sfcgal,
|
|
}:
|
|
|
|
let
|
|
gdal = gdalMinimal;
|
|
in
|
|
postgresqlBuildExtension (finalAttrs: {
|
|
pname = "postgis";
|
|
version = "3.5.2";
|
|
|
|
outputs = [
|
|
"out"
|
|
"doc"
|
|
];
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "postgis";
|
|
repo = "postgis";
|
|
tag = finalAttrs.version;
|
|
hash = "sha256-1kOLtG6AMavbWQ1lHG2ABuvIcyTYhgcbjuVmqMR4X+g=";
|
|
};
|
|
|
|
patches = [
|
|
# Backport patch for compatibility with GDAL 3.11
|
|
# FIXME: remove in next update
|
|
(fetchpatch {
|
|
url = "https://git.osgeo.org/gitea/postgis/postgis/commit/614eca7c169cd6e9819801d3ea99d5258262c58b.patch";
|
|
hash = "sha256-VkNZFANAt8Jv+ExCusGvi+ZWB7XLcAheefSx7akA7Go=";
|
|
})
|
|
];
|
|
|
|
buildInputs =
|
|
[
|
|
geos
|
|
proj
|
|
gdal
|
|
json_c
|
|
protobufc
|
|
pcre2.dev
|
|
]
|
|
++ lib.optional stdenv.hostPlatform.isDarwin libiconv
|
|
++ lib.optional withSfcgal sfcgal;
|
|
|
|
nativeBuildInputs = [
|
|
autoconf
|
|
automake
|
|
libtool
|
|
libxml2
|
|
perl
|
|
pkg-config
|
|
protobufc
|
|
which
|
|
] ++ lib.optional jitSupport llvm;
|
|
|
|
dontDisableStatic = true;
|
|
|
|
nativeCheckInputs = [
|
|
postgresql
|
|
postgresqlTestHook
|
|
cunit
|
|
libxslt
|
|
];
|
|
|
|
postgresqlTestUserOptions = "LOGIN SUPERUSER";
|
|
|
|
# postgis config directory assumes /include /lib from the same root for json-c library
|
|
env.NIX_LDFLAGS = "-L${lib.getLib json_c}/lib";
|
|
|
|
setOutputFlags = false;
|
|
preConfigure = ''
|
|
./autogen.sh
|
|
'';
|
|
|
|
configureFlags = [
|
|
"--with-pgconfig=${postgresql.pg_config}/bin/pg_config"
|
|
"--with-gdalconfig=${gdal}/bin/gdal-config"
|
|
"--with-jsondir=${json_c.dev}"
|
|
"--disable-extension-upgrades-install"
|
|
] ++ lib.optional withSfcgal "--with-sfcgal=${sfcgal}/bin/sfcgal-config";
|
|
|
|
makeFlags = [
|
|
"PERL=${perl}/bin/perl"
|
|
];
|
|
|
|
doCheck = stdenv.hostPlatform.isLinux;
|
|
|
|
preCheck = ''
|
|
substituteInPlace doc/postgis-out.xml --replace-fail "http://docbook.org/xml/5.0/dtd/docbook.dtd" "${docbook5}/xml/dtd/docbook/docbookx.dtd"
|
|
# The test suite hardcodes it to use /tmp.
|
|
export PGIS_REG_TMPDIR="$TMPDIR/pgis_reg"
|
|
'';
|
|
|
|
# create aliases for all commands adding version information
|
|
postInstall = ''
|
|
for prog in $out/bin/*; do # */
|
|
ln -s $prog $prog-${finalAttrs.version}
|
|
done
|
|
|
|
mkdir -p $doc/share/doc/postgis
|
|
mv doc/* $doc/share/doc/postgis/
|
|
'';
|
|
|
|
passthru.tests.extension = postgresqlTestExtension {
|
|
inherit (finalAttrs) finalPackage;
|
|
sql =
|
|
''
|
|
CREATE EXTENSION postgis;
|
|
CREATE EXTENSION postgis_raster;
|
|
CREATE EXTENSION postgis_topology;
|
|
-- st_makepoint goes through c code
|
|
select st_makepoint(1, 1);
|
|
''
|
|
+ lib.optionalString withSfcgal ''
|
|
CREATE EXTENSION postgis_sfcgal;
|
|
CREATE TABLE geometries (
|
|
name varchar,
|
|
geom geometry(PolygonZ) NOT NULL
|
|
);
|
|
|
|
INSERT INTO geometries(name, geom) VALUES
|
|
('planar geom', 'PolygonZ((1 1 0, 1 2 0, 2 2 0, 2 1 0, 1 1 0))'),
|
|
('nonplanar geom', 'PolygonZ((1 1 1, 1 2 -1, 2 2 2, 2 1 0, 1 1 1))');
|
|
|
|
SELECT name from geometries where cg_isplanar(geom);
|
|
'';
|
|
asserts =
|
|
[
|
|
{
|
|
query = "postgis_version()";
|
|
expected = "'${lib.versions.major finalAttrs.version}.${lib.versions.minor finalAttrs.version} USE_GEOS=1 USE_PROJ=1 USE_STATS=1'";
|
|
description = "postgis_version() returns correct values.";
|
|
}
|
|
]
|
|
++ lib.optional withSfcgal {
|
|
query = "postgis_sfcgal_version()";
|
|
expected = "'${sfcgal.version}'";
|
|
description = "postgis_sfcgal_version() returns correct value.";
|
|
};
|
|
};
|
|
|
|
meta = {
|
|
description = "Geographic Objects for PostgreSQL";
|
|
homepage = "https://postgis.net/";
|
|
changelog = "https://git.osgeo.org/gitea/postgis/postgis/raw/tag/${finalAttrs.version}/NEWS";
|
|
license = lib.licenses.gpl2Plus;
|
|
maintainers = with lib.maintainers; [ marcweber ];
|
|
teams = [ lib.teams.geospatial ];
|
|
inherit (postgresql.meta) platforms;
|
|
};
|
|
})
|