diff options
Diffstat (limited to 'emacs.org')
-rwxr-xr-x | emacs.org | 1554 |
1 files changed, 0 insertions, 1554 deletions
diff --git a/emacs.org b/emacs.org deleted file mode 100755 index a316202..0000000 --- a/emacs.org +++ /dev/null @@ -1,1554 +0,0 @@ -#+TITLE: Emacs Configuration -#+AUTHOR: Thanos Apollo -#+PROPERTY: header-args :tangle ~/.emacs.d/init.el :mkdirp yes -#+auto_tangle: t -#+STARTUP: overview - -* System Information -** Essentials -Set my name and email address -#+begin_src emacs-lisp - (setf user-full-name "Thanos Apollo" - user-mail-address "[email protected]") -#+end_src -Check the ~$HOSTNAME~ to set a variable for different devices -#+begin_src emacs-lisp - (defvar is-zeus (equal (system-name) "zeus")) - (defvar is-hermes (equal (system-name) "hermes")) - (defvar is-phone (equal (system-name) "localhost")) -#+end_src -Setup default browser as ~firefox~ -#+begin_src emacs-lisp - (setf browse-url-browser-function 'browse-url-generic - browse-url-generic-program "firefox") -#+end_src -Set backup fails at ~~/Trash~ -#+begin_src emacs-lisp - (setf backup-directory-alist '((".*" . "~/.Trash"))) -#+end_src -Define essential keybindings -#+begin_src emacs-lisp - (define-prefix-command 'thanos/applications-map) - (global-set-key (kbd "C-c a") 'thanos/applications-map) - (when is-zeus - (define-key 'thanos/applications-map (kbd "g") 'guix)) - - (define-prefix-command 'Create) - (define-key thanos/applications-map (kbd "C-c") 'Create) - - (global-set-key (kbd "<escape>") 'keyboard-escape-quit) -#+end_src -** Paths -#+begin_src emacs-lisp - ;; mu4e - (add-to-list 'load-path "/usr/share/emacs/site-lisp/elpa/mu4e-1.8.14") - - ;; custom themes - (add-to-list 'custom-theme-load-path (expand-file-name "~/.emacs.d/themes/")) -#+end_src -* Setting Up Packages -** List of required packages -Request the following packages: -#+begin_src emacs-lisp - (defvar thanos/packages - '(emms tree-sitter org-snooze org-drill - all-the-icons all-the-icons-dired - all-the-icons-ivy-rich toc-org emojify - doom-themes doom-modeline gruvbox-theme counsel - vterm multi-vterm which-key ivy ivy-rich helpful - password-store org org-modern org-roam - visual-fill-column rainbow-delimiters flycheck - lsp-mode lsp-ui json-mode rjsx-mode - typescript-mode python-mode pyvenv company - company-box magit elfeed elfeed-goodies paredit - corfu monkeytype sudo-edit consult alsamixer - simple-httpd eshell-syntax-highlighting - org-superstar pdf-tools org-auto-tangle sly - org-download eshell-git-prompt eshell-vterm - hackernews circe gptel beacon ement mu4e-alert - pass eat nov yeetube stumpwm-mode telega - transmission)) -#+end_src -** Installation & activation -Set ~package-archives~, and install packages -#+begin_src emacs-lisp - (setf package-archives '(("melpa" . "https://melpa.org/packages/") - ("elpa" . "https://elpa.gnu.org/packages/") - ("nongnu" . "https://elpa.nongnu.org/nongnu/"))) - ;; Activate all the packages - (package-initialize) - ;; Install the missing packages - (dolist (package thanos/packages) - (unless (package-installed-p package) - (package-install package))) - - ;; Set and load custom.el - (setf custom-file (concat user-emacs-directory "custom.el")) - (load custom-file 'noerror) -#+end_src -* UI Settings -** Basic UI -Fonts and basic appearance settings for each device -#+begin_src emacs-lisp - (setf inhibit-startup-message t) - (setf initial-scratch-message nil) - (setf company-box-icons-alist 'company-box-icons-images) - ;; Transparency - (add-to-list 'default-frame-alist '(alpha-background . 90)) - (add-to-list 'default-frame-alist '(alpha 90 90)) - - - (add-hook 'dired-mode-hook 'all-the-icons-dired-mode) - - (when (equal is-phone nil) - (scroll-bar-mode -1) - (set-fringe-mode 10)) - - (beacon-mode 1) - (tool-bar-mode -1) - (tooltip-mode -1) - (menu-bar-mode -1) - (which-key-mode 1) - (blink-cursor-mode -1) - (menu-bar--visual-line-mode-enable) - (global-visual-line-mode 1) - - ;; Set emojis for emacs 29 - (require 'emojify) - (setf global-emojify-mode 1) - - (setf visible-bell t) - - (column-number-mode) - (global-display-line-numbers-mode 1) - (menu-bar--display-line-numbers-mode-relative) - ;;Disable line numbers for some modes - (dolist (mode '(pdf-view-mode-hook - org-mode-hook - term-mode-hook - shell-mode-hook - eshell-mode-hook - vterm-mode-hook - elfeed - vterm-mode - telega-chat-mode-hook - telega-root-mode-hook - nov-mode-hook - transmission-mode-hook)) - (add-hook mode (lambda () - (display-line-numbers-mode 0)))) - - ;; Set font-size for each device - (custom-set-faces - (if is-hermes '(default ((t (:inherit nil :height 120 :family "Jetbrains Mono")))) - '(default ((t (:inherit nil :height 135 :family "Jetbrains Mono")))))) -#+end_src -** Theme -#+begin_src emacs-lisp - (load-theme 'doom-monokai-classic) - - (doom-modeline-mode 1) - - (setf doom-modeline-height 35) - - ;; Don't display battery-mode on desktop - (if is-zeus - (display-battery-mode 0) - (display-battery-mode 1)) -#+end_src -** Ivy -#+begin_src emacs-lisp - (require 'ivy) - - (ivy-mode 1) - ;(setf ivy-use-virtual-buffers t) - ;(setf enable-recursive-minibuffers t) - (global-set-key (kbd "C-s") 'swiper) - (define-key ivy-minibuffer-map (kbd "TAB") 'ivy-alt-done) - (global-set-key "\C-s" 'swiper) - (global-set-key (kbd "C-c C-r") 'ivy-resume) - (global-set-key (kbd "<f6>") 'ivy-resume) - (global-set-key (kbd "M-x") 'counsel-M-x) - (global-set-key (kbd "C-x C-f") 'counsel-find-file) - (global-set-key (kbd "<f1> f") 'counsel-describe-function) - (global-set-key (kbd "<f1> v") 'counsel-describe-variable) - (global-set-key (kbd "<f1> o") 'counsel-describe-symbol) - (global-set-key (kbd "<f1> l") 'counsel-find-library) - (global-set-key (kbd "<f2> i") 'counsel-info-lookup-symbol) - (global-set-key (kbd "<f2> u") 'counsel-unicode-char) - (global-set-key (kbd "C-c g") 'counsel-git) - (global-set-key (kbd "C-c j") 'counsel-git-grep) - (global-set-key (kbd "C-c k") 'counsel-ag) - (global-set-key (kbd "C-x l") 'counsel-locate) - (global-set-key (kbd "C-S-o") 'counsel-rhythmbox) - (define-key minibuffer-local-map (kbd "C-r") 'counsel-minibuffer-history) - - (ivy-rich-mode 1) - (all-the-icons-ivy-rich-mode 1) - - (setf ivy-use-selectable-prompt t) - - (global-set-key (kbd "C-c m") 'consult-imenu) - (define-key thanos/applications-map (kbd "t") 'counsel-load-theme) -#+end_src -** Helpful -#+begin_src emacs-lisp - (require 'helpful) - (global-set-key (kbd "C-h f") #'helpful-callable) - (global-set-key (kbd "C-h v") #'helpful-variable) - (global-set-key (kbd "C-h k") #'helpful-key) - (global-set-key (kbd "C-h x") #'helpful-command) - - (global-set-key (kbd "C-c C-d") #'helpful-at-point) - (global-set-key (kbd "C-h F") #'helpful-function) - - (setf counsel-describe-function-function #'helpful-callable) - (setf counsel-describe-variable-function #'helpful-variable) -#+end_src -** Navigation -#+begin_src emacs-lisp - (global-set-key (kbd "C-x r d") 'bookmark-delete) - (global-set-key (kbd "C-x r C-r") 'bookmark-rename) - - ;; ibuffer - (global-set-key (kbd "C-x C-b") 'ibuffer) -#+end_src -* Pass -** Setup -Generate a random password between 20 and 40 characters -#+begin_src emacs-lisp - (setf password-store-password-length (+ 20 (random 20))) -#+end_src -** Pass Launcher -#+begin_src emacs-lisp - (require 'password-store) - - (defun thanos/pass-launcher () - "Launch Emacs as a front-end for pass." - (interactive) - (cl-flet ((pass-autotype (entry) - (let ((user (password-store-get-field entry "user")) - (pass (password-store-get entry))) - (start-process-shell-command - "xdotool" nil - (if user - (format "sleep 0.3 && xdotool getactivewindow type '%s' && xdotool getactivewindow key Tab && xdotool getactivewindow type '%s'" user pass) - (format "sleep 0.3 && xdotool getactivewindow type 'thanosapollo' && xdotool getactivewindow key Tab && xdotool getactivewindow type '%s'" pass)))))) - (let ((ivy-height 100)) - (unwind-protect - (with-selected-frame - (make-frame '((name . "thanos/pass-launcher") - (minibuffer . only) - (fullscreen . 0) - (undecorated . t) - (internal-border-width . 10) - (width . 80) - (height . 11))) - (let* ((choice (completing-read "Choose an action: " '("AUTO" "COPY PASS" "COPY USERNAME" "EDIT" "GENERATE"))) - (action (pcase choice - ("AUTO" #'pass-autotype) - ("COPY PASS" #'password-store-copy) - ("COPY USERNAME" #'(lambda (entry) (password-store-copy-field entry "user"))) - ("EDIT" #'password-store-edit) - ("GENERATE" #'password-store-generate)))) - (funcall action (completing-read "Search: " (password-store-list))) - (delete-frame))))))) - - (defun smtp-get-pass () - "Get password for smtp" - (interactive) - (password-store-copy-field "fastmail.com/[email protected]" "smtp")) -#+end_src -** Keybindings -#+begin_src emacs-lisp - (define-prefix-command 'thanos/pass) - (global-set-key (kbd "C-c p") 'thanos/pass) - (define-key thanos/pass (kbd "i") 'password-store-insert) - (define-key thanos/pass (kbd "e") 'password-store-edit) - (define-key thanos/pass (kbd "g") 'password-store-generate) - (define-key thanos/pass (kbd "s") 'smtp-get-pass) -#+end_src - -* App Launcher -#+begin_src emacs-lisp - (defun thanos/app-launcher () - "Launch Emacs as an Application Launcher." - (interactive) - (let ((ivy-height 100)) - (unwind-protect - (with-selected-frame - (make-frame '((name . "thanos/emacs-launcher") - (minibuffer . only) - (fullscreen . 0) - (undecorated . t) - (internal-border-width . 10) - (width . 80) - (height . 11))) - (counsel-linux-app) - (delete-frame))))) -#+end_src -* VM Manager -#+begin_src emacs-lisp - (defvar vm-directory "~/virtual-machines/") - - (defun vm-create-image () - "Create qcow2 image." - (interactive) - (let ((name (format "%s%s.qcow2" vm-directory (read-string "Name: "))) - (size (format "%s" (read-string "Size(G): ")))) - (shell-command - (format "qemu-img create -f qcow2 %s %sG" name size)))) - - - (defun vm-run () - "Spawn Virtual Machine." - (interactive) - (let ((memory (format "%sG" (read-string "Memory(G): "))) - (cores (read-string "Cores: ")) - (image (read-file-name "Image: " vm-directory)) - (iso (if (y-or-n-p "Load iso?? ") - (read-file-name "ISO: ") - nil))) - (start-process-shell-command - "virtual-machine" nil - (format "qemu-system-x86_64 -enable-kvm -m %s -smp %s -hda %s -vga qxl -device virtio-serial-pci -spice port=5784,disable-ticketing -display spice-app %s " - memory cores image (when iso (concat "-cdrom " iso)))))) -#+end_src -* Dired -** Functions -#+begin_src emacs-lisp - (require 'dired) - - (defun dired-watch-video () - "Watch play file with mpv." - (interactive) - (call-process-shell-command - (format "mpv \"%s\"" (dired-get-filename)) nil 0)) - - (defun dired-set-wallpaper () - "Set NAME as wallpaper using feh." - (interactive) - (call-process-shell-command - (format "feh --bg-scale %s" (dired-get-filename)) nil 0)) - - (defun dired-delete-files-except () - "Delete all files inside directory except match." - (interactive) - (let* ((directory (read-directory-name "Select directory: ")) - (files (directory-files directory t)) - (except-match (read-string "Except the ones that have: "))) - (dolist (file files) - (unless (or (string= "." (substring file -1)) - (string= ".." (substring file -2)) - (string-match except-match file)) - (dired-delete-file file t))))) - - (defun dired-delete-file-match () - "Delete all files inside directory except match." - (interactive) - (let* ((directory (read-directory-name "Select directory: ")) - (files (directory-files directory t)) - (match (read-string "Delete files that match: "))) - (dolist (file files) - (when (string-match-p match file) - (dired-delete-file file t))))) - - (defun dired-rename-capitalize-file () - "Capitalize the base name of the file at point in a dired buffer." - (interactive) - (let* ((file (dired-get-file-for-visit)) - (new-file (capitalize (file-name-nondirectory file)))) - (if (string-prefix-p "." file) - (message "Skipping file starting with '.'") - (progn - (rename-file file (concat (file-name-directory file) new-file)) - (revert-buffer) - (message "Renamed %s to %s" file new-file))))) -#+end_src -** Keybindings -#+begin_src emacs-lisp - (require 'dired) - (define-key dired-mode-map (kbd "b") 'dired-up-directory) - (define-key dired-mode-map (kbd "v") 'dired-watch-video) - (define-key dired-mode-map (kbd "z") 'wdired-change-to-wdired-mode) - (define-key dired-mode-map (kbd "C-c w") 'dired-set-wallpaper) - (define-key global-map (kbd "C-c d") 'dired-delete-files-except) -#+end_src -** All-the-icons -#+begin_src emacs-lisp - (add-hook 'dired-mode-hook 'all-the-icons-dired-mode) - (setf all-the-icons-dired-monochrome 'nil - all-the-icons-dired-v-adjust 0.10) -#+end_src -* Org -** Org-Roam -#+begin_src emacs-lisp - ;; Create ~/Notes, ignore errors if it's already made - (ignore-errors - (make-directory "~/Notes")) - - (setf org-roam-directory "~/Notes" - org-roam-dailies-directory "journal/") - - (org-roam-db-autosync-enable) - - (setf org-roam-node-display-template (concat "${title:50} "(propertize "${tags:30}" 'face 'org-tag))) - - (setf org-roam-db-node-include-function - (lambda () - (not (or (member "journal" (org-get-tags)) - (member "memorize" (org-get-tags)))))) - - ;; Functions - (defun org-insert-book () - "Insert org-link from ~/Library for book" - (interactive) - (let* ((book-path (read-file-name "Book: " "~/Library/"))) - (org-insert-link nil book-path (file-name-base book-path)))) - - ;;; Keybindings - (define-key org-mode-map (kbd "C-c b") 'org-insert-book) - - ;; Set maps - (define-prefix-command 'thanos/notes) - (global-set-key (kbd "C-c n") 'thanos/notes) - ;; org-roam keys - (define-key thanos/notes (kbd "t") 'org-roam-buffer-toggle) - (define-key thanos/notes (kbd "f") 'org-roam-node-find) - (define-key thanos/notes (kbd "i") 'org-roam-node-insert) - ;; Journaling - (define-prefix-command 'Journal) - (define-key thanos/notes (kbd "C-j") 'Journal) - (define-key Journal (kbd "d") 'Journaling/dailies) - (define-key Journal (kbd "C-c") 'org-roam-dailies-capture-today) - (define-key Journal (kbd "C-t") 'org-roam-dailies-capture-tomorrow) - (define-key Journal (kbd "C-y") 'org-roam-dailies-capture-yesterday) - (define-key Journal (kbd "c") 'org-roam-dailies-goto-today) - (define-key Journal (kbd "t") 'org-roam-dailies-goto-tomorrow) - (define-key Journal (kbd "y") 'org-roam-dailies-goto-yesterday) - - (define-key org-mode-map (kbd "C-c C-.") 'org-roam-tag-add) - (define-key org-mode-map (kbd "C-c i") 'org-id-get-create) - - ;; Templates - (setf org-roam-capture-templates - '(("d" "default" plain - "%?" - :if-new (file+head "%<%Y%m%d%H%M%S>-${slug}.org" "#+title: ${title}\n") - :unnarrowed t) - ("l" "programming language" plain - "* Characteristics\n\n- Family: %?\n- Inspired by: \n\n* Reference:\n\n" - :if-new (file+head "%<%Y%m%d%H%M%S>-${slug}.org" "#+title: ${title}\n") - :unnarrowed t) - ("p" "MUS" plain "* Goals\n\n%?\n\n* Tasks\n\n** TODO Add initial tasks\n\n* Dates\n\n" - :if-new (file+head "%<%Y%m%d%H%M%S>-${slug}.org" "#+title: ${title}\n#+filetags: MUS") - :unnarrowed t))) - ;; Dailies - (setf org-roam-dailies-capture-templates - '(("d" "default" entry - "* %?" - :target (file+head "%<%Y-%m-%d>.org" - "#+title: %<%Y-%m-%d>\n")) - ("j" "Daily Journaling" entry - (file "~/org/Templates/journaling.org") - :target (file+head "%<%Y-%m-%d>.org" - "#+title: %<%Y-%m-%d>\n")) - ("i" "Improve" entry - (file "~/org/Templates/improve.org") - :target (file+head "%<%Y-%m-%d>.org" - "#+title: %<%Y-%m-%d>\n")))) -#+end_src -** Themes -*** Dracula -#+begin_src emacs-lisp - (defun thanos/org-theme-dracula () - "Enable Dracula theme for Org headers." - (interactive) - (dolist - (face - '((org-level-1 1.7 "#8be9fd" extra-bold) - (org-level-2 1.6 "#bd93f9" extra-bold) - (org-level-3 1.5 "#50fa7b" bold) - (org-level-4 1.4 "#ff79c6" semi-bold) - (org-level-5 1.3 "#9aedfe" normal) - (org-level-6 1.2 "#caa9fa" normal) - (org-level-7 1.1 "#5af78e" normal) - (org-level-8 1.0 "#ff92d0" normal))) - (set-face-attribute (nth 0 face) nil - :font "JetBrains Mono" - :weight (nth 3 face) - :height (nth 1 face) - :foreground (nth 2 face))) - (set-face-attribute 'org-table nil - :font "JetBrains Mono" - :weight 'normal - :height 1.0 - :foreground "#bfafdf")) -#+end_src -*** Darkone -#+begin_src emacs-lisp - (defun thanos/org-theme-darkone () - "Enable Darkone theme for Org headers." - (interactive) - (dolist - (face - '((org-level-1 1.70 "#51afef" bold) - (org-level-2 1.55 "#7FBCD2" bold) - (org-level-3 1.40 "#da8548" bold) - (org-level-4 1.20 "#da8548" semi-bold) - (org-level-5 1.20 "#5699af" normal) - (org-level-6 1.20 "#a9a1e1" normal) - (org-level-7 1.10 "#46d9ff" normal) - (org-level-8 1.00 "#ff6c6b" normal))) - (set-face-attribute (nth 0 face) nil - :font "Jetbrains Mono" - :weight (nth 3 face) - :height (nth 1 face) - :foreground (nth 2 face))) - (set-face-attribute 'org-table nil - :font "Jetbrains Mono" - :weight 'normal - :height 1.0 - :foreground "#A66CFF")) -#+end_src -*** Gruvbox -#+begin_src emacs-lisp - (defun thanos/org-theme-gruvbox () - "Enable Darkone theme for Org headers." - (interactive) - (dolist - (face - '((org-level-1 1.70 "#fb4934" bold) - (org-level-2 1.55 "#98971a" bold) - (org-level-3 1.40 "#458588" bold) - (org-level-4 1.20 "#b16286" semi-bold) - (org-level-5 1.20 "#689d6a" normal) - (org-level-6 1.20 "#d3869b" normal) - (org-level-7 1.10 "#8ec07c" normal) - (org-level-8 1.00 "#ebdbb2" normal))) - (set-face-attribute (nth 0 face) nil - :font "Jetbrains Mono" - :weight (nth 3 face) - :height (nth 1 face) - :foreground (nth 2 face))) - (set-face-attribute 'org-table nil - :font "Jetbrains Mono" - :weight 'normal - :height 1.0 - :foreground "#A66CFF")) -#+end_src -*** Org Modern -#+begin_src emacs-lisp - (modify-all-frames-parameters - '((right-divider-width . 5) - (internal-border-width . 5))) - (dolist (face '(window-divider - window-divider-first-pixel - window-divider-last-pixel)) - (face-spec-reset-face face) - (set-face-foreground face (face-attribute 'default :background))) - (set-face-background 'fringe (face-attribute 'default :background)) - - (setf - ;; Edit settings - org-auto-align-tags nil - org-tags-column 0 - org-catch-invisible-edits 'show-and-error - org-special-ctrl-a/e t - org-insert-heading-respect-content t - - ;; Org styling, hide markup etc. - org-hide-emphasis-markers t - org-pretty-entities t - - ;; Agenda styling - org-agenda-tags-column 0 - org-agenda-block-separator ?─ - org-agenda-time-grid - '((daily today require-timed) - (800 1000 1200 1400 1600 1800 2000) - " ┄┄┄┄┄ " "┄┄┄┄┄┄┄┄┄┄┄┄┄┄┄") - org-agenda-current-time-string - "⭠ now ─────────────────────────────────────────────────") - - (global-org-modern-mode) - - (setf org-modern-todo nil) -#+end_src -** Settings -#+begin_src emacs-lisp - (require 'ox-md nil t) - (require 'org-download) - ;;(require 'org-drill) - - (setf org-directory "~/org/" - org-agenda-files '("~/org/agenda.org") - org-default-notes-file (expand-file-name "notes.org" org-directory) - org-ellipsis " ▼ " - org-log-done 'time - org-hide-emphasis-markers nil ;;change to t to hide emphasis markers - org-table-convert-region-max-lines 20000 - org-agenda-start-log-mode t - org-log-done 'time - org-log-into-drawer t - org-todo-keywords ;; This overwrites the default Doom org-todo-keywords - '((sequence - "TODO(t)" ;; A task that is ready to be tackled - "BLOG(b)" ;; Blog writing assignments - "GYM(g)" ;; Things to accomplish at the gym - "WAIT(w)" ;; Something is holding up this task - "|" ;; The pipe necessary to separate "active" states and "inactive" states - "DONE(d)" ;; Task has been completed - "CANCELLED(c)" )) - org-superstar-headline-bullets-list '("◉" "●" "○" "●" "○" "●" "◆") - org-superstar-itembullet-alist '((?+ . ?➤) (?- . ?✦))) ;; changes +/- symbols in item lists) -#+end_src - -=Keybindings= -#+begin_src emacs-lisp - (define-key org-mode-map (kbd "C-c t") 'org-time-stamp-inactive) - (define-key org-mode-map (kbd "C-c s") 'org-download-screenshot) -#+end_src -=Hooks= -#+begin_src emacs-lisp - (add-hook 'org-mode-hook 'thanos/org-theme-gruvbox) - (add-hook 'org-mode-hook 'flyspell-mode) - (add-hook 'org-mode-hook 'toc-org-mode) -#+end_src -** Babel -#+begin_src emacs-lisp - (defadvice org-edit-src-code (around set-buffer-file-name activate compile) - (let ((file-name (buffer-file-name))) ;; (1) - ad-do-it ;; (2) - (setf buffer-file-name file-name))) ;; (3) - - (org-babel-do-load-languages - 'org-babel-load-languages - '((emacs-lisp . t) - (python . t))) - - - (setf org-structure-template-alist - '(("e" . "src emacs-lisp") - ("p" . "src python") - ("l" . "src lisp") - ("b" . "src bash") - ("q" . "QUOTE"))) - - ;;Auto tangle - (add-hook 'org-mode-hook 'org-auto-tangle-mode) -#+end_src -** Org-download -#+begin_src emacs-lisp - (when (or (eq is-zeus t) - (eq is-hermes t)) - (setf org-download-screenshot-method "grim -g \"$(slurp)\" %s")) -#+end_src - -* Memorize -#+begin_src emacs-lisp - ;; (when is-zeus - ;; (load-file "~/Developer/memorize/memorize.el")) -#+end_src -* Markdown -** Theme -#+begin_src emacs-lisp - (defun thanos/markdown-theme () - (interactive) - (dolist - (face - '(markdown-header-face-1 :height 2.0)))) -#+end_src -** Settings -#+begin_src emacs-lisp - (require 'markdown-mode) - (setf markdown-header-scaling t) - (add-to-list 'auto-mode-alist '("\\.md\\'" . gfm-mode)) - (setf markdown-command "multimarkdown") -#+end_src -* DevTools -** Essentials -#+begin_src emacs-lisp - (electric-pair-mode 1) - (auto-insert-mode 1) - (global-flycheck-mode) - (global-set-key (kbd "M-.") 'xref-find-definitions) - (global-set-key (kbd "C-c l") 'display-line-numbers-mode) - - - (require 'company) - (add-hook 'after-init-hook 'global-company-mode) - (define-key company-active-map (kbd "TAB") 'company-indent-or-complete-common) - (setf company-idle-delay - (lambda () (if (company-in-string-or-comment) nil 0.0))) - - (require 'company-box) - (add-hook 'company-mode-hook 'company-box-mode) - - (setf indent-tabs-mode nil) - - (defun insert-brackets (&optional arg) - (interactive "P") - (insert-pair arg ?\[ ?\])) - - (global-set-key (kbd "C-x M-[") 'insert-brackets) -#+end_src -** Magit -#+begin_src emacs-lisp - (require 'magit) - (setf magit-display-buffer-function #'magit-display-buffer-same-window-except-diff-v1) - (define-prefix-command 'thanos/magit) - (global-set-key (kbd "C-c g") 'thanos/magit) - (define-key thanos/magit (kbd "c") 'magit-clone) -#+end_src -** Auto-insertions -+ Shell scripting/bash -#+begin_src emacs-lisp - (define-auto-insert '("\\.sh\\'" . "Bash skeleton") - '("Description:" \n - "#!/bin/bash")) - (add-hook 'shell-script-mode #'auto-insert) -#+end_src -** Emacs lisp -#+begin_src emacs-lisp - (setf tab-always-indent 'complete) - (add-to-list 'completion-styles 'initials t) - - (add-hook 'emacs-lisp-mode-hook #'rainbow-delimiters-mode) - (add-hook 'emacs-lisp-mode-hook #'company-mode) - (add-hook 'emacs-lisp-mode-hook #'display-line-numbers-mode) - - ;; Disable checkdoc flycheck for org-src buffers - (add-hook 'org-src-mode-hook #'(lambda () - (flycheck-disable-checker 'emacs-lisp-checkdoc))) -#+end_src -** Common Lisp -#+begin_src emacs-lisp - (setf inferior-lisp-program "sbcl") - (add-hook 'lisp-mode-hook #'rainbow-delimiters-mode) - (add-hook 'lisp-mode-hook #'company-mode) - (add-hook 'lisp-mode-hook #'display-line-numbers-mode) -#+end_src -** Scheme -#+begin_src emacs-lisp - (add-hook 'scheme-mode-hook #'rainbow-delimiters-mode) - (add-hook 'scheme-mode-hook #'company-mode) -#+end_src -** LSP -#+begin_src emacs-lisp - (defun thanos/lsp-mode-setup () - (setf lsp-headerline-breadcrumb-segments '(path-up-to-project file symbols)) - (lsp-headerline-breadcrumb-mode)) - - (require 'lsp-mode) - (add-hook 'lsp-mode #'thanos/lsp-mode-setup) - (setf lsp-keymap-prefix "C-c l") - (lsp-enable-which-key-integration t) - - (require 'lsp-ui) - (add-hook 'lsp-mode 'lsp-ui-mode) - (setf lsp-ui-doc-position 'bottom) -#+end_src -** Python -#+begin_src emacs-lisp - ;; set pylsp with lsp-mode - (setf lsp-pyls-server-command "~/usr/bin/pylsp") - - (require 'python-mode) - (add-to-list 'auto-mode-alist '("\\.py\\'" . python-mode)) - (add-hook 'python-mode 'lsp-deferred) -#+end_src -** JSON -#+begin_src emacs-lisp - (require 'json-mode) - (add-to-list 'auto-mode-alist '("\\.json'" . json-mode)) -#+end_src -* Elfeed -** Feeds -#+begin_src emacs-lisp - (require 'elfeed) - (require 'elfeed-goodies) - (setf elfeed-feeds - '(("https://hackaday.com/blog/feed/" - hackaday linux) - ("https://protesilaos.com/news.xml" - protesilaos) - ("https://protesilaos.com/codelog.xml" - proetesilaos) - ("https://guix.gnu.org/feeds/blog.atom" - gnu guix) - ("https://thanosapollo.com/posts/index.xml" - thanos) - ("http://nullprogram.com/feed/" - emacs linux) - ("https://drewdevault.com/blog/index.xml" - sourcehut drewdevault) - ("https://spacepub.space/feeds/videos.xml?videoChannelId=2" - drewdevault video) - ("https://odysee.com/$/rss/@DistroTube:2" - video dt) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UC7YOGHUfC1Tb6E4pudI9STA" - video mental) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCAiiOTio8Yu69c3XnR7nQBQ" - video daviwil) - ("https://videos.lukesmith.xyz/feeds/videos.atom?sort=-publishedAt&isLocal=true" - video luke) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCrc2iv2-G1FZ3VscM3zu2jg" - video zoogirl) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UC0uTPqBCFIpZxlz_Lv1tk_g" - video prot) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCq6VFHwMzcMXbuKyG7SQYIg" - video moist) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UC05XpvbHZUQOfA6xk4dlmcw" - video djware) - ("https://archlinux.org/feeds/news/" - ArchLinux Latest) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCsBjURrPoezykLs9EqgamOA" - fireship video) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCl-J-ovSJhA3or73Q2uVpow" - medicosperf video) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCSuHzQ3GrHSzoBbwrIq3LLA" - naomi video) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCqYPhGiB9tkShZorfgcL2lA" - WhatIveLearned video) - ("http://wikileaks.org/feed" - wikileaks) - ("https://hackernoon.com/feed" - hackernoon) - ("https://sachachua.com/blog/feed/" - sacha emacs) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCtMVHI3AJD4Qk4hcbZnI9ZQ" - video OrdinaeryGamers) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCl2mFZoRqjw_ELax4Yisf6w" - video Louis) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UC1yNl2E66ZzKApQdRuTQ4tw " - video sabine) - ("https://bits.debian.org/feeds/feed.rss" - debian linux) - ("https://torrentfreak.com/feed" - torrentfreak) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UCM6SlP9fiwPIjhkWmbg8Ojg" - video liberated-programmer) - ("https://odysee.com/$/rss/@seytonic:c" - video seytonic) - ("https://www.youtube.com/feeds/videos.xml?channel_id=UC1yNl2E66ZzKApQdRuTQ4tw" - video sabine) - ("https://wp.medscape.com/cx/rssfeeds/2700.xml" - med medscape) - ("https://nyxt.atlas.engineer/feed" - nyxt))) -#+end_src -** Watch Videos -Create function to watch videos using ~mpv~ -#+begin_src emacs-lisp - (defun elfeed-v-mpv (url) - "Watch a video from URL in MPV" - (start-process-shell-command "elfeed-video" nil (format "mpv \"%s\"" url))) - - (defun elfeed-view-mpv (&optional use-generic-p) - "Youtube-feed link" - (interactive "P") - (let ((entries (elfeed-search-selected))) - (cl-loop for entry in entries - do (elfeed-untag entry 'unread) - when (elfeed-entry-link entry) - do (elfeed-v-mpv it)) - (mapc #'elfeed-search-update-entry entries) - (unless (use-region-p) (forward-line)))) -#+end_src -** Settings & Keys -#+begin_src emacs-lisp - (define-key elfeed-search-mode-map (kbd "v") 'elfeed-view-mpv) - (define-key elfeed-search-mode-map (kbd "U") 'elfeed-update) - (define-key thanos/applications-map (kbd "f") 'elfeed) - - (setf elfeed-goodies/entry-pane-size 0.55) - (elfeed-goodies/setup) -#+end_src - -* mu4e -** Setting up mail -#+begin_src emacs-lisp - (require 'smtpmail) - (require 'mu4e) - - (when is-zeus (setf mu4e-update-interval (* 10 60))) - - (setf mu4e-get-mail-command "mbsync -a") - - (defun set-mu4e-context (context-name full-name mail-address signature) - "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")) - (mu4e-compose-signature . ,signature))))) - ;;Fixing duplicate UID errors when using mbsync and mu4e - (setf mu4e-change-filenames-when-moving t) - - (setf mu4e-maildir-shortcuts - '(("/Public/Inbox" . ?I) - ("/Inbox" . ?i) - ("/Sent" . ?s) - ("/Emacs/dev" . ?e) - ("/Guix/dev" . ?g))) - - (setf mu4e-contexts - (list - (make-mu4e-context - :name "Fastmail" - :match-func - (lambda (msg) - (when msg - (string-prefix-p "/" (mu4e-message-field msg :maildir)))) - :vars '((user-mail-address . "[email protected]") - (user-full-name . "Thanos Apollo") - (mu4e-drafts-folder . "/Drafts") - (mu4e-sent-folder . "/Sent") - (mu4e-refile-folder . "/Archive") - (mu4e-trash-folder . "/Trash"))) - (make-mu4e-context - :name "Public" - :match-func - (lambda (msg) - (when msg - (string-prefix-p "/" (mu4e-message-field msg :maildir)))) - :vars '((user-mail-address . "[email protected]") - (user-full-name . "Thanos Apollo") - (mu4e-drafts-folder . "/Drafts") - (mu4e-sent-folder . "/Sent") - (mu4e-refile-folder . "/Archive") - (mu4e-trash-folder . "/Trash"))))) - - (setf message-send-mail-function 'smtpmail-send-it - smtpmail-smtp-server "smtp.fastmail.com" - smtpmail-smtp-service 465 - smtpmail-stream-type 'ssl - mu4e-compose-signature "Thanos Apollo\nhttps://thanosapollo.com" - mu4e-compose-context-policy 'ask - mu4e-compose-format-flowed t) - - (setf mu4e-view-actions - (delete-dups - (append - '(("gapply git patches" . mu4e-action-git-apply-patch) - ("mgit am patch" . mu4e-action-git-apply-mbox) - ("bb4 am patch" . mu4e-action-git-apply-b4) - ("ssetup reword list with b4" . mu4e-action-setup-reword-b4) - ("crun checkpatch script" . my-mu4e-action-run-check-patch) - ("MCheck if merged" . my-mu4e-action-check-if-merged))))) -#+end_src -** Actions -#+begin_src emacs-lisp - (setf mu4e-view-actions - (delete-dups - (append - '(("gapply git patches" . mu4e-action-git-apply-patch) - ("mgit am patch" . mu4e-action-git-apply-mbox) - ("bb4 am patch" . mu4e-action-git-apply-b4) - ("ssetup reword list with b4" . mu4e-action-setup-reword-b4) - ("crun checkpatch script" . my-mu4e-action-run-check-patch) - ("MCheck if merged" . my-mu4e-action-check-if-merged))))) -#+end_src -** Notifications/Style -#+begin_src emacs-lisp - (require 'mu4e-alert) - (mu4e-alert-enable-mode-line-display) -#+end_src -** Keybindings -#+begin_src emacs-lisp - (define-key thanos/applications-map (kbd "m") 'mu4e) -#+end_src - -* Eshell -** Configuration with Eat -#+begin_src emacs-lisp - (setf eshell-visual-commands '()) - (eat-eshell-mode 1) -#+end_src -** Environment -#+begin_src emacs-lisp - (setenv "EDITOR" "emacsclient -n") - (setenv "DEBEMAIL" "[email protected]") - (setenv "DEBNAME" "Thanos Apollo") -#+end_src -** Completions -#+begin_src emacs-lisp - ;;;; sudo completion - (defun pcomplete/sudo () - "Completion rules for the `sudo' command." - (let ((pcomplete-ignore-case t)) - (pcomplete-here (funcall pcomplete-command-completion-function)) - (while (pcomplete-here (pcomplete-entries))))) - - ;;;; systemctl completion - (defcustom pcomplete-systemctl-commands - '("disable" "enable" "status" "start" "restart" "stop" "reenable" - "list-units" "list-unit-files") - "p-completion candidates for `systemctl' main commands" - :type '(repeat (string :tag "systemctl command")) - :group 'pcomplete) - - (defvar pcomplete-systemd-units - (split-string - (shell-command-to-string - "(systemctl list-units --all --full --no-legend;systemctl list-unit-files --full --no-legend)|while read -r a b; do echo \" $a\";done;")) - "p-completion candidates for all `systemd' units") - - (defvar pcomplete-systemd-user-units - (split-string - (shell-command-to-string - "(systemctl list-units --user --all --full --no-legend;systemctl list-unit-files --user --full --no-legend)|while read -r a b;do echo \" $a\";done;")) - "p-completion candidates for all `systemd' user units") - - (defun pcomplete/systemctl () - "Completion rules for the `systemctl' command." - (pcomplete-here (append pcomplete-systemctl-commands '("--user"))) - (cond ((pcomplete-test "--user") - (pcomplete-here pcomplete-systemctl-commands) - (pcomplete-here pcomplete-systemd-user-units)) - (t (pcomplete-here pcomplete-systemd-units)))) - - ;;;; man completion - (defvar pcomplete-man-user-commands - (split-string - (shell-command-to-string - "apropos -s 1 .|while read -r a b; do echo \" $a\";done;")) - "p-completion candidates for `man' command") - - (defun pcomplete/man () - "Completion rules for the `man' command." - (pcomplete-here pcomplete-man-user-commands)) - - ;; hut completion - (defcustom pcomplete-hut-commands - '("builds" "export" "git" "graphql" "lists" "help" "hg" - "init" "meta" "pages" "paste" "todo") - "p-completion candidates for `hut' main commands" - :type '(repeat (string :tag "hut command")) - :group 'pcomplete) - - (defun pcomplete/hut () - "Completion rules for `hut' command" - (pcomplete-here (append pcomplete-hut-commands))) -#+end_src -** Aliases & Paths -#+begin_src emacs-lisp - (setf thanos/eshell-aliases - '((g . magit) - (gl . magit-log) - (d . dired) - (o . find-file) - (oo . find-file-other-window) - (ll . (lambda () (eshell/ls '-la))) - (eshell/clear . eshell/clear-scrollback))) - - ;; Define aliases using `mapc` - (mapc (lambda (alias) - (defalias (car alias) (cdr alias))) - thanos/eshell-aliases) - - ;; PATH - (defvar eshell-path-env (getenv "~/.local/bin")) -#+end_src -** Prompt -#+begin_src emacs-lisp - (require 'eshell-git-prompt) - ;; customize multiline theme - (defun eshell-git-prompt-multiline () - "Eshell Git prompt inspired by spaceship-prompt." - (let (separator hr dir git git-dirty time sign command) - (setf separator (with-face " | " 'eshell-git-prompt-multiline-secondary-face)) - (setf hr (with-face (concat "\n" (make-string (/ (window-total-width) 2) ?─) "\n") 'eshell-git-prompt-multiline-secondary-face)) - (setf dir - (concat - (concat (abbreviate-file-name (eshell/pwd))))) - (setf git - (concat (with-face "⎇" 'eshell-git-prompt-exit-success-face) - (concat (eshell-git-prompt--branch-name)))) - (setf git-dirty - (when (eshell-git-prompt--branch-name) - (if (eshell-git-prompt--collect-status) - (with-face " ✎" 'eshell-git-prompt-modified-face) - (with-face " ✔" 'eshell-git-prompt-exit-success-face)))) - (setf time (with-face (format-time-string "%I:%M:%S %p") 'eshell-git-prompt-multiline-secondary-face)) - (setf sign - (if (= (user-uid) 0) - (with-face "\n#" 'eshell-git-prompt-multiline-sign-face) - (with-face "\nλ" 'eshell-git-prompt-multiline-sign-face))) - (setf command (with-face " " 'eshell-git-prompt-multiline-command-face)) - - - (eshell-git-prompt---str-read-only - (concat hr dir separator git git-dirty separator time sign command)))) - - (eshell-git-prompt-use-theme 'multiline) - - (eshell-syntax-highlighting-global-mode 1) - - (setf eshell-highlight-prompt t) -#+end_src -** Multi Eshell -#+begin_src emacs-lisp - (defun if-void (arg default) - (if (boundp arg) - (eval arg) - default - )) - - (defgroup multi-eshell nil - "Simple support for having multiple shells open." - :group 'languages) - - (defcustom multi-eshell-shell-function '(eshell) - "Command called to create shell" - :group 'multi-eshell) - - (defcustom multi-eshell-name "*eshell*" "The name of the buffer opened by the shell command." - :type 'string - :group 'multi-eshell) - - (defun multi-eshell-function () "This function opens the appropriate shell." (eval multi-eshell-shell-function) ) - ;;;(defvar multi-eshell-function `(shell) ) ;;; Defines the shell. ('shell) or ('eshell) - ;(defvar multi-eshell-name "*eshell*") ;;; Name of default shell or eshell buffer - - (defvar multi-eshell-ring (make-ring 100) "This stores a bunch of buffers, which are shells created by multi-eshell." ) - (setf multi-eshell-index 0 ) - (defvar multi-eshell-last-buffer nil) - - (defun multi-eshell-is-current-buffer-current-multi-eshell (&optional ignored) - "Checks if current buffer is the current multi-eshell." - (eq (current-buffer) (ring-ref multi-eshell-ring multi-eshell-index)) - ) - - (defun multi-eshell-switch-to-current-shell (&optional ignored) - "Switch to shell buffer." - (if (buffer-live-p (ring-ref multi-eshell-ring multi-eshell-index)) - (switch-to-buffer (ring-ref multi-eshell-ring multi-eshell-index)) - ) - ) - - (defun multi-eshell-current-shell (&optional ignored) - "Returns the current multi-eshell." - (ring-ref multi-eshell-ring multi-eshell-index) - ) - - (defun multi-eshell-switch-to-next-live-shell (&optional ignored) - "Switches to the next live shell. Creates one if none exists." - (interactive "p") - (let ((still-looking t) - (empty nil)) - (while (and still-looking (not empty)) - (if (ring-empty-p multi-eshell-ring) - (progn - (setf empty t) - (multi-eshell 1) - ) - (progn - (if (buffer-live-p (ring-ref multi-eshell-ring multi-eshell-index)) - (progn - (setf multi-eshell-index (+ multi-eshell-index 1)) - (switch-to-buffer (ring-ref multi-eshell-ring multi-eshell-index)) - (setf still-looking nil) - ) - (ring-remove multi-eshell-ring multi-eshell-index) - ) - ) - ) - ) - ) - ) - - ;;;###autoload - (defun multi-eshell-go-back (&optional ignored) - "Switch to buffer multi-eshell-last-buffer." - (interactive "p") - (if (buffer-live-p multi-eshell-last-buffer) - (switch-to-buffer multi-eshell-last-buffer) - (message "Last buffer visited before multi-eshell is gone. Nothing to go back to..") - )) - - - ;;;###autoload - (defun multi-eshell-switch (&optional ignored) - "If current buffer is not an multi-eshell, switch to current multi-eshell buffer. Otherwise, switch to next multi-eshell buffer." - (interactive "p") - (progn - (setf multi-eshell-last-buffer (current-buffer)) - (let ((still-looking t) - (empty nil)) - (if (ring-empty-p multi-eshell-ring) - (multi-eshell 1) - (if (and (buffer-live-p (multi-eshell-current-shell) ) - (not (eq (multi-eshell-current-shell) (current-buffer)))) - (switch-to-buffer (multi-eshell-current-shell)) - (multi-eshell-switch-to-next-live-shell) - ) - ) - ))) - - ;;;###autoload - (defun multi-eshell (&optional numshells) - "Creates a shell buffer. If one already exists, this creates a new buffer, with the name '*shell*<n>', where n is chosen by the function generate-new-buffer-name." - (interactive "p") - (progn - (setf multi-eshell-last-buffer (current-buffer)) - (dotimes (i (if-void 'numshells 1) nil) - (let ( (tempname (generate-new-buffer-name "*tempshell*")) - (new-buff-name (generate-new-buffer-name multi-eshell-name)) - (localdir default-directory) - ) - (if (eq (get-buffer multi-eshell-name) nil) ;If a - (progn - (multi-eshell-function) - ;(process-send-string (get-buffer-process new-buff-name) (concat "cd " localdir "\n")) - (ring-insert multi-eshell-ring (current-buffer) ) - (setf multi-eshell-index (+ multi-eshell-index 1)) - ) - (progn - (interactive) - (multi-eshell-function) - (rename-buffer tempname) - (multi-eshell-function) - (rename-buffer new-buff-name ) - (switch-to-buffer tempname) - (rename-buffer multi-eshell-name) - (switch-to-buffer new-buff-name) - ;(process-send-string (get-buffer-process new-buff-name) (concat "cd " localdir "\n")) - (ring-insert multi-eshell-ring (current-buffer) ) - (setf multi-eshell-index (+ multi-eshell-index 1)) - ) - ) - ) - ) - ) - ) - - (defun shell-with-name (name) - "Creates a shell with name given by the first argument, and switches to it. If a buffer with name already exists, we simply switch to it." - (let ((buffer-of-name (get-buffer name)) - (tempname (generate-new-buffer-name "*tempshell*") ) ) - (cond ((bufferp buffer-of-name) ;If the buffer exists, switch to it (assume it is a shell) - (switch-to-buffer name)) - ( (bufferp (get-buffer multi-eshell-name)) - (progn - (multi-eshell-function) - (rename-buffer tempname) - (multi-eshell-function) - (rename-buffer name) - (switch-to-buffer tempname) - (rename-buffer multi-eshell-name) - (switch-to-buffer name))) - ( t - (progn - (multi-eshell-function) - (rename-buffer name)))))) -#+end_src -** Keybindings -#+begin_src emacs-lisp - (define-prefix-command 'thanos/eshell-map) - (global-set-key (kbd "C-c e") 'thanos/eshell-map) - - (define-key thanos/eshell-map (kbd "o") 'multi-eshell) - (define-key thanos/eshell-map (kbd "n") 'multi-eshell-switch) -#+end_src -* Vterm -#+begin_src emacs-lisp - (defvar thanos/vterm-map (make-sparse-keymap)) - (define-prefix-command 'thanos/vterm-map) - (define-key global-map (kbd "C-c v") 'thanos/vterm-map) - (define-key thanos/vterm-map (kbd "n") 'multi-vterm-next) - (define-key thanos/vterm-map (kbd "p") 'multi-vterm-prev) - (define-key thanos/vterm-map (kbd "d") 'multi-vterm-dedicated-open) - (define-key thanos/vterm-map (kbd "o") 'multi-vterm) -#+end_src -* Chatgpt -#+begin_src emacs-lisp - (require 'gptel) - (define-key 'thanos/applications-map (kbd "c") 'gptel-send) - (setf gptel-api-key (password-store-get "chatgpt/api") - gptel-model 'gpt-4-32k) -#+end_src -* Multimedia -** YeeTube -*** Vimeo -+ Downlaod videos from ~vimeo~, /just change .json to .mpd on master.json/ - #+begin_src emacs-lisp - (defun yeetube-download-vimeo-videos () - (interactive) - (let ((url "") - (name "") - (download-counter 1)) - (while (not (string= url "q")) - (setf url (read-string "Enter URL (q to quit): ")) - (unless (string= url "q") - (setf name (read-string (format "Custom name (download counter: %d) " download-counter))) - (setf download-counter (1+ download-counter)) - (call-process-shell-command - (format - "yt-dlp '%s' -o '%s'" - (replace-regexp-in-string "\\.json" ".m3u8" url) name) - nil 0))))) - #+end_src -*** Ffmpeg -+ Use ~ffmpeg~ to download videos - -#+begin_src emacs-lisp - (defun yeetube-download-videos-ffmpeg () - "Download one or multiple videos using yt-dlp. - This command is not meant to be used in the *Yeetube Search* buffer. - - Usage Example: - Open a Dired buffer and navigate where you want to download your videos, - then run this command interactively. You can leave the 'Custom name:' - prompt blank to keep the default name." - (interactive) - (let ((url "") - (name "") - (download-counter 1) - (stored-contents nil)) - ;; Read links and names until "q" is entered - (while (not (string= url "q")) - (setf url (read-string "Enter URL (q to quit): ")) - (unless (string= url "q") - (setf name (read-string (format "Custom name (download counter: %d) " download-counter))) - (push (cons url name) stored-contents) - (setf download-counter (1+ download-counter)))) - ;; Process the collected links and names - (dolist (pair stored-contents) - (let ((url (car pair)) - (name (cdr pair))) - (async-shell-command - (format - "ffmpeg -protocol_whitelist file,crypto,data,https,tls,tcp -stats -i '%s' -codec copy '%s.mp4'" - url name)))))) -#+end_src -*** Keybindings -#+begin_src emacs-lisp - (when is-zeus - (load-file "~/Developer/yeetube.el/yeetube.el")) - (require 'yeetube) - - (setf yeetube-results-limit 30 - yeetube-mpv-disable-video t) - - (define-prefix-command 'thanos/yeetube) - (global-set-key (kbd "C-c y") 'thanos/yeetube) - (define-key thanos/yeetube (kbd "s") 'yeetube-search) - (define-key thanos/yeetube (kbd "b") 'yeetube-play-saved-video) - (define-key thanos/yeetube (kbd "d") 'yeetube-download-videos) - (define-key thanos/yeetube (kbd "p") 'yeetube-mpv-toggle-pause) - (define-key thanos/yeetube (kbd "C-p") 'yeetube-mpv-toggle-video) - (define-key thanos/yeetube (kbd "k") 'yeetube-remove-saved-video) - (define-key thanos/yeetube (kbd "u") 'yeetube-change-platform) - (define-key thanos/yeetube (kbd "C-d") 'yeetube-download-vimeo-videos) - - (define-key yeetube-mode-map (kbd "c") 'yeetube-switch-mpv) -#+end_src - -** EMMS -#+begin_src emacs-lisp - (require 'emms) - (emms-all) - (setf emms-player-list '(emms-player-mpv) - emms-player-mpv-parameters '("--no-video") - emms-info-functions '(emms-info-native) - emms-playlist-buffer-name "*Music*" - emms-source-file-default-directory "~/Music/jazz") - (define-key 'thanos/applications-map (kbd "e") 'emms) - (define-key emms-playlist-mode-map (kbd "A") 'emms-add-directory-tree) -#+end_src -* Chat -** Ement -#+begin_src emacs-lisp - (defun ement-login () - (interactive) - (ement-connect - :user-id "@thanos_apollon:matrix.org" - :password (password-store-get "matrix/thanos_apollon") - :uri-prefix "https://matrix-client.matrix.org")) - - (define-key thanos/applications-map (kbd "M-e") 'ement-login) -#+end_src -** ERC -#+begin_src emacs-lisp - ;;; Code: - (require 'erc) - - (setf erc-modules - '(sasl netsplit fill button match track completion readonly - networks ring autojoin noncommands irccontrols move-to-prompt stamp - menu list)) - - (defun erc-libera () - "Login to liberachat with erc." - (interactive) - (erc-tls :server "irc.libera.chat" :port 6697 - :nick "thanosapollo" - :user "thanosapollo" - :password (password-store-get "liberachat/thanos_apollo"))) - - (defun erc-mouse () - "Login to liberachat with erc." - (interactive) - (erc-tls :server "irc.myanonamouse.net" :port 6697 - :nick "Skylosophos" - :user "Skylosophos" - :password (password-store-get "myanonamouse.net/irc"))) - - (define-key thanos/applications-map (kbd "i") 'erc-libera) -#+end_src -** Telega -#+begin_src emacs-lisp - (require 'telega) - (add-hook 'telega-root-mode-hook 'emojify-mode) - (add-hook 'telega-chat-mode-hook 'emojify-mode) -#+end_src -* Extras -** StumpWM -#+begin_src emacs-lisp - (require 'stumpwm-mode) - (setf stumpwm-shell-program "~/.stumpwm.d/modules/util/stumpish/stumpish") -#+end_src -** pdf-tools -#+begin_src emacs-lisp - (require 'pdf-tools) - (pdf-tools-install) - ;;Add pdf-isearch-minor-mode hook, otherwise isearch will be buggy - ;;Darkmode hook, cause I don't want color or light in my life, I'm a vampire. - (add-hook 'pdf-view-mode-hook 'pdf-isearch-minor-mode) - (add-hook 'pdf-view-mode-hook 'pdf-view-midnight-minor-mode) - (add-to-list 'auto-mode-alist '("\\.pdf\\'" . 'pdf-view-mode)) -#+end_src -** nov -#+begin_src emacs-lisp - (add-to-list 'auto-mode-alist '("\\.epub\\'" . nov-mode)) - - (defun my-nov-font-setup () - (face-remap-add-relative 'variable-pitch - :family "Jetbrains Mono" - :height 100)) - (add-hook 'nov-mode-hook 'my-nov-font-setup) -#+end_src -** Random functions -#+begin_src emacs-lisp - (defun thanos/center-buffer () - "Centers/Uncenters selected buffer" - (interactive) - (if visual-fill-column-center-text - (setf visual-fill-column-center-text nil) - (setf visual-fill-column-center-text t)) - (visual-fill-column-mode 1)) - - - (defun thanos/rofi-switch-window () - "Navigate X11 buffers using rofi." - (interactive) - (start-process-shell-command - "rofi" nil "rofi -show window")) - - (defun thanos/run-in-background (command) - "Run COMMAND in the background." - (let ((command-parts (split-string command "[ ]+"))) - (apply #'call-process `(,(car command-parts) nil 0 nil ,@(cdr command-parts))))) - - (defun rofi () - "Run Rofi." - (interactive) - (thanos/run-in-background "rofi -show drun")) - - (defun thanos/volume-increase () - "Increase Volume." - (interactive) - (start-process-shell-command - "amixer" nil "amixer sset Master 5%+")) - - (defun thanos/volume-decrease () - "Decrease Volume." - (interactive) - (start-process-shell-command - "amixer" nil "amixer sset Master 5%-")) - - (defun thanos/restore-wallpaper () - "Set NAME as wallpaper." - (interactive) - (start-process-shell-command - "feh" nil "feh --bg-scale ~/dotfiles/wallpaper.png")) - - (defun thanos/emacs-keys () - "Swap caps with ctrl." - (interactive) - (start-process-shell-command - "setxkbmap" nil "setxkbmap us -option ctrl:swapcaps")) - - (defun thanos/greek-keyboard () - "Swap caps with ctrl." - (interactive) - (start-process-shell-command - "setxkbmap" nil "setxkbmap gr")) - - (defun thanos/exwm-update-class () - (exwm-workspace-rename-buffer exwm-class-name)) - - (defun eshell-new() - "Open a new instance of eshell." - (interactive) - (eshell 'N)) - - (defun make-mini-geiser () - (interactive) - (split-window-below 60) - (geiser nil)) - - (defun start-polybar () - "Check which system is running, start polybar accordingly." - (interactive) - (if (string= (system-name) "fsociety") - (start-process-shell-command - "polybar" nil "polybar main & polybar second") - (start-process-shell-command - "polybar" nil "polybar main"))) - - (defun create-text-scratch () - "create a scratch buffer" - (interactive) - (switch-to-buffer (get-buffer-create "*Text Scratch*")) - (markdown-mode) - (gptel-mode)) - - (define-key Create (kbd "t") 'create-text-scratch) - - (defun create-scratch () - (interactive) - (switch-to-buffer (get-buffer-create "*scratch*")) - (emacs-lisp-mode)) - - (defun thanos/frame () - (let ((frame (make-frame '((minibuffer . only))))) - (set-frame-height frame 300) - (set-frame-width frame 800) - (counsel-linux-app) - frame)) - - (define-key Create (kbd "e") 'create-scratch) - ;; -#+end_src - |