Signed-off-by: Michael Thomson <michael@michaelthomson.dev>
This commit is contained in:
Michael Thomson 2024-11-14 17:04:54 -05:00
parent b535f8ad4a
commit 80f6040765
No known key found for this signature in database
GPG Key ID: 8EFECCD347C72F7D
10 changed files with 45 additions and 278 deletions

View File

@ -11,7 +11,6 @@
../../modules/home-manager/tmux
../../modules/home-manager/taskwarrior
../../modules/home-manager/zoxide
../../modules/home-manager/irssi
];
home.username = "mthomson";
home.homeDirectory = "/home/mthomson";

View File

@ -11,7 +11,6 @@
../../modules/home-manager/tmux
../../modules/home-manager/taskwarrior
../../modules/home-manager/zoxide
../../modules/home-manager/irssi
../../modules/home-manager/syncthing
../../modules/home-manager/email
../../modules/home-manager/password-store

View File

@ -32,15 +32,10 @@
nix.settings.experimental-features = [ "nix-command" "flakes" ];
environment.systemPackages = with pkgs; [
hello
man-pages
man-pages-posix
];
environment.variables = {
EDITOR = "nvim";
};
services = {
skhd = {
enable = true;
@ -59,7 +54,7 @@
};
};
programs.zsh.enable = true;
# programs.zsh.enable = true;
system.stateVersion = 5;

View File

@ -4,13 +4,11 @@
imports = [
../../modules/home-manager/git
../../modules/home-manager/nixvim
../../modules/home-manager/emacs
../../modules/home-manager/wezterm
../../modules/home-manager/kitty
../../modules/home-manager/zsh
../../modules/home-manager/tmux
../../modules/home-manager/zoxide
../../modules/home-manager/irssi
../../modules/home-manager/email
../../modules/home-manager/password-store
../../modules/home-manager/taskwarrior
@ -32,6 +30,18 @@
java = {
enable = true;
};
zk = {
enable = true;
settings = {
notebook = {
dir = "~/zk";
};
};
};
};
home.sessionVariables = {
ZK_NOTEBOOK_DIR = "\${HOME}/zk";
};
home.packages = with pkgs; [
@ -42,7 +52,6 @@
cowsay
lazygit
k9s
tintin
nb
w3m
kubectl
@ -53,13 +62,13 @@
wireguard-tools
kompose
inetutils
devenv
_1password-cli
calcurse
glow
gcc
luajit
qemu
nchat
go
emanote
];
programs.home-manager.enable = true;

View File

@ -1,16 +0,0 @@
{ pkgs, config, ... }:
{
home.packages = with pkgs; [
emacs
fzf
ripgrep
emacs-lsp-booster
(nerdfonts.override { fonts = [ "Iosevka" ]; })
];
home.file.".emacs.d" = {
source = ./emacs.d;
recursive = true;
};
}

View File

@ -1,3 +0,0 @@
(setq package-enable-at-startup nil)
(setenv "LSP_USE_PLISTS" "true")

View File

