mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-11-11 04:02:55 +03:00
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
|
||||
, 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 {
|
||||
name = "gpsd-2.95";
|
||||
name = "gpsd-3.10";
|
||||
|
||||
src = fetchurl {
|
||||
url = "http://download.berlios.de/gpsd/${name}.tar.gz";
|
||||
sha256 = "1bjhyjg561kwp6zc2wg58njdvpnsj5yaa2slz8g3ga1176jl68w3";
|
||||
url = "http://download-mirror.savannah.gnu.org/releases/gpsd/${name}.tar.gz";
|
||||
sha256 = "0823hl5zgwnbgm0fq3i4z34lv76cpj0k6m0zjiygiyrxrz0w4vvh";
|
||||
};
|
||||
|
||||
nativeBuildInputs = [ makeWrapper pkgconfig docbook_xml_dtd_412 docbook_xsl
|
||||
xmlto bc pythonPackages.wrapPython ];
|
||||
nativeBuildInputs = [
|
||||
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
|
||||
libXpm libXaw libXext libxslt libusb1 ];
|
||||
patches = [
|
||||
./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;
|
||||
|
||||
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";
|
||||
|
||||
meta = {
|
||||
|
Loading…
Reference in New Issue
Block a user