aboutsummaryrefslogtreecommitdiff
path: root/emms-info-metaflac.el
diff options
context:
space:
mode:
authorYe Wenbin <wenbinye@gmail.com>2008-05-03 15:09:00 +0000
committerYe Wenbin <wenbinye@gmail.com>2008-05-03 15:09:00 +0000
commitbbefa2ae801843625389a80b7b28c7e579fab96d (patch)
treedeb2f5d286fa4043d02d2d1f698f7312197a60c7 /emms-info-metaflac.el
parent84976d82cfda6fac3af21b1e1b0df81c2136c80b (diff)
Get and set Flac file tags
darcs-hash:20080503150900-94065-f674212fe81666e233d381462fbe3bd1f67f9eae.gz
Diffstat (limited to 'emms-info-metaflac.el')
-rw-r--r--emms-info-metaflac.el107
1 files changed, 107 insertions, 0 deletions
diff --git a/emms-info-metaflac.el b/emms-info-metaflac.el
new file mode 100644
index 0000000..fe94db0
--- /dev/null
+++ b/emms-info-metaflac.el
@@ -0,0 +1,107 @@
+;;; emms-info-metaflac.el --- Info-method for EMMS using metaflac
+
+;; Copyright (C) 2006 Free Software Foundation, Inc.
+
+;; Author: Matthew Kennedy <mkennedy@gentoo.org>
+;; Keywords:
+
+;; This file 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, or (at your option)
+;; any later version.
+
+;; This file 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 GNU Emacs; see the file COPYING. If not, write to the
+;; Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
+;; Boston, MA 02110-1301 USA
+
+;;; Commentary:
+
+;; This code has been adapted from code found in emms-info-mp3info.el
+;; written by Ulrik Jensen <terryp@daimi.au.dk> which contains the
+;; following attribution:
+
+;; This code has been adapted from code found in mp3player.el, written
+;; by Jean-Philippe Theberge (jphiltheberge@videotron.ca), Mario
+;; Domgoergen (kanaldrache@gmx.de) and Jorgen Schäfer
+;; <forcer@forcix.cx>
+
+;; To activate this method for getting info, use something like:
+
+;; (require 'emms-info-metaflac)
+;; (add-to-list 'emms-info-methods-list 'emms-info-metaflac)
+
+;;; Code:
+
+(eval-when-compile (require 'cl))
+(require 'emms-info)
+
+(defvar emms-info-metaflac-version "0.1 $Revision: 1.10 $"
+ "EMMS info metaflac version string.")
+
+;; $Id: emms-info-mp3info.el,v 1.10 2005/08/12 18:01:16 xwl Exp $
+
+(defgroup emms-info-metaflac nil
+ "An EMMS-info method for getting/setting FLAC tags, using the
+external metaflac program"
+ :group 'emms-info)
+
+(defcustom emms-info-metaflac-program-name "metaflac"
+ "*The name/path of the metaflac program."
+ :type 'string
+ :group 'emms-info-metaflac)
+
+(defcustom emms-info-metaflac-options
+ '("--no-utf8-convert"
+ "--show-tag=TITLE"
+ "--show-tag=ARTIST"
+ "--show-tag=ALBUM"
+ "--show-tag=NOTE"
+ "--show-tag=YEAR"
+ "--show-tag=TRACKNUMBER"
+ "--show-tag=GENRE")
+ "The argument to pass to `emms-info-metaflac-program-name'."
+ :type '(repeat string)
+ :group 'emms-info-metaflac)
+
+(defun emms-info-metaflac (track)
+ "Get the FLAC tag of file TRACK, using `emms-info-metaflac-program'
+and return an emms-info structure representing it."
+ (when (and (eq 'file (emms-track-type track))
+ (string-match "\\.\\(flac\\|FLAC\\)\\'" (emms-track-name track)))
+ (with-temp-buffer
+ (when (zerop
+ (apply 'call-process
+ emms-info-metaflac-program-name
+ nil t nil
+ "--show-total-samples"
+ "--show-sample-rate"
+ (append emms-info-metaflac-options
+ (list (emms-track-name track)))))
+ (goto-char (point-min))
+ (emms-track-set track 'info-playing-time
+ (/ (string-to-number (buffer-substring (point) (line-end-position)))
+ (progn
+ (forward-line 1)
+ (string-to-number (buffer-substring (point) (line-end-position))))))
+ (forward-line 1)
+ (while (looking-at "^\\([^=\n]+\\)=\\(.*\\)$")
+ (let ((name (intern (concat "info-" (downcase (match-string 1)))))
+ (value (match-string 2)))
+ (when (> (length value)
+ 0)
+ (emms-track-set track
+ name
+ (if (eq name 'info-playing-time)
+ (string-to-number value)
+ value))))
+ (forward-line 1))))))
+
+(provide 'emms-info-metaflac)
+
+;;; emms-info-metaflac.el ends here