aboutsummaryrefslogtreecommitdiff
path: root/home-manager/general/programs/emacs/#init.el#
diff options
context:
space:
mode:
authorspl3g <spleefer6@yandex.ru>2023-12-31 15:08:06 +0300
committerspl3g <spleefer6@yandex.ru>2025-05-01 14:56:39 +0300
commitb8a5c62b112859f463a53ac97b43f7f8cdc544a9 (patch)
tree8b320bc9631fbd60ffe4b701e6afee148bb2313a /home-manager/general/programs/emacs/#init.el#
parent7db487dba2262af7b7822d110122ff496070ca92 (diff)
uhm
Diffstat (limited to 'home-manager/general/programs/emacs/#init.el#')
-rw-r--r--home-manager/general/programs/emacs/#init.el#735
1 files changed, 735 insertions, 0 deletions
diff --git a/home-manager/general/programs/emacs/#init.el# b/home-manager/general/programs/emacs/#init.el#
new file mode 100644
index 0000000..b17a54b
--- /dev/null
+++ b/home-manager/general/programs/emacs/#init.el#
@@ -0,0 +1,735 @@
+(setq gc-cons-threshold (* 50 1000 1000))
+
+(require 'use-package)
+(eval-and-compile
+ (setq use-package-always-ensure t
+ use-package-expand-minimally t))
+
+(use-package savehist
+ :init
+ (setq savehist-file "~/.config/emacs/var/savehist.el")
+ :config
+ (setq history-length 500)
+ (setq savehist-additional-variables '(kill-ring search-ring))
+ (savehist-mode t))
+
+(use-package meow
+ :config
+ (defun meow-setup ()
+ (setq meow-cheatsheet-layout meow-cheatsheet-layout-qwerty)
+ (meow-motion-overwrite-define-key
+ '("j" . meow-next)
+ '("k" . meow-prev)
+ '("<escape>" . ignore))
+ (meow-leader-define-key
+ ;; SPC j/k will run the original command in MOTION state.
+ '("j" . "H-j")
+ '("k" . "H-k")
+ ;; Use SPC (0-9) for digit arguments.
+ '("1" . meow-digit-argument)
+ '("2" . meow-digit-argument)
+ '("3" . meow-digit-argument)
+ '("4" . meow-digit-argument)
+ '("5" . meow-digit-argument)
+ '("6" . meow-digit-argument)
+ '("7" . meow-digit-argument)
+ '("8" . meow-digit-argument)
+ '("9" . meow-digit-argument)
+ '("0" . meow-digit-argument)
+ '("/" . meow-keypad-describe-key)
+ '("?" . meow-cheatsheet)
+ '("bk" . kill-this-buffer))
+ (meow-normal-define-key
+ '("0" . meow-expand-0)
+ '("9" . meow-expand-9)
+ '("8" . meow-expand-8)
+ '("7" . meow-expand-7)
+ '("6" . meow-expand-6)
+ '("5" . meow-expand-5)
+ '("4" . meow-expand-4)
+ '("3" . meow-expand-3)
+ '("2" . meow-expand-2)
+ '("1" . meow-expand-1)
+ '("-" . negative-argument)
+ '(";" . meow-reverse)
+ '("," . meow-inner-of-thing)
+ '("." . meow-bounds-of-thing)
+ '("[" . meow-beginning-of-thing)
+ '("]" . meow-end-of-thing)
+ '("a" . meow-append)
+ '("A" . meow-open-below)
+ '("b" . meow-back-word)
+ '("B" . meow-back-symbol)
+ '("c" . meow-change)
+ '("d" . meow-delete)
+ '("D" . meow-backward-delete)
+ '("e" . meow-next-word)
+ '("E" . meow-next-symbol)
+ '("f" . meow-find)
+ '("g" . meow-cancel-selection)
+ '("G" . meow-grab)
+ '("h" . meow-left)
+ '("H" . meow-left-expand)
+ '("i" . meow-insert)
+ '("I" . meow-open-above)
+ '("j" . meow-next)
+ '("J" . meow-next-expand)
+ '("k" . meow-prev)
+ '("K" . meow-prev-expand)
+ '("l" . meow-right)
+ '("L" . meow-right-expand)
+ '("m" . meow-join)
+ '("n" . meow-search)
+ '("o" . meow-block)
+ '("O" . meow-to-block)
+ '("p" . meow-yank)
+ '("q" . meow-quit)
+ '("Q" . meow-goto-line)
+ '("r" . meow-replace)
+ '("R" . meow-swap-grab)
+ '("s" . meow-kill)
+ '("t" . meow-till)
+ '("u" . meow-undo)
+ '("U" . meow-undo-in-selection)
+ '("v" . meow-visit)
+ '("w" . meow-mark-word)
+ '("W" . meow-mark-symbol)
+ '("x" . meow-line)
+ '("X" . meow-goto-line)
+ '("y" . meow-save)
+ '("Y" . meow-sync-grab)
+ '("z" . meow-pop-selection)
+ '("'" . repeat)
+ '("<escape>" . ignore)))
+ (setq meow-use-enhanced-selection-effect t)
+ (meow-setup))
+ ;; (meow-global-mode 1))
+
+(use-package kakoune
+ ;; Having a non-chord way to escape is important, since key-chords don't work in macros
+ :bind ("C-z" . ryo-modal-mode)
+ :hook (after-init . my/kakoune-setup)
+ :config
+ (defun ryo-enter () "Enter normal mode" (interactive) (ryo-modal-mode 1))
+ (defun my/kakoune-setup ()
+ "Call kakoune-setup-keybinds and then add some personal config."
+ (kakoune-setup-keybinds)
+ (setq ryo-modal-cursor-type 'box)
+ (add-hook 'prog-mode-hook #'ryo-enter)
+ (define-key ryo-modal-mode-map (kbd "SPC h") 'help-command)
+ ;; Access all C-x bindings easily
+ (define-key ryo-modal-mode-map (kbd "z") ctl-x-map)
+ (ryo-modal-keys
+ ("," save-buffer)
+ ("P" counsel-yank-pop)
+ ("m" mc/mark-next-like-this)
+ ("M" mc/skip-to-next-like-this)
+ ("n" mc/mark-previous-like-this)
+ ("N" mc/skip-to-previous-like-this)
+ ("M-m" mc/edit-lines)
+ ("*" mc/mark-all-like-this)
+ ("v" er/expand-region)
+ ("C-v" set-rectangular-region-anchor)
+ ("M-s" mc/split-region)
+ (";" (("q" delete-window)
+ ("v" split-window-horizontally)
+ ("s" split-window-vertically)))
+ ("C-h" windmove-left)
+ ("C-j" windmove-down)
+ ("C-k" windmove-up)
+ ("C-l" windmove-right)
+ ("C-u" scroll-down-command :first '(deactivate-mark))
+ ("C-d" scroll-up-command :first '(deactivate-mark)))))
+
+;; This overrides the default mark-in-region with a prettier-looking one,
+;; and provides a couple extra commands
+(use-package visual-regexp
+ :ryo
+ ("s" vr/mc-mark)
+ ("?" vr/replace)
+ ("M-/" vr/query-replace))
+
+;; Emacs incremental search doesn't work with multiple cursors, but this fixes that
+(use-package phi-search
+ :bind (("C-s" . phi-search)
+ ("C-r" . phi-search-backward)))
+
+;; Probably the first thing you'd miss is undo and redo, which requires an extra package
+;; to work like it does in kakoune (and almost every other editor).
+(use-package undo-tree
+ :config
+ (global-undo-tree-mode)
+ :ryo
+ ("u" undo-tree-undo)
+ ("U" undo-tree-redo)
+ ("SPC u" undo-tree-visualize)
+ :bind (:map undo-tree-visualizer-mode-map
+ ("h" . undo-tree-visualize-switch-branch-left)
+ ("j" . undo-tree-visualize-redo)
+ ("k" . undo-tree-visualize-undo)
+ ("l" . undo-tree-visualize-switch-branch-right)))
+
+
+(use-package general
+ :config
+ ;; SPC as the global leader key
+ (general-create-definer spl3g/leader-keys
+ :prefix "C-c")
+
+ (spl3g/leader-keys
+ ;; Buffers
+ "b" '(:ignore t :wk "Buffer")
+ "bi" '(ibuffer :wk "ibuffer")
+ "bk" '(kill-this-buffer :wk "Kill this buffer")
+ "bn" '(next-buffer :wk "Next buffer")
+ "bp" '(previous-buffer :wk "Previous buffer")
+ "br" '(revert-buffer :wk "Reload buffer")
+ "." '(find-file :wk "Find file")
+ ;; Splits
+ "w" '(:ignore t :wk "Splits")
+ "wv" '(split-window-right :wk "Split vertical")
+ "ws" '(split-window-below :wk "Split")
+ "ww" '(other-window :wk "Cycle throug windows")
+ "wc" '(delete-window :wk "Close window")
+ "wd" '(delete-window :wk "Close window")
+ "wl" '(evil-window-right :wk "")
+ "wj" '(evil-window-down :wk "")
+ "wk" '(evil-window-up :wk "")
+ "wh" '(evil-window-left :wk "")
+ "wo" '(delete-other-windows :wk "")
+ ;; Files
+ "f" '(:ignore t :wk "Files")
+ "fc" '((lambda () (interactive) (find-file "~/nixfiles/home-manager/programs/emacs/config.org")) :wk "Edit emacs config")
+ "fu" '(crux-sudo-edit :wk "Sudo edit file")
+ ;; Compilation
+ "c" '(:ignore t :wk "Compilation")
+ "cc" '(compile :wk "Compile")
+ "cr" '(recompile :wk "Recompile")
+ ))
+
+(defun spl3g/disable-scroll-bars (frame)
+ (modify-frame-parameters frame
+ '((vertical-scroll-bars . nil)
+ (horizontal-scroll-bars . nil))))
+(add-hook 'after-make-frame-functions 'spl3g/disable-scroll-bars)
+
+(setq default-frame-alist '((font . "Source Code Pro")))
+(set-face-attribute 'default nil
+ :font "Source Code Pro"
+ :height 110
+ :weight 'medium)
+(set-face-attribute 'fixed-pitch nil
+ :font "Source Code Pro"
+ :height 110
+ :weight 'medium)
+(set-face-attribute 'variable-pitch nil
+ :font "Rubik"
+ :height 110
+ :weight 'medium)
+(set-face-attribute 'font-lock-comment-face nil
+ :slant 'italic)
+(set-face-attribute 'font-lock-keyword-face nil
+ :weight 'bold)
+
+(add-hook 'prog-mode-hook 'display-line-numbers-mode)
+(visual-line-mode 1)
+
+(use-package catppuccin-theme
+ :ensure t
+ :config
+ (load-theme 'catppuccin t)
+ (setq catppuccin-flavor 'macchiato)
+ (catppuccin-reload))
+
+(use-package all-the-icons
+ :ensure t
+ :if (display-graphic-p))
+
+(use-package mood-line
+
+ ;; Enable mood-line
+ :config
+ (mood-line-mode)
+ :custom
+ (mood-line-segment-modal-meow-state-alist
+ '((normal "N" . mood-line-meow-normal)
+ (insert "I" . mood-line-meow-insert)
+ (keypad "K" . mood-line-meow-keypad)
+ (beacon "B" . mood-line-meow-beacon)
+ (motion "M" . mood-line-meow-motion)))
+ (mood-line-glyph-alist mood-line-glyphs-fira-code)
+ :custom-face
+ (mood-line-meow-beacon ((t (:foreground "#f9e2af" :weight bold))))
+ (mood-line-meow-insert ((t (:foreground "#a6e3a1" :weight bold))))
+ (mood-line-meow-keypad ((t (:foreground "#cba6f7" :weight bold))))
+ (mood-line-meow-motion ((t (:foreground "#fab387" :weight bold))))
+ (mood-line-meow-normal ((t (:weight bold))))
+ (mode-line-inactive ((t (:box (:line-width (2 . 6) :color "#11111b") :inverse-video nil :foreground "#6c7086" :background "#11111b"))))
+ (mode-line ((t (:box (:line-width (2 . 6) :color "#181825") :background "#181825")))))
+
+(use-package good-scroll
+ :init (good-scroll-mode))
+
+(use-package dashboard
+ :init
+ (dashboard-setup-startup-hook)
+ :config
+ (setq initial-buffer-choice (lambda () (get-buffer-create "*dashboard*")))
+ (setq dashboard-banner-logo-title "Yep, it's emacs, not vim")
+ (setq dashboard-startup-banner 'logo)
+ (setq dashboard-center-content t)
+ (add-to-list 'dashboard-item-generators '(config . dashboard-open-config))
+ (setq dashboard-items '((recents . 5)
+ (agenda . 5))))
+
+(setq ring-bell-function 'ignore)
+
+(use-package indent-guide
+ :hook (prog-mode . indent-guide-mode))
+
+(setq window-resize-pixelwise t)
+(setq frame-resize-pixelwise t)
+(save-place-mode t)
+(defalias 'yes-or-no #'y-or-n-p)
+
+(add-hook 'org-mode-hook 'org-indent-mode)
+(require 'org-tempo)
+
+(use-package toc-org
+ :hook (org-mode . toc-org-mode))
+
+(use-package org-bullets
+ :hook (org-mode . org-bullets-mode))
+
+(use-package org-auto-tangle
+ :hook (org-mode . org-auto-tangle-mode))
+
+(use-package org-download
+ :hook
+ (dired-mode . org-download-enable))
+
+(use-package direnv
+ :config
+ (direnv-mode))
+
+(use-package vertico
+ :init
+ (vertico-mode)
+ :bind (:map vertico-map
+ ("M-j" . vertico-next)
+ ("M-k" . vertico-previous)
+ ("RET" . vertico-directory-enter)
+ ("DEL" . vertico-directory-delete-char)
+ ("M-DEL" . vertico-directory-delete-word)))
+
+(use-package emacs
+ :init
+ ;; Add prompt indicator to `completing-read-multiple'.
+ ;; We display [CRM<separator>], e.g., [CRM,] if the separator is a comma.
+ (defun crm-indicator (args)
+ (cons (format "[CRM%s] %s"
+ (replace-regexp-in-string
+ "\\`\\[.*?]\\*\\|\\[.*?]\\*\\'" ""
+ crm-separator)
+ (car args))
+ (cdr args)))
+ (advice-add #'completing-read-multiple :filter-args #'crm-indicator)
+
+ ;; Do not allow the cursor in the minibuffer prompt
+ (setq minibuffer-prompt-properties
+ '(read-only t cursor-intangible t face minibuffer-prompt))
+ (add-hook 'minibuffer-setup-hook #'cursor-intangible-mode)
+
+ ;; Emacs 28: Hide commands in M-x which do not work in the current mode.
+ ;; Vertico commands are hidden in normal buffers.
+ ;; (setq read-extended-command-predicate
+ ;; #'command-completion-default-include-p)
+
+ ;; Enable recursive minibuffers
+ (setq enable-recursive-minibuffers t))
+
+(use-package orderless
+ :init
+ (setq completion-styles '(orderless basic)
+ completion-category-defaults nil
+ completion-category-overrides '((file (styles partial-completion)))))
+
+(use-package marginalia
+ :bind (:map minibuffer-local-map
+ ("M-A" . marginalia-cycle))
+ :init
+ (marginalia-mode))
+
+(use-package consult
+ ;; Replace bindings. Lazily loaded due by `use-package'.
+ :bind (;; C-c bindings in `mode-specific-map'
+ ("C-c k" . consult-kmacro)
+ ("C-c m" . consult-man)
+ ("C-c i" . consult-info)
+ ([remap Info-search] . consult-info)
+ ("C-c f r" . consult-recent-file)
+ ("C-c ," . consult-buffer)
+ ;; C-x bindings in `ctl-x-map'
+ ("C-x M-:" . consult-complex-command) ;; orig. repeat-complex-command
+ ("C-x 4 b" . consult-buffer-other-window) ;; orig. switch-to-buffer-other-window
+ ("C-x 5 b" . consult-buffer-other-frame) ;; orig. switch-to-buffer-other-frame
+ ("C-x p b" . consult-project-buffer) ;; orig. project-switch-to-buffer
+ ;; Custom M-# bindings for fast register access
+ ("M-#" . consult-register-load)
+ ("M-'" . consult-register-store) ;; orig. abbrev-prefix-mark (unrelated)
+ ("C-M-#" . consult-register)
+ ;; Other custom bindings
+ ("M-y" . consult-yank-pop) ;; orig. yank-pop
+ ;; M-g bindings in `goto-map'
+ ("C-c c e" . consult-compile-error)
+ ("M-g f" . consult-flymake) ;; Alternative: consult-flycheck
+ ("M-g g" . consult-goto-line) ;; orig. goto-line
+ ("M-g M-g" . consult-goto-line) ;; orig. goto-line
+ ("M-g o" . consult-outline) ;; Alternative: consult-org-heading
+ ;; M-s bindings in `search-map'
+ ("M-s d" . consult-fd)
+ ("M-s g" . consult-grep)
+ ("M-s G" . consult-git-grep)
+ ("M-s l" . consult-line)
+ ("M-s L" . consult-line-multi)
+ ("M-s k" . consult-keep-lines)
+ ("M-s u" . consult-focus-lines)
+ ;; Isearch integration
+ ("M-s e" . consult-isearch-history)
+ :map isearch-mode-map
+ ("M-e" . consult-isearch-history) ;; orig. isearch-edit-string
+ ("M-s e" . consult-isearch-history) ;; orig. isearch-edit-string
+ ("M-s l" . consult-line) ;; needed by consult-line to detect isearch
+ ("M-s L" . consult-line-multi) ;; needed by consult-line to detect isearch
+ ("M-r" . consult-history)
+ ;; Minibuffer history
+ :map minibuffer-local-map
+ ("M-s" . consult-history) ;; orig. next-matching-history-element
+ ("M-r" . consult-history)) ;; orig. previous-matching-history-element)
+
+ ;; Enable automatic preview at point in the *Completions* buffer. This is
+ ;; relevant when you use the default completion UI.
+ :hook
+ (completion-list-mode . consult-preview-at-point-mode)
+ (eshell-mode . (lambda ()
+ (keymap-set eshell-mode-map "M-h" 'consult-history)))
+
+ ;; The :init configuration is always executed (Not lazy)
+ :init
+
+ ;; Optionally configure the register formatting. This improves the register
+ ;; preview for `consult-register', `consult-register-load',
+ ;; `consult-register-store' and the Emacs built-ins.
+ (setq register-preview-delay 0.5
+ register-preview-function #'consult-register-format)
+
+ ;; Optionally tweak the register preview window.
+ ;; This adds thin lines, sorting and hides the mode line of the window.
+ (advice-add #'register-preview :override #'consult-register-window)
+
+ ;; Configure other variables and modes in the :config section,
+ ;; after lazily loading the package.
+ :config
+
+ ;; Optionally configure preview. The default value
+ ;; is 'any, such that any key triggers the preview.
+ ;; (setq consult-preview-key 'any)
+ ;; (setq consult-preview-key "M-.")
+ ;; (setq consult-preview-key '("S-<down>" "S-<up>"))
+ ;; For some commands and buffer sources it is useful to configure the
+ ;; :preview-key on a per-command basis using the `consult-customize' macro.
+ (consult-customize
+ consult-ripgrep consult-git-grep consult-grep
+ consult-bookmark consult-recent-file consult-xref
+ consult--source-bookmark consult--source-file-register
+ consult--source-recent-file consult--source-project-recent-file)
+ ;; :preview-key "M-."
+
+ ;; Optionally configure the narrowing key.
+ ;; Both < and C-+ work reasonably well.
+ (setq consult-narrow-key "<") ;; "C-+"
+
+ ;; Optionally make narrowing help available in the minibuffer.
+ ;; You may want to use `embark-prefix-help-command' or which-key instead.
+ ;; (define-key consult-narrow-map (vconcat consult-narrow-key "?") #'consult-narrow-help)
+
+ ;; By default `consult-project-function' uses `project-root' from project.el.
+ ;; Optionally configure a different project root function.
+;;;; 1. project.el (the default)
+ ;; (setq consult-project-function #'consult--default-project--function)
+;;;; 2. vc.el (vc-root-dir)
+ ;; (setq consult-project-function (lambda (_) (vc-root-dir)))
+;;;; 3. locate-dominating-file
+ ;; (setq consult-project-function (lambda (_) (locate-dominating-file "." ".git")))
+;;;; 4. projectile.el (projectile-project-root)
+ ;; (autoload 'projectile-project-root "projectile")
+ ;; (setq consult-project-function (lambda (_) (projectile-project-root)))
+;;;; 5. No project support
+ ;; (setq consult-project-function nil)
+ )
+
+(use-package smartparens
+ :init (smartparens-global-mode)
+ :config
+ ;; Snitched from doom
+ (let ((unless-list '(sp-point-before-word-p
+ sp-point-after-word-p
+ sp-point-before-same-p)))
+ (sp-pair "'" nil :unless unless-list)
+ (sp-pair "\"" nil :unless unless-list))
+ (dolist (brace '("(" "{" "["))
+ (sp-pair brace nil
+ :post-handlers '(("||\n[i]" "RET") ("| " "SPC"))
+ :unless '(sp-point-before-word-p sp-point-before-same-p)))
+ (sp-local-pair sp-lisp-modes "(" ")" :unless '(:rem sp-point-before-same-p))
+ (sp-local-pair sp-lisp-modes "(" ")" :unless '(:rem sp-point-before-same-p))
+
+ (sp-local-pair '(python-mode python-ts-mode) "f'" "'")
+
+ ;; Major-mode specific fixes
+ (sp-local-pair 'ruby-mode "{" "}"
+ :pre-handlers '(:rem sp-ruby-pre-handler)
+ :post-handlers '(:rem sp-ruby-post-handler))
+
+ ;; Don't do square-bracket space-expansion where it doesn't make sense to
+ (sp-local-pair '(emacs-lisp-mode org-mode markdown-mode gfm-mode)
+ "[" nil :post-handlers '(:rem ("| " "SPC")))
+
+ (sp-local-pair '(emacs-lisp-mode org-mode)
+ "'" nil)
+
+ ;; Reasonable default pairs for HTML-style comments
+ (sp-local-pair (append sp--html-modes '(markdown-mode gfm-mode))
+ "<!--" "-->"
+ :unless '(sp-point-before-word-p sp-point-before-same-p)
+ :actions '(insert) :post-handlers '(("| " "SPC")))
+ ;; Expand C-style comment blocks.
+ (defun +default-open-doc-comments-block (&rest _ignored)
+ (save-excursion
+ (newline)
+ (indent-according-to-mode)))
+ (sp-local-pair
+ '(js2-mode typescript-mode rjsx-mode rust-mode c-mode c++-mode objc-mode
+ csharp-mode java-mode php-mode css-mode scss-mode less-css-mode
+ stylus-mode scala-mode)
+ "/*" "*/"
+ :actions '(insert)
+ :post-handlers '(("| " "SPC")
+ (" | " "*")
+ ("|[i]\n[i]" "RET"))))
+
+;; (use-package dap-mode
+;; :defer t
+;; :config
+;; (require 'dap-python)
+;; (setq dap-python-debugger 'debugpy))
+
+(use-package move-text
+ :bind (("C-M-k" . move-text-up)
+ ("C-M-j" . move-text-down)))
+
+(global-visual-line-mode t)
+
+(use-package no-littering)
+
+(use-package rainbow-delimiters
+ :hook (prog-mode . rainbow-delimiters-mode))
+
+(use-package crux
+ :bind (("C-c o t" . crux-visit-shell-buffer)))
+
+(use-package helpful
+ :bind (("C-h f" . 'helpful-callable)
+ ("C-h v" . 'helpful-variable)
+ ("C-h k" . 'helpful-key)
+ ("C-h x" . 'helpful-command)
+ ("C-c C-d" . 'helpful-at-point)
+ ("C-h F" . 'helpful-function)))
+
+(add-hook 'eshell-mode-hook
+ (lambda ()
+ (keymap-set eshell-mode-map "M-<tab>" 'consult-fish-completions)))
+
+(use-package eat
+ :hook (eshell-mode . eat-eshell-mode)
+ :custom
+ (eat-enable-auto-line-mode t))
+
+;; (defun eat-toggle ()
+;; "Open eat terminal as a popup."
+;; (interactive)
+;; (if (eq major-mode 'eat-mode)
+;; (delete-window)
+;; (let ((buff (get-buffer-create eat-buffer-name)))
+;; (cl-assert (and buff (buffer-live-p buff)))
+;; (funcall #'pop-to-buffer buff)
+;; (with-current-buffer buff
+;; (setq-local split-width-threshold nil)
+;; (setq-local window-min-height 2)
+;; (unless (derived-mode-p 'eat-mode)
+;; (eat))))))
+
+;; (defun eat-modes()
+;; (cond
+;; ((and (eq major-mode 'eat-mode) (member 'meow-normal-mode local-minor-modes))
+;; (eat-emacs-mode))
+;; ((and (eq major-mode 'eat-mode) (member 'meow-insert-mode local-minor-modes))
+;; (eat-semi-char-mode))))
+;; (add-hook 'meow-normal-mode-hook #'eat-modes)
+;; (add-hook 'meow-insert-mode-hook #'eat-modes)
+
+(use-package fish-completion
+ :hook (eshell-mode . fish-completion-mode))
+
+(use-package eglot
+ :bind (("C-c s e e" . eglot)
+ ("C-c s e d" . eldoc)
+ ("C-c s e r" . eglot-rename)
+ ("C-c s e s" . eglot-shutdown)
+ ("C-c s e f" . eglot-find-declaration)
+ ("C-c s e i" . eglot-find-implementation))
+ :hook
+ (nix-mode . eglot-ensure)
+ (python-ts-mode . eglot-ensure)
+ :config
+ (add-to-list 'eglot-server-programs '(python-ts-mode . ("pylsp"))))
+
+(use-package lsp-pyright)
+(use-package py-autopep8
+ :hook (python-mode . py-autopep8-mode))
+
+(use-package rust-mode
+ :mode "\\.rs\\'")
+(use-package flycheck-rust
+ :config
+ (with-eval-after-load 'rust-mode
+ (add-hook 'flycheck-mode-hook #'flycheck-rust-setup)))
+
+(use-package fish-mode
+ :mode "\\.fish\\'")
+
+(use-package nix-mode
+ :mode ("\\.nix\\'" "\\.nix.in\\'"))
+(use-package nix-drv-mode
+ :ensure nix-mode
+ :mode "\\.drv\\'")
+(use-package nix-shell
+ :ensure nix-mode
+ :commands (nix-shell-unpack nix-shell-configure nix-shell-build))
+(use-package nix-repl
+ :ensure nix-mode
+ :commands (nix-repl))
+
+(use-package web-mode
+ :mode
+ ("\\.phtml\\'"
+ "\\.tpl\\.php\\'"
+ "\\.[agj]sp\\'"
+ "\\.as[cp]x\\'"
+ "\\.erb\\'"
+ "\\.mustache\\'"
+ "\\.djhtml\\'"))
+
+(use-package js2-mode)
+
+(use-package corfu
+ :custom
+ (corfu-cycle t)
+ (corfu-preselect 'prompt)
+ (corfu-auto t)
+ (corfu-popupinfo-delay 0.0)
+ :bind
+ (:map corfu-map
+ ("TAB" . corfu-next)
+ ([tab] . corfu-next)
+ ("S-TAB" . corfu-previous)
+ ([backtab] . corfu-previous))
+
+ :init
+ (global-corfu-mode)
+ (corfu-history-mode)
+ (corfu-popupinfo-mode)
+ :config
+ (add-to-list 'savehist-additional-variables 'corfu-history))
+(use-package emacs
+ :init
+ (setq completion-cycle-threshold 3)
+
+ (setq read-extended-command-predicate
+ #'command-completion-default-include-p)
+
+ (setq tab-always-indent 'complete))
+
+(use-package cape
+ :demand t
+ :config
+ (add-to-list 'completion-at-point-functions #'cape-dabbrev)
+ (add-to-list 'completion-at-point-functions #'cape-file)
+ (add-to-list 'completion-at-point-functions #'cape-elisp-block)
+ )
+
+(use-package tree-sitter
+ :init
+ (global-tree-sitter-mode)
+ :config
+ (add-hook 'tree-sitter-mode-hook 'tree-sitter-hl-mode))
+(use-package treesit-auto
+ :custom
+ (treesit-auto-install 'prompt)
+ :config
+ (treesit-auto-add-to-auto-mode-alist 'all)
+ (global-treesit-auto-mode))
+
+(use-package tree-sitter-langs)
+
+;; (use-package yasnippet
+;; :init (yas-global-mode))
+;; (use-package yasnippet-snippets)
+
+(use-package flymake
+ :after eglot
+ :bind (("C-c s f f" . flymake-start)
+ ("C-c s f l" . flymake-show-buffer-diagnostics)
+ ("C-c s f p" . flymake-show-project-diagnostics)))
+
+(use-package dired
+ :custom
+ (dired-listing-switches "-al --group-directories-first"))
+
+
+
+;; (add-to-list 'load-path "~/telega.el")
+;; (require 'telega)
+
+(use-package magit
+ :bind (("C-c o g" . magit)))
+
+;; (use-package exwm)
+;; (require 'exwm)
+;; (require 'exwm-config)
+;; (exwm-config-example)
+
+;; (use-package code-cells)
+
+;; (use-package orgnote
+;; :defer t)
+
+(use-package copilot
+ :hook (python-ts-mode . copilot-mode)
+ :bind ("M-RET" . copilot-accept-completion))
+
+(setq gc-cons-threshold (* 2 1000 1000))
+(setq read-process-output-max (* 1024 1024))
+(custom-set-variables
+ ;; custom-set-variables 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.
+ '(package-selected-packages
+ '(dired web-mode vertico use-package treesit-auto tree-sitter-langs toc-org smartparens rust-mode rainbow-delimiters py-autopep8 org-download org-bullets org-auto-tangle orderless no-littering nix-mode move-text mood-line marginalia magit lsp-pyright kakoune js2-mode indent-guide helpful good-scroll general flycheck-rust fish-mode fish-completion eglot eat direnv dashboard crux corfu copilot consult catppuccin-theme cape all-the-icons snow meow)))
+(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.
+ )