aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTassilo Horn <tassilo@member.fsf.org>2007-08-15 18:32:00 +0000
committerTassilo Horn <tassilo@member.fsf.org>2007-08-15 18:32:00 +0000
commite56608e2156199b226ee0f76977dc85e53cc24a5 (patch)
treef005e9b53ab6a865317ca2a972652280a1eb5d25
parenteb8dcf8d1fa030351093571714cf55cc8c73fa1b (diff)
support-for-renaming-files-with-tag-editor.dpatch
With `R' in a playlist (calls `emms-tag-editor-rename') the file(s) corresponding to the (marked) track(s) or the track at point will be renamed according to the format specified in `emms-tag-editor-rename-format'. Work ok for me, but there's a little problem maybe someone can fix: - If users use the cache it has to be updated somehow. `emms-cache-sync' seems to remove the renamed files. So you have to re-insert all renamed tracks to get them into the cache again. darcs-hash:20070815183247-c06f4-1419a175a28e72530fba2a67ee3925a45f311a1c.gz
-rw-r--r--emms-tag-editor.el58
1 files changed, 56 insertions, 2 deletions
diff --git a/emms-tag-editor.el b/emms-tag-editor.el
index b5ed32f..a99e8ec 100644
--- a/emms-tag-editor.el
+++ b/emms-tag-editor.el
@@ -27,7 +27,6 @@
;;; Code:
-(provide 'emms-tag-editor)
(eval-when-compile
(require 'cl))
(require 'emms)
@@ -639,4 +638,59 @@ With prefix argument, bury the tag edit buffer."
(goto-char (point-max))
(insert (apply 'format args) "\n")))
-;;; emms-tag-editor.el ends here
+;;
+;; Renaming files according their tags
+;;
+
+(defvar emms-tag-editor-rename-format "%a - %l - %n - %t"
+ "When `emms-tag-editor-rename' is invoked the track's file will
+be renamed according this format specification. The file
+extension will be added automatically.
+
+It uses the format specs defined in `emms-tag-editor-tags'.")
+
+(defun emms-tag-editor-rename ()
+ "Rename the file corresponding to track at point or all marked
+tracks according to the value of
+`emms-tag-editor-rename-format'."
+ (interactive)
+ (if (emms-mark-has-markedp)
+ (emms-tag-editor-rename-marked-tracks)
+ (emms-tag-editor-rename-track (emms-tag-editor-track-at))))
+
+(defun emms-tag-editor-rename-track (track)
+ "Rename TRACK's file according `emms-tag-editor-rename-format's
+value."
+ (let* ((file (or (emms-track-get track 'info-file)
+ (emms-track-get track 'name)))
+ (path (file-name-directory file))
+ (suffix (file-name-extension file))
+ (new-file (concat
+ path
+ (format-spec
+ emms-tag-editor-rename-format
+ (apply 'format-spec-make
+ (apply 'append
+ (mapcar (lambda (tag)
+ (list (string-to-char (cdr tag))
+ (or (emms-track-get track (car tag)) "")))
+ emms-tag-editor-tags))))
+ "." suffix)))
+ (rename-file file new-file)
+ (message "Renamed \"%s\" to \"%s\"." file new-file)))
+
+(defun emms-tag-editor-rename-marked-tracks ()
+ "Rename the files corresponding to all marked tracks according
+`emms-tag-editor-rename-format's value."
+ (let ((tracks (emms-mark-mapcar-marked-track
+ 'emms-tag-editor-track-at t)))
+ (if (null tracks)
+ (message "No track marked!")
+ (progn
+ (dolist (track tracks)
+ (emms-tag-editor-rename-track track))))))
+
+(define-key emms-playlist-mode-map "R" 'emms-tag-editor-rename)
+
+(provide 'emms-tag-editor)
+;;; Emms-tag-editor.el ends here