commit f51e838e808a32b1500323f3ab62a048fde29574 Author: Tom Willemse Date: Fri Nov 4 14:22:37 2016 +0100 Rename sermon -> circe-serenity diff --git a/circe-serenity.el b/circe-serenity.el new file mode 100644 index 0000000..55e783a --- /dev/null +++ b/circe-serenity.el @@ -0,0 +1,252 @@ +;;; circe-serenity.el --- Clean up Circe buffers -*- lexical-binding: t; -*- + +;; Copyright (C) 2016 Tom Willemse + +;; Author: Tom Willemse +;; 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 . + +;;; 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 it's pronounced somewhat +;; similarly to cermin, which is an amalgamation of circe +;; minimalistic. + +;;; Code: + +(defvar circe-serenity-longest-nick 0 + "The longest known nick.") +(make-variable-buffer-local 'circe-serenity-longest-nick) + +(defvar circe-serenity-original-format-say nil + "The original value of `circe-format-say'.") +(defvar circe-serenity-original-format-self-say nil + "The original value of `circe-format-self-say'.") +(defvar circe-serenity-original-format-action nil + "The original value of `circe-format-action'.") +(defvar circe-serenity-original-format-self-action nil + "The original value of `circe-format-self-action'.") +(defvar circe-serenity-original-format-server-message nil + "The original value of `circe-format-server-message'.") +(defvar circe-serenity-original-format-server-join-in-channel nil + "The original value of `circe-format-server-join-in-channel'.") +(defvar circe-serenity-original-format-server-join nil + "The original value of `circe-format-server-join'.") +(defvar circe-serenity-original-format-server-quit nil + "The original value of `circe-format-server-quit'.") +(defvar circe-serenity-original-format-server-quit-channel nil + "The original value of `circe-format-server-quit-channel'.") +(defvar circe-serenity-original-format-server-part nil + "The original value of `circe-format-server-part'.") +(defvar circe-serenity-original-format-server-nick-change nil + "The original value of `circe-format-server-nick-change'.") +(defvar circe-serenity-original-format-server-topic nil + "The original vlaue of `circe-format-server-topic'.") + +(defun circe-serenity--fill-string () + (make-string (+ circe-serenity-longest-nick 3) ?\s)) + +(defun circe-serenity--update-longest-nick (keywords) + (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) + (circe-serenity--update-longest-nick keywords) + (propertize + (lui-format (format "{nick:%ds} {body}" circe-serenity-longest-nick) + keywords) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-self-say-formatter (&rest keywords) + (propertize (format (format "%%%ds %%s" circe-serenity-longest-nick) + ">" (plist-get keywords :body)) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-action-formatter (&rest keywords) + (propertize + (lui-format + (format "{intro:%ds} {nick} {body}" circe-serenity-longest-nick) + (plist-put keywords :intro "*")) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-server-message-formatter (&rest keywords) + (propertize + (lui-format + (format "{intro:%ds} {body}" circe-serenity-longest-nick) + (plist-put keywords :intro "***")) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-server-join-in-channel-formatter (&rest keywords) + (propertize + (lui-format + (format "{intro:%ds} {nick} joined {channel}" + circe-serenity-longest-nick) + (plist-put keywords :intro ">>>")) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-server-join-formatter (&rest keywords) + (propertize + (lui-format + (format "{intro:%ds} {nick} logged on" + circe-serenity-longest-nick) + (plist-put keywords :intro ">>>")) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-server-quit-formatter (&rest keywords) + (propertize + (lui-format + (format "{intro:%ds} {nick} logged off" + circe-serenity-longest-nick) + (plist-put keywords :intro "<<<")) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-server-quit-channel-formatter (&rest keywords) + (propertize + (lui-format + (format "{intro:%ds} {nick} left {channel}" + circe-serenity-longest-nick) + (plist-put keywords :intro "<<<")) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-server-part-formatter (&rest keywords) + (propertize + (lui-format + (format "{intro:%ds} {nick} parted from {channel}" + circe-serenity-longest-nick) + (plist-put keywords :intro "***")) + 'wrap-prefix (circe-serenity--fill-string))) + +(defun circe-serenity-server-nick-change-formatter (&rest keywords) + (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))) + +(defun circe-serenity-server-topic-formatter (&rest keywords) + (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))) + +;;;###autoload +(defun enable-circe-serenity () + (interactive) + (if (null circe-serenity-original-format-say) + (setq circe-serenity-original-format-say + circe-format-say)) + (setq circe-format-say #'circe-serenity-say-formatter) + + (if (null circe-serenity-original-format-self-say) + (setq circe-serenity-original-format-self-say + circe-format-self-say)) + (setq circe-format-self-say #'circe-serenity-say-formatter) + + (if (null circe-serenity-original-format-action) + (setq circe-serenity-original-format-action + circe-format-action)) + (setq circe-format-action #'circe-serenity-action-formatter) + + (if (null circe-serenity-original-format-self-action) + (setq circe-serenity-original-format-self-action + circe-format-self-action)) + (setq circe-format-self-action #'circe-serenity-action-formatter) + + (if (null circe-serenity-original-format-server-message) + (setq circe-serenity-original-format-server-message + circe-format-server-message)) + (setq circe-format-server-message #'circe-serenity-server-message-formatter) + + (if (null circe-serenity-original-format-server-join-in-channel) + (setq circe-serenity-original-format-server-join-in-channel + circe-format-server-join-in-channel)) + (setq circe-format-server-join-in-channel + #'circe-serenity-server-join-in-channel-formatter) + + (if (null circe-serenity-original-format-server-join) + (setq circe-serenity-original-format-server-join + circe-format-server-join)) + (setq circe-format-server-join #'circe-serenity-server-join-formatter) + + (if (null circe-serenity-original-format-server-quit) + (setq circe-serenity-original-format-server-quit + circe-format-server-quit)) + (setq circe-format-server-quit #'circe-serenity-server-quit-formatter) + + (if (null circe-serenity-original-format-server-quit-channel) + (setq circe-serenity-original-format-server-quit-channel + circe-format-server-quit-channel)) + (setq circe-format-server-quit-channel + #'circe-serenity-server-quit-channel-formatter) + + (if (null circe-serenity-original-format-server-part) + (setq circe-serenity-original-format-server-part + circe-format-server-part)) + (setq circe-format-server-part #'circe-serenity-server-part-formatter) + + (if (null circe-serenity-original-format-server-nick-change) + (setq circe-serenity-original-format-server-nick-change + circe-format-server-nick-change)) + (setq circe-format-server-nick-change + #'circe-serenity-server-nick-change-formatter) + + (if (null circe-serenity-original-format-server-topic) + (setq circe-serenity-original-format-server-topic + circe-format-server-topic)) + (setq circe-format-server-topic + #'circe-serenity-server-topic-formatter)) + +(defun disable-circe-serenity () + (interactive) + (setq circe-format-say circe-serenity-original-format-say + circe-serenity-original-format-say nil + circe-format-self-say circe-serenity-original-format-self-say + circe-serenity-original-format-self-say nil + circe-format-action circe-serenity-original-format-action + circe-serenity-original-format-action nil + circe-format-self-action circe-serenity-original-format-self-action + circe-serenity-original-format-self-action nil + circe-format-server-message circe-serenity-original-format-server-message + circe-serenity-original-format-server-message nil + circe-format-server-join-in-channel circe-serenity-original-format-server-join-in-channel + circe-serenity-original-format-server-join-in-channel nil + circe-format-server-join circe-serenity-original-format-server-join + circe-serenity-original-format-server-join nil + circe-format-server-quit circe-serenity-original-format-server-quit + circe-serenity-original-format-server-quit nil + circe-format-server-quit-channel circe-serenity-original-format-server-quit-channel + circe-serenity-original-format-server-quit-channel nil + circe-format-server-part circe-serenity-original-format-server-part + circe-serenity-original-format-server-part nil + circe-format-server-nick-change circe-serenity-original-format-server-nick-change + circe-serenity-original-format-server-nick-change nil + circe-format-server-topic circe-serenity-original-format-server-topic + circe-serenity-original-format-topic nil)) + +(provide 'circe-serenity) +;;; circe-serenity.el ends here