emacs: added company-mode and some random stuff
This commit is contained in:
1
.gitignore
vendored
1
.gitignore
vendored
@@ -1 +1,2 @@
|
|||||||
.github
|
.github
|
||||||
|
noise.nix
|
||||||
|
@@ -29,12 +29,6 @@
|
|||||||
fsType = "btrfs";
|
fsType = "btrfs";
|
||||||
options = [ "compress-force=zstd:3" ];
|
options = [ "compress-force=zstd:3" ];
|
||||||
};
|
};
|
||||||
|
|
||||||
swapDevices = [
|
|
||||||
{
|
|
||||||
device = "/dev/disk/by-uuid/d4cef4cd-19b0-4d1b-8569-9985ff42270c";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
zramSwap = {
|
zramSwap = {
|
||||||
enable = true;
|
enable = true;
|
||||||
algorithm = "lz4";
|
algorithm = "lz4";
|
||||||
|
@@ -27,6 +27,7 @@
|
|||||||
#language servers
|
#language servers
|
||||||
rust-analyzer
|
rust-analyzer
|
||||||
ccls
|
ccls
|
||||||
|
clang-tools
|
||||||
nodePackages.typescript-language-server
|
nodePackages.typescript-language-server
|
||||||
rnix-lsp
|
rnix-lsp
|
||||||
python3Packages.python-lsp-server
|
python3Packages.python-lsp-server
|
||||||
|
@@ -32,7 +32,11 @@ c-white-2 "#ebdbb2")
|
|||||||
auto-window-vscroll nil
|
auto-window-vscroll nil
|
||||||
scroll-step 1
|
scroll-step 1
|
||||||
display-line-numbers-type 'relative
|
display-line-numbers-type 'relative
|
||||||
|
confirm-kill-processes nil
|
||||||
inhibit-startup-screen t)
|
inhibit-startup-screen t)
|
||||||
|
(add-hook 'emacs-startup-hook
|
||||||
|
(lambda () (delete-other-windows)) t)
|
||||||
|
|
||||||
|
|
||||||
;;add packages and shit
|
;;add packages and shit
|
||||||
(require 'package)
|
(require 'package)
|
||||||
@@ -44,6 +48,7 @@ c-white-2 "#ebdbb2")
|
|||||||
;(use-package gruvbox-theme
|
;(use-package gruvbox-theme
|
||||||
; :init (load-theme 'gruvbox-dark-hard t))
|
; :init (load-theme 'gruvbox-dark-hard t))
|
||||||
|
|
||||||
|
|
||||||
(use-package doom-themes
|
(use-package doom-themes
|
||||||
:config
|
:config
|
||||||
(setq doom-themes-enable-bold t
|
(setq doom-themes-enable-bold t
|
||||||
@@ -63,6 +68,7 @@ c-white-2 "#ebdbb2")
|
|||||||
(ivy-mode 1))
|
(ivy-mode 1))
|
||||||
|
|
||||||
(use-package elcord
|
(use-package elcord
|
||||||
|
:defer 0
|
||||||
:config
|
:config
|
||||||
(elcord-mode 1))
|
(elcord-mode 1))
|
||||||
|
|
||||||
@@ -72,6 +78,7 @@ c-white-2 "#ebdbb2")
|
|||||||
|
|
||||||
(use-package evil
|
(use-package evil
|
||||||
:config
|
:config
|
||||||
|
(evil-set-initial-state 'vterm-mode 'insert)
|
||||||
(evil-set-undo-system 'undo-tree)
|
(evil-set-undo-system 'undo-tree)
|
||||||
(evil-mode 1))
|
(evil-mode 1))
|
||||||
|
|
||||||
@@ -100,16 +107,19 @@ c-white-2 "#ebdbb2")
|
|||||||
)
|
)
|
||||||
|
|
||||||
(use-package lsp-mode
|
(use-package lsp-mode
|
||||||
|
:defer 0
|
||||||
:init
|
:init
|
||||||
(setq )
|
(setq )
|
||||||
:config
|
:config
|
||||||
(lsp-mode 1))
|
(lsp-mode 1))
|
||||||
|
|
||||||
(use-package lsp-treemacs
|
(use-package lsp-treemacs
|
||||||
|
:defer 0
|
||||||
:config
|
:config
|
||||||
(lsp-treemacs-sync-mode 1))
|
(lsp-treemacs-sync-mode 1))
|
||||||
|
|
||||||
(use-package lsp-ui
|
(use-package lsp-ui
|
||||||
|
:defer 0
|
||||||
:init
|
:init
|
||||||
(setq lsp-ui-doc-show-with-cursor t)
|
(setq lsp-ui-doc-show-with-cursor t)
|
||||||
:config
|
:config
|
||||||
@@ -117,6 +127,7 @@ c-white-2 "#ebdbb2")
|
|||||||
(lsp-ui-doc-enable 1))
|
(lsp-ui-doc-enable 1))
|
||||||
|
|
||||||
(use-package company
|
(use-package company
|
||||||
|
:defer 0
|
||||||
:after lsp-mode
|
:after lsp-mode
|
||||||
:config
|
:config
|
||||||
(define-key company-active-map (kbd "C-n") 'company-select-next)
|
(define-key company-active-map (kbd "C-n") 'company-select-next)
|
||||||
@@ -124,6 +135,9 @@ c-white-2 "#ebdbb2")
|
|||||||
(define-key company-search-map (kbd "C-n") 'company-select-next)
|
(define-key company-search-map (kbd "C-n") 'company-select-next)
|
||||||
(define-key company-search-map (kbd "C-e") 'company-select-previous))
|
(define-key company-search-map (kbd "C-e") 'company-select-previous))
|
||||||
|
|
||||||
|
(use-package company-quickhelp
|
||||||
|
:hook (company-mode . company-quickhelp-mode))
|
||||||
|
|
||||||
(use-package tree-sitter-langs)
|
(use-package tree-sitter-langs)
|
||||||
|
|
||||||
(use-package tree-sitter
|
(use-package tree-sitter
|
||||||
@@ -146,6 +160,9 @@ c-white-2 "#ebdbb2")
|
|||||||
|
|
||||||
(use-package rustic)
|
(use-package rustic)
|
||||||
|
|
||||||
|
(add-hook 'c-mode-hook 'lsp)
|
||||||
|
(add-hook 'c++-mode-hook 'lsp)
|
||||||
|
|
||||||
(use-package magit)
|
(use-package magit)
|
||||||
|
|
||||||
(use-package nix-mode
|
(use-package nix-mode
|
||||||
@@ -165,14 +182,19 @@ c-white-2 "#ebdbb2")
|
|||||||
(setq centaur-tabs-style "bar"
|
(setq centaur-tabs-style "bar"
|
||||||
centaur-tabs-set-bar 'left
|
centaur-tabs-set-bar 'left
|
||||||
centaur-tabs-height 18
|
centaur-tabs-height 18
|
||||||
|
centaur-tabs-set-modified-marker t
|
||||||
centaur-tabs-set-icons t)
|
centaur-tabs-set-icons t)
|
||||||
(centaur-tabs-group-buffer-groups)
|
(centaur-tabs-group-buffer-groups)
|
||||||
(centaur-tabs-mode 1)
|
(centaur-tabs-mode 1)
|
||||||
(centaur-tabs-headline-match)
|
(centaur-tabs-headline-match)
|
||||||
(set-face-attribute 'tab-line nil :background c-bg :foreground c-fg)
|
(set-face-attribute 'tab-line nil :background c-bg :foreground c-fg)
|
||||||
(set-face-attribute 'centaur-tabs-active-bar-face nil :background c-red-2)
|
(set-face-attribute 'centaur-tabs-active-bar-face nil :background c-red-2)
|
||||||
|
(set-face-attribute 'centaur-tabs-modified-marker-selected nil :foreground c-red-2)
|
||||||
|
(set-face-attribute 'centaur-tabs-modified-marker-unselected nil :foreground c-red-2)
|
||||||
(set-face-attribute 'centaur-tabs-selected nil :background c-fg :foreground c-bg)
|
(set-face-attribute 'centaur-tabs-selected nil :background c-fg :foreground c-bg)
|
||||||
(set-face-attribute 'centaur-tabs-unselected nil :background c-bg :foreground c-fg))
|
(set-face-attribute 'centaur-tabs-unselected nil :background c-bg :foreground c-fg)
|
||||||
|
(set-face-attribute 'centaur-tabs-selected-modified nil :background c-fg :foreground c-bg)
|
||||||
|
(set-face-attribute 'centaur-tabs-unselected-modified nil :background c-bg :foreground c-fg))
|
||||||
|
|
||||||
(use-package general)
|
(use-package general)
|
||||||
|
|
||||||
@@ -187,6 +209,12 @@ c-white-2 "#ebdbb2")
|
|||||||
(define-key vterm-mode-map (kbd "<f2>") 'vterm-toggle-forward)
|
(define-key vterm-mode-map (kbd "<f2>") 'vterm-toggle-forward)
|
||||||
(define-key vterm-mode-map (kbd "<f3>") 'vterm-toggle-backward))
|
(define-key vterm-mode-map (kbd "<f3>") 'vterm-toggle-backward))
|
||||||
|
|
||||||
|
(use-package org)
|
||||||
|
|
||||||
|
(use-package org-bullets
|
||||||
|
:config
|
||||||
|
(add-hook 'org-mode-hook (lambda () (org-bullets-mode 1))))
|
||||||
|
|
||||||
|
|
||||||
(defface bufname
|
(defface bufname
|
||||||
`((t :foreground ,c-fg
|
`((t :foreground ,c-fg
|
||||||
@@ -268,19 +296,6 @@ c-white-2 "#ebdbb2")
|
|||||||
(kill-buffer b))))
|
(kill-buffer b))))
|
||||||
|
|
||||||
(defun run-in-vterm (command)
|
(defun run-in-vterm (command)
|
||||||
"Execute string COMMAND in a new vterm.
|
|
||||||
|
|
||||||
Interactively, prompt for COMMAND with the current buffer's file
|
|
||||||
name supplied. When called from Dired, supply the name of the
|
|
||||||
file at point.
|
|
||||||
|
|
||||||
Like `async-shell-command`, but run in a vterm for full terminal features.
|
|
||||||
|
|
||||||
The new vterm buffer is named in the form `*foo bar.baz*`, the
|
|
||||||
command and its arguments in earmuffs.
|
|
||||||
|
|
||||||
When the command terminates, the shell remains open, but when the
|
|
||||||
shell exits, the buffer is killed."
|
|
||||||
(interactive
|
(interactive
|
||||||
(list
|
(list
|
||||||
(let* ((f (cond (buffer-file-name)
|
(let* ((f (cond (buffer-file-name)
|
||||||
@@ -291,15 +306,29 @@ shell exits, the buffer is killed."
|
|||||||
(cons filename 0)
|
(cons filename 0)
|
||||||
(cons 'shell-command-history 1)
|
(cons 'shell-command-history 1)
|
||||||
(list filename)))))
|
(list filename)))))
|
||||||
(with-current-buffer (vterm (concat "*" command "*"))
|
(with-current-buffer (vterm-toggle)
|
||||||
(set-process-sentinel vterm--process #'run-in-vterm-kill)
|
(set-process-sentinel vterm--process #'run-in-vterm-kill)
|
||||||
(vterm-send-string (concat command))
|
(vterm-send-string (concat command))
|
||||||
(vterm-send-return)))
|
(vterm-send-return)))
|
||||||
|
|
||||||
|
(defun candrun ()
|
||||||
|
(let ((full buffer-file-name)
|
||||||
|
(file (file-name-sans-extension buffer-file-name)))
|
||||||
|
(pcase (file-name-extension full)
|
||||||
|
("c" (concat "gcc " full " -o " file " && " file " && rm " file))
|
||||||
|
("java" (concat "java" full))
|
||||||
|
("py" (concat "python" full))
|
||||||
|
("cpp" (concat "g++ " full " -o " file " && " file " && rm " file))
|
||||||
|
("hs" (concat "ghc -dynamic" full " && " file " && rm " file " " file ".o"))
|
||||||
|
("sh" (concat "sh" full))
|
||||||
|
("bash" (concat "bash" full))
|
||||||
|
("zsh" (concat "zsh" full))
|
||||||
|
("js" (concat "node" full))
|
||||||
|
("ts" (concat "tsc" full " && node " file ".js && rm " file ".js" ))
|
||||||
|
("rs" (concat "rustc" full " -o " file " && " file " && rm " file)))))
|
||||||
|
|
||||||
(general-define-key
|
(general-define-key
|
||||||
:states '(normal emacs visual motion treemacs Eshell)
|
:states '(normal emacs visual motion treemacs Eshell override)
|
||||||
:keymaps '(normal emacs override Eshell)
|
|
||||||
"M-o" 'treemacs
|
"M-o" 'treemacs
|
||||||
"M-v" 'split-window-vertically
|
"M-v" 'split-window-vertically
|
||||||
"M-h" 'split-window-horizontally
|
"M-h" 'split-window-horizontally
|
||||||
@@ -317,11 +346,16 @@ shell exits, the buffer is killed."
|
|||||||
"M-w" 'centaur-tabs--kill-this-buffer-dont-ask
|
"M-w" 'centaur-tabs--kill-this-buffer-dont-ask
|
||||||
"M-S-w" 'kill-window
|
"M-S-w" 'kill-window
|
||||||
"M-S-," 'centaur-tabs-backward
|
"M-S-," 'centaur-tabs-backward
|
||||||
"M-S-." 'centaur-tabs-forward
|
"M-S-." 'centaur-tabs-forward)
|
||||||
|
|
||||||
|
(general-define-key
|
||||||
|
:states '(override insert normal visual treemacs motion)
|
||||||
|
"M-f" 'lsp-format-buffer
|
||||||
"<f4>" (lambda () (interactive) (vterm t))
|
"<f4>" (lambda () (interactive) (vterm t))
|
||||||
"C-<f1>" 'vterm-toggle-cd
|
"C-<f1>" 'vterm-toggle-cd
|
||||||
"<f1>" 'vterm-toggle
|
"<f1>" 'vterm-toggle
|
||||||
"f5" (lambda () (interactive) (run-in-vterm (concat "gcc " buffer-file-name " -o " (file-name-sans-extension buffer-file-name) " && " (file-name-sans-extension buffer-file-name)))))
|
"<f5>" (lambda () (interactive) (run-in-vterm (candrun))))
|
||||||
|
|
||||||
|
|
||||||
(general-define-key
|
(general-define-key
|
||||||
:states '(normal insert)
|
:states '(normal insert)
|
||||||
|
Reference in New Issue
Block a user