@ -1,225 +0,0 @@
(defvar bootstrap-version)
(let ((bootstrap-file
(expand-file-name
"straight/repos/straight.el/bootstrap.el"
(or (bound-and-true-p straight-base-dir)
user-emacs-directory)))
(bootstrap-version 7))
(unless (file-exists-p bootstrap-file)
(with-current-buffer
(url-retrieve-synchronously
"https://raw.githubusercontent.com/radian-software/straight.el/develop/install.el"
'silent 'inhibit-cookies)
(goto-char (point-max))
(eval-print-last-sexp)))
(load bootstrap-file nil 'nomessage))
(straight-use-package 'use-package)
(setq straight-use-package-by-default t)
;; Turn off unwanted GUI elements.
(menu-bar-mode -1)
(scroll-bar-mode -1)
(tool-bar-mode -1)
(tooltip-mode -1)
;; Set the default font.
;; Append a size -NN to the font name.
(add-to-list 'default-frame-alist
'(font . "Iosevka Nerd Font-16"))
;; garbage collect when not in focus
(if (boundp 'after-focus-change-function)
(add-function :after after-focus-change-function
(lambda () (unless (frame-focus-state)
(garbage-collect))))
(add-hook 'after-focus-change-function
'garbage-collect))
;; set name and email
(setq user-full-name "Michael Thomson")
(setq user-mail-address "michael@michaelthomson.dev")
;; display columna nd line numbers on all buffers
(column-number-mode 1)
(global-display-line-numbers-mode 1)
;; paren closing and tab fix
(electric-pair-mode 1)
(electric-indent-mode -1)
(setq-default tab-width 2)
(setq-default indent-tabs-mode nil)
(setq-default indent-line-function 'insert-tab)
;; save history of mini buffer commands and opened files
(savehist-mode 1)
(recentf-mode 1)
;; disable lock file creation and send backups to a different directory
(setq backup-directory-alist '(("." . "~/.saves")))
(setq backup-by-copying t)
(setq version-control t)
(setq delete-old-versions t)
(setq create-lockfiles nil)
;; scroll wheel improvments
(setq mouse-wheel-progressive-speed nil)
(setq scroll-conservatively 101)
;; y or n for prompts
(setq use-short-answers t)
(setq use-dialog-box nil)
;; disable startup screen and messages buffer
(setq inhibit-startup-message t)
(setq message-log-max nil)
(kill-buffer "*Messages*")
;; prog mode truncate lines and highlight lines
(add-hook 'prog-mode-hook
(lambda () (toggle-truncate-lines 1)))
(add-hook 'prog-mode-hook 'hl-line-mode)
;; theme
(use-package catppuccin-theme
:config
(load-theme 'catppuccin :no-confirm)
(setq catppuccin-flavor 'frappe) ;; or 'latte, 'macchiato, or 'mocha
(catppuccin-reload))
;; evil
(use-package evil
:init
(setq evil-want-keybinding nil)
:config
(setq evil-want-keybinding nil
evil-auto-indent nil
evil-want-C-u-scroll t
evil-shift-width 2
evil-undo-system 'undo-redo
evil-vsplit-window-right t)
(evil-mode t))
(use-package evil-collection
:after evil
:config
(evil-collection-init))
;; vertico
(use-package vertico
:init
(vertico-mode))
(use-package savehist
:init
(savehist-mode))
(use-package marginalia
:after vertico
:init
(marginalia-mode))
(use-package nerd-icons-completion
:after marginalia
:config
(nerd-icons-completion-mode)
(add-hook 'marginalia-mode-hook #'nerd-icons-completion-marginalia-setup))
(use-package orderless
:custom
(completion-styles '(orderless basic))
(completion-category-defaults nil)
(completion-category-overrides '((file (styles partial-completion)))))
(use-package consult
:bind (;; A recursive grep
("M-s M-g" . consult-grep)
;; Search for files names recursively
("M-s M-f" . consult-find)
;; Search through the outline (headings) of the file
("M-s M-o" . consult-outline)
;; Search the current buffer
("M-s M-l" . consult-line)
;; Switch to another buffer, or bookmarked file, or recently
;; opened file.
("M-s M-b" . consult-buffer)))
;; icons
(use-package all-the-icons
:if (display-graphic-p))
;;;; Code Completion
(use-package corfu
:custom
(corfu-cycle t) ;; Enable cycling for `corfu-next/previous'
(corfu-auto t) ;; Enable auto completion
(corfu-separator ?\s) ;; Orderless field separator
(corfu-auto-delay 0) ;; TOO SMALL - NOT RECOMMENDED
(corfu-auto-prefix 1)
:init
(global-corfu-mode))
(use-package flycheck
:config
(add-hook 'after-init-hook #'global-flycheck-mode))
;; treesitter
(use-package treesit-auto
:custom
(treesit-auto-install 'prompt)
:config
(treesit-auto-add-to-auto-mode-alist 'all)
(global-treesit-auto-mode))
(use-package lsp-mode
:init
(setq lsp-keymap-prefix "C-c l")
(setq lsp-use-plists t)
:hook ((tsx-ts-mode . lsp)
(typescript-ts-mode . lsp)
(js-ts-mode . lsp)
(go-ts-mode . lsp)
(vue-mode . lsp))
:commands lsp)
(use-package lsp-ui :commands lsp-ui-mode)
(setq read-process-output-max (* 10 1024 1024)) ;; 10mb
(setq gc-cons-threshold 200000000)
;; emacs-lsp-booster
(defun lsp-booster--advice-json-parse (old-fn &rest args)
"Try to parse bytecode instead of json."
(or
(when (equal (following-char) ?#)
(let ((bytecode (read (current-buffer))))
(when (byte-code-function-p bytecode)
(funcall bytecode))))
(apply old-fn args)))
(advice-add (if (progn (require 'json)
(fboundp 'json-parse-buffer))
'json-parse-buffer
'json-read)
:around
#'lsp-booster--advice-json-parse)
(defun lsp-booster--advice-final-command (old-fn cmd &optional test?)
"Prepend emacs-lsp-booster command to lsp CMD."
(let ((orig-result (funcall old-fn cmd test?)))
(if (and (not test?) ;; for check lsp-server-present?
(not (file-remote-p default-directory)) ;; see lsp-resolve-final-command, it would add extra shell wrapper
lsp-use-plists
(not (functionp 'json-rpc-connection)) ;; native json-rpc
(executable-find "emacs-lsp-booster"))
(progn
(when-let ((command-from-exec-path (executable-find (car orig-result)))) ;; resolve command from exec-path (in case not found in $PATH)
(setcar orig-result command-from-exec-path))
(message "Using emacs-lsp-booster for %s!" orig-result)
(cons "emacs-lsp-booster" orig-result))
orig-result)))
(advice-add 'lsp-resolve-final-command :around #'lsp-booster--advice-final-command)
;; languages
(use-package vue-mode)

View File

@ -1,19 +0,0 @@
{ pkgs, config, ... }:
{
programs = {
irssi = {
enable = true;
networks = {
liberachat = {
nick = "DrDeww";
server = {
address = "irc.libera.chat";
port = 6697;
autoConnect = false;
};
};
};
};
};
}

View File

@ -8,7 +8,6 @@
luajit
lua-language-server
nil
(nerdfonts.override { fonts = [ "JetBrainsMono" ]; })
];
programs.neovim = {

View File

@ -43,6 +43,7 @@
cursorline = true;
scrolloff = 10;
hlsearch = true;
foldlevel = 99;
};
keymaps = [
@ -66,6 +67,21 @@
key = "<leader>u";
action = "<cmd>UndotreeToggle<CR>";
}
{
mode = "n";
key = "<leader>zf";
action = "<cmd>ZkNotes<CR>";
}
{
mode = "n";
key = "<leader>zt";
action = "<cmd>ZkTags<CR>";
}
{
mode = "n";
key = "<leader>zn";
action = "<cmd>ZkNew<CR>";
}
];
plugins = {
@ -75,6 +91,7 @@
};
treesitter = {
enable = true;
folding = true;
settings = {
highlight = {
enable = true;
@ -112,6 +129,15 @@
pick = {};
};
};
zk = {
enable = true;
settings = {
picker = "minipick";
};
};
render-markdown = {
enable = true;
};
friendly-snippets = {
enable = true;
};
@ -197,6 +223,9 @@
cssls = {
enable = true;
};
stylelint_lsp = {
enable = true;
};
volar = {
enable = true;
tslsIntegration = true;