aboutsummaryrefslogtreecommitdiffstats
path: root/emacs/.emacs.d/vendor-lisp
diff options
context:
space:
mode:
authorGravatar Tom Willemse2016-11-24 21:45:55 +0100
committerGravatar Tom Willemse2016-11-24 21:45:55 +0100
commitd3d6e313ecb60424a5defe6ffa5d9a5793f61013 (patch)
treea8ff6600e07dc31d63303d4ea9e63ccd1697e10f /emacs/.emacs.d/vendor-lisp
parent0fcfe9e6f7c4279f9742675393f0220f16c02c5c (diff)
downloadnew-dotfiles-d3d6e313ecb60424a5defe6ffa5d9a5793f61013.tar.gz
new-dotfiles-d3d6e313ecb60424a5defe6ffa5d9a5793f61013.zip
Move circe-serenity to separate project
Diffstat (limited to 'emacs/.emacs.d/vendor-lisp')
-rw-r--r--emacs/.emacs.d/vendor-lisp/circe-serenity/circe-serenity.el205
1 files changed, 0 insertions, 205 deletions
diff --git a/emacs/.emacs.d/vendor-lisp/circe-serenity/circe-serenity.el b/emacs/.emacs.d/vendor-lisp/circe-serenity/circe-serenity.el
deleted file mode 100644
index d7c3dc9..0000000
--- a/emacs/.emacs.d/vendor-lisp/circe-serenity/circe-serenity.el
+++ /dev/null
@@ -1,205 +0,0 @@
-;;; circe-serenity.el --- Clean up Circe buffers -*- lexical-binding: t; -*-
-
-;; Copyright (C) 2016 Tom Willemse
-
-;; Author: Tom Willemse <chelys@drd>
-;; Keywords: convenience
-
-;; This program 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 3 of the License, or
-;; (at your option) any later version.
-
-;; This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
-
-;;; Commentary:
-
-;; This is an extension module for Circe. It creates what I think is
-;; a more minimalistic view of Circe buffers. It right-aligns all the
-;; nicks, right-justifies and simplifies certain messages. It takes
-;; care of both `fill-prefix' and `wrap-prefix' so it should be usable
-;; with and without `lui-fill-type'.
-
-;; The name circe-serenity was chosen because I think the buffers feel
-;; cleaner and more serene with this setup.
-
-;;; Code:
-
-(defvar circe-serenity-longest-nick 0
- "The longest known nick.")
-(make-variable-buffer-local 'circe-serenity-longest-nick)
-
-(defvar circe-serenity--formatters-alist nil
- "Alist of which formatter to use for which circe format.")
-
-(defun circe-serenity--define-formatter (formatter format)
- "Define that FORMATTER should be used for FORMAT."
- (setf (alist-get format circe-serenity--formatters-alist) formatter))
-
-(defun circe-serenity--fill-string ()
- "Create a padded string as long as `circe-serenity-longest-nick'."
- (make-string (+ circe-serenity-longest-nick 3) ?\s))
-
-(defun circe-serenity--update-longest-nick (keywords)
- "Keep track of the longest nick seen so far.
-KEYWORDS is a plist which should contain a :nick key."
- (let* ((nick (plist-get keywords :nick))
- (len (length nick)))
- (when (> len circe-serenity-longest-nick)
- (setq circe-serenity-longest-nick len)
- (when lui-fill-type
- (setq-local lui-fill-type (circe-serenity--fill-string))))))
-
-(defun circe-serenity-say-formatter (&rest keywords)
- "Format a message from a user.
-KEYWORDS should be a plist with at least a :nick and :body. It
-is passed on to `lui-format'."
- (circe-serenity--update-longest-nick keywords)
- (propertize
- (lui-format (format "{nick:%ds} {body}" circe-serenity-longest-nick)
- keywords)
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-say-formatter 'circe-format-say)
-(circe-serenity--define-formatter 'circe-serenity-say-formatter 'circe-format-self-say)
-
-(defun circe-serenity-action-formatter (&rest keywords)
- "Format a user's action message.
-KEYWORDS should be plist with at least the keys :nick and :body.
-A key :intro is added to the plist and then passed on to
-`lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {nick} {body}" circe-serenity-longest-nick)
- (plist-put keywords :intro "*"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-action-formatter 'circe-format-action)
-
-(defun circe-serenity-server-message-formatter (&rest keywords)
- "Format a message from the server.
-KEYWORDS should be a plist with at least a :body key. A key
-:intro is added to the plist and then passed on to `lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {body}" circe-serenity-longest-nick)
- (plist-put keywords :intro "***"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-server-message-formatter 'circe-format-server-message)
-
-(defun circe-serenity-server-join-in-channel-formatter (&rest keywords)
- "Format a message from a user joining a channel.
-KEYWORDS should be a plist with at least a :nick and :channel
-key. A key :intro is added to the plist and then passed on to
-`lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {nick} joined {channel}"
- circe-serenity-longest-nick)
- (plist-put keywords :intro ">>>"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-server-join-in-channel-formatter
- 'circe-format-server-join-in-channel)
-
-(defun circe-serenity-server-join-formatter (&rest keywords)
- "Format a message from a user joining the server.
-KEYWORDS should be a plist with at least a :nick key. A key
-:intro is added to the plist and then passed on to `lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {nick} logged on"
- circe-serenity-longest-nick)
- (plist-put keywords :intro ">>>"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-server-join-formatter 'circe-format-server-join)
-
-(defun circe-serenity-server-quit-formatter (&rest keywords)
- "Format a message from a user quitting the server.
-KEYWORDS should be a plist with at least a :nick key. A key
-:intro is added to the plist and then passed on to `lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {nick} logged off"
- circe-serenity-longest-nick)
- (plist-put keywords :intro "<<<"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-server-quit-formatter 'circe-format-server-quit)
-
-(defun circe-serenity-server-quit-channel-formatter (&rest keywords)
- "Format a message from a user quitting a channel.
-KEYWORDS should be a plist with at least a :nick and :channel
-key. A key :intro is added to the plist and then passed on to
-`lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {nick} left {channel}"
- circe-serenity-longest-nick)
- (plist-put keywords :intro "<<<"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-server-quit-channel-formatter
- 'circe-format-server-quit-channel)
-
-(defun circe-serenity-server-part-formatter (&rest keywords)
- "Format a message from a user parting a channel.
-KEYWORDS should be a plist with at least a :nick and :channel
-key. A key :intro is added to the plist and then passed on to
-`lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {nick} parted from {channel}"
- circe-serenity-longest-nick)
- (plist-put keywords :intro "***"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-server-part-formatter 'circe-format-server-part)
-
-(defun circe-serenity-server-nick-change-formatter (&rest keywords)
- "Format a message from a user changing their nick.
-KEYWORDS should be a plist with at least a :new-nick and
-:old-nick key. A key :intro is added to the plist and then
-passed on to `lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {old-nick} is now know as {new-nick}"
- circe-serenity-longest-nick)
- (plist-put keywords :intro "***"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-server-nick-change-formatter
- 'circe-format-server-nick-change)
-
-(defun circe-serenity-server-topic-formatter (&rest keywords)
- "Format a message of a topic having changed.
-KEYWORDS should be a plist with at least a :nick and :new-topic
-key. A key :intro is added to the plist and then passed on to
-`lui-format'."
- (propertize
- (lui-format
- (format "{intro:%ds} {nick} changed topic to: {new-topic}"
- circe-serenity-longest-nick)
- (plist-put keywords :intro "***"))
- 'wrap-prefix (circe-serenity--fill-string)))
-(circe-serenity--define-formatter 'circe-serenity-server-topic-formatter 'circe-format-server-topic)
-
-;;;###autoload
-(defun enable-circe-serenity ()
- "Enable Serenity for Circe."
- (interactive)
- (dolist (format-pair circe-serenity--formatters-alist)
- (cl-destructuring-bind (format . formatter) format-pair
- (if (null (get format 'circe-serenity-original))
- (put format 'circe-serenity-original (symbol-value format)))
- (set format formatter))))
-
-(defun disable-circe-serenity ()
- "Disable Serenity for Circe."
- (interactive)
- (dolist (format-pair circe-serenity--formatters-alist)
- (let ((format (car format-pair)))
- (set format (get format 'circe-serenity-original))
- (put format 'circe-serenity-original nil))))
-
-(provide 'circe-serenity)
-;;; circe-serenity.el ends here