aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--emms-playlist-sort.el65
1 files changed, 53 insertions, 12 deletions
diff --git a/emms-playlist-sort.el b/emms-playlist-sort.el
index 9f7285c..4cfea2b 100644
--- a/emms-playlist-sort.el
+++ b/emms-playlist-sort.el
@@ -33,8 +33,33 @@
(require 'emms-score)
-;;; sort macro
+;;; Customizations
+(defgroup emms-playlist-sort nil
+ "Sorting Emacs Multimedia System playlists."
+ :prefix "emms-playlist-sort-"
+ :group 'emms)
+
+;; FIXME, Should better avoid relying on setting before loading
+(defcustom emms-playlist-sort-prefix "S"
+ "Prefix key sequence for `emms-playlist-sort-map'.
+If you want to customize it, you must set this variable before
+loading `emms-playlist-sort'."
+ :type 'string
+ :group 'emms-playlist-sort)
+
+(defcustom emms-playlist-sort-list '(info-artist info-album)
+ "Sorting list used by `emms-playlist-sort-by-list'.
+Currently it understands the following fields: name info-artist
+info-title info-album info-genre info-playing-time
+info-tracknumber."
+ :type 'symbol
+ :group 'emms-playlist-sort)
+
+
+;;; Interfaces
+
+;; sort macro
(defmacro define-emms-playlist-sort (attribute)
"Macro for defining emms playlist sort functions."
`(defun ,(intern (format "emms-playlist-sort-by-%s" attribute)) ()
@@ -66,17 +91,12 @@ See `emms-sort-natural-order-less-p'."
(interactive)
(emms-playlist-sort 'emms-sort-natural-order-less-p))
-(defgroup emms-playlist-sort nil
- "*Sorting Emacs Multimedia System playlists."
- :prefix "emms-playlist-sort-"
- :group 'emms)
-
-;; FIXME: Should better avoid relying on setting before loading.
-(defcustom emms-playlist-sort-prefix "S"
- "*Prefix key sequence for `emms-playlist-sort-map'.
-You should set this variable before loading this file."
- :type 'string
- :group 'emms-playlist-sort)
+(defun emms-playlist-sort-by-list ()
+ "Sort emms playlist by `emms-playlist-sort-list'.
+The sort will be carried out until comparsion succeeds,
+increasingly."
+ (interactive)
+ (emms-playlist-sort 'emms-playlist-sort-by-list-p))
(defvar emms-playlist-sort-map
(let ((map (make-sparse-keymap)))
@@ -87,6 +107,7 @@ You should set this variable before loading this file."
(define-key map (kbd "y") 'emms-playlist-sort-by-info-year)
(define-key map (kbd "o") 'emms-playlist-sort-by-info-note)
(define-key map (kbd "N") 'emms-playlist-sort-by-natural-order)
+ (define-key map (kbd "l") 'emms-playlist-sort-by-list)
map))
(eval-after-load "emms-playlist-mode"
@@ -95,6 +116,9 @@ You should set this variable before loading this file."
emms-playlist-sort-prefix
emms-playlist-sort-map)))
+
+;;; Low Level
+
(defun emms-playlist-sort (predicate &optional start end)
"Sort the playlist buffer by PREDICATE.
If START and END are not provided, the whole buffer will be sorted."
@@ -135,6 +159,23 @@ ie. by album name and then by track number."
(string-to-number (or (emms-track-get b 'info-tracknumber)
"0"))))))
+(defun emms-playlist-sort-by-list-p (a b)
+ (catch 'return
+ (dolist (info emms-playlist-sort-list)
+ (case info
+ ((name info-artist info-title info-album info-genre)
+ (when (string< (emms-track-get a info)
+ (emms-track-get b info))
+ (throw 'return t)))
+ ((info-playing-time)
+ (when (< (emms-track-get a info)
+ (emms-track-get b info))
+ (throw 'return t)))
+ ((info-tracknumber)
+ (when (< (string-to-number (or (emms-track-get a info) "0"))
+ (string-to-number (or (emms-track-get b info) "0")))
+ (throw 'return t)))))))
+
(provide 'emms-playlist-sort)
;;; emms-playlist-sort.el ends here