Skip to content

Commit

Permalink
Merge pull request #31601 from LumiGuide/release-17.09-fix-hplip
Browse files Browse the repository at this point in the history
Fix hplip on release-17.09 by upgrading
  • Loading branch information
Thomas Tuegel committed Nov 13, 2017
2 parents c19136c + 23b1bdd commit 8ac6c47
Show file tree
Hide file tree
Showing 3 changed files with 203 additions and 6 deletions.
193 changes: 193 additions & 0 deletions pkgs/misc/drivers/hplip/3.16.11.nix
@@ -0,0 +1,193 @@
{ stdenv, fetchurl, substituteAll
, pkgconfig
, makeWrapper
, cups, zlib, libjpeg, libusb1, pythonPackages, sane-backends, dbus, usbutils
, net_snmp, openssl, polkit, nettools
, bash, coreutils, utillinux
, qtSupport ? true
, withPlugin ? false
}:

let

name = "hplip-${version}";
version = "3.16.11";

src = fetchurl {
url = "mirror://sourceforge/hplip/${name}.tar.gz";
sha256 = "094vkyr0rjng72m13dgr824cdl7q20x23qjxzih4w7l9njn0rqpn";
};

plugin = fetchurl {
url = "http://www.openprinting.org/download/printdriver/auxfiles/HP/plugins/${name}-plugin.run";
sha256 = "1y3wdax2wb6kdd8bi40wl7v9s8ffyjz95bz42sjcpzzddmlhcaxg";
};

hplipState = substituteAll {
inherit version;
src = ./hplip.state;
};

hplipPlatforms = {
"i686-linux" = "x86_32";
"x86_64-linux" = "x86_64";
"armv6l-linux" = "arm32";
"armv7l-linux" = "arm32";
};

hplipArch = hplipPlatforms."${stdenv.system}"
or (throw "HPLIP not supported on ${stdenv.system}");

pluginArches = [ "x86_32" "x86_64" "arm32" ];

in

assert withPlugin -> builtins.elem hplipArch pluginArches
|| throw "HPLIP plugin not supported on ${stdenv.system}";

