From f1e8a7f1a52f13291bf8e45106233059add14e89 Mon Sep 17 00:00:00 2001 From: Julien Danjou Date: Sat, 21 Jul 2012 13:08:32 +0200 Subject: [PATCH] erc-notifications: new file --- lisp/erc/ChangeLog | 4 ++ lisp/erc/erc-notifications.el | 90 +++++++++++++++++++++++++++++++++++ 2 files changed, 94 insertions(+) create mode 100644 lisp/erc/erc-notifications.el diff --git a/lisp/erc/ChangeLog b/lisp/erc/ChangeLog index f84df4c7b89..37758048258 100644 --- a/lisp/erc/ChangeLog +++ b/lisp/erc/ChangeLog @@ -1,3 +1,7 @@ +2012-07-21 Julien Danjou + + * erc-notifications.el: New file. + 2012-06-15 Julien Danjou * erc.el (erc-open): Use `auth-source' for password retrieval when diff --git a/lisp/erc/erc-notifications.el b/lisp/erc/erc-notifications.el new file mode 100644 index 00000000000..4faffc913c5 --- /dev/null +++ b/lisp/erc/erc-notifications.el @@ -0,0 +1,90 @@ +;; erc-notifications.el -- Send notification on PRIVMSG or mentions + +;; Copyright (C) 2012 Free Software Foundation, Inc. + +;; Author: Julien Danjou +;; Keywords: comm + +;; This file is part of GNU Emacs. + +;; GNU Emacs 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. + +;; GNU Emacs 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 GNU Emacs. If not, see . + +;;; Commentary: + +;; This implements notifications using `notifications-notify' on +;; PRIVMSG received and on public nickname mentions. + +;;; Code: + +(require 'erc) +(require 'xml) +(require 'notifications) +(require 'erc-match) +(require 'dbus) + +(defgroup erc-notifications nil + "Send notifications on PRIVMSG or mentions." + :group 'erc) + +(defvar erc-notifications-last-notification nil + "Last notification id.") + +(defcustom erc-notifications-icon nil + "Icon to use for notification." + :group 'erc-notifications + :type 'file) + +(defun erc-notifications-notify (nick msg) + "Notify that NICK send some MSG. +This will replace the last notification sent with this function." + (dbus-ignore-errors + (setq erc-notifications-last-notification + (notifications-notify :title (xml-escape-string nick) + :body (xml-escape-string msg) + :replaces-id erc-notifications-last-notification + :app-icon erc-notifications-icon)))) + +(defun erc-notifications-PRIVMSG (proc parsed) + (let ((nick (car (erc-parse-user (erc-response.sender parsed)))) + (target (car (erc-response.command-args parsed))) + (msg (erc-response.contents parsed))) + (when (and (erc-current-nick-p target) + (not (and (boundp 'erc-track-exclude) + (member nick erc-track-exclude))) + (not (erc-is-message-ctcp-and-not-action-p msg))) + (erc-notifications-notify nick msg))) + ;; Return nil to continue processing by ERC + nil) + +(defun erc-notifications-notify-on-match (match-type nickuserhost msg) + (when (eq match-type 'current-nick) + (let ((nick (nth 0 (erc-parse-user nickuserhost)))) + (unless (or (string-match-p "^Server:" nick) + (when (boundp 'erc-track-exclude) + (member nick erc-track-exclude))) + (erc-notifications-notify nick msg))))) + +;;;###autoload(autoload 'erc-notifications-mode "erc-notifications" "" t) +(define-erc-module notifications nil + "Send notifications on private message reception and mentions." + ;; Enable + ((add-hook 'erc-server-PRIVMSG-functions 'erc-notifications-PRIVMSG) + (add-hook 'erc-text-matched-hook 'erc-notifications-notify-on-match)) + ;; Disable + ((remove-hook 'erc-server-PRIVMSG-functions 'erc-notifications-PRIVMSG) + (remove-hook 'erc-text-matched-hook 'erc-notifications-notify-on-match))) + +(provide 'erc-notifications) + +;;; erc-notifications.el ends here -- 2.39.2