summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVibhav Pant <vibhavp@gmail.com>2016-12-31 18:21:45 +0530
committerVibhav Pant <vibhavp@gmail.com>2016-12-31 18:21:45 +0530
commitaa6bcdf0c33ff86eb92794202ee5bd70f6d9bde3 (patch)
treea2b957b3f2043f17f4c5798d19f6e70bc5703657
parent8a165813cb9321a8979ac6d98530f5e4392fb879 (diff)
downloademacs-features/erc-message-tags.tar.gz
Add support for IRCv3 message tags.features/erc-message-tags
* erc-backend.el: erc-response: Add `tags' element. Add (erc-parse-tags). (erc-parse-server-response): Use (erc-parse-tags) to parse message tags (if any), and store them in `erc-resopnse' struct. * erc.el: (erc-display-message): Expose message tags with text properties of the corresponding message line.
-rw-r--r--lisp/erc/erc-backend.el30
-rw-r--r--lisp/erc/erc.el5
2 files changed, 29 insertions, 6 deletions
diff --git a/lisp/erc/erc-backend.el b/lisp/erc/erc-backend.el
index 288e8efe73e..eed56174a85 100644
--- a/lisp/erc/erc-backend.el
+++ b/lisp/erc/erc-backend.el
@@ -53,6 +53,7 @@
;; CONTENTS --- `erc-response.contents'
;; SENDER --- `erc-response.sender'
;; LINE --- `erc-response.unparsed'
+;; TAGS --- `erc-response.tags'
;;
;; WARNING, WARNING!!
;; It's probably not a good idea to destructively modify the list
@@ -115,7 +116,8 @@
(sender "" :type string)
(command "" :type string)
(command-args '() :type list)
- (contents "" :type string))
+ (contents "" :type string)
+ (tags '() :type list))
;;; User data
@@ -955,16 +957,34 @@ See also `erc-server-send'."
;;;; Handling responses
+(defun erc-parse-tags (string)
+ "Parse IRCv3 tags list in STRING to a (tag . value) alist."
+ (let ((tags)
+ (tag-strings (split-string string ";")))
+ (dolist (tag-string tag-strings tags)
+ (let ((pair (split-string tag-string "=")))
+ (push (if (consp pair)
+ pair
+ `(,pair))
+ tags)))))
+
(defun erc-parse-server-response (proc string)
"Parse and act upon a complete line from an IRC server.
PROC is the process (connection) from which STRING was received.
PROCs `process-buffer' is `current-buffer' when this function is called."
(unless (string= string "") ;; Ignore empty strings
(save-match-data
- (let ((posn (if (eq (aref string 0) ?:)
- (string-match " " string)
- 0))
- (msg (make-erc-response :unparsed string)))
+ (let* ((tag-list (when (eq (aref string 0) ?@)
+ (substring string 1 (string-match " " string))))
+ (msg (make-erc-response :unparsed string :tags (when tag-list
+ (erc-parse-tags
+ tag-list))))
+ (string (if tag-list
+ (substring string (+ 1 (string-match " " string)))
+ string))
+ (posn (if (eq (aref string 0) ?:)
+ (string-match " " string)
+ 0)))
(setf (erc-response.sender msg)
(if (eq posn 0)
diff --git a/lisp/erc/erc.el b/lisp/erc/erc.el
index 8501e2cba7d..c66f9f56ec6 100644
--- a/lisp/erc/erc.el
+++ b/lisp/erc/erc.el
@@ -2700,7 +2700,10 @@ See also `erc-format-message' and `erc-display-line'."
(unless (erc-hide-current-message-p parsed)
(erc-put-text-property 0 (length string) 'erc-parsed parsed string)
(erc-put-text-property 0 (length string) 'rear-sticky t string)
- (erc-display-line string buffer)))))
+ (when (erc-response.tags parsed)
+ (erc-put-text-property 0 (length string) 'tags (erc-response.tags parsed)
+ string))
+ (erc-display-line string buffer)))))
(defun erc-message-type-member (position list)
"Return non-nil if the erc-parsed text-property at POSITION is in LIST.