pythonPackages.buildPythonApplication {
inherit name src;
format = "other";

buildInputs = [
libjpeg
cups
libusb1
sane-backends
dbus
net_snmp
openssl
];

nativeBuildInputs = [
pkgconfig
];

pythonPath = with pythonPackages; [
dbus
pillow
pygobject2
reportlab
usbutils
] ++ stdenv.lib.optionals qtSupport [
pyqt4
];

makeWrapperArgs = [ ''--prefix PATH : "${nettools}/bin"'' ];

prePatch = ''
# HPLIP hardcodes absolute paths everywhere. Nuke from orbit.
find . -type f -exec sed -i \
-e s,/etc/hp,$out/etc/hp, \
-e s,/etc/sane.d,$out/etc/sane.d, \
-e s,/usr/include/libusb-1.0,${libusb1.dev}/include/libusb-1.0, \
-e s,/usr/share/hal/fdi/preprobe/10osvendor,$out/share/hal/fdi/preprobe/10osvendor, \
-e s,/usr/lib/systemd/system,$out/lib/systemd/system, \
-e s,/var/lib/hp,$out/var/lib/hp, \
{} +
'';

preConfigure = ''
export configureFlags="$configureFlags
--with-hpppddir=$out/share/cups/model/HP
--with-cupsfilterdir=$out/lib/cups/filter
--with-cupsbackenddir=$out/lib/cups/backend
--with-icondir=$out/share/applications
--with-systraydir=$out/xdg/autostart
--with-mimedir=$out/etc/cups
--enable-policykit
"
export makeFlags="
halpredir=$out/share/hal/fdi/preprobe/10osvendor
rulesdir=$out/etc/udev/rules.d
policykit_dir=$out/share/polkit-1/actions
policykit_dbus_etcdir=$out/etc/dbus-1/system.d
policykit_dbus_sharedir=$out/share/dbus-1/system-services
hplip_confdir=$out/etc/hp
hplip_statedir=$out/var/lib/hp
"
'';

enableParallelBuilding = true;

postInstall = stdenv.lib.optionalString withPlugin ''
sh ${plugin} --noexec --keep
cd plugin_tmp
cp plugin.spec $out/share/hplip/
mkdir -p $out/share/hplip/data/firmware
cp *.fw.gz $out/share/hplip/data/firmware
mkdir -p $out/share/hplip/data/plugins
cp license.txt $out/share/hplip/data/plugins
mkdir -p $out/share/hplip/prnt/plugins
for plugin in lj hbpl1; do
cp $plugin-${hplipArch}.so $out/share/hplip/prnt/plugins
ln -s $out/share/hplip/prnt/plugins/$plugin-${hplipArch}.so \
$out/share/hplip/prnt/plugins/$plugin.so
done
mkdir -p $out/share/hplip/scan/plugins
for plugin in bb_soap bb_marvell bb_soapht fax_marvell; do
cp $plugin-${hplipArch}.so $out/share/hplip/scan/plugins
ln -s $out/share/hplip/scan/plugins/$plugin-${hplipArch}.so \
$out/share/hplip/scan/plugins/$plugin.so
done
mkdir -p $out/var/lib/hp
cp ${hplipState} $out/var/lib/hp/hplip.state
mkdir -p $out/etc/sane.d/dll.d
mv $out/etc/sane.d/dll.conf $out/etc/sane.d/dll.d/hpaio.conf
rm $out/etc/udev/rules.d/56-hpmud.rules
'';

# The installed executables are just symlinks into $out/share/hplip,
# but wrapPythonPrograms ignores symlinks. We cannot replace the Python
# modules in $out/share/hplip with wrapper scripts because they import
# 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
py=$(readlink -m $bin)
rm $bin
echo "patching \`$py'..."
patchPythonScript "$py"
echo "wrapping \`$bin'..."
makeWrapper "$py" "$bin" \
--prefix PATH ':' "$program_PATH" \
--set PYTHONNOUSERSITE "true" \
$makeWrapperArgs
done
'';

postFixup = ''
substituteInPlace $out/etc/hp/hplip.conf --replace /usr $out
'' + stdenv.lib.optionalString (!withPlugin) ''
# A udev rule to notify users that they need the binary plugin.
# Needs a lot of patching but might save someone a bit of confusion:
substituteInPlace $out/etc/udev/rules.d/56-hpmud.rules \
--replace {,${bash}}/bin/sh \
--replace {/usr,${coreutils}}/bin/nohup \
--replace {,${utillinux}/bin/}logger \
--replace {/usr,$out}/bin
'';

meta = with stdenv.lib; {
description = "Print, scan and fax HP drivers for Linux";
homepage = http://hplipopensource.com/;
license = if withPlugin
then licenses.unfree
else with licenses; [ mit bsd2 gpl2Plus ];
platforms = [ "i686-linux" "x86_64-linux" "armv6l-linux" "armv7l-linux" ];
maintainers = with maintainers; [ jgeerds nckx ];
};
}
12 changes: 6 additions & 6 deletions pkgs/misc/drivers/hplip/default.nix
Expand Up @@ -4,23 +4,23 @@
, cups, zlib, libjpeg, libusb1, pythonPackages, sane-backends, dbus, usbutils
, net_snmp, openssl, polkit, nettools
, bash, coreutils, utillinux
, qtSupport ? true
, withQt5 ? true
, withPlugin ? false
}:

let

name = "hplip-${version}";
version = "3.16.11";
version = "3.17.10";

src = fetchurl {
url = "mirror://sourceforge/hplip/${name}.tar.gz";
sha256 = "094vkyr0rjng72m13dgr824cdl7q20x23qjxzih4w7l9njn0rqpn";
sha256 = "0v27hg856b5z2rilczcbfgz8ksxn0n810g1glac3mxkj8qbl8wqg";
};

plugin = fetchurl {
url = "http://www.openprinting.org/download/printdriver/auxfiles/HP/plugins/${name}-plugin.run";
sha256 = "1y3wdax2wb6kdd8bi40wl7v9s8ffyjz95bz42sjcpzzddmlhcaxg";
sha256 = "07am3dnl0ipgfswz5wndprryljh9rqbfhq7mm4d4yyj3bdnnzlig";
};

hplipState = substituteAll {
Expand Down Expand Up @@ -69,8 +69,8 @@ pythonPackages.buildPythonApplication {
pygobject2
reportlab
usbutils
] ++ stdenv.lib.optionals qtSupport [
pyqt4
] ++ stdenv.lib.optionals withQt5 [
pyqt5
];

makeWrapperArgs = [ ''--prefix PATH : "${nettools}/bin"'' ];
Expand Down
4 changes: 4 additions & 0 deletions pkgs/top-level/all-packages.nix
Expand Up @@ -18887,6 +18887,10 @@ with pkgs;

hplipWithPlugin = hplip.override { withPlugin = true; };

hplip_3_16_11 = callPackage ../misc/drivers/hplip/3.16.11.nix { };

hplipWithPlugin_3_16_11 = hplip.override { withPlugin = true; };

epkowa = callPackage ../misc/drivers/epkowa { };

illum = callPackage ../tools/system/illum { };
Expand Down

0 comments on commit 8ac6c47

Please sign in to comment.