summaryrefslogtreecommitdiff
path: root/.emacs.d/emacs.org
diff options
context:
space:
mode:
authorThanos Apollo <[email protected]>2023-02-10 21:29:26 +0200
committerThanos Apollo <[email protected]>2023-02-10 21:29:26 +0200
commit44e63b0e4e4f6ef4f27d7acb51a51649010676c0 (patch)
tree2bd82cedd2c69dfba9d75d5e6470ae374486994c /.emacs.d/emacs.org
parent84b556331e481edb8d493dda63890c8682647e86 (diff)
emacs: Update setup for GuixSD
Diffstat (limited to '.emacs.d/emacs.org')
-rw-r--r--.emacs.d/emacs.org148
1 files changed, 75 insertions, 73 deletions
diff --git a/.emacs.d/emacs.org b/.emacs.d/emacs.org
index 893bcab..424106b 100644
--- a/.emacs.d/emacs.org
+++ b/.emacs.d/emacs.org
@@ -52,10 +52,19 @@ We check the ~$HOSTNAME~, if it's one of my devices running GuixSD.
we use ~guix-emacs-autoload-packages~ to load emacs packages installed using guix if ~t~
+ If you are running GuixSD, replace the following hostnames ~fsociety~ or ~heisenberg~ with your own ~$HOSTNAME~
#+begin_src emacs-lisp
- (when (or (string= (system-name) "fsociety")
- (string= (system-name) "heisenberg"))
+ ;; When guix t, load emacs packages
+ (when (require 'guix t)
(add-to-list 'load-path "~/.guix-profile/share/emacs/site-lisp")
(guix-emacs-autoload-packages))
+
+ (with-eval-after-load 'geiser-guile
+ (add-to-list 'geiser-guile-load-path "~/dotfiles/.config/guix"))
+
+ ;; Personal Information
+ (setq user-full-name "Thanos Apollo")
+ (setq user-mail-address "[email protected]")
+ (setq copyright-names-regexp
+ (format "%s <%s>" user-full-name user-mail-address))
#+end_src
** Define and install packages
*** List of required packages
@@ -1036,78 +1045,71 @@ In macOS, I have installed it through homebrew.
* mu4e | Email Configuration
-# ** MacOS
-# If it's a mac, load from homebrew path
-
-# #+begin_src emacs-lisp
-# (when (equal system-type 'darwin)
-# (use-package mu4e
-# :load-path "/opt/homebrew/share/emacs/site-lisp/mu/mu4e/"))
-# #+end_src
-
#+begin_src emacs-lisp
-(when (equal system-type 'darwin)
- (use-package mu4e
- :load-path "/opt/homebrew/share/emacs/site-lisp/mu/mu4e/"))
-
-(require 'mu4e)
-
-(setq mu4e-update-interval (* 10 60))
-(setq mu4e-get-mail-command "mbsync -a")
-(setq mu4e-maildir-list "~/Mail/Inbox")
-
-(defun set-mu4e-context (context-name full-name mail-address signature server)
- "Return a mu4e context named CONTEXT-NAME with :match-func matching
- folder name CONTEXT-NAME in Maildir. The context's `user-mail-address',
- `user-full-name' and `mu4e-compose-signature'`smtpmail-smpt-server' is set to MAIL-ADDRESS
- FULL-NAME SIGNATURE and SERVER respectively.
- Special folders are set to context specific folders."
- (let ((dir-name (concat "/" context-name)))
- (make-mu4e-context
- :name context-name
- ;; we match based on the maildir of the message
- :match-func
- `(lambda (msg)
- (when msg
- (string-match-p
- ,(concat "^" dir-name)
- (mu4e-message-field msg :maildir))))
- :vars
- `((user-mail-address . ,mail-address)
- (user-full-name . ,full-name)
- (mu4e-sent-folder . ,(concat dir-name "/Sent"))
- (mu4e-drafts-folder . ,(concat dir-name "/Drafts"))
- (mu4e-trash-folder . ,(concat dir-name "/Trash"))
- (mu4e-trash-folder . ,(concat dir-name "/Starred"))
- (mu4e-refile-folder . ,(concat dir-name "/Archive"))
- (smtpmail-smtp-service . ,465)
- (smtpmail-smtp-server . ,server)
- (mu4e-compose-signature . ,signature)))))
-;;Fixing duplicate UID errors when using mbsync and mu4e
-(setq mu4e-change-filenames-when-moving t)
-
-(setq mu4e-maildir-shortcuts
- '(("/Fastmail/Inbox" . ?i)
- ("/Fastmail/Sent" . ?s)
- ;; ("/Gmail/Trash" . ?t)
- ;; ("/Gmail/Drafts" . ?d)
- ;; ("/Gmail/[Gmail]/All Mail" . ?a
- ))
-
-(setq mu4e-contexts
- `(, (set-mu4e-context
- "Fastmail" "Thanos Apollo"
- "[email protected]" "Thanos\nhttps://thanosapollo.com/public"
- "smtp.fastmail.com")))
-
-;; (setq smtpmail-smtp-service 465
-;; smtpmail-stream-type 'ssl
-;; smtpmail-smtp-server "smtp.fastmail.com")
-
-
-
-(setq message-send-mail-function 'smtpmail-send-it
- smtpmail-stream-type 'ssl)
+ ;; In macOS, load mu4e through homebrew
+ (when (equal system-type 'darwin)
+ (use-package mu4e
+ :load-path "/opt/homebrew/share/emacs/site-lisp/mu/mu4e/"))
+ ;; Check if we have mu4e available
+ ;; if t load mu4e settings
+ (when (require 'mu4e t)
+ (setq mu4e-update-interval (* 10 60))
+ (setq mu4e-get-mail-command "mbsync -a")
+ (setq mu4e-maildir-list "~/Mail/Inbox")
+
+ (defun set-mu4e-context (context-name full-name mail-address signature server)
+ "Return a mu4e context named CONTEXT-NAME with :match-func matching
+ folder name CONTEXT-NAME in Maildir. The context's `user-mail-address',
+ `user-full-name' and `mu4e-compose-signature'`smtpmail-smpt-server' is set to MAIL-ADDRESS
+ FULL-NAME SIGNATURE and SERVER respectively.
+ Special folders are set to context specific folders."
+ (let ((dir-name (concat "/" context-name)))
+ (make-mu4e-context
+ :name context-name
+ ;; we match based on the maildir of the message
+ :match-func
+ `(lambda (msg)
+ (when msg
+ (string-match-p
+ ,(concat "^" dir-name)
+ (mu4e-message-field msg :maildir))))
+ :vars
+ `((user-mail-address . ,mail-address)
+ (user-full-name . ,full-name)
+ (mu4e-sent-folder . ,(concat dir-name "/Sent"))
+ (mu4e-drafts-folder . ,(concat dir-name "/Drafts"))
+ (mu4e-trash-folder . ,(concat dir-name "/Trash"))
+ (mu4e-trash-folder . ,(concat dir-name "/Starred"))
+ (mu4e-refile-folder . ,(concat dir-name "/Archive"))
+ (smtpmail-smtp-service . ,465)
+ (smtpmail-smtp-server . ,server)
+ (mu4e-compose-signature . ,signature)))))
+ ;;Fixing duplicate UID errors when using mbsync and mu4e
+ (setq mu4e-change-filenames-when-moving t)
+
+ (setq mu4e-maildir-shortcuts
+ '(("/Fastmail/Inbox" . ?i)
+ ("/Fastmail/Sent" . ?s)
+ ;; ("/Gmail/Trash" . ?t)
+ ;; ("/Gmail/Drafts" . ?d)
+ ;; ("/Gmail/[Gmail]/All Mail" . ?a
+ ))
+
+ (setq mu4e-contexts
+ `(, (set-mu4e-context
+ "Fastmail" "Thanos Apollo"
+ "[email protected]" "Thanos\nhttps://thanosapollo.com/public"
+ "smtp.fastmail.com")))
+
+ ;; (setq smtpmail-smtp-service 465
+ ;; smtpmail-stream-type 'ssl
+ ;; smtpmail-smtp-server "smtp.fastmail.com")
+
+
+
+ (setq message-send-mail-function 'smtpmail-send-it
+ smtpmail-stream-type 'ssl))
+
#+end_src