emacs update
moved emacs from home-manager packages to system packages updated config to use tree-sitter and lsp-mode
This commit is contained in:
30
.github/workflows/main.yml
vendored
30
.github/workflows/main.yml
vendored
@@ -1,30 +0,0 @@
|
||||
name: main
|
||||
|
||||
on:
|
||||
push:
|
||||
pull_request:
|
||||
workflow_dispatch:
|
||||
jobs:
|
||||
packages:
|
||||
name: test packages
|
||||
runs-on: ubuntu-latest
|
||||
strategy:
|
||||
matrix:
|
||||
pkg:
|
||||
- anup
|
||||
- discord
|
||||
- proxychains
|
||||
- st
|
||||
- dmenu
|
||||
steps:
|
||||
- uses: actions/checkout@v2.3.4
|
||||
- uses: cachix/install-nix-action@v13
|
||||
with:
|
||||
install_url: https://github.com/numtide/nix-flakes-installer/releases/download/nix-2.4pre20210429_d15a196/install
|
||||
extra_nix_config: |
|
||||
experimental-features = nix-command flakes
|
||||
- uses: cachix/cachix-action@v10
|
||||
with:
|
||||
name: natto1784
|
||||
authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}'
|
||||
- run: nix build -L .#${{ matrix.pkg }}
|
16
flake.lock
generated
16
flake.lock
generated
@@ -34,6 +34,21 @@
|
||||
"type": "gitlab"
|
||||
}
|
||||
},
|
||||
"emacs": {
|
||||
"locked": {
|
||||
"lastModified": 1631467754,
|
||||
"narHash": "sha256-lZbeo1Y/jni/KW1W+DnaeCPgIu+W+ks8qp3xlRtUYFQ=",
|
||||
"owner": "nix-community",
|
||||
"repo": "emacs-overlay",
|
||||
"rev": "e00f171142307b3c9bb962beeaaf09d0254f9e31",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "nix-community",
|
||||
"repo": "emacs-overlay",
|
||||
"type": "github"
|
||||
}
|
||||
},
|
||||
"flake-compat": {
|
||||
"flake": false,
|
||||
"locked": {
|
||||
@@ -339,6 +354,7 @@
|
||||
"root": {
|
||||
"inputs": {
|
||||
"agenix": "agenix",
|
||||
"emacs": "emacs",
|
||||
"home-manager": "home-manager",
|
||||
"home-manager-unstable": "home-manager-unstable",
|
||||
"mailserver": "mailserver",
|
||||
|
@@ -11,6 +11,7 @@
|
||||
nvim.url = github:nix-community/neovim-nightly-overlay;
|
||||
mailserver.url = gitlab:simple-nixos-mailserver/nixos-mailserver;
|
||||
nbfc.url = github:natto1784/nbfc-linux/yawr;
|
||||
emacs.url = github:nix-community/emacs-overlay;
|
||||
};
|
||||
|
||||
outputs = inputs@{self, nixpkgs, unstable, master, ... }:
|
||||
@@ -36,6 +37,7 @@
|
||||
overlays = overlays ++ [
|
||||
inputs.nur.overlay
|
||||
inputs.nvim.overlay
|
||||
inputs.emacs.overlay
|
||||
channels
|
||||
(_:_:{nbfc-linux=inputs.nbfc.defaultPackage.${system};})
|
||||
];
|
||||
@@ -49,6 +51,7 @@
|
||||
./modules/nvidia-offload.nix
|
||||
./modules/pipewire.nix
|
||||
./modules/xorg.nix
|
||||
./modules/emacs
|
||||
];
|
||||
commonModules = [
|
||||
./modules/nvim
|
||||
|
@@ -1,45 +0,0 @@
|
||||
;;settings
|
||||
(setq display-line-numbers-type 'relative)
|
||||
(setq inhibit-startup-screen t)
|
||||
(set-face-attribute 'default nil :font "Fira Mono for Powerline" :height 120)
|
||||
|
||||
|
||||
|
||||
;;add packages and shit
|
||||
(require 'package)
|
||||
(add-to-list 'package-archives '("melpa" . "http://melpa.org/packages/"))
|
||||
(package-initialize)
|
||||
(setq pkgs '(ivy gruvbox-theme elcord rainbow-delimiters))
|
||||
(while pkgs
|
||||
(require (car pkgs))
|
||||
(setq pkgs (cdr pkgs)))
|
||||
|
||||
|
||||
;;package config and modes
|
||||
(global-hl-line-mode 1)
|
||||
(scroll-bar-mode 0)
|
||||
(tool-bar-mode 0)
|
||||
(menu-bar-mode 0)
|
||||
(fringe-mode 0)
|
||||
(global-display-line-numbers-mode 1)
|
||||
(load-theme 'gruvbox-dark-hard t)
|
||||
(ivy-mode 1)
|
||||
(elcord-mode 1)
|
||||
|
||||
|
||||
;;keybinds
|
||||
;ivy
|
||||
(define-key ivy-minibuffer-map (kbd "C-n") 'ivy-next-line)
|
||||
(define-key ivy-minibuffer-map (kbd "C-e") 'ivy-previous-line)
|
||||
(define-key ivy-minibuffer-map (kbd "C-i") 'ivy-done)
|
||||
|
||||
|
||||
;;hooks
|
||||
;exclude line numbers
|
||||
(setq exclude-ln '(term-mode-hook eshell-mode-hook shell-mode-hook))
|
||||
(while exclude-ln
|
||||
(add-hook (car exclude-ln) (lambda () (display-line-numbers-mode 0)))
|
||||
(setq exclude-ln (cdr exclude-ln)))
|
||||
|
||||
;rainbow delims
|
||||
(add-hook 'prog-mode-hook 'rainbow-delimiters-mode)
|
1
home/config/emacs/init.el
Symbolic link
1
home/config/emacs/init.el
Symbolic link
@@ -0,0 +1 @@
|
||||
../../../modules/emacs/init.el
|
@@ -1,18 +1,60 @@
|
||||
{ pkgs, config, ... }:
|
||||
{
|
||||
#i dont really use emacs but eh
|
||||
programs.emacs = {
|
||||
enable = true;
|
||||
enable = false;
|
||||
extraPackages = epkgs: with epkgs; [
|
||||
elcord
|
||||
gruvbox-theme
|
||||
ivy
|
||||
rainbow-delimiters
|
||||
evil
|
||||
evil-colemak-basics
|
||||
treemacs
|
||||
treemacs-evil
|
||||
lsp-mode
|
||||
lsp-treemacs
|
||||
lsp-ui
|
||||
tree-sitter
|
||||
tree-sitter-langs
|
||||
tsc
|
||||
];
|
||||
overrides = self: super: {
|
||||
gruvbox-theme = self.melpaPackages.gruvbox-theme.overrideAttrs(_: {
|
||||
patches = [ ../../config/emacs/gruvbox-el.patch ];
|
||||
});
|
||||
overrides = self: super : {
|
||||
tsc = super.tsc.overrideAttrs(oa:
|
||||
let
|
||||
tsc-dyn = version: pkgs.fetchurl {
|
||||
url = "https://github.com/emacs-tree-sitter/elisp-tree-sitter/releases/download/${version}/tsc-dyn.so";
|
||||
sha256 = "sha256-oOq/TAooHRUo7JypCblrB/ztABowAHv2LRhFL/ZmVrg=";
|
||||
};
|
||||
in { postInstall = oa.postInstall or "" + "cp ${tsc-dyn "0.15.2"} $out/share/emacs/site-lisp/elpa/tsc-${super.tsc.version}/tsc-dyn.so" ;});
|
||||
tree-sitter-langs = pkgs.symlinkJoin rec {
|
||||
name = "tree-sitter-langs";
|
||||
paths =
|
||||
let
|
||||
tree-sitter-grammars = pkgs.stdenv.mkDerivation rec {
|
||||
name = "tree-sitter-grammars";
|
||||
version = "0.10.4";
|
||||
src = pkgs.fetchzip {
|
||||
url = "https://github.com/emacs-tree-sitter/tree-sitter-langs/releases/download/${version}/tree-sitter-grammars-linux-${version}.tar.gz";
|
||||
sha256 = "sha256-Z+JtuGLTCVhCJBR60cbcDgWtdKcoYGWoeI5u9GcfvUQ=";
|
||||
stripRoot = false;
|
||||
};
|
||||
installPhase = ''
|
||||
install -d $out/langs/bin
|
||||
install -m444 * $out/langs/bin
|
||||
echo -n $version > $out/langs/bin/BUNDLE-VERSION
|
||||
'';
|
||||
};
|
||||
in
|
||||
[
|
||||
(super.tree-sitter-langs.overrideAttrs (oldAttrs: {
|
||||
postPatch = oldAttrs.postPatch or "" + ''
|
||||
substituteInPlace ./tree-sitter-langs-build.el \
|
||||
--replace "tree-sitter-langs-grammar-dir tree-sitter-langs--dir" "tree-sitter-langs-grammar-dir \"${tree-sitter-grammars}/langs\""
|
||||
'';
|
||||
}))
|
||||
tree-sitter-grammars
|
||||
];
|
||||
};
|
||||
};
|
||||
};
|
||||
home.file.emacs = {
|
||||
|
@@ -28,6 +28,7 @@
|
||||
lohit-fonts.gurmukhi
|
||||
nerdfonts
|
||||
font-awesome
|
||||
monoid
|
||||
];
|
||||
users.users.natto = {
|
||||
isNormalUser = true;
|
||||
|
62
modules/emacs/default.nix
Normal file
62
modules/emacs/default.nix
Normal file
@@ -0,0 +1,62 @@
|
||||
{ pkgs, config, ... }:
|
||||
{
|
||||
environment.systemPackages = with pkgs; [
|
||||
(emacsWithPackagesFromUsePackage {
|
||||
config = ./init.el;
|
||||
alwaysEnsure = true;
|
||||
extraEmacsPackages = epkgs: with epkgs; [
|
||||
use-package
|
||||
tsc
|
||||
];
|
||||
override = epkgs : epkgs // {
|
||||
tsc = epkgs.melpaPackages.tsc.overrideAttrs(oa:
|
||||
let
|
||||
version = "0.15.1";
|
||||
tsc-dyn = fetchurl {
|
||||
url = "https://github.com/emacs-tree-sitter/elisp-tree-sitter/releases/download/${version}/tsc-dyn.so";
|
||||
sha256 = "sha256-TrwyQZEfARHfafT4IhxR+p7vpjSuw9lUcgOSwCvPxe4=";
|
||||
};
|
||||
version-file = writeText "DYN-VERSION" version;
|
||||
in {
|
||||
/* src = fetchFromGitHub {
|
||||
owner = "emacs-tree-sitter";
|
||||
repo = "elisp-tree-sitter";
|
||||
rev = version;
|
||||
sha256 = "sha256-dGWg4dj+85kxytvm+nNEJUN9UXdr9L6pSRz5OqDMFAM=";
|
||||
};*/
|
||||
postInstall = ''
|
||||
cp ${tsc-dyn} $out/share/emacs/site-lisp/elpa/tsc-${oa.version}/tsc-dyn.so
|
||||
cp ${version-file} $out/share/emacs/site-lisp/elpa/tsc-${oa.version}/DYN-VERSION
|
||||
'';
|
||||
});
|
||||
tree-sitter-langs = epkgs.melpaPackages.tree-sitter-langs.overrideAttrs (oa:
|
||||
let
|
||||
tree-sitter-grammars = super.stdenv.mkDerivation rec {
|
||||
name = "tree-sitter-grammars";
|
||||
version = "0.10.4";
|
||||
src = fetchzip {
|
||||
url = "https://github.com/emacs-tree-sitter/tree-sitter-langs/releases/download/${version}/tree-sitter-grammars-linux-${version}.tar.gz";
|
||||
sha256 = "sha256-Z+JtuGLTCVhCJBR60cbcDgWtdKcoYGWoeI5u9GcfvUQ=";
|
||||
stripRoot = false;
|
||||
};
|
||||
installPhase = ''
|
||||
install -d $out/langs/bin
|
||||
install -m444 * $out/langs/bin
|
||||
echo -n $version > $out/langs/bin/BUNDLE-VERSION
|
||||
'';
|
||||
};
|
||||
in {
|
||||
postPatch = oa.postPatch or "" + ''
|
||||
substituteInPlace ./tree-sitter-langs-build.el \
|
||||
--replace "tree-sitter-langs-grammar-dir tree-sitter-langs--dir" "tree-sitter-langs-grammar-dir \"${tree-sitter-grammars}/langs\""
|
||||
'';
|
||||
# postInstall = oa.postInstall or "" + ''
|
||||
# mkdir $out/share/emacs/site-lisp/elpa/tree-sitter-langs-${oa.version}/bin
|
||||
# cp ${binaries}/* $out/share/emacs/site-lisp/elpa/tree-sitter-langs-${oa.version}/bin/
|
||||
# '';
|
||||
});
|
||||
gruvbox-theme = epkgs.melpaPackages.gruvbox-theme.overrideAttrs(_: { patches = [ ./gruvbox-el.patch ]; } );
|
||||
};
|
||||
})
|
||||
];
|
||||
}
|
101
modules/emacs/init.el
Normal file
101
modules/emacs/init.el
Normal file
@@ -0,0 +1,101 @@
|
||||
;;settings
|
||||
(setq display-line-numbers-type 'relative)
|
||||
(setq inhibit-startup-screen t)
|
||||
(set-face-attribute 'default nil :font "Monoid" :height 120)
|
||||
(global-hl-line-mode 1)
|
||||
(scroll-bar-mode 0)
|
||||
(tool-bar-mode 0)
|
||||
(menu-bar-mode 0)
|
||||
(fringe-mode 0)
|
||||
(global-display-line-numbers-mode 1)
|
||||
(setq initial-major-mode 'emacs-lisp-mode)
|
||||
|
||||
;;add packages and shit
|
||||
(require 'package)
|
||||
(add-to-list 'package-archives '("melpa" . "http://melpa.org/packages/"))
|
||||
(package-initialize)
|
||||
(require 'use-package)
|
||||
|
||||
|
||||
;;package config and modes
|
||||
(use-package gruvbox-theme
|
||||
:init
|
||||
(load-theme 'gruvbox-dark-hard t))
|
||||
|
||||
(use-package ivy
|
||||
:config
|
||||
(ivy-mode 1))
|
||||
|
||||
(use-package elcord
|
||||
:config
|
||||
(elcord-mode 1))
|
||||
|
||||
(use-package evil
|
||||
:config
|
||||
(evil-mode 1))
|
||||
|
||||
(use-package evil-colemak-basics
|
||||
:init
|
||||
(setq evil-colemak-basics-layout-mod 'mod-dh)
|
||||
:config
|
||||
(global-evil-colemak-basics-mode 1))
|
||||
|
||||
(use-package treemacs
|
||||
:config
|
||||
(treemacs-filewatch-mode 1)
|
||||
(treemacs-git-mode 'deferred))
|
||||
|
||||
(use-package treemacs-evil
|
||||
:bind (:map evil-treemacs-state-map
|
||||
("n" . treemacs-next-line)
|
||||
("e" . treemacs-previous-line)
|
||||
("M-n" . treemacs-next-neighbour)
|
||||
("M-e" . treemacs-previous-neighbour)
|
||||
("M-N" . treemacs-next-line-other-window)
|
||||
("M-E" . treemacs-previous-line-other-window)
|
||||
("M" . treemacs-collapse-parent-node))
|
||||
:init
|
||||
|
||||
(use-package lsp-mode
|
||||
:config
|
||||
(lsp-mode 1))
|
||||
|
||||
(use-package lsp-treemacs
|
||||
:config
|
||||
(lsp-treemacs-sync-mode))
|
||||
|
||||
(use-package lsp-ui
|
||||
:config
|
||||
(lsp-ui-peek-enable 1)
|
||||
(lsp-ui-doc-enable 1))
|
||||
|
||||
(use-package tree-sitter-langs)
|
||||
|
||||
(use-package tree-sitter
|
||||
:config
|
||||
(global-tree-sitter-mode)
|
||||
:init
|
||||
(add-to-list 'tree-sitter-major-mode-language-alist '(fundamental-mode . bash))
|
||||
(add-hook 'tree-sitter-after-on-hook #'tree-sitter-hl-mode))
|
||||
|
||||
(use-package rainbow-delimiters
|
||||
:hook (prog-mode . rainbow-delimiters-mode))
|
||||
|
||||
;(use-package rustic)
|
||||
|
||||
;;keybinds
|
||||
;ivy
|
||||
(define-key ivy-minibuffer-map (kbd "C-n") 'ivy-next-line)
|
||||
(define-key ivy-minibuffer-map (kbd "C-e") 'ivy-previous-line)
|
||||
(define-key ivy-minibuffer-map (kbd "C-i") 'ivy-done)
|
||||
|
||||
;evil-treemacs
|
||||
(evil-define-key 'treemacs treemacs-mode-map (kbd "m") #'treemacs-COLLAPSE-action)
|
||||
(evil-define-key 'treemacs treemacs-mode-map (kbd "i") #'treemacs-RET-action))
|
||||
|
||||
;;hooks
|
||||
;exclude line numbers
|
||||
(setq exclude-ln '(term-mode-hook eshell-mode-hook shell-mode-hook))
|
||||
(while exclude-ln
|
||||
(add-hook (car exclude-ln) (lambda () (display-line-numbers-mode 0)))
|
||||
(setq exclude-ln (cdr exclude-ln)))
|
@@ -29,7 +29,7 @@
|
||||
nvim-tree-lua
|
||||
vim-vsnip
|
||||
nvim-treesitter
|
||||
vim-polyglot
|
||||
vim-nix
|
||||
(gruvbox.overrideAttrs (oa: { patches = [ ./gruvbox.patch ]; }))
|
||||
];
|
||||
};
|
||||
|
@@ -60,10 +60,12 @@ cdhbind('m', 'h')
|
||||
cdhbind('n', 'j')
|
||||
cdhbind('e', 'k')
|
||||
cdhbind('i', 'l')
|
||||
cdhbind('h', 'i')
|
||||
cdhbind('j', 'm')
|
||||
cdhbind('u', 'i')
|
||||
cdhbind('l', 'u')
|
||||
cdhbind('k', 'n')
|
||||
cdhbind('l', 'e')
|
||||
cdhbind('f', 'e')
|
||||
cdhbind('t', 'f')
|
||||
cdhbind('j', 't')
|
||||
bind('n', "<M-s>", ":w<CR>", {noremap=true})
|
||||
bind('n', "<M-n>", ":resize -2<CR>", {noremap=true, silent=true})
|
||||
bind('n', "<M-e>", ":resize +2<CR>", {noremap=true, silent=true})
|
||||
|
Reference in New Issue
Block a user