From 89dccfb79e116160dd4c906c09b1a85747cf8b22 Mon Sep 17 00:00:00 2001 From: Nate Anderson <nate.anderson@vasion.com> Date: Fri, 28 Mar 2025 14:56:16 -0600 Subject: [PATCH] More stuff --- init.el | 226 ++++++++++++++++++++++++-------- vline.el | 389 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 558 insertions(+), 57 deletions(-) create mode 100644 vline.el diff --git a/init.el b/init.el index e3aae0f..df2e0e3 100644 --- a/init.el +++ b/init.el @@ -11,7 +11,15 @@ (require 'use-package) (setq use-package-always-ensure t) ;; Auto-install packages -;; Bell Settings +;; autosave everything!! +(use-package super-save + :config + (super-save-mode +1)) + + +;; +;; UI enhancements +;; (setq ring-bell-function 'ignore) (setq visible-bell t) @@ -19,7 +27,7 @@ (set-face-attribute 'default nil :family "Hurmit Nerd Font Mono" :foundry "PfEd" - :height 120 + :height 140 :background "#000000" :foreground "#ffffff") @@ -32,59 +40,72 @@ (scroll-bar-mode -1) (global-display-line-numbers-mode 1) -(use-package super-save - :ensure t +(use-package beacon + :defer 2 :config - (super-save-mode +1)) + (beacon-mode 1)) -;; magit -(use-package magit - :ensure t) - -;; Packages with deferred loading -(use-package helm - :defer 1 - :bind (("M-x" . helm-M-x) - ("C-c h" . helm-command-prefix)) +(use-package dashboard :config - (global-unset-key (kbd "C-x c")) - (define-key helm-map (kbd "<tab>") 'helm-execute-persistent-action) - (define-key helm-map (kbd "C-i") 'helm-execute-persistent-action) - (define-key helm-map (kbd "C-z") 'helm-select-action) - (when (executable-find "curl") - (setq helm-google-suggest-use-curl-p t)) - (setq helm-split-window-in-side-p t - helm-move-to-line-cycle-in-source t - helm-ff-search-library-in-sexp t - helm-scroll-amount 8 - helm-ff-file-name-history-use-recentf t - helm-echo-input-in-header-line t - helm-autoresize-max-height 0 - helm-autoresize-min-height 20) - (helm-autoresize-mode 1) - (helm-mode 1)) + (dashboard-setup-startup-hook) -(use-package catppuccin-theme - :config - (setq catppuccin-flavor 'macchiato) - (load-theme 'catppuccin t) - (add-hook 'after-init-hook (lambda () (run-with-timer 0.5 nil #'catppuccin-reload)))) - -(use-package which-key - :defer 1 - :config - (setq which-key-idle-delay 0.01 - which-key-idle-secondary-delay 0.01) - (which-key-setup-side-window-right-bottom) - (which-key-mode)) + (setq dashboard-projects-backend 'projectile) + (setq dashboard-items '((recents . 5) + (bookmarks . 5) + (projects . 5) + (agenda . 5) + (registers . 5))) + ;; (use-package nerd-icons) + ;; (setq dashboard-display-icons-p t) ; display icons on both GUI and terminal + ;; (setq dashboard-icon-type 'nerd-icons) ; use `nerd-icons' package + ;; (setq dashboard-set-heading-icons t) + ;; (setq dashboard-set-file-icons t) + (use-package page-break-lines)) (use-package git-gutter :defer 2 :config (global-git-gutter-mode +1)) +(use-package catppuccin-theme + :config + (setq catppuccin-flavor 'macchiato) + (load-theme 'catppuccin t) + (add-hook 'after-init-hook (lambda () (run-with-timer 0.5 nil #'catppuccin-reload))) + ) + +(use-package which-key + :defer 1 + :config + (setq which-key-idle-delay 0 + which-key-idle-secondary-delay 0) + (which-key-setup-side-window-right-bottom) + (which-key-mode)) + +;; cleaner modeline +(use-package mood-line + :config + (mood-line-mode) + ;:custom () + ) + +;; +;; MEOW!! +;; (use-package meow :config + ;; Add selection back after using meow-save + (defun my/after-meow-save (&rest _args) + "Reactivate the selection after saving." + (let ((selection (meow--make-selection + 'select + (region-beginning) + (region-end)))) + (meow--select selection))) + + (advice-add 'meow-save :after #'my/after-meow-save) + (advice-add 'meow-clipboard-save :after #'my/after-meow-save) + (defvar meow-lsp-keymap (let ((keymap (make-sparse-keymap))) (define-key keymap (kbd "d") #'xref-find-definitions) @@ -119,10 +140,11 @@ '("8" . meow-digit-argument) '("9" . meow-digit-argument) '("0" . meow-digit-argument) - '("/" . helm-do-grep-ag) + '("/" . projectile-ripgrep) '("a" . eglot-code-actions) '("b" . helm-mini) - '("f" . helm-find-files)) + '("f" . projectile-find-file) + '("d" . helm-find-files)) (meow-normal-define-key '("0" . meow-expand-0) '("1" . meow-expand-1) @@ -142,6 +164,9 @@ '("[" . meow-beginning-of-thing) '("]" . meow-end-of-thing) '("/" . meow-visit) + '(">" . meow-indent) + '("<" . meow-indent) + '("%" . mark-whole-buffer) '("a" . meow-append) '("A" . meow-open-below) '("b" . meow-back-word) @@ -185,29 +210,112 @@ '("." . repeat) '("~" . upcase-region) '("`" . downcase-region) + '("<up>" . windmove-up) + '("<down>" . windmove-down) + '("<left>" . windmove-left) + '("<right>" . windmove-right) '("<escape>" . ignore))) - (meow-setup) (meow-global-mode 1)) -;; Lazy load other packages that are only needed for specific file types -(use-package markdown-mode :defer t) -(use-package go-mode :defer t) -;; (use-package cider :defer t) -(use-package eglot :defer t) -(add-hook 'go-mode-hook 'eglot-ensure) +;; +;; Other goodies +;; + +(use-package magit + :defer t) + +(use-package projectile + :defer t + :config + (use-package helm + :defer t + :bind (("M-x" . helm-M-x) + ("C-c h" . helm-command-prefix)) + :config + (global-unset-key (kbd "C-x c")) + (define-key helm-map (kbd "<tab>") 'helm-execute-persistent-action) + (define-key helm-map (kbd "C-i") 'helm-execute-persistent-action) + (define-key helm-map (kbd "C-z") 'helm-select-action) + (when (executable-find "curl") + (setq helm-google-suggest-use-curl-p t)) + (setq helm-split-window-in-side-p t + helm-move-to-line-cycle-in-source t + helm-ff-search-library-in-sexp t + helm-scroll-amount 8 + helm-ff-file-name-history-use-recentf t + helm-echo-input-in-header-line t + helm-autoresize-max-height 0 + helm-autoresize-min-height 20) + (helm-autoresize-mode 1) + (helm-mode 1)) + (use-package helm-projectile + :defer t) + (use-package helm-rg + :defer t) + (use-package ripgrep + :defer t) + ) + + +;; +;; LSP +;; +(use-package eglot + :defer t + :hook (prog-mode . eglot-ensure) ; hook eglot for any programming-mode-derived mode + ) -;; If using Company (recommended) (use-package company - :ensure t + :defer t :hook (eglot-managed-mode . company-mode) :config (setq company-idle-delay 0.1 company-minimum-prefix-length 1)) +;; Coding Specific +(use-package yaml-mode + :defer t) +(use-package markdown-mode + :defer t) +(use-package go-mode + :defer t) +(use-package dockerfile-mode + :defer t) +(use-package docker-compose-mode + :defer t) +(use-package cider + :defer t) +(use-package rainbow-delimiters + :hook (prog-mode . rainbow-delimiters-mode) + :defer t) +(use-package hl-todo + :hook (prog-mode . hl-todo-mode) + :config + (setq hl-todo-keyword-faces + '(("TODO" . "#FF0000") + ("FIXME" . "#FF0000") + ("DEBUG" . "#A020F0") + ("GOTCHA" . "#FF4500") + ("STUB" . "#1E90FF")))) -;; Optionally, measure startup time +;; LLM +(use-package gptel + :defer t + :config + (setq + gptel-model 'claude-3-5-haiku-20241022 + gptel-backend (gptel-make-anthropic "Claude" + :stream t :key gptel-api-key))) + +;; vterm +(use-package vterm + :defer t) + +;; +;; Startup +;; (add-hook 'emacs-startup-hook (lambda () (message "Emacs loaded in %s seconds" @@ -218,11 +326,15 @@ ;; Your init file should contain only one such instance. ;; If there is more than one, they won't work right. '(package-selected-packages - '(magit super-save company which-key use-package-hydra meow markdown-mode helm go-mode git-gutter eglot-inactive-regions cider catppuccin-theme))) + '(beacon catppuccin-theme cider company dashboard docker-compose-mode + dockerfile-mode eglot-inactive-regions git-gutter go-mode + gptel helm-projectile helm-rg hl-todo magit markdown-mode + meow mood-line nerd-icons page-break-lines + rainbow-delimiters ripgrep super-save use-package-hydra + vterm which-key yaml-mode))) (custom-set-faces ;; custom-set-faces was added by Custom. ;; If you edit it by hand, you could mess it up, so be careful. ;; Your init file should contain only one such instance. ;; If there is more than one, they won't work right. ) -(put 'downcase-region 'disabled nil) diff --git a/vline.el b/vline.el new file mode 100644 index 0000000..164b804 --- /dev/null +++ b/vline.el @@ -0,0 +1,389 @@ +;;; vline.el --- show vertical line (column highlighting) mode. + +;; Copyright (C) 2002, 2008-2012 by Taiki SUGAWARA <buzz.taiki@gmail.com> + +;; Author: Taiki SUGAWARA <buzz.taiki@gmail.com> +;; Maintainer: Taiki SUGAWARA <buzz.taiki@gmail.com> +;; Keywords: faces, editing, emulating +;; Version: 1.11 +;; Time-stamp: <2012-01-08 12:40:18 UTC taiki> +;; URL: http://www.emacswiki.org/cgi-bin/wiki/vline.el +;; URL: http://bitbucket.org/buzztaiki/elisp/src/tip/vline.el + +;; This file is free software; you can redistribute it and/or modify +;; it under the terms of the GNU General Public License as published by +;; the Free Software Foundation; either version 2, or (at your option) +;; any later version. + +;; This file is distributed in the hope that it will be useful, +;; but WITHOUT ANY WARRANTY; without even the implied warranty of +;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +;; GNU General Public License for more details. + +;; You should have received a copy of the GNU General Public License +;; along with GNU Emacs; see the file COPYING. If not, write to +;; the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, +;; Boston, MA 02110-1301, USA. + +;;; Commentary: + +;; put followings your .emacs +;; (require 'vline) +;; +;; if you display a vertical line, type M-x vline-mode. `vline-mode' doesn't +;; effect other buffers, because it is a buffer local minor mode. if you hide +;; a vertical line, type M-x vline-mode again. +;; +;; if you display a vertical line in all buffers, type M-x vline-global-mode. +;; +;; `vline-style' provides a display style of vertical line. see +;; `vline-style' docstring. +;; +;; if you don't want to visual line highlighting (ex. for performance +;; issue), please to set `vline-visual' to nil. +;; +;; if you don't want to use timer (ex. you want to highlight column +;; during moving cursors), please to set `vline-use-timer' to nil. + +;;; Change Log: + +;; 2012-01-08 taiki +;; fix for the Lint warnings. + +;; 2010-02-02 taiki +;; improve performance. + +;; 2009-08-26 taiki +;; support org-mode, outline-mode + +;; 2009-08-18 taiki +;; add autoload cookies. + +;; 2009-08-18 taiki +;; fix last line highlighting probrem. + +;; 2009-08-18 taiki +;; support visual line highlighting. +;; - Added face vline-visual. +;; - Added defcustom vline-visual-face. +;; - Added defcustom vline-visual. +;; +;; 2009-08-17 taiki +;; fix continuas line problem. +;; - Don't display vline when cursor into fringe +;; - Don't expand eol more than window width. +;; +;; 2008-10-22 taiki +;; fix coding-system problem. +;; - Added vline-multiwidth-space-list +;; - Use ucs code-point for japanese fullwidth space. +;; +;; 2008-01-22 taiki +;; applied patch from Lennart Borgman +;; - Added :group 'vline +;; - Added defcustom vline-current-window-only +;; - Added header items to simplify for users + +;;; TODO: +;; - track window-scroll-functions, window-size-change-functions. +;; - consider other minor modes (using {after,before}-string overlay). +;; - don't use {post,after}-command-hook for performance?? + +;;; Code: + +(defvar vline-overlay-table-size 200) +(defvar vline-overlay-table (make-vector vline-overlay-table-size nil)) +(defvar vline-line-char ?|) +(defvar vline-multiwidth-space-list + (list + ?\t + (decode-char 'ucs #x3000) ; japanese fullwidth space + )) +(defvar vline-timer nil) + +(defcustom vline-style 'face + "This variable holds vertical line display style. +Available values are followings: +`face' : use face. +`compose' : use composit char. +`mixed' : use face and composit char." + :type '(radio + (const face) + (const compose) + (const mixed)) + :group 'vline) + + +(defface vline + '((t (:background "light steel blue"))) + "A default face for vertical line highlighting." + :group 'vline) + +(defface vline-visual + '((t (:background "gray90"))) + "A default face for vertical line highlighting in visual lines." + :group 'vline) + +(defcustom vline-face 'vline + "A face for vertical line highlighting." + :type 'face + :group 'vline) + +(defcustom vline-visual-face 'vline-visual + "A face for vertical line highlighting in visual lines." + :type 'face + :group 'vline) + +(defcustom vline-current-window-only nil + "If non-nil then highlight column in current window only. +If the buffer is shown in several windows then highlight column only +in the currently selected window." + :type 'boolean + :group 'vline) + +(defcustom vline-visual t + "If non-nil then highlight column in visual lines. +If you specified `force' then use force visual line highlighting even +if `truncate-lines' is non-nil." + :type '(radio + (const nil) + (const t) + (const force)) + :group 'vline) + +(defcustom vline-use-timer t + "If non-nil, use idle timer instead of (post|after)-command-hook." + :type 'boolean + :group 'vline) + +(defcustom vline-idle-time 0.02 + "Idle time for highlighting column." + :type 'number + :group 'vline) + +;;;###autoload +(define-minor-mode vline-mode + "Display vertical line mode." + :global nil + :lighter " VL" + :group 'vline + (if vline-mode + (progn + (add-hook 'pre-command-hook 'vline-pre-command-hook nil t) + (if vline-use-timer + (vline-set-timer) + (add-hook 'post-command-hook 'vline-post-command-hook nil t))) + (vline-cancel-timer) + (vline-clear) + (remove-hook 'pre-command-hook 'vline-pre-command-hook t) + (remove-hook 'post-command-hook 'vline-post-command-hook t))) + +;;;###autoload +(define-global-minor-mode vline-global-mode + vline-mode + (lambda () + (unless (minibufferp) + (vline-mode 1))) + :group 'vline) + +(defun vline-pre-command-hook () + (when (and vline-mode (not (minibufferp))) + (vline-clear))) + +(defun vline-post-command-hook () + (when (and vline-mode (not (minibufferp))) + (vline-show))) + +(defun vline-set-timer () + (setq vline-timer + (run-with-idle-timer + vline-idle-time t 'vline-timer-callback))) + +(defun vline-cancel-timer () + (when (timerp vline-timer) + (cancel-timer vline-timer))) + +(defun vline-timer-callback () + (when (and vline-mode (not (minibufferp))) + (vline-show))) + +(defun vline-clear () + (mapcar (lambda (ovr) + (and ovr (delete-overlay ovr))) + vline-overlay-table)) + +(defsubst vline-into-fringe-p () + (eq (nth 1 (posn-at-point)) 'right-fringe)) + +(defsubst vline-visual-p () + (or (eq vline-visual 'force) + (and (not truncate-lines) + vline-visual))) + +(defsubst vline-current-column () + (if (or (not (vline-visual-p)) + ;; margin for full-width char + (< (1+ (current-column)) (window-width))) + (current-column) + ;; hmm.. posn-at-point is not consider tab width. + (- (current-column) + (save-excursion + (vertical-motion 0) + (current-column))))) + +(defsubst vline-move-to-column (col &optional bol-p) + (if (or (not (vline-visual-p)) + ;; margin for full-width char + (< (1+ (current-column)) (window-width))) + (move-to-column col) + (unless bol-p + (vertical-motion 0)) + (let ((bol-col (current-column))) + (- (move-to-column (+ bol-col col)) + bol-col)))) + +(defsubst vline-invisible-p (pos) + (let ((inv (get-char-property pos 'invisible))) + (and inv + (or (eq buffer-invisibility-spec t) + (memq inv buffer-invisibility-spec) + (assq inv buffer-invisibility-spec))))) + +(defsubst vline-forward (n) + (unless (memq n '(-1 0 1)) + (error "n(%s) must be 0 or 1" n)) + (if (not (vline-visual-p)) + (progn + (forward-line n) + ;; take care of org-mode, outline-mode + (when (and (not (bobp)) + (vline-invisible-p (1- (point)))) + (goto-char (1- (point)))) + (when (vline-invisible-p (point)) + (if (< n 0) + (while (and (not (bobp)) (vline-invisible-p (point))) + (goto-char (previous-char-property-change (point)))) + (while (and (not (bobp)) (vline-invisible-p (point))) + (goto-char (next-char-property-change (point)))) + (forward-line 1)))) + (vertical-motion n))) + +(defun vline-face (visual-p) + (if visual-p + vline-visual-face + vline-face)) + +(defun vline-show (&optional point) + (vline-clear) + (save-window-excursion + (save-excursion + (if point + (goto-char point) + (setq point (point))) + (let* ((column (vline-current-column)) + (lcolumn (current-column)) + (i 0) + (compose-p (memq vline-style '(compose mixed))) + (face-p (memq vline-style '(face mixed))) + (line-char (if compose-p vline-line-char ? )) + (line-str (make-string 1 line-char)) + (visual-line-str line-str) + (in-fringe-p (vline-into-fringe-p))) + (when face-p + (setq line-str (propertize line-str 'face (vline-face nil))) + (setq visual-line-str (propertize visual-line-str 'face (vline-face t)))) + (goto-char (window-end nil t)) + (vline-forward 0) + (while (and (not in-fringe-p) + (< i (window-height)) + (< i (length vline-overlay-table)) + (not (bobp))) + (let ((cur-column (vline-move-to-column column t)) + (cur-lcolumn (current-column))) + ;; non-cursor line only (workaround of eol probrem. + (unless (= (point) point) + ;; if column over the cursor's column (when tab or wide char is appered. + (when (> cur-column column) + (let ((lcol (current-column))) + (backward-char) + (setq cur-column (- cur-column (- lcol (current-column)))))) + (let* ((ovr (aref vline-overlay-table i)) + (visual-p (or (< lcolumn (current-column)) + (> lcolumn (+ (current-column) + (- column cur-column))))) + ;; consider a newline, tab and wide char. + (str (concat (make-string (- column cur-column) ? ) + (if visual-p visual-line-str line-str))) + (char (char-after))) + ;; create overlay if not found. + (unless ovr + (setq ovr (make-overlay 0 0)) + (overlay-put ovr 'rear-nonsticky t) + (aset vline-overlay-table i ovr)) + + ;; initialize overlay. + (overlay-put ovr 'face nil) + (overlay-put ovr 'before-string nil) + (overlay-put ovr 'after-string nil) + (overlay-put ovr 'invisible nil) + (overlay-put ovr 'window + (if vline-current-window-only + (selected-window) + nil)) + + (cond + ;; multiwidth space + ((memq char vline-multiwidth-space-list) + (setq str + (concat str + (make-string (- (save-excursion (forward-char) + (current-column)) + (current-column) + (string-width str)) + ? ))) + (move-overlay ovr (point) (1+ (point))) + (overlay-put ovr 'invisible t) + (overlay-put ovr 'after-string str)) + ;; eol + ((eolp) + (move-overlay ovr (point) (point)) + (overlay-put ovr 'after-string str) + ;; don't expand eol more than window width + (when (and (not truncate-lines) + (>= (1+ column) (window-width)) + (>= column (vline-current-column)) + (not (vline-into-fringe-p))) + (delete-overlay ovr))) + (t + (cond + (compose-p + (let (str) + (when char + (setq str (compose-chars + char + (cond ((= (char-width char) 1) + '(tc . tc)) + ((= cur-column column) + '(tc . tr)) + (t + '(tc . tl))) + line-char)) + (when face-p + (setq str (propertize str 'face (vline-face visual-p)))) + (move-overlay ovr (point) (1+ (point))) + (overlay-put ovr 'invisible t) + (overlay-put ovr 'after-string str)))) + (face-p + (move-overlay ovr (point) (1+ (point))) + (overlay-put ovr 'face (vline-face visual-p)))))))) + (setq i (1+ i)) + (vline-forward -1))))))) + +(provide 'vline) + +;;; Local Variables: +;;; time-stamp-format: "%:y-%02m-%02d %02H:%02M:%02S %Z %u" +;;; time-stamp-line-limit: 16 +;;; End: + +;;; vline.el ends here