aboutsummaryrefslogtreecommitdiffstats
path: root/emacs/.emacs.d/site-lisp/oni-jabber.el
blob: f498868d45a0c50156a88f708b4d2d63c1bd6733 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
;;; oni-jabber.el --- Extra commands and functions for jabber  -*- lexical-binding: t; -*-

;; Copyright (C) 2016  Tom Willemse

;; Author: Tom Willemse <tom@ryuslash.org>
;; Keywords:

;; 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:

;; Here are some extra commands and functions for jabber.

;;; Code:

(require 'jabber-chat)

;;;###autoload
(defun oni-jabber-set-roster-mode-line ()
  "Change the mode-line to only show the buffer id."
  (unless (eq major-mode 'jabber-roster-mode)
    (error "Will not change mode-line, not in the jabber roster buffer"))
  (setq mode-line-format
        (list (propertize " %m" 'face 'mode-line-buffer-id))))

;;;###autoload
(defun oni-jabber-show-status-in-buffer
    (who _oldstatus _newstatus _statustext proposed-alert)
  "Check to see if WHO has a buffer and if so print their new status.

Insert PROPOSED-ALERT in the buffer if it is non-nil."
  (let ((buffer (get-buffer (jabber-chat-get-buffer (symbol-name who)))))
    (when (and buffer proposed-alert)
      (with-current-buffer buffer
        (ewoc-enter-last jabber-chat-ewoc (list :notice proposed-alert
                                                :time (current-time)))))))

(provide 'oni-jabber)
;;; oni-jabber.el ends here