commit
8036ee50aa
@ -1,66 +1,62 @@
|
|||||||
{ stdenv, fetchurl, substituteAll
|
{ stdenv, fetchurl, substituteAll
|
||||||
, pkgconfig
|
, pkgconfig
|
||||||
|
, makeWrapper
|
||||||
, cups, zlib, libjpeg, libusb1, pythonPackages, sane-backends, dbus, usbutils
|
, cups, zlib, libjpeg, libusb1, pythonPackages, sane-backends, dbus, usbutils
|
||||||
, net_snmp, polkit
|
, net_snmp, openssl, polkit, nettools
|
||||||
, bash, coreutils, utillinux
|
, bash, coreutils, utillinux
|
||||||
, qtSupport ? true, qt4
|
, qtSupport ? true
|
||||||
, withPlugin ? false
|
, withPlugin ? false
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
|
|
||||||
name = "hplip-${version}";
|
name = "hplip-${version}";
|
||||||
version = "3.15.9";
|
version = "3.16.11";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://sourceforge/hplip/${name}.tar.gz";
|
url = "mirror://sourceforge/hplip/${name}.tar.gz";
|
||||||
sha256 = "0vcxz3gsqcamlzx61xm77h7c769ya8kdhzwafa9w2wvkf3l8zxd1";
|
sha256 = "094vkyr0rjng72m13dgr824cdl7q20x23qjxzih4w7l9njn0rqpn";
|
||||||
};
|
};
|
||||||
|
|
||||||
plugin = fetchurl {
|
plugin = fetchurl {
|
||||||
url = "http://www.openprinting.org/download/printdriver/auxfiles/HP/plugins/${name}-plugin.run";
|
url = "http://www.openprinting.org/download/printdriver/auxfiles/HP/plugins/${name}-plugin.run";
|
||||||
sha256 = "1ahalw83xm8x0h6hljhnkknry1hny9flkrlzcymv8nmwgic0kjgs";
|
sha256 = "1y3wdax2wb6kdd8bi40wl7v9s8ffyjz95bz42sjcpzzddmlhcaxg";
|
||||||
};
|
};
|
||||||
|
|
||||||
hplipState =
|
hplipState = substituteAll {
|
||||||
substituteAll
|
inherit version;
|
||||||
{
|
src = ./hplip.state;
|
||||||
inherit version;
|
};
|
||||||
src = ./hplip.state;
|
|
||||||
};
|
|
||||||
|
|
||||||
hplipPlatforms =
|
hplipPlatforms = {
|
||||||
{
|
"i686-linux" = "x86_32";
|
||||||
"i686-linux" = "x86_32";
|
"x86_64-linux" = "x86_64";
|
||||||
"x86_64-linux" = "x86_64";
|
"armv6l-linux" = "arm32";
|
||||||
"armv6l-linux" = "arm32";
|
"armv7l-linux" = "arm32";
|
||||||
"armv7l-linux" = "arm32";
|
};
|
||||||
};
|
|
||||||
|
|
||||||
hplipArch = hplipPlatforms."${stdenv.system}"
|
hplipArch = hplipPlatforms."${stdenv.system}"
|
||||||
or (throw "HPLIP not supported on ${stdenv.system}");
|
or (throw "HPLIP not supported on ${stdenv.system}");
|
||||||
|
|
||||||
pluginArches = [ "x86_32" "x86_64" ];
|
pluginArches = [ "x86_32" "x86_64" "arm32" ];
|
||||||
|
|
||||||
in
|
in
|
||||||
|
|
||||||
assert withPlugin -> builtins.elem hplipArch pluginArches
|
assert withPlugin -> builtins.elem hplipArch pluginArches
|
||||||
|| throw "HPLIP plugin not supported on ${stdenv.system}";
|
|| throw "HPLIP plugin not supported on ${stdenv.system}";
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
pythonPackages.buildPythonApplication {
|
||||||
inherit name src version;
|
inherit name src;
|
||||||
|
format = "other";
|
||||||
|
|
||||||
buildInputs = [
|
buildInputs = [
|
||||||
libjpeg
|
libjpeg
|
||||||
cups
|
cups
|
||||||
libusb1
|
libusb1
|
||||||
pythonPackages.python
|
|
||||||
pythonPackages.wrapPython
|
|
||||||
sane-backends
|
sane-backends
|
||||||
dbus
|
dbus
|
||||||
net_snmp
|
net_snmp
|
||||||
] ++ stdenv.lib.optionals qtSupport [
|
openssl
|
||||||
qt4
|
|
||||||
];
|
];
|
||||||
|
|
||||||
nativeBuildInputs = [
|
nativeBuildInputs = [
|
||||||
@ -71,13 +67,14 @@ stdenv.mkDerivation {
|
|||||||
dbus
|
dbus
|
||||||
pillow
|
pillow
|
||||||
pygobject2
|
pygobject2
|
||||||
recursivePthLoader
|
|
||||||
reportlab
|
reportlab
|
||||||
usbutils
|
usbutils
|
||||||
] ++ stdenv.lib.optionals qtSupport [
|
] ++ stdenv.lib.optionals qtSupport [
|
||||||
pyqt4
|
pyqt4
|
||||||
];
|
];
|
||||||
|
|
||||||
|
makeWrapperArgs = [ ''--prefix PATH : "${nettools}/bin"'' ];
|
||||||
|
|
||||||
prePatch = ''
|
prePatch = ''
|
||||||
# HPLIP hardcodes absolute paths everywhere. Nuke from orbit.
|
# HPLIP hardcodes absolute paths everywhere. Nuke from orbit.
|
||||||
find . -type f -exec sed -i \
|
find . -type f -exec sed -i \
|
||||||
@ -92,6 +89,7 @@ stdenv.mkDerivation {
|
|||||||
|
|
||||||
preConfigure = ''
|
preConfigure = ''
|
||||||
export configureFlags="$configureFlags
|
export configureFlags="$configureFlags
|
||||||
|
--with-hpppddir=$out/share/cups/model/HP
|
||||||
--with-cupsfilterdir=$out/lib/cups/filter
|
--with-cupsfilterdir=$out/lib/cups/filter
|
||||||
--with-cupsbackenddir=$out/lib/cups/backend
|
--with-cupsbackenddir=$out/lib/cups/backend
|
||||||
--with-icondir=$out/share/applications
|
--with-icondir=$out/share/applications
|
||||||
@ -148,32 +146,30 @@ stdenv.mkDerivation {
|
|||||||
rm $out/etc/udev/rules.d/56-hpmud.rules
|
rm $out/etc/udev/rules.d/56-hpmud.rules
|
||||||
'';
|
'';
|
||||||
|
|
||||||
fixupPhase = ''
|
# The installed executables are just symlinks into $out/share/hplip,
|
||||||
# Wrap the user-facing Python scripts in $out/bin without turning the
|
# but wrapPythonPrograms ignores symlinks. We cannot replace the Python
|
||||||
# ones in $out /share into shell scripts (they need to be importable).
|
# modules in $out/share/hplip with wrapper scripts because they import
|
||||||
# Note that $out/bin contains only symlinks to $out/share.
|
# each other as libraries. Instead, we emulate wrapPythonPrograms by
|
||||||
|
# 1. Calling patchPythonProgram on the original script in $out/share/hplip
|
||||||
|
# 2. Making our own wrapper pointing directly to the original script.
|
||||||
|
dontWrapPythonPrograms = true;
|
||||||
|
preFixup = ''
|
||||||
|
buildPythonPath "$out $pythonPath"
|
||||||
|
|
||||||
for bin in $out/bin/*; do
|
for bin in $out/bin/*; do
|
||||||
py=`readlink -m $bin`
|
py=$(readlink -m $bin)
|
||||||
rm $bin
|
rm $bin
|
||||||
cp $py $bin
|
echo "patching \`$py'..."
|
||||||
wrapPythonProgramsIn $bin "$out $pythonPath"
|
patchPythonScript "$py"
|
||||||
sed -i "s@$(dirname $bin)/[^ ]*@$py@g" $bin
|
echo "wrapping \`$bin'..."
|
||||||
|
makeWrapper "$py" "$bin" \
|
||||||
|
--prefix PATH ':' "$program_PATH" \
|
||||||
|
--set PYTHONNOUSERSITE "true" \
|
||||||
|
$makeWrapperArgs
|
||||||
done
|
done
|
||||||
|
'';
|
||||||
|
|
||||||
# Remove originals. Knows a little too much about wrapPythonProgramsIn.
|
postFixup = ''
|
||||||
rm -f $out/bin/.*-wrapped
|
|
||||||
|
|
||||||
# Merely patching shebangs in $out/share does not cause trouble.
|
|
||||||
for i in $out/share/hplip{,/*}/*.py; do
|
|
||||||
substituteInPlace $i \
|
|
||||||
--replace /usr/bin/python \
|
|
||||||
${pythonPackages.python}/bin/${pythonPackages.python.executable} \
|
|
||||||
--replace "/usr/bin/env python" \
|
|
||||||
${pythonPackages.python}/bin/${pythonPackages.python.executable}
|
|
||||||
done
|
|
||||||
|
|
||||||
wrapPythonProgramsIn $out/lib "$out $pythonPath"
|
|
||||||
|
|
||||||
substituteInPlace $out/etc/hp/hplip.conf --replace /usr $out
|
substituteInPlace $out/etc/hp/hplip.conf --replace /usr $out
|
||||||
'' + stdenv.lib.optionalString (!withPlugin) ''
|
'' + stdenv.lib.optionalString (!withPlugin) ''
|
||||||
# A udev rule to notify users that they need the binary plugin.
|
# A udev rule to notify users that they need the binary plugin.
|
||||||
@ -192,6 +188,6 @@ stdenv.mkDerivation {
|
|||||||
then licenses.unfree
|
then licenses.unfree
|
||||||
else with licenses; [ mit bsd2 gpl2Plus ];
|
else with licenses; [ mit bsd2 gpl2Plus ];
|
||||||
platforms = [ "i686-linux" "x86_64-linux" "armv6l-linux" "armv7l-linux" ];
|
platforms = [ "i686-linux" "x86_64-linux" "armv6l-linux" "armv7l-linux" ];
|
||||||
maintainers = with maintainers; [ jgeerds nckx ];
|
maintainers = with maintainers; [ jgeerds ttuegel ];
|
||||||
};
|
};
|
||||||
}
|
}
|
@ -4,23 +4,23 @@
|
|||||||
, cups, zlib, libjpeg, libusb1, pythonPackages, sane-backends, dbus, usbutils
|
, cups, zlib, libjpeg, libusb1, pythonPackages, sane-backends, dbus, usbutils
|
||||||
, net_snmp, openssl, polkit, nettools
|
, net_snmp, openssl, polkit, nettools
|
||||||
, bash, coreutils, utillinux
|
, bash, coreutils, utillinux
|
||||||
, qtSupport ? true
|
, withQt5 ? true
|
||||||
, withPlugin ? false
|
, withPlugin ? false
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
|
|
||||||
name = "hplip-${version}";
|
name = "hplip-${version}";
|
||||||
version = "3.16.11";
|
version = "3.17.9";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://sourceforge/hplip/${name}.tar.gz";
|
url = "mirror://sourceforge/hplip/${name}.tar.gz";
|
||||||
sha256 = "094vkyr0rjng72m13dgr824cdl7q20x23qjxzih4w7l9njn0rqpn";
|
sha256 = "0y46jjq8jdfk9m4vjq55h8yggibvqbi9rl08vni7vbhxym1diamj";
|
||||||
};
|
};
|
||||||
|
|
||||||
plugin = fetchurl {
|
plugin = fetchurl {
|
||||||
url = "http://www.openprinting.org/download/printdriver/auxfiles/HP/plugins/${name}-plugin.run";
|
url = "http://hplipopensource.com/hplip-web/plugin/${name}-plugin.run";
|
||||||
sha256 = "1y3wdax2wb6kdd8bi40wl7v9s8ffyjz95bz42sjcpzzddmlhcaxg";
|
sha256 = "10z8vzwcwmwni7s4j9xp0fa7l4lwrhl4kp450dga3fj0cck1gxwq";
|
||||||
};
|
};
|
||||||
|
|
||||||
hplipState = substituteAll {
|
hplipState = substituteAll {
|
||||||
@ -69,8 +69,8 @@ pythonPackages.buildPythonApplication {
|
|||||||
pygobject2
|
pygobject2
|
||||||
reportlab
|
reportlab
|
||||||
usbutils
|
usbutils
|
||||||
] ++ stdenv.lib.optionals qtSupport [
|
] ++ stdenv.lib.optionals withQt5 [
|
||||||
pyqt4
|
pyqt5
|
||||||
];
|
];
|
||||||
|
|
||||||
makeWrapperArgs = [ ''--prefix PATH : "${nettools}/bin"'' ];
|
makeWrapperArgs = [ ''--prefix PATH : "${nettools}/bin"'' ];
|
||||||
@ -188,6 +188,6 @@ pythonPackages.buildPythonApplication {
|
|||||||
then licenses.unfree
|
then licenses.unfree
|
||||||
else with licenses; [ mit bsd2 gpl2Plus ];
|
else with licenses; [ mit bsd2 gpl2Plus ];
|
||||||
platforms = [ "i686-linux" "x86_64-linux" "armv6l-linux" "armv7l-linux" ];
|
platforms = [ "i686-linux" "x86_64-linux" "armv6l-linux" "armv7l-linux" ];
|
||||||
maintainers = with maintainers; [ jgeerds nckx ];
|
maintainers = with maintainers; [ jgeerds ttuegel ];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -18887,9 +18887,9 @@ with pkgs;
|
|||||||
|
|
||||||
hplipWithPlugin = hplip.override { withPlugin = true; };
|
hplipWithPlugin = hplip.override { withPlugin = true; };
|
||||||
|
|
||||||
hplip_3_15_9 = callPackage ../misc/drivers/hplip/3.15.9.nix { };
|
hplip_3_16_11 = callPackage ../misc/drivers/hplip/3.16.11.nix { };
|
||||||
|
|
||||||
hplipWithPlugin_3_15_9 = hplip_3_15_9.override { withPlugin = true; };
|
hplipWithPlugin_3_16_11 = hplip.override { withPlugin = true; };
|
||||||
|
|
||||||
epkowa = callPackage ../misc/drivers/epkowa { };
|
epkowa = callPackage ../misc/drivers/epkowa { };
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user