fix up from work

This commit is contained in:
Joe Ardent 2025-06-14 12:04:29 -07:00
parent 1c82c0ccf4
commit d8cab4e766
13 changed files with 160 additions and 114 deletions

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
(global-set-key [C-tab] #'other-window) (global-set-key [C-tab] #'other-window)
(global-set-key [C-S-tab] #'sother-window) (global-set-key [C-S-tab] #'sother-window)
(global-set-key [C-iso-lefttab] #'sother-window) (global-set-key [C-iso-lefttab] #'sother-window)

View file

@ -216,7 +216,8 @@ be updated accordingly.
#+end_quote #+end_quote
#+begin_src emacs-lisp :tangle no :results none #+begin_src emacs-lisp :tangle no :results none
(org-babel-tangle) ;; -*- lexical-binding: t; -*-
(org-babel-tangle)
#+end_src #+end_src
@ -672,6 +673,7 @@ Now we are ready to load our per-module configuration files:
This module defines everything related to the aesthetics of Emacs. This module defines everything related to the aesthetics of Emacs.
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-theme.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-theme.el" :mkdirp yes
;; -*- lexical-binding: t; -*-
;;; Everything related to the look of Emacs ;;; Everything related to the look of Emacs
#+end_src #+end_src
@ -1014,6 +1016,7 @@ in the function ~prot/enable-variable-pitch~.
:END: :END:
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-essentials.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-essentials.el" :mkdirp yes
;; -*- lexical-binding: t; -*-
;;; Essential configurations ;;; Essential configurations
(use-package emacs (use-package emacs
:ensure nil :ensure nil
@ -1569,73 +1572,74 @@ soon as I type a space after some characters I am using ~orderless~.
(There are more details in Prot's file, for the interested reader) (There are more details in Prot's file, for the interested reader)
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-completion.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-completion.el" :mkdirp yes
;;; General minibuffer settings ;; -*- lexical-binding: t; -*-
(use-package minibuffer ;;; General minibuffer settings
:ensure nil (use-package minibuffer
:config :ensure nil
;;;; Completion styles :config
(setq completion-styles '(basic substring initials flex orderless)) ; also see `completion-category-overrides' ;;;; Completion styles
(setq completion-pcm-leading-wildcard t) ; Emacs 31: make `partial-completion' behave like `substring' (setq completion-styles '(basic substring initials flex orderless)) ; also see `completion-category-overrides'
(setq completion-pcm-leading-wildcard t) ; Emacs 31: make `partial-completion' behave like `substring'
;; Reset all the per-category defaults so that (i) we use the ;; Reset all the per-category defaults so that (i) we use the
;; standard `completion-styles' and (ii) can specify our own styles ;; standard `completion-styles' and (ii) can specify our own styles
;; in the `completion-category-overrides' without having to ;; in the `completion-category-overrides' without having to
;; explicitly override everything. ;; explicitly override everything.
(setq completion-category-defaults nil) (setq completion-category-defaults nil)
;; A non-exhaustve list of known completion categories: ;; A non-exhaustve list of known completion categories:
;; ;;
;; - `bookmark' ;; - `bookmark'
;; - `buffer' ;; - `buffer'
;; - `charset' ;; - `charset'
;; - `coding-system' ;; - `coding-system'
;; - `color' ;; - `color'
;; - `command' (e.g. `M-x') ;; - `command' (e.g. `M-x')
;; - `customize-group' ;; - `customize-group'
;; - `environment-variable' ;; - `environment-variable'
;; - `expression' ;; - `expression'
;; - `face' ;; - `face'
;; - `file' ;; - `file'
;; - `function' (the `describe-function' command bound to `C-h f') ;; - `function' (the `describe-function' command bound to `C-h f')
;; - `info-menu' ;; - `info-menu'
;; - `imenu' ;; - `imenu'
;; - `input-method' ;; - `input-method'
;; - `kill-ring' ;; - `kill-ring'
;; - `library' ;; - `library'
;; - `minor-mode' ;; - `minor-mode'
;; - `multi-category' ;; - `multi-category'
;; - `package' ;; - `package'
;; - `project-file' ;; - `project-file'
;; - `symbol' (the `describe-symbol' command bound to `C-h o') ;; - `symbol' (the `describe-symbol' command bound to `C-h o')
;; - `theme' ;; - `theme'
;; - `unicode-name' (the `insert-char' command bound to `C-x 8 RET') ;; - `unicode-name' (the `insert-char' command bound to `C-x 8 RET')
;; - `variable' (the `describe-variable' command bound to `C-h v') ;; - `variable' (the `describe-variable' command bound to `C-h v')
;; - `consult-grep' ;; - `consult-grep'
;; - `consult-isearch' ;; - `consult-isearch'
;; - `consult-kmacro' ;; - `consult-kmacro'
;; - `consult-location' ;; - `consult-location'
;; - `embark-keybinding' ;; - `embark-keybinding'
;; ;;
(setq completion-category-overrides (setq completion-category-overrides
;; NOTE 2021-10-25: I am adding `basic' because it works better as a ;; NOTE 2021-10-25: I am adding `basic' because it works better as a
;; default for some contexts. Read: ;; default for some contexts. Read:
;; <https://debbugs.gnu.org/cgi/bugreport.cgi?bug=50387>. ;; <https://debbugs.gnu.org/cgi/bugreport.cgi?bug=50387>.
;; ;;
;; `partial-completion' is a killer app for files, because it ;; `partial-completion' is a killer app for files, because it
;; can expand ~/.l/s/fo to ~/.local/share/fonts. ;; can expand ~/.l/s/fo to ~/.local/share/fonts.
;; ;;
;; If `basic' cannot match my current input, Emacs tries the ;; If `basic' cannot match my current input, Emacs tries the
;; next completion style in the given order. In other words, ;; next completion style in the given order. In other words,
;; `orderless' kicks in as soon as I input a space or one of its ;; `orderless' kicks in as soon as I input a space or one of its
;; style dispatcher characters. ;; style dispatcher characters.
'((file (styles . (basic partial-completion orderless))) '((file (styles . (basic partial-completion orderless)))
(bookmark (styles . (basic substring))) (bookmark (styles . (basic substring)))
(library (styles . (basic substring))) (library (styles . (basic substring)))
(embark-keybinding (styles . (basic substring))) (embark-keybinding (styles . (basic substring)))
(imenu (styles . (basic substring orderless))) (imenu (styles . (basic substring orderless)))
(consult-location (styles . (basic substring orderless))) (consult-location (styles . (basic substring orderless)))
(kill-ring (styles . (emacs22 orderless))) (kill-ring (styles . (emacs22 orderless)))
(eglot (styles . (emacs22 substring orderless)))))) (eglot (styles . (emacs22 substring orderless))))))
#+end_src #+end_src
** The =nebkor-completion.el= for the ~orderless~ completion style ** The =nebkor-completion.el= for the ~orderless~ completion style
@ -2236,6 +2240,7 @@ I use ~vertico-repeat~ to mimic the functionality that ~helm-resume~ would provi
My old custom functions file. My old custom functions file.
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-functions.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-functions.el" :mkdirp yes
;; -*- lexical-binding: t; -*-
(defun diff-and-set-modified-p () (defun diff-and-set-modified-p ()
"Diff the current buffer with its associated file and set buffer modified status." "Diff the current buffer with its associated file and set buffer modified status."
(let* ((tmpfile (diff-file-local-copy (current-buffer))) (let* ((tmpfile (diff-file-local-copy (current-buffer)))
@ -2427,6 +2432,7 @@ Now on to the configurations.
tweak to ensure that ~consult-imenu~ returns good ~imenu~ results to us. tweak to ensure that ~consult-imenu~ returns good ~imenu~ results to us.
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-search.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-search.el" :mkdirp yes
;; -*- lexical-binding: t; -*-
(use-package imenu (use-package imenu
:ensure nil :ensure nil
:config :config
@ -2744,14 +2750,15 @@ them manually. I prefer this extra layer of safety. Plus, we have the
#+end_quote #+end_quote
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-dired.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-dired.el" :mkdirp yes
;;; Dired file manager and prot-dired.el extras ;; -*- lexical-binding: t; -*-
(use-package dired ;;; Dired file manager and prot-dired.el extras
:ensure nil (use-package dired
:commands (dired) :ensure nil
:config :commands (dired)
(setq dired-recursive-copies 'always) :config
(setq dired-recursive-deletes 'always) (setq dired-recursive-copies 'always)
(setq delete-by-moving-to-trash t)) (setq dired-recursive-deletes 'always)
(setq delete-by-moving-to-trash t))
#+end_src #+end_src
** The =nebkor-dired.el= switches for how files are listed (~ls~) ** The =nebkor-dired.el= switches for how files are listed (~ls~)
@ -3093,14 +3100,15 @@ name.
#+end_quote #+end_quote
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-window.el" #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-window.el"
;;; General window and buffer configurations ;; -*- lexical-binding: t; -*-
(use-package uniquify ;;; General window and buffer configurations
:ensure nil (use-package uniquify
:config :ensure nil
;;;; `uniquify' (unique names for buffers) :config
(setq uniquify-buffer-name-style 'forward) ;;;; `uniquify' (unique names for buffers)
(setq uniquify-strip-common-suffix t) (setq uniquify-buffer-name-style 'forward)
(setq uniquify-after-kill-buffer-p t)) (setq uniquify-strip-common-suffix t)
(setq uniquify-after-kill-buffer-p t))
#+end_src #+end_src
@ -3276,18 +3284,19 @@ integrates with ~magit~ ([[#h:b08af527-9ebf-4425-ac3a-24b4f371a4fd][The =nebkor-
#+end_quote #+end_quote
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-git.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-git.el" :mkdirp yes
;;;; `ediff' ;; -*- lexical-binding: t; -*-
(use-package ediff ;;;; `ediff'
:ensure nil (use-package ediff
:commands (ediff-buffers ediff-files ediff-buffers3 ediff-files3) :ensure nil
:init :commands (ediff-buffers ediff-files ediff-buffers3 ediff-files3)
(setq ediff-split-window-function 'split-window-horizontally) :init
(setq ediff-window-setup-function 'ediff-setup-windows-plain) (setq ediff-split-window-function 'split-window-horizontally)
:config (setq ediff-window-setup-function 'ediff-setup-windows-plain)
(setq ediff-keep-variants nil) :config
(setq ediff-make-buffers-readonly-at-startup nil) (setq ediff-keep-variants nil)
(setq ediff-merge-revisions-with-ancestor t) (setq ediff-make-buffers-readonly-at-startup nil)
(setq ediff-show-clashes-only t)) (setq ediff-merge-revisions-with-ancestor t)
(setq ediff-show-clashes-only t))
#+end_src #+end_src
** The =nebkor-git.el= section about project management (~project~) ** The =nebkor-git.el= section about project management (~project~)
@ -3454,6 +3463,21 @@ branches, etc.
'(("~/src/prototypes" . 1)))) '(("~/src/prototypes" . 1))))
#+end_src #+end_src
#+begin_quote
The difftastic Emacs package is designed to integrate difftastic - a structural diff tool - into
your Emacs workflow, enhancing your code review and comparison experience. This package
automatically displays difftastics output within Emacs using faces from your user theme, ensuring
consistency with your overall coding environment.
#+end_quote
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-git.el"
(elpaca (difftastic :host "github.com" :repo "pkryger/difftastic.el")
(use-package difftastic))
(use-package difftastic-bindings
:config (difftastic-bindings-mode))
#+end_src
** Finally, we provide the =nebkor-git.el= module ** Finally, we provide the =nebkor-git.el= module
:PROPERTIES: :PROPERTIES:
:CUSTOM_ID: h:4e7035c5-9350-4c51-be85-85f2539ed295 :CUSTOM_ID: h:4e7035c5-9350-4c51-be85-85f2539ed295
@ -3537,28 +3561,29 @@ Org is far more capable, so I switched to it completely.
#+end_quote #+end_quote
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-org.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-org.el" :mkdirp yes
;;; Calendar ;; -*- lexical-binding: t; -*-
(use-package calendar ;;; Calendar
:ensure nil (use-package calendar
:commands (calendar) :ensure nil
:config :commands (calendar)
(setq calendar-mark-diary-entries-flag nil) :config
(setq calendar-mark-holidays-flag t) (setq calendar-mark-diary-entries-flag nil)
(setq calendar-mode-line-format nil) (setq calendar-mark-holidays-flag t)
(setq calendar-time-display-form (setq calendar-mode-line-format nil)
'( 24-hours ":" minutes (setq calendar-time-display-form
(when time-zone (format "(%s)" time-zone)))) '( 24-hours ":" minutes
(setq calendar-week-start-day 1) ; Monday (when time-zone (format "(%s)" time-zone))))
(setq calendar-date-style 'iso) (setq calendar-week-start-day 1) ; Monday
(setq calendar-time-zone-style 'numeric) ; Emacs 28.1 (setq calendar-date-style 'iso)
(setq calendar-time-zone-style 'numeric) ; Emacs 28.1
(require 'solar) (require 'solar)
(setq calendar-latitude 35.17 ; Not my actual coordinates (setq calendar-latitude 35.17 ; Not my actual coordinates
calendar-longitude 33.36) calendar-longitude 33.36)
(require 'cal-dst) (require 'cal-dst)
(setq calendar-standard-time-zone-name "+0700") (setq calendar-standard-time-zone-name "+0700")
(setq calendar-daylight-time-zone-name "+0800")) (setq calendar-daylight-time-zone-name "+0800"))
#+end_src #+end_src
** The =nebkor-org.el= section about appointment reminders (~appt~) ** The =nebkor-org.el= section about appointment reminders (~appt~)
@ -4513,6 +4538,7 @@ title of the task, and the like. The documentation string of
:END: :END:
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-langs.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-langs.el" :mkdirp yes
;; -*- lexical-binding: t; -*-
;;;; Tabs, indentation, and the TAB key ;;;; Tabs, indentation, and the TAB key
(use-package emacs (use-package emacs
:ensure nil :ensure nil
@ -5334,6 +5360,7 @@ PDF Tools is an absolute powerhouse for reading and annotating PDF
files. It is my goto tool for reading any academic papers. files. It is my goto tool for reading any academic papers.
#+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-study.el" :mkdirp yes #+begin_src emacs-lisp :tangle "nebkor-modules/nebkor-study.el" :mkdirp yes
;; -*- lexical-binding: t; -*-
;;; PDF Tools for reading and annotating PDF files ;;; PDF Tools for reading and annotating PDF files
(use-package pdf-tools (use-package pdf-tools
:ensure (:host github :repo "vedang/pdf-tools" :branch "master") :ensure (:host github :repo "vedang/pdf-tools" :branch "master")
@ -6318,6 +6345,7 @@ figure it out.
:END: :END:
#+begin_src emacs-lisp :tangle "custom-lisp/nebkor-personal.el" :mkdirp yes #+begin_src emacs-lisp :tangle "custom-lisp/nebkor-personal.el" :mkdirp yes
;; -*- lexical-binding: t; -*-
(global-set-key [C-tab] #'other-window) (global-set-key [C-tab] #'other-window)
(global-set-key [C-S-tab] #'sother-window) (global-set-key [C-S-tab] #'sother-window)
(global-set-key [C-iso-lefttab] #'sother-window) (global-set-key [C-iso-lefttab] #'sother-window)

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;; General minibuffer settings ;;; General minibuffer settings
(use-package minibuffer (use-package minibuffer
:ensure nil :ensure nil

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;; Dired file manager and prot-dired.el extras ;;; Dired file manager and prot-dired.el extras
(use-package dired (use-package dired
:ensure nil :ensure nil

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;; Essential configurations ;;; Essential configurations
(use-package emacs (use-package emacs
:ensure nil :ensure nil

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
(defun diff-and-set-modified-p () (defun diff-and-set-modified-p ()
"Diff the current buffer with its associated file and set buffer modified status." "Diff the current buffer with its associated file and set buffer modified status."
(let* ((tmpfile (diff-file-local-copy (current-buffer))) (let* ((tmpfile (diff-file-local-copy (current-buffer)))

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;;; `ediff' ;;;; `ediff'
(use-package ediff (use-package ediff
:ensure nil :ensure nil
@ -74,4 +75,10 @@
(setq magit-repository-directories (setq magit-repository-directories
'(("~/src/prototypes" . 1)))) '(("~/src/prototypes" . 1))))
(elpaca (difftastic :host "github.com" :repo "pkryger/difftastic.el")
(use-package difftastic))
(use-package difftastic-bindings
:config (difftastic-bindings-mode))
(provide 'nebkor-git) (provide 'nebkor-git)

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;;; Tabs, indentation, and the TAB key ;;;; Tabs, indentation, and the TAB key
(use-package emacs (use-package emacs
:ensure nil :ensure nil

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;; Calendar ;;; Calendar
(use-package calendar (use-package calendar
:ensure nil :ensure nil

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
(use-package imenu (use-package imenu
:ensure nil :ensure nil
:config :config

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;; PDF Tools for reading and annotating PDF files ;;; PDF Tools for reading and annotating PDF files
(use-package pdf-tools (use-package pdf-tools
:ensure (:host github :repo "vedang/pdf-tools" :branch "master") :ensure (:host github :repo "vedang/pdf-tools" :branch "master")

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;; Everything related to the look of Emacs ;;; Everything related to the look of Emacs
;;(add-to-list 'default-frame-alist '(background-color . "snow")) ;;(add-to-list 'default-frame-alist '(background-color . "snow"))

View file

@ -1,3 +1,4 @@
;; -*- lexical-binding: t; -*-
;;; General window and buffer configurations ;;; General window and buffer configurations
(use-package uniquify (use-package uniquify
:ensure nil :ensure nil