;;; emms-player-mplayer.el --- mplayer support for EMMS ;; Copyright (C) 2005, 2006, 2007 Free Software Foundation, Inc. ;; Authors: William Xu ;; Jorgen Schaefer ;; 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 2 ;; 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 mplayer. It supports pause and ;; seeking. ;;; Code: (require 'emms-compat) (require 'emms-player-simple) (define-emms-simple-player mplayer '(file url) (regexp-opt '(".ogg" ".mp3" ".wav" ".mpg" ".mpeg" ".wmv" ".wma" ".mov" ".avi" ".divx" ".ogm" ".asf" ".mkv" "http://" "mms://" ".rm" ".rmvb" ".mp4" ".flac" ".vob" ".m4a")) "mplayer" "-slave" "-quiet" "-really-quiet") (define-emms-simple-player mplayer-playlist '(streamlist) "http://" "mplayer" "-slave" "-quiet" "-really-quiet" "-playlist") (emms-player-set emms-player-mplayer 'pause 'emms-player-mplayer-pause) ;;; Pause is also resume for mplayer (emms-player-set emms-player-mplayer 'resume nil) (emms-player-set emms-player-mplayer 'seek 'emms-player-mplayer-seek) (emms-player-set emms-player-mplayer 'seek-to 'emms-player-mplayer-seek-to) (defun emms-player-mplayer-pause () "Depends on mplayer's -slave mode." (process-send-string emms-player-simple-process-name "pause\n")) (defun emms-player-mplayer-seek (sec) "Depends on mplayer's -slave mode." (process-send-string emms-player-simple-process-name (format "seek %d\n" sec))) (defun emms-player-mplayer-seek-to (sec) "Depends on mplayer's -slave mode." (process-send-string emms-player-simple-process-name (format "seek %d 2\n" sec))) (defun emms-player-mplayer-subtitle-checker () (let* ((track (emms-playlist-current-selected-track)) (name (emms-track-name track)) (ext (file-name-extension name)) (sub (replace-regexp-in-string (concat ext "$") "sub" name)) ;; TODO, script for chinese, gb, big, etc. (srt (replace-regexp-in-string (concat ext "$") "srt" name)) (choices (emms-remove-if-not 'file-exists-p (list sub srt))) (subtitle nil)) (cond ((> (length choices) 1) (setq subtitle (ido-completing-read "Select subtitles: " choices))) ((= (length choices) 1) (setq subtitle (car choices)))) (when subtitle (setq emms-player-mplayer-parameters (append emms-player-mplayer-parameters (list "-sub" subtitle)))))) (defun emms-player-mplayer-start-with-subtitle-checker (track) "Start the player process by checking possible subtitles additionally." (let ((emms-player-mplayer-parameters emms-player-mplayer-parameters)) (emms-player-mplayer-subtitle-checker) (emms-player-simple-start (emms-track-name track) emms-player-mplayer emms-player-mplayer-command-name emms-player-mplayer-parameters))) ;; Uncomment me if you want to use ;; `emms-player-mplayer-start-with-subtitle-checker'. We need to ;; redefine `emms-player-mplayer-start', since i can't figure out an ;; easy way to achieve this by modifying the emms source. (xwl) ;; ;; (defalias 'emms-player-mplayer-start ;; 'emms-player-mplayer-start-with-subtitle-checker) (provide 'emms-player-mplayer) ;;; emms-player-mplayer.el ends here