guix-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[bug#56803] [PATCH 3/6] gnu: Add python-mpv.


From: Tomasz Jeneralczyk
Subject: [bug#56803] [PATCH 3/6] gnu: Add python-mpv.
Date: Wed, 27 Jul 2022 21:00:25 +0200

Author states that the license of the library is inherited from libmpv,
which can be either GPLv2 or LPGLv2.1. That's why the package's license is
set to be the same as mpv's.

One of the tests had to be disabled because it would neither fail or pass,
blocking all other tests from running and the package from finishing its build
process. I have no clue on why it happens.

Rarely some tests fail without any apparent reason. This is possibly related
to: https://github.com/jaseg/python-mpv/issues/209

Also add copyright.

* gnu/packages/python-xyz.scm (python-mpv): Add variable.
---
 gnu/packages/python-xyz.scm | 62 +++++++++++++++++++++++++++++++++++++
 1 file changed, 62 insertions(+)

diff --git a/gnu/packages/python-xyz.scm b/gnu/packages/python-xyz.scm
index ac7c0d6066..5bc40ecaea 100644
--- a/gnu/packages/python-xyz.scm
+++ b/gnu/packages/python-xyz.scm
@@ -124,6 +124,7 @@
 ;;; Copyright © 2022 Artyom V. Poptsov <poptsov.artyom@gmail.com>
 ;;; Copyright © 2022 Paul A. Patience <paul@apatience.com>
 ;;; Copyright © 2022 Jean-Pierre De Jesus DIAZ <me@jeandudey.tech>
+;;; Copyright © 2022 Tomasz Jeneralczyk <tj@schwi.pl>
 ;;;
 ;;; This file is part of GNU Guix.
 ;;;
@@ -30203,3 +30204,64 @@ (define-public python-bsdiff4
 binary diff utility.  It also provides two command-line tools, @code{bsdiff4}
 and @code{bspatch4}.")
     (license license:bsd-2)))
+
+(define-public python-mpv
+  (package
+    (name "python-mpv")
+    (version "v1.0.1")
+    (source
+     (origin
+       ;; python-mpv from pypi does not include the tests directory.
+       (method git-fetch)
+       (uri (git-reference
+             (url "https://github.com/jaseg/python-mpv";)
+             (commit version)))
+       (file-name (git-file-name name version))
+       (sha256
+        (base32
+         "10w6j3n62ap45sf6q487kz8z6g58sha37i14fa2hhng794z7a8jh"))
+       (modules '((guix build utils)))
+       (snippet
+        (with-extensions (list mpv)
+          #~(begin
+              ;; Without an absolute path it is not able find and
+              ;; load the libmpv library.
+              (substitute* "mpv.py"
+                (("(sofile = )(.*)" _ pre post)
+                 (string-append pre "\"" #$mpv "/lib/\" + " post)))
+              ;; One of the tests never completes, so neutering it using
+              ;; early return allows other test to run without issue.
+              (substitute* "tests/test_mpv.py"
+                ;; Note the typo in "prooperty" - this was fixed later in
+                ;; upstream but has no effect on whether the tests hangs or 
not.
+                (("test_wait_for_prooperty_event_overflow.*" line)
+                 ;; The long whitespace between \n and return is to match the
+                 ;; identation level, which is significant in python.
+                 (string-append line "\n        return\n"))))))))
+    (build-system python-build-system)
+    (arguments
+     (list #:phases
+           (with-imported-modules '((guix build utils))
+             #~(modify-phases %standard-phases
+                 (add-before 'check 'prepare-for-tests
+                   (lambda _
+                     ;; Fontconfig throws errors when it has no cache dir to 
use.
+                     (setenv "XDG_CACHE_HOME" (getcwd))
+                     ;; Some tests fail without a writable and readable HOME.
+                     (setenv "HOME" (getcwd))))))))
+    (native-inputs
+     (list python-xvfbwrapper)) ; needed for tests only
+    (inputs (list mpv))
+    (propagated-inputs (list python-pillow)) ; for raw screenshots
+    (home-page "https://github.com/jaseg/python-mpv";)
+    (synopsis "Python interface to the mpv media player")
+    (description
+     "python-mpv is a ctypes-based python interface to the mpv media player.
+It gives you more or less full control of all features of the player, just
+as the lua interface does.")
+    ;; From the project's README:
+    ;;  python-mpv inherits the underlying libmpv's license, which can be 
either
+    ;;  GPLv2 or later (default) or LGPLv2.1 or later. For details, see the mpv
+    ;;  copyright page.
+    (license (package-license mpv))))
+
-- 
2.37.1






reply via email to

[Prev in Thread] Current Thread [Next in Thread]