gpsd: update 2.95 -> 3.10
Build system is changed, gpsd uses scons now. The expressions needs some more work, TODO comments added. (xgps didn't work before this change either.) I added an option for the gpsd group, which is set to upstream default: "dialout". Note that our default gpsd user is "gpsd", while upstream uses "nobody" by default.
This commit is contained in:
parent
f7006116b3
commit
c54b9b7b60
@ -0,0 +1,25 @@
|
|||||||
|
From d7e56abcae8bcb85dc935e94418a2f0e9956941b Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Bj=C3=B8rn=20Forsman?= <bjorn.forsman@gmail.com>
|
||||||
|
Date: Mon, 17 Feb 2014 20:52:50 +0000
|
||||||
|
Subject: [PATCH 1/2] Import LD_LIBRARY_PATH to allow running 'scons check'
|
||||||
|
without 'chrpath'
|
||||||
|
|
||||||
|
---
|
||||||
|
SConstruct | 1 +
|
||||||
|
1 file changed, 1 insertion(+)
|
||||||
|
|
||||||
|
diff --git a/SConstruct b/SConstruct
|
||||||
|
index 14e2f59..86b94bc 100644
|
||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -215,6 +215,7 @@ import_env = (
|
||||||
|
'PKG_CONFIG_LIBDIR', # Pass more environment variables to pkg-config (required for crossbuilds)
|
||||||
|
'STAGING_DIR', # Required by the OpenWRT and CeroWrt builds.
|
||||||
|
'STAGING_PREFIX', # Required by the OpenWRT and CeroWrt builds.
|
||||||
|
+ 'LD_LIBRARY_PATH', # Allows running 'scons check' without 'chrpath'
|
||||||
|
)
|
||||||
|
envs = {}
|
||||||
|
for var in import_env:
|
||||||
|
--
|
||||||
|
1.9.0
|
||||||
|
|
@ -0,0 +1,28 @@
|
|||||||
|
From aed93b6ada5b9b76b85d11d9bad732ca005295af Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Bj=C3=B8rn=20Forsman?= <bjorn.forsman@gmail.com>
|
||||||
|
Date: Sat, 15 Mar 2014 15:08:01 +0100
|
||||||
|
Subject: [PATCH 2/2] Import XML_CATALOG_FILES to be able to validate the
|
||||||
|
manual
|
||||||
|
|
||||||
|
In nixos/nixpkgs, 'xmlto' depends on $XML_CATALOG_FILES to be able to
|
||||||
|
validate XML documents. Because without it, it'll try to go online to
|
||||||
|
download DTD's and builders don't have network access...
|
||||||
|
---
|
||||||
|
SConstruct | 1 +
|
||||||
|
1 file changed, 1 insertion(+)
|
||||||
|
|
||||||
|
diff --git a/SConstruct b/SConstruct
|
||||||
|
index 86b94bc..a0b3d25 100644
|
||||||
|
--- a/SConstruct
|
||||||
|
+++ b/SConstruct
|
||||||
|
@@ -216,6 +216,7 @@ import_env = (
|
||||||
|
'STAGING_DIR', # Required by the OpenWRT and CeroWrt builds.
|
||||||
|
'STAGING_PREFIX', # Required by the OpenWRT and CeroWrt builds.
|
||||||
|
'LD_LIBRARY_PATH', # Allows running 'scons check' without 'chrpath'
|
||||||
|
+ 'XML_CATALOG_FILES', # Enables validating the manual with 'xmlto' using nix build system
|
||||||
|
)
|
||||||
|
envs = {}
|
||||||
|
for var in import_env:
|
||||||
|
--
|
||||||
|
1.9.0
|
||||||
|
|
@ -1,28 +1,61 @@
|
|||||||
{ fetchurl, stdenv, pythonPackages, pkgconfig, dbus, dbus_glib
|
{ fetchurl, stdenv, scons, pythonFull, pkgconfig, dbus, dbus_glib
|
||||||
, ncurses, libX11, libXt, libXpm, libXaw, libXext, makeWrapper
|
, ncurses, libX11, libXt, libXpm, libXaw, libXext, makeWrapper
|
||||||
, libusb1, docbook_xml_dtd_412, docbook_xsl, bc
|
, libusb1, docbook_xml_dtd_412, docbook_xsl, bc
|
||||||
, libxslt, xmlto, gpsdUser ? "gpsd" }:
|
, libxslt, xmlto, gpsdUser ? "gpsd", gpsdGroup ? "dialout"
|
||||||
|
}:
|
||||||
|
|
||||||
|
# TODO: the 'xgps' program doesn't work: "ImportError: No module named gobject"
|
||||||
|
# TODO: put the X11 deps behind a guiSupport parameter for headless support
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "gpsd-2.95";
|
name = "gpsd-3.10";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "http://download.berlios.de/gpsd/${name}.tar.gz";
|
url = "http://download-mirror.savannah.gnu.org/releases/gpsd/${name}.tar.gz";
|
||||||
sha256 = "1bjhyjg561kwp6zc2wg58njdvpnsj5yaa2slz8g3ga1176jl68w3";
|
sha256 = "0823hl5zgwnbgm0fq3i4z34lv76cpj0k6m0zjiygiyrxrz0w4vvh";
|
||||||
};
|
};
|
||||||
|
|
||||||
nativeBuildInputs = [ makeWrapper pkgconfig docbook_xml_dtd_412 docbook_xsl
|
nativeBuildInputs = [
|
||||||
xmlto bc pythonPackages.wrapPython ];
|
scons makeWrapper pkgconfig docbook_xml_dtd_412 docbook_xsl xmlto bc
|
||||||
|
pythonFull
|
||||||
|
];
|
||||||
|
|
||||||
pythonPath = [ pythonPackages.curses ];
|
buildInputs = [
|
||||||
|
pythonFull dbus dbus_glib ncurses libX11 libXt libXpm libXaw libXext
|
||||||
|
libxslt libusb1
|
||||||
|
];
|
||||||
|
|
||||||
buildInputs = [ pythonPackages.python dbus dbus_glib ncurses libX11 libXt
|
patches = [
|
||||||
libXpm libXaw libXext libxslt libusb1 ];
|
./0001-Import-LD_LIBRARY_PATH-to-allow-running-scons-check-.patch
|
||||||
|
./0002-Import-XML_CATALOG_FILES-to-be-able-to-validate-the-.patch
|
||||||
|
];
|
||||||
|
|
||||||
configureFlags = "--enable-static --enable-dbus --enable-gpsd-user=${gpsdUser}";
|
# - leapfetch=no disables going online at build time to fetch leap-seconds
|
||||||
|
# info. See <gpsd-src>/build.txt for more info.
|
||||||
|
# - chrpath=no stops the build from using 'chrpath' (which we don't have).
|
||||||
|
# 'chrpath' is used to be able to run the tests from the source tree, but
|
||||||
|
# we use $LD_LIBRARY_PATH instead.
|
||||||
|
buildPhase = ''
|
||||||
|
mkdir -p "$out"
|
||||||
|
sed -e "s|python_lib_dir = .*|python_lib_dir = \"$out/lib/${pythonFull.python.libPrefix}/site-packages\"|" -i SConstruct
|
||||||
|
scons prefix="$out" leapfetch=no gpsd_user=${gpsdUser} gpsd_group=${gpsdGroup} \
|
||||||
|
systemd=yes udevdir="$out/lib/udev" chrpath=no
|
||||||
|
'';
|
||||||
|
|
||||||
doCheck = true;
|
doCheck = true;
|
||||||
|
|
||||||
|
checkPhase = ''
|
||||||
|
export LD_LIBRARY_PATH="$PWD"
|
||||||
|
scons check
|
||||||
|
'';
|
||||||
|
|
||||||
|
# TODO: the udev rules file and the hotplug script need fixes to work on NixOS
|
||||||
|
installPhase = ''
|
||||||
|
scons install
|
||||||
|
mkdir -p "$out/lib/udev/rules.d"
|
||||||
|
scons udev-install
|
||||||
|
'';
|
||||||
|
|
||||||
postInstall = "wrapPythonPrograms";
|
postInstall = "wrapPythonPrograms";
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user