* .emacs.d/init.el: Extend zoneinfo-style-world-list.
[~bandali/configs] / .emacs.d / lisp / bandali-erc.el
index 1670af6..04d5fd3 100644 (file)
@@ -1,9 +1,9 @@
 ;;; bandali-erc.el --- bandali's ERC setup           -*- lexical-binding: t; -*-
 
 ;;; bandali-erc.el --- bandali's ERC setup           -*- lexical-binding: t; -*-
 
-;; Copyright (C) 2018-2020  Amin Bandali
+;; Copyright (C) 2018-2021  Amin Bandali
 
 ;; Author: Amin Bandali <bandali@gnu.org>
 
 ;; Author: Amin Bandali <bandali@gnu.org>
-;; Keywords: tools
+;; Keywords: IRC, chat, client, Internet
 
 ;; 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
 
 ;; 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
 
 ;;; Commentary:
 
 
 ;;; Commentary:
 
-;; My ERC setup for IRC.  It uses my fork of ZNC.el.
+;; My ERC setup for IRC in GNU Emacs.
 
 ;;; Code:
 
 
 ;;; Code:
 
-(defvar b/erc-detach-on-kill t
-  "Whether killing a channel should send a DETACH command (for ZNC).")
-
 (with-eval-after-load 'erc
 (with-eval-after-load 'erc
-  (make-directory (b/var "erc/dcc/") t)
+  (make-directory (b/var "erc/dcc") t)
   (csetq
    erc-auto-query 'bury
    erc-autojoin-domain-only nil
   (csetq
    erc-auto-query 'bury
    erc-autojoin-domain-only nil
@@ -36,7 +33,7 @@
    erc-email-userid "bandali"
    erc-format-nick-function 'erc-format-@nick
    erc-join-buffer 'bury
    erc-email-userid "bandali"
    erc-format-nick-function 'erc-format-@nick
    erc-join-buffer 'bury
-   erc-lurker-hide-list '("JOIN" "PART" "QUIT")
+   ;; erc-lurker-hide-list '("JOIN" "PART" "QUIT")
    erc-nick "bandali"
    erc-prompt "erc>"
    erc-prompt-for-password nil
    erc-nick "bandali"
    erc-prompt "erc>"
    erc-prompt-for-password nil
@@ -50,7 +47,7 @@
   (declare-function erc-default-target "erc")
   (declare-function erc-current-nick "erc")
   (defun erc-cmd-OPME ()
   (declare-function erc-default-target "erc")
   (declare-function erc-current-nick "erc")
   (defun erc-cmd-OPME ()
-    "Request chanserv to op me."
+    "Ask chanserv to op me in the current channel."
     (erc-message "PRIVMSG"
                  (format "chanserv op %s %s"
                          (erc-default-target)
     (erc-message "PRIVMSG"
                  (format "chanserv op %s %s"
                          (erc-default-target)
@@ -58,7 +55,7 @@
                  nil))
   (declare-function erc-cmd-DEOP "erc" (&rest people))
   (defun erc-cmd-DEOPME ()
                  nil))
   (declare-function erc-cmd-DEOP "erc" (&rest people))
   (defun erc-cmd-DEOPME ()
-    "Deop myself from current channel."
+    "Deop myself in the current channel."
     (erc-cmd-DEOP (format "%s" (erc-current-nick))))
   (add-to-list 'erc-modules 'keep-place)
   (add-to-list 'erc-modules 'log)
     (erc-cmd-DEOP (format "%s" (erc-current-nick))))
   (add-to-list 'erc-modules 'keep-place)
   (add-to-list 'erc-modules 'log)
   ;; (erc-fill-mode -1)
 
   ;; erc-log
   ;; (erc-fill-mode -1)
 
   ;; erc-log
+  (defun b/erc-log-directory (buffer target _nick server _port)
+    (let ((directory (concat (b/var "erc/logs/")
+                             ;; (or (with-current-buffer buffer
+                             ;;       (symbol-name erc-network))
+                             ;;     server)
+                             server
+                             (if (erc-server-buffer-p buffer)
+                                 (concat "/" server)
+                               (and target (concat "/" target))))))
+      (unless (file-exists-p directory)
+        (make-directory directory 'make-parents))
+      directory))
+  (defun b/erc-log-file-name (&rest _)
+    (concat (format-time-string "%Y-%m-%d") ".log"))
   (csetq
    ;; erc-enable-logging 'erc-log-all-but-server-buffers
   (csetq
    ;; erc-enable-logging 'erc-log-all-but-server-buffers
-   erc-generate-log-file-name-function 'erc-generate-log-file-name-with-date
-   erc-log-channels-directory (b/var "erc/logs")
+   erc-generate-log-file-name-function #'b/erc-log-file-name
+   erc-log-channels-directory #'b/erc-log-directory
    erc-log-file-coding-system 'utf-8
    erc-log-write-after-insert t
    erc-log-write-after-send t
    erc-log-file-coding-system 'utf-8
    erc-log-write-after-insert t
    erc-log-write-after-send t
 
   ;; key bindings
   (global-set-key (kbd "C-c w e") #'erc-switch-to-buffer-other-window)
 
   ;; key bindings
   (global-set-key (kbd "C-c w e") #'erc-switch-to-buffer-other-window)
-  (define-key erc-mode-map (kbd "M-a") #'erc-track-switch-buffer)
-
-  ;; hooks
-  (defun b/erc-detach-or-kill-channel ()
-    (if b/erc-detach-on-kill
-        (when (erc-server-process-alive)
-          (let ((tgt (erc-default-target)))
-            (erc-server-send (format "DETACH %s" tgt) nil tgt)))
-      (erc-kill-channel)))
-  (add-hook 'erc-kill-channel-hook #'b/erc-detach-or-kill-channel)
-  (remove-hook 'erc-kill-channel-hook #'erc-kill-channel))
+  (define-key erc-mode-map (kbd "M-a") #'erc-track-switch-buffer))
 
 ;; global key bindings
 (global-set-key
 
 ;; global key bindings
 (global-set-key
- (kbd "C-c a e f")
+ (kbd "C-c a e l")
  (lambda ()
    (interactive)
  (lambda ()
    (interactive)
-   (let* ((auth (auth-source-search :host "znca"))
-          (p (if (null auth)
-                 (error "Couldn't find znca's authinfo")
-              (funcall (plist-get (car auth) :secret)))))
-     (erc-tls :server "znc.emacsconf.org" :port 6697
-              :password (concat "bandali/freenode:" p)))))
+   (erc-tls :server "irc.libera.chat" :port 6697
+            :client-certificate t)))
 (global-set-key
  (kbd "C-c a e o")
  (lambda ()
    (interactive)
 (global-set-key
  (kbd "C-c a e o")
  (lambda ()
    (interactive)
-   (let* ((auth (auth-source-search :host "znca"))
-          (p (if (null auth)
-                 (error "Couldn't find znca's authinfo")
-              (funcall (plist-get (car auth) :secret)))))
-     (erc-tls :server "znc.emacsconf.org" :port 6697
-              :password (concat "bandali/oftc:" p)))))
+   (erc-tls :server "irc.oftc.net" :port 6697
+            :client-certificate t)))
 (global-set-key
  (kbd "C-c a e t")
  (lambda ()
    (interactive)
 (global-set-key
  (kbd "C-c a e t")
  (lambda ()
    (interactive)
-   (let* ((auth (auth-source-search :host "znca"))
-          (p (if (null auth)
-                 (error "Couldn't find znca's authinfo")
-              (funcall (plist-get (car auth) :secret)))))
-     (erc-tls :server "znc.emacsconf.org" :port 6697
-              :password (concat "bandali/tildechat:" p)))))
+   (erc-tls :server "na.tilde.chat" :port 6697
+            :client-certificate t)))
 
 (provide 'bandali-erc)
 ;;; bandali-erc.el ends here
 
 (provide 'bandali-erc)
 ;;; bandali-erc.el ends here