aboutsummaryrefslogtreecommitdiffstats
path: root/emacs/.emacs.d/init/oni-circe-init.org
diff options
context:
space:
mode:
authorGravatar Tom Willemse2017-01-08 13:33:08 +0100
committerGravatar Tom Willemse2017-01-08 13:33:08 +0100
commit0ee856c6f35f9eda412534f9e2a7b5e4954e6af6 (patch)
tree4710d1224c8a8781d3462d0dbc364209f38bef10 /emacs/.emacs.d/init/oni-circe-init.org
parent562791b0ae258ba68851a025f954614fed1f0dd1 (diff)
parenta6a88fd424ea806ce89ce6b2aa1e0d6664b918de (diff)
downloadnew-dotfiles-0ee856c6f35f9eda412534f9e2a7b5e4954e6af6.tar.gz
new-dotfiles-0ee856c6f35f9eda412534f9e2a7b5e4954e6af6.zip
Merge remote-tracking branch 'origin/index' into index
Diffstat (limited to 'emacs/.emacs.d/init/oni-circe-init.org')
-rw-r--r--emacs/.emacs.d/init/oni-circe-init.org68
1 files changed, 67 insertions, 1 deletions
diff --git a/emacs/.emacs.d/init/oni-circe-init.org b/emacs/.emacs.d/init/oni-circe-init.org
index 7521c04..b7fd14e 100644
--- a/emacs/.emacs.d/init/oni-circe-init.org
+++ b/emacs/.emacs.d/init/oni-circe-init.org
@@ -5,6 +5,7 @@
(require 'circe-color-nicks)
(require 'circe-serenity)
(require 'oni-circe)
+ (require 'mowedline)
#+END_SRC
I switched to Circe from ERC because I couldn't make the
@@ -21,7 +22,9 @@ I spend most of my time on IRC on Freenode.
"#ninthfloor"
"#dispass"
"#linuxvoice"
- "#conkeror")
+ "#conkeror"
+ "#emacs-circe"
+ "#chicken")
:nickserv-password
,(oni-circe-get-password-for "irc.freenode.net")))
#+END_SRC
@@ -50,3 +53,66 @@ Serenity.
#+BEGIN_SRC emacs-lisp
(enable-circe-serenity)
#+END_SRC
+
+Add external tracking. Show the status of tracked buffers in
+mowedline instead in the mode-line. With color!
+
+This code has been generously donated by [[http://retroj.net][retroj]], the author of
+mowedline.
+
+First define a function to parse the text properties from the tracking
+buffers list so that highlights (from mentions) also appear in
+mowedline.
+
+#+BEGIN_SRC emacs-lisp
+ (defun mowedline-colorize-mode-line-spec (s)
+ (cond
+ ((stringp s) (string-trim s))
+ ((eq ':propertize (car s))
+ (let ((s (cadr s))
+ (face (plist-get (cddr s) 'face)))
+ (if face
+ `(color ,(face-foreground face)
+ ,(substring-no-properties s))
+ s)))
+ (t "")))
+#+END_SRC
+
+Also tell mowedline to use the dbus interface directly, instead of
+going through the command-line interface.
+
+#+BEGIN_SRC emacs-lisp
+ (setq mowedline-update-function 'mowedline-update/dbus)
+#+END_SRC
+
+#+BEGIN_SRC emacs-lisp
+ (defvar jjf-tracking-buffers '())
+ (defvar jjf-external-tracking-timer nil)
+ (defun jjf-external-tracking ()
+ (setq jjf-external-tracking-timer nil)
+ (mowedline-update
+ 'irc
+ (if (stringp jjf-tracking-buffers)
+ (mowedline-colorize jjf-tracking-buffers t)
+ (format "%S" (mapcar #'mowedline-colorize-mode-line-spec
+ jjf-tracking-buffers)))))
+
+ (defun oni:clear-irc-mowedline-widget ()
+ (mowedline-clear 'irc))
+
+ (defun jjf-external-tracking-advice (orig-fun &rest args)
+ "Update my external status bar when tracking computes a new
+ status line, and suppress tracking in the mode-line. Since
+ tracking-status may be called many times in quick succession, for
+ example on a make-frame-visible event, we use a short timer to
+ only call the updater once within a minimum duration."
+ (setq jjf-tracking-buffers (apply orig-fun args))
+ (when jjf-external-tracking-timer
+ (cancel-timer jjf-external-tracking-timer))
+ (setq jjf-external-tracking-timer
+ (run-at-time 0.2 nil 'jjf-external-tracking))
+ nil)
+
+ (advice-add 'tracking-status :around #'jjf-external-tracking-advice)
+ (add-hook 'kill-emacs-hook 'oni:clear-irc-mowedline-widget)
+#+END_SRC