aboutsummaryrefslogtreecommitdiff
path: root/emms-player-xine.el
blob: 98c3c282e8b5c339e674a76aee3e309e9db0b43c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
;;; emms-player-xine.el --- xine support for EMMS  -*- lexical-binding: t; -*-

;; Copyright (C) 2007, 2008, 2009 Free Software Foundation, Inc.

;; Author: Tassilo Horn <tassilo@member.fsf.org>

;; This file is part of EMMS.

;; EMMS is free software; you can redistribute it and/or
;; modify it under the terms of the GNU General Public License
;; as published by the Free Software Foundation; either version 3
;; of the License, or (at your option) any later version.

;; EMMS is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;; GNU General Public License for more details.

;; You should have received a copy of the GNU General Public License
;; along with EMMS; if not, write to the Free Software Foundation,
;; Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.

;;; Commentary:

;; This provides a player that uses xine. It supports pause and
;; seeking.

;;; Code:

;; TODO: The video window cannot be disabled. I asked on
;; gmane.comp.video.xine.user (<87y7ohqcbq.fsf@baldur.tsdh.de>)...

;; TODO: Implement seek-to with "SetPositionX%\n" where X is in {0,10,..,90}

(require 'emms-player-simple)

(define-emms-simple-player xine '(file url)
  (concat "\\`\\(http[s]?\\|mms\\)://\\|"
          (emms-player-simple-regexp
           "ogg" "mp3" "wav" "mpg" "mpeg" "wmv" "wma"
           "mov" "avi" "divx" "ogm" "ogv" "asf" "mkv"
           "rm" "rmvb" "mp4" "flac" "vob"))
  "xine" "--no-gui" "--no-logo" "--no-splash" "--no-reload" "--stdctl")

(emms-player-set emms-player-xine
                 'pause
                 'emms-player-xine-pause)

;;; Pause is also resume for xine
(emms-player-set emms-player-xine
                 'resume
                 nil)

(emms-player-set emms-player-xine
                 'seek
                 'emms-player-xine-seek)

(defun emms-player-xine-pause ()
  "Depends on xine's --stdctl mode."
  (process-send-string
   emms-player-simple-process-name "pause\n"))

(defun emms-player-xine-seek (secs)
  "Depends on xine's --stdctl mode."
  ;; xine-ui's stdctl supports only seeking forward/backward in 7/15/30 and 60
  ;; second steps, so we take the value that is nearest to SECS.
  (let ((s (emms-nearest-value secs '(-60 -30 -15 -7 7 15 30 60))))
    (when (/= s secs)
      (message (concat "EMMS: Xine only supports seeking for [+/-] 7/15/30/60 "
                       "seconds, so we seeked %d seconds") s))
    (process-send-string
     emms-player-simple-process-name
     (if (< s 0)
         (format "SeekRelative%d\n" s)
       (format "SeekRelative+%d\n" s)))))

(defun emms-nearest-value (val list)
  "Returns the value of LIST which is nearest to VAL.

LIST should be a list of integers."
  (let* ((nearest (car list))
         (dist (abs (- val nearest))))
    (dolist (lval (cdr list))
      (let ((ndist (abs (- val lval))))
        (when (< ndist dist)
          (setq nearest lval
                dist    ndist))))
    nearest))


(provide 'emms-player-xine)
;;; emms-player-xine.el ends here