xpra: modernize

Port to Python 3 and GTK+ 3.
This commit is contained in:
Jan Tojnar 2018-09-13 17:43:31 +02:00
parent 2e38f5fc6e
commit 3b685ee517
No known key found for this signature in database
GPG Key ID: 7FAB2A15F7A607A4
2 changed files with 66 additions and 31 deletions

View File

@ -1,6 +1,6 @@
{ stdenv, lib, fetchurl, callPackage, python2Packages, pkgconfig { stdenv, lib, fetchurl, callPackage, substituteAll, python3, pkgconfig
, xorg, gtk2, glib, pango, cairo, gdk_pixbuf, atk , xorg, gtk3, glib, pango, cairo, gdk_pixbuf, atk
, makeWrapper, xorgserver, getopt, xauth, utillinux, which , wrapGAppsHook, xorgserver, getopt, xauth, utillinux, which
, ffmpeg, x264, libvpx, libwebp , ffmpeg, x264, libvpx, libwebp
, libfakeXinerama , libfakeXinerama
, gst_all_1, pulseaudio, gobjectIntrospection , gst_all_1, pulseaudio, gobjectIntrospection
@ -9,7 +9,7 @@
with lib; with lib;
let let
inherit (python2Packages) cython buildPythonApplication; inherit (python3.pkgs) cython buildPythonApplication;
xf86videodummy = callPackage ./xf86videodummy { }; xf86videodummy = callPackage ./xf86videodummy { };
in buildPythonApplication rec { in buildPythonApplication rec {
@ -21,7 +21,14 @@ in buildPythonApplication rec {
sha256 = "1azvvddjfq7lb5kmbn0ilgq2nf7pmymsc3b9lhbjld6w156qdv01"; sha256 = "1azvvddjfq7lb5kmbn0ilgq2nf7pmymsc3b9lhbjld6w156qdv01";
}; };
nativeBuildInputs = [ pkgconfig ]; patches = [
(substituteAll {
src = ./fix-paths.patch;
inherit (xorg) xkeyboardconfig;
})
];
nativeBuildInputs = [ pkgconfig gobjectIntrospection wrapGAppsHook ];
buildInputs = [ buildInputs = [
cython cython
@ -30,11 +37,10 @@ in buildPythonApplication rec {
xorg.xproto xorg.fixesproto xorg.libXtst xorg.libXfixes xorg.libXcomposite xorg.libXdamage xorg.xproto xorg.fixesproto xorg.libXtst xorg.libXfixes xorg.libXcomposite xorg.libXdamage
xorg.libXrandr xorg.libxkbfile xorg.libXrandr xorg.libxkbfile
pango cairo gdk_pixbuf atk gtk2 glib pango cairo gdk_pixbuf atk gtk3 glib
ffmpeg libvpx x264 libwebp ffmpeg libvpx x264 libwebp
gobjectIntrospection
gst_all_1.gstreamer gst_all_1.gstreamer
gst_all_1.gst-plugins-base gst_all_1.gst-plugins-base
gst_all_1.gst-plugins-good gst_all_1.gst-plugins-good
@ -42,38 +48,34 @@ in buildPythonApplication rec {
gst_all_1.gst-libav gst_all_1.gst-libav
pam pam
makeWrapper
]; ];
propagatedBuildInputs = with python2Packages; [ propagatedBuildInputs = with python3.pkgs; [
pillow pygtk pygobject2 rencode pycrypto cryptography pycups lz4 dbus-python pillow rencode pycrypto cryptography pycups lz4 dbus-python
netifaces numpy websockify pygobject3 gst-python pam netifaces numpy websockify pygobject3 pycairo gst-python pam
]; ];
preBuild = '' NIX_CFLAGS_COMPILE = [
export NIX_CFLAGS_COMPILE="$NIX_CFLAGS_COMPILE $(pkg-config --cflags gtk+-2.0) $(pkg-config --cflags pygtk-2.0) $(pkg-config --cflags xtst)" # error: 'import_cairo' defined but not used
substituteInPlace xpra/server/auth/pam_auth.py --replace "/lib/libpam.so.1" "${pam}/lib/libpam.so" "-Wno-error=unused-function"
substituteInPlace xpra/x11/bindings/keyboard_bindings.pyx --replace "/usr/share/X11/xkb" "${xorg.xkeyboardconfig}/share/X11/xkb" ];
'';
setupPyBuildFlags = ["--with-Xdummy" "--without-strict"];
postInstall = '' setupPyBuildFlags = [
wrapProgram $out/bin/xpra \ "--with-Xdummy"
--set XPRA_INSTALL_PREFIX "$out" \ "--without-strict"
--set GI_TYPELIB_PATH "$GI_TYPELIB_PATH" \ "--with-gtk3"
--set GST_PLUGIN_SYSTEM_PATH_1_0 "$GST_PLUGIN_SYSTEM_PATH_1_0" \ "--without-gtk2"
--prefix LD_LIBRARY_PATH : ${libfakeXinerama}/lib \ ];
preFixup = ''
gappsWrapperArgs+=(
--set XPRA_INSTALL_PREFIX "$out"
--prefix LD_LIBRARY_PATH : ${libfakeXinerama}/lib
--prefix PATH : ${stdenv.lib.makeBinPath [ getopt xorgserver xauth which utillinux pulseaudio ]} --prefix PATH : ${stdenv.lib.makeBinPath [ getopt xorgserver xauth which utillinux pulseaudio ]}
)
''; '';
preCheck = "exit 0"; doCheck = false;
#TODO: replace postInstall with postFixup to avoid double wrapping of xpra; needs more work though
#postFixup = ''
# sed -i '3iexport FONTCONFIG_FILE="${fontsConf}"' $out/bin/xpra
# sed -i '4iexport PATH=${stdenv.lib.makeBinPath [ getopt xorgserver xauth which utillinux ]}\${PATH:+:}\$PATH' $out/bin/xpra
#'';
passthru = { inherit xf86videodummy; }; passthru = { inherit xf86videodummy; };

View File

@ -0,0 +1,33 @@
--- a/setup.py
+++ b/setup.py
@@ -1885,7 +1885,7 @@
if OSX:
pycairo = "py3cairo"
else:
- pycairo = "pycairo"
+ pycairo = "py3cairo"
cython_add(Extension("xpra.client.gtk3.cairo_workaround",
["xpra/client/gtk3/cairo_workaround.pyx"],
**pkgconfig(pycairo)
--- a/xpra/client/gtk3/cairo_workaround.pyx
+++ b/xpra/client/gtk3/cairo_workaround.pyx
@@ -65,7 +65,7 @@
void cairo_surface_flush (cairo_surface_t *surface)
void cairo_surface_mark_dirty (cairo_surface_t *surface)
-cdef extern from "pycairo/pycairo.h":
+cdef extern from "py3cairo.h":
ctypedef struct Pycairo_CAPI_t:
pass
ctypedef struct PycairoSurface:
--- a/xpra/x11/bindings/keyboard_bindings.pyx
+++ b/xpra/x11/bindings/keyboard_bindings.pyx
@@ -19,7 +19,7 @@
DEF PATH_MAX = 1024
DEF DFLT_XKB_RULES_FILE = "base"
-DEF DFLT_XKB_CONFIG_ROOT = "/usr/share/X11/xkb"
+DEF DFLT_XKB_CONFIG_ROOT = "@xkeyboardconfig@/share/X11/xkb"
###################################
# Headers, python magic