gnupg: explicitly allow-loopback-pinentry
[~bandali/configs] / .emacs.d / init.el
index b05904f..e854395 100644 (file)
@@ -74,7 +74,7 @@
 ;;; whoami
 
 (setq user-full-name "Amin Bandali"
-      user-mail-address "amin@bndl.org")
+      user-mail-address "amin@shemshak.org")
 
 \f
 ;;; comment macro
@@ -473,8 +473,6 @@ For disabling the behaviour for certain buffers and/or modes."
  ("C-c F d" . delete-frame)
  ("C-c F D" . server-edit)
 
- ("C-c o"   . other-window)
-
  ("C-S-h C" . describe-char)
  ("C-S-h F" . describe-face)
 
@@ -484,6 +482,9 @@ For disabling the behaviour for certain buffers and/or modes."
  ("s-p"     . beginning-of-buffer)
  ("s-n"     . end-of-buffer)
 
+ ("M-o"     . other-window)
+ ("M-O"     . facemenu-keymap)
+
  :map emacs-lisp-mode-map
  ("<C-return>" . a/add-elisp-section))
 
@@ -657,7 +658,7 @@ For disabling the behaviour for certain buffers and/or modes."
 (use-feature recentf
   :defer 0.2
   :config
-  (add-to-list 'recentf-exclude "^/\\(?:ssh\\|su\\|sudo\\)?:")
+  ;; (add-to-list 'recentf-exclude "^/\\(?:ssh\\|su\\|sudo\\)?:")
   (setq recentf-max-saved-items 2000))
 
 ;; smart M-x enhancement (needed by counsel for history)
@@ -1016,7 +1017,8 @@ For disabling the behaviour for certain buffers and/or modes."
   ;; ’ can be part of a word
   (setq ispell-local-dictionary-alist
         `((nil "[[:alpha:]]" "[^[:alpha:]]"
-               "['\x2019]" nil ("-B") nil utf-8)))
+               "['\x2019]" nil ("-B") nil utf-8))
+        ispell-program-name (executable-find "hunspell"))
   ;; don't send ’ to the subprocess
   (defun endless/replace-apostrophe (args)
     (cons (replace-regexp-in-string
@@ -1222,7 +1224,8 @@ For disabling the behaviour for certain buffers and/or modes."
   :commands (sml/apply-theme)
   :demand
   :config
-  (sml/setup))
+  (sml/setup)
+  (smart-mode-line-enable))
 
 (use-package doom-themes)
 
@@ -1336,10 +1339,22 @@ For disabling the behaviour for certain buffers and/or modes."
          ("<end>"  . mwim-end-of-line-or-code)))
 
 (use-package projectile
+  :defer 0.5
   :bind-keymap ("C-c P" . projectile-command-map)
   :config
   (projectile-mode)
 
+  (defun a/projectile-mode-line-fun ()
+  "Report project name and type in the modeline."
+  (let ((project-name (projectile-project-name))
+        (project-type (projectile-project-type)))
+    (format "%s%s"
+            projectile-mode-line-prefix
+            (if project-type
+                (format ":%s" project-type)
+              ""))))
+  (setq projectile-mode-line-function 'a/projectile-mode-line-fun)
+
   (defun my-projectile-invalidate-cache (&rest _args)
     ;; ignore the args to `magit-checkout'
     (projectile-invalidate-cache nil))
@@ -1561,7 +1576,8 @@ For disabling the behaviour for certain buffers and/or modes."
    :token nday-students-token
    :subscribed-channels '(general)
    :full-and-display-names t)
-  (add-to-list 'swiper-font-lock-exclude 'slack-message-buffer-mode t)
+  (with-eval-after-load 'swiper
+    (add-to-list 'swiper-font-lock-exclude 'slack-message-buffer-mode t))
   (setq lui-time-stamp-format "[%Y-%m-%d %H:%M:%S]"
         lui-time-stamp-only-when-changed-p t
         lui-time-stamp-position 'right)
@@ -1619,7 +1635,7 @@ For disabling the behaviour for certain buffers and/or modes."
             (nnimap-address "127.0.0.1")
             (nnimap-server-port 143)
             (nnimap-authenticator plain)
-            (nnimap-user "amin@bndl.local"))
+            (nnimap-user "amin@shemshak.local"))
      (nnimap "gnu"
             (nnimap-stream plain)
             (nnimap-address "127.0.0.1")
@@ -1646,6 +1662,7 @@ For disabling the behaviour for certain buffers and/or modes."
                                  (list ".*guile-devel.gnu.org" "l.gnu.guile.devel")
                                  (list ".*guile-user.gnu.org" "l.gnu.guile.user")
                                  (list ".*guix-devel.gnu.org" "l.gnu.guix.devel")
+                                 (list ".*help-guix.gnu.org" "l.gnu.guix.help")
                                  (list ".*info-guix.gnu.org" "l.gnu.guix.info")
                                  (list ".*savannah-hackers-public.gnu.org" "l.gnu.savannah.hackers.public")
                                  (list ".*savannah-users.gnu.org" "l.gnu.savannah.users")
@@ -1742,6 +1759,9 @@ For disabling the behaviour for certain buffers and/or modes."
      ("l\\.gnu\\.guix\\.devel"
       (to-address . "guix-devel@gnu.org")
       (to-list    . "guix-devel@gnu.org"))
+     ("l\\.gnu\\.guix\\.help"
+      (to-address . "help-guix@gnu.org")
+      (to-list    . "help-guix@gnu.org"))
      ("l\\.gnu\\.guix\\.info"
       (to-address . "info-guix@gnu.org")
       (to-list    . "info-guix@gnu.org"))
@@ -1868,7 +1888,7 @@ https://bandali.eu.org")
 https://csclub.uwaterloo.ca/~abandali/")
   (setq gnus-posting-styles
         '((".*"
-           (address "amin@bndl.org")
+           (address "amin@shemshak.org")
            (body "\nBest,\n")
            (eval (setq a/message-cite-say-hi t)))
           ("nnimap\\+gnu:.*"
@@ -1877,7 +1897,7 @@ https://csclub.uwaterloo.ca/~abandali/")
            (eval (set (make-local-variable 'message-user-fqdn) "fencepost.gnu.org")))
           ((header "subject" "ThankCRM")
            (to "webmasters-comment@gnu.org")
-           (body "Added  to 2019supporters.html.\n\nMoving to campaigns.\n")
+           (body "")
            (eval (setq a/message-cite-say-hi nil)))
           ("nnimap\\+uw:.*"
            (address "abandali@uwaterloo.ca")
@@ -1956,7 +1976,7 @@ https://csclub.uwaterloo.ca/~abandali/")
         message-subscribed-address-functions
         '(gnus-find-subscribed-addresses)
         message-dont-reply-to-names
-        "\\(\\(amin@bndl\\.org\\)\\|\\(.*@\\(aminb\\|amin\\.bndl\\)\\.org\\)\\|\\(\\(bandali\\|aminb?\\|mab\\)@gnu\\.org\\)\\|\\(a\\(min\\.\\)?bandali@uwaterloo\\.ca\\)\\|\\(abandali@csclub\\.uwaterloo\\.ca\\)\\)")
+        "\\(\\(amin@\\(shemshak\\|bndl\\)\\.org\\)\\|\\(.*@aminb\\.org\\)\\|\\(\\(bandali\\|aminb?\\|mab\\)@gnu\\.org\\)\\|\\(a\\(min\\.\\)?bandali@uwaterloo\\.ca\\)\\|\\(abandali@csclub\\.uwaterloo\\.ca\\)\\)")
   (require 'company-ebdb)
   :hook (;; (message-setup . mml-secure-message-sign-pgpmime)
          (message-mode . flyspell-mode)
@@ -2111,6 +2131,7 @@ https://csclub.uwaterloo.ca/~abandali/")
 (use-feature erc-track
   :after erc
   :custom
+  (erc-track-enable-keybindings nil)
   (erc-track-exclude-types '("JOIN" "MODE" "NICK" "PART" "QUIT"
                              "324" "329" "332" "333" "353" "477"))
   (erc-track-priority-faces-only 'all)
@@ -2123,7 +2144,7 @@ https://csclub.uwaterloo.ca/~abandali/")
   :after erc)
 
 (use-package znc
-  :straight (:host nil :repo "https://git.bndl.org/amin/znc.el")
+  :straight (:host nil :repo "https://git.shemshak.org/amin/znc.el")
   :bind (("C-c a e e" . znc-erc)
          ("C-c a e a" . znc-all))
   :config
@@ -2132,11 +2153,11 @@ https://csclub.uwaterloo.ca/~abandali/")
                 ((null auth) (error "Couldn't find znca's authinfo"))
                 (t (funcall (plist-get (car auth) :secret)))))))
     (setq znc-servers
-          `(("znc.bndl.org" 1337 t
+          `(("znc.shemshak.org" 1337 t
              ((freenode "amin/freenode" ,pwd)))
-            ("znc.bndl.org" 1337 t
+            ("znc.shemshak.org" 1337 t
              ((moznet "amin/moznet" ,pwd)))
-            ("znc.bndl.org" 1337 t
+            ("znc.shemshak.org" 1337 t
              ((oftc "amin/oftc" ,pwd)))))))
 
 \f