aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--emms-info-native.el41
1 files changed, 19 insertions, 22 deletions
diff --git a/emms-info-native.el b/emms-info-native.el
index e275e87..f253791 100644
--- a/emms-info-native.el
+++ b/emms-info-native.el
@@ -228,17 +228,18 @@ their comments have almost the same format as Vorbis.")
(defconst emms-info-native--vorbis-identification-header-bindat-spec
'((packet-type u8)
- (eval (when (not (= last 1))
- (error "Vorbis identification header type mismatch: expected 1, got %s"
+ (eval (unless (= last 1)
+ (error "Vorbis header type mismatch: expected 1, got %s"
last)))
(vorbis vec 6)
- (eval (when (not (equal last emms-info-native--vorbis-magic-array))
+ (eval (unless (equal last emms-info-native--vorbis-magic-array)
(error "Vorbis framing mismatch: expected ‘%s’, got ‘%s’"
emms-info-native--vorbis-magic-array
last)))
(vorbis-version u32r)
- (eval (when (not (= last 0))
- (error "Vorbis version mismatch: expected 0, got %s" last)))
+ (eval (unless (= last 0)
+ (error "Vorbis version mismatch: expected 0, got %s"
+ last)))
(audio-channels u8)
(audio-sample-rate u32r)
(bitrate-maximum u32r)
@@ -247,18 +248,17 @@ their comments have almost the same format as Vorbis.")
(blocksize u8)
(framing-flag u8)
(eval (unless (= last 1))
- (error "Vorbis framing bit mismatch: expected 1, got %s" last)))
- "Vorbis identification header specification.
-Identification, framing and version data are verified, otherwise
-the data is assumed to be valid.")
+ (error "Vorbis framing bit mismatch: expected 1, got %s"
+ last)))
+ "Vorbis identification header specification.")
(defconst emms-info-native--vorbis-comment-header-bindat-spec
'((packet-type u8)
- (eval (when (not (= last 3))
- (error "Vorbis comment header type mismatch: expected 3, got %s"
+ (eval (unless (= last 3)
+ (error "Vorbis header type mismatch: expected 3, got %s"
last)))
(vorbis vec 6)
- (eval (when (not (equal last emms-info-native--vorbis-magic-array))
+ (eval (unless (equal last emms-info-native--vorbis-magic-array)
(error "Vorbis framing mismatch: expected ‘%s’, got ‘%s’"
emms-info-native--vorbis-magic-array
last)))
@@ -268,26 +268,23 @@ the data is assumed to be valid.")
(vendor-string vec (vendor-length))
(user-comments-list-length u32r)
(eval (when (> last emms-info-native--max-num-vorbis-comments)
- (error "Vorbis user comment list length %s is too long" last)))
+ (error "Vorbis user comment list length %s is too long"
+ last)))
(user-comments repeat
(user-comments-list-length)
(struct emms-info-native--vorbis-comment-field-bindat-spec))
(framing-bit u8)
(eval (unless (= last 1))
- (error "Vorbis framing bit mismatch: expected 1, got %s" last)))
- "Vorbis comment header specification.
-Header type and framing data are verified. Too long vendor
-string and comment list will also trigger an error.")
+ (error "Vorbis framing bit mismatch: expected 1, got %s"
+ last)))
+ "Vorbis comment header specification.")
(defconst emms-info-native--vorbis-comment-field-bindat-spec
'((length u32r)
(eval (when (> last emms-info-native--max-vorbis-comment-size)
(error "Vorbis comment length %s is too long" last)))
(user-comment vec (length)))
- "Vorbis comment field specification.
-Too long comment will trigger an error.
-
-This field is used in Opus and FLAC comment structures as well.")
+ "Vorbis comment field specification.")
(defconst emms-info-native--vorbis-headers-bindat-spec
'((identification-header struct emms-info-native--vorbis-identification-header-bindat-spec)
@@ -350,7 +347,7 @@ lower case and VALUE is the decoded value."
(let ((comment-string (decode-coding-string (mapconcat
#'byte-to-string
comment
- "")
+ nil)
'utf-8)))
(when (string-match "^\\(.+?\\)=\\(.+?\\)$" comment-string)
(cons (downcase (match-string 1 comment-string))