Merge remote-tracking branch 'enklave/master' into 20.03
This commit is contained in:
commit
0eb9a9272b
3
.gitmodules
vendored
3
.gitmodules
vendored
@ -7,6 +7,9 @@
|
|||||||
[submodule "lass/5pkgs/autowifi"]
|
[submodule "lass/5pkgs/autowifi"]
|
||||||
path = lass/5pkgs/autowifi
|
path = lass/5pkgs/autowifi
|
||||||
url = https://github.com/Lassulus/autowifi
|
url = https://github.com/Lassulus/autowifi
|
||||||
|
[submodule "jeschli/2configs/elisp"]
|
||||||
|
path = jeschli/2configs/elisp
|
||||||
|
url = https://github.com/Jeschli/misc-elisp-scripts.git
|
||||||
[submodule "submodules/brockman"]
|
[submodule "submodules/brockman"]
|
||||||
path = submodules/brockman
|
path = submodules/brockman
|
||||||
url = https://github.com/kmein/brockman.git
|
url = https://github.com/kmein/brockman.git
|
||||||
|
@ -7,6 +7,8 @@
|
|||||||
<stockholm/jeschli/2configs/emacs.nix>
|
<stockholm/jeschli/2configs/emacs.nix>
|
||||||
<stockholm/jeschli/2configs/firefox.nix>
|
<stockholm/jeschli/2configs/firefox.nix>
|
||||||
<stockholm/jeschli/2configs/rust.nix>
|
<stockholm/jeschli/2configs/rust.nix>
|
||||||
|
<stockholm/jeschli/2configs/haskell.nix>
|
||||||
|
<stockholm/jeschli/2configs/steam.nix>
|
||||||
<stockholm/jeschli/2configs/python.nix>
|
<stockholm/jeschli/2configs/python.nix>
|
||||||
./desktop.nix
|
./desktop.nix
|
||||||
./i3-configuration.nix
|
./i3-configuration.nix
|
||||||
@ -36,10 +38,19 @@
|
|||||||
# List packages installed in system profile. To search, run:
|
# List packages installed in system profile. To search, run:
|
||||||
# $ nix search wget
|
# $ nix search wget
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
wget vim git
|
|
||||||
rofi
|
|
||||||
ag
|
ag
|
||||||
alacritty
|
alacritty
|
||||||
|
google-chrome
|
||||||
|
chromium
|
||||||
|
copyq
|
||||||
|
direnv
|
||||||
|
go
|
||||||
|
git
|
||||||
|
gitAndTools.hub
|
||||||
|
sbcl
|
||||||
|
rofi
|
||||||
|
vim
|
||||||
|
wget
|
||||||
];
|
];
|
||||||
|
|
||||||
users.users.ombi = {
|
users.users.ombi = {
|
||||||
@ -49,18 +60,27 @@
|
|||||||
|
|
||||||
users.users.jeschli = {
|
users.users.jeschli = {
|
||||||
isNormalUser = true;
|
isNormalUser = true;
|
||||||
|
extraGroups = [ "audio" ];
|
||||||
};
|
};
|
||||||
|
|
||||||
# services.xserver.synaptics.enable = true;
|
# services.xserver.synaptics.enable = true;
|
||||||
services.xserver.libinput.enable = true;
|
services.xserver.libinput.enable = true;
|
||||||
services.xserver.libinput.disableWhileTyping = true;
|
services.xserver.libinput.disableWhileTyping = true;
|
||||||
|
|
||||||
|
hardware.pulseaudio.enable = true;
|
||||||
|
|
||||||
#Enable ssh daemon
|
#Enable ssh daemon
|
||||||
services.openssh.enable = true;
|
services.openssh.enable = true;
|
||||||
|
|
||||||
|
#Enable clight
|
||||||
|
services.clight.enable = true;
|
||||||
|
services.geoclue2.enable = true;
|
||||||
|
location.provider = "geoclue2";
|
||||||
|
|
||||||
users.users.root.openssh.authorizedKeys.keys = [
|
users.users.root.openssh.authorizedKeys.keys = [
|
||||||
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDM1xtX/SF2IzfAIzrXvH4HsW05eTBX8U8MYlEPadq0DS/nHC45hW2PSEUOVsH0UhBRAB+yClVLyN+JAYsuOoQacQqAVq9R7HAoFITdYTMJCxVs4urSRv0pWwTopRIh1rlI+Q0QfdMoeVtO2ZKG3KoRM+APDy2dsX8LTtWjXmh/ZCtpGl1O8TZtz2ZyXyv9OVDPnQiFwPU3Jqs2Z036c+kwxWlxYc55FRuqwRtQ48c/ilPMu+ZvQ22j1Ch8lNuliyAg1b8pZdOkMJF3R8b46IQ8FEqkr3L1YQygYw2M50B629FPgHgeGPMz3mVd+5lzP+okbhPJjMrUqZAUwbMGwGzZ ombi@nixos"
|
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDM1xtX/SF2IzfAIzrXvH4HsW05eTBX8U8MYlEPadq0DS/nHC45hW2PSEUOVsH0UhBRAB+yClVLyN+JAYsuOoQacQqAVq9R7HAoFITdYTMJCxVs4urSRv0pWwTopRIh1rlI+Q0QfdMoeVtO2ZKG3KoRM+APDy2dsX8LTtWjXmh/ZCtpGl1O8TZtz2ZyXyv9OVDPnQiFwPU3Jqs2Z036c+kwxWlxYc55FRuqwRtQ48c/ilPMu+ZvQ22j1Ch8lNuliyAg1b8pZdOkMJF3R8b46IQ8FEqkr3L1YQygYw2M50B629FPgHgeGPMz3mVd+5lzP+okbhPJjMrUqZAUwbMGwGzZ ombi@nixos"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKFXgtbgeivxlMKkoEJ4ANhtR+LRMSPrsmL4U5grFUME jeschli@nixos"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKFXgtbgeivxlMKkoEJ4ANhtR+LRMSPrsmL4U5grFUME jeschli@nixos"
|
||||||
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIG7C3bgoL9VeVl8pgu8sp3PCOs6TXk4R9y7JKJAHGsfm root@baeckerei"
|
||||||
];
|
];
|
||||||
|
|
||||||
# This value determines the NixOS release with which your system is to be
|
# This value determines the NixOS release with which your system is to be
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
xkbOptions = "caps:super";
|
xkbOptions = "caps:super";
|
||||||
exportConfiguration = true;
|
exportConfiguration = true;
|
||||||
|
|
||||||
displayManager.slim.enable = true;
|
displayManager.lightdm.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
# Configure fonts
|
# Configure fonts
|
||||||
|
@ -21,7 +21,7 @@ let
|
|||||||
floating_modifier $mod
|
floating_modifier $mod
|
||||||
|
|
||||||
# start a terminal
|
# start a terminal
|
||||||
bindsym $mod+Return exec i3-sensible-terminal
|
bindsym $mod+Return exec alacritty
|
||||||
|
|
||||||
# kill focused window
|
# kill focused window
|
||||||
bindsym $mod+Shift+q kill
|
bindsym $mod+Shift+q kill
|
||||||
@ -32,6 +32,11 @@ let
|
|||||||
# start dmenu (a program launcher)
|
# start dmenu (a program launcher)
|
||||||
bindsym $mod+d exec ${pkgs.rofi}/bin/rofi -modi drun#run -combi-modi drun#run -show combi -show-icons -display-combi run
|
bindsym $mod+d exec ${pkgs.rofi}/bin/rofi -modi drun#run -combi-modi drun#run -show combi -show-icons -display-combi run
|
||||||
|
|
||||||
|
bindsym $mod+x exec ${pkgs.rofi}/bin/rofi -modi window -show window -auto-select
|
||||||
|
|
||||||
|
bindsym $mod+F1 exec xinput --list | grep Touchpad | sed 's/.*id=\([0-9][0-9]\).*/\1/' | xargs xinput disable
|
||||||
|
bindsym $mod+F2 exec xinput --list | grep Touchpad | sed 's/.*id=\([0-9][0-9]\).*/\1/' | xargs xinput enable
|
||||||
|
|
||||||
# There also is the (new) i3-dmenu-desktop which only displays applications
|
# There also is the (new) i3-dmenu-desktop which only displays applications
|
||||||
# shipping a .desktop file. It is a wrapper around dmenu, so you need that
|
# shipping a .desktop file. It is a wrapper around dmenu, so you need that
|
||||||
# installed.
|
# installed.
|
||||||
|
1
jeschli/2configs/elisp
Submodule
1
jeschli/2configs/elisp
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit ae1a03ddee80d73ac166af75cdb1d93d24fa44b9
|
@ -114,29 +114,29 @@ let
|
|||||||
("NEXT" ("WAITING") ("CANCELLED") ("HOLD"))
|
("NEXT" ("WAITING") ("CANCELLED") ("HOLD"))
|
||||||
("DONE" ("WAITING") ("CANCELLED") ("HOLD")))))
|
("DONE" ("WAITING") ("CANCELLED") ("HOLD")))))
|
||||||
|
|
||||||
(setq org-directory "~/projects/notes_private")
|
(setq org-directory "~/projects/notes_privat")
|
||||||
(setq org-default-notes-file "~/projects/notes_private/refile.org")
|
(setq org-default-notes-file "~/projects/notes_privat/refile.org")
|
||||||
|
|
||||||
;; I use C-c c to start capture mode
|
;; I use C-c c to start capture mode
|
||||||
(global-set-key (kbd "C-c c") 'org-capture)
|
(global-set-key (kbd "C-c c") 'org-capture)
|
||||||
|
|
||||||
;; Capture templates for: TODO tasks, Notes, appointments, phone calls, meetings, and org-protocol
|
;; Capture templates for: TODO tasks, Notes, appointments, phone calls, meetings, and org-protocol
|
||||||
(setq org-capture-templates
|
(setq org-capture-templates
|
||||||
(quote (("t" "todo" entry (file "~/git/org/refile.org")
|
(quote (("t" "todo" entry (file org-default-notes-file)
|
||||||
"* TODO %?\n%U\n%a\n" :clock-in t :clock-resume t)
|
"* TODO %?\n%U\n%a\n" :clock-in t :clock-resume t)
|
||||||
("r" "respond" entry (file "~/git/org/refile.org")
|
("r" "respond" entry (file org-default-notes-file)
|
||||||
"* NEXT Respond to %:from on %:subject\nSCHEDULED: %t\n%U\n%a\n" :clock-in t :clock-resume t :immediate-finish t)
|
"* NEXT Respond to %:from on %:subject\nSCHEDULED: %t\n%U\n%a\n" :clock-in t :clock-resume t :immediate-finish t)
|
||||||
("n" "note" entry (file "~/git/org/refile.org")
|
("n" "note" entry (file org-default-notes-file)
|
||||||
"* %? :NOTE:\n%U\n%a\n" :clock-in t :clock-resume t)
|
"* %? :NOTE:\n%U\n%a\n" :clock-in t :clock-resume t)
|
||||||
("j" "Journal" entry (file+datetree "~/git/org/diary.org")
|
("j" "Journal" entry (file+datetree "~/git/org/diary.org")
|
||||||
"* %?\n%U\n" :clock-in t :clock-resume t)
|
"* %?\n%U\n" :clock-in t :clock-resume t)
|
||||||
("w" "org-protocol" entry (file "~/git/org/refile.org")
|
("w" "org-protocol" entry (file org-default-notes-file)
|
||||||
"* TODO Review %c\n%U\n" :immediate-finish t)
|
"* TODO Review %c\n%U\n" :immediate-finish t)
|
||||||
("m" "Meeting" entry (file "~/git/org/refile.org")
|
("m" "Meeting" entry (file org-default-notes-file)
|
||||||
"* MEETING with %? :MEETING:\n%U" :clock-in t :clock-resume t)
|
"* MEETING with %? :MEETING:\n%U" :clock-in t :clock-resume t)
|
||||||
("p" "Phone call" entry (file "~/git/org/refile.org")
|
("p" "Phone call" entry (file org-default-notes-file)
|
||||||
"* PHONE %? :PHONE:\n%U" :clock-in t :clock-resume t)
|
"* PHONE %? :PHONE:\n%U" :clock-in t :clock-resume t)
|
||||||
("h" "Habit" entry (file "~/git/org/refile.org")
|
("h" "Habit" entry (file org-default-notes-file)
|
||||||
"* NEXT %?\n%U\n%a\nSCHEDULED: %(format-time-string \"%<<%Y-%m-%d %a .+1d/3d>>\")\n:PROPERTIES:\n:STYLE: habit\n:REPEAT_TO_STATE: NEXT\n:END:\n"))))
|
"* NEXT %?\n%U\n%a\nSCHEDULED: %(format-time-string \"%<<%Y-%m-%d %a .+1d/3d>>\")\n:PROPERTIES:\n:STYLE: habit\n:REPEAT_TO_STATE: NEXT\n:END:\n"))))
|
||||||
|
|
||||||
;; Remove empty LOGBOOK drawers on clock out
|
;; Remove empty LOGBOOK drawers on clock out
|
||||||
@ -144,7 +144,7 @@ let
|
|||||||
(interactive)
|
(interactive)
|
||||||
(save-excursion
|
(save-excursion
|
||||||
(beginning-of-line 0)
|
(beginning-of-line 0)
|
||||||
(org-remove-empty-drawer-at "LOGBOOK" (point))))
|
(org-remove-empty-drawer-at (point))))
|
||||||
|
|
||||||
(add-hook 'org-clock-out-hook 'bh/remove-empty-drawer-on-clock-out 'append)
|
(add-hook 'org-clock-out-hook 'bh/remove-empty-drawer-on-clock-out 'append)
|
||||||
|
|
||||||
|
@ -9,235 +9,76 @@ let
|
|||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
orgAgendaView = import ./emacs-org-agenda.nix;
|
# The emacs packages that I use
|
||||||
|
# I differ between
|
||||||
|
# - stable (Packages that I use for some time - happy with it)
|
||||||
|
# - unstable (Packages that I use for some time - but may drop)
|
||||||
|
# - testing (Packages that I try out - the new stuff)
|
||||||
|
emacsPkgs = epkgs:
|
||||||
|
(with epkgs.melpaPackages ;
|
||||||
|
|
||||||
packageRepos = ''
|
## windows-purpose (testing)
|
||||||
(require 'package) ;; You might already have this line
|
[ window-purpose ] ++
|
||||||
(let* ((no-ssl (and (memq system-type '(windows-nt ms-dos))
|
|
||||||
(not (gnutls-available-p))))
|
|
||||||
(url (concat (if no-ssl "http" "https") "://melpa.org/packages/")))
|
|
||||||
(add-to-list 'package-archives (cons "melpa" url) t)
|
|
||||||
(add-to-list 'package-archives
|
|
||||||
'("org" . "http://orgmode.org/elpa/") t)
|
|
||||||
)
|
|
||||||
(when (< emacs-major-version 24)
|
|
||||||
;; For important compatibility libraries like cl-lib
|
|
||||||
(add-to-list 'package-archives '("gnu" . "http://elpa.gnu.org/packages/")))
|
|
||||||
(package-initialize)
|
|
||||||
'';
|
|
||||||
|
|
||||||
evilMode = ''
|
## helm (stable)
|
||||||
;; Evil Mode
|
# emacs completion engine
|
||||||
(require 'evil)
|
[ helm helm-ag ] ++
|
||||||
(evil-mode 1)
|
|
||||||
;; (require 'evil-org)
|
|
||||||
;; (add-hook 'org-mode-hook 'evil-org-mode)
|
|
||||||
;; (evil-org-set-key-theme '(navigation insert textobjects additional calendar))
|
|
||||||
;; (require 'evil-org-agenda)
|
|
||||||
;; (evil-org-agenda-set-keys)
|
|
||||||
'';
|
|
||||||
|
|
||||||
goMode = ''
|
## deft (testing)
|
||||||
(setq godoc-and-godef-command "go doc") ;godoc has no cli support any more, thats go doc now
|
# text search for a directory
|
||||||
(add-to-list 'exec-path "~/go/bin")
|
[ deft ] ++
|
||||||
(add-hook 'go-mode-hook
|
|
||||||
(lambda ()
|
|
||||||
(setq-default)
|
|
||||||
(setq tab-width 2)
|
|
||||||
(setq standard-indent 2)
|
|
||||||
(setq indent-tabs-mode nil)))
|
|
||||||
'';
|
|
||||||
|
|
||||||
ido = ''
|
## lsp mode (unstable)
|
||||||
(require 'ido)
|
# Language Server Protocol mode
|
||||||
(ido-mode t)
|
# Used for rust
|
||||||
'';
|
[ company-lsp dap-mode helm-lsp lsp-mode lsp-treemacs lsp-ui ] ++
|
||||||
|
|
||||||
helm = ''
|
## emacs convenience (stable)
|
||||||
(helm-mode 1)
|
# Mixed and general purpose
|
||||||
(global-set-key (kbd "M-x") #'helm-M-x)
|
[ ag company direnv evil google-this spacemacs-theme ] ++
|
||||||
(global-set-key (kbd "C-x r b") #'helm-filtered-bookmarks)
|
|
||||||
(global-set-key (kbd "C-x C-f") #'helm-find-files)
|
|
||||||
'';
|
|
||||||
|
|
||||||
magit = ''
|
## common lisp (testing)
|
||||||
(global-set-key (kbd "C-x g") 'magit-status) ; "Most Magit commands are commonly invoked from the status buffer"
|
[ slime ] ++
|
||||||
'';
|
|
||||||
|
|
||||||
windowCosmetics = ''
|
## magit (stable)
|
||||||
(menu-bar-mode -1)
|
[ magit ] ++
|
||||||
(tool-bar-mode -1) ; Disable the button bar atop screen
|
|
||||||
(scroll-bar-mode -1) ; Disable scroll bar
|
|
||||||
(toggle-scroll-bar -1)
|
|
||||||
(setq inhibit-startup-screen t) ; Disable startup screen with graphics
|
|
||||||
(setq-default indent-tabs-mode nil) ; Use spaces instead of tabs
|
|
||||||
(setq default-tab-width 2) ; Two spaces is a tab
|
|
||||||
(setq tab-width 2) ; Four spaces is a tab
|
|
||||||
(setq visible-bell nil) ; Disable annoying visual bell graphic
|
|
||||||
(setq ring-bell-function 'ignore) ; Disable super annoying audio bell
|
|
||||||
'';
|
|
||||||
|
|
||||||
orgMode = ''
|
## bunch of programming languages (unstable)
|
||||||
(add-to-list 'auto-mode-alist '("\\.\\(org\\|org_archive\\|txt\\)$" . org-mode))
|
[ go-mode haskell-mode nix-mode ] ++
|
||||||
(global-set-key "\C-cl" 'org-store-link)
|
|
||||||
(global-set-key "\C-ca" 'org-agenda)
|
|
||||||
(global-set-key "\C-cb" 'org-iswitchb)
|
|
||||||
(global-set-key "\C-c L" 'org-insert-link-global)
|
|
||||||
(global-set-key "\C-c o" 'org-open-at-point-global)
|
|
||||||
(setq org-link-frame-setup '((file . find-file))) ; open link in same frame.
|
|
||||||
(if (boundp 'org-user-agenda-files)
|
|
||||||
(setq org-agenda-files org-user-agenda-files)
|
|
||||||
(setq org-agenda-files (quote ("~/projects/notes_privat")))
|
|
||||||
)
|
|
||||||
'';
|
|
||||||
|
|
||||||
theme = ''
|
## rust (unstable)
|
||||||
(load-theme 'monokai-alt t)
|
[ racer rust-mode ] ++
|
||||||
(load-theme 'whiteboard t)
|
|
||||||
(disable-theme 'monokai-alt)
|
|
||||||
(disable-theme 'whiteboard)
|
|
||||||
|
|
||||||
(defun mh/load-whiteboard-theme ()
|
## python (stable)
|
||||||
"load whiteboard theme"
|
# Python IDE for emacs
|
||||||
(interactive)
|
[ elpy ]) ++
|
||||||
(message "whiteboard loaded")
|
|
||||||
(disable-theme 'monokai-alt)
|
|
||||||
(enable-theme 'whiteboard)
|
|
||||||
)
|
|
||||||
|
|
||||||
(defun mh/load-monokai-theme ()
|
|
||||||
"load monokai theme"
|
|
||||||
(interactive)
|
|
||||||
(message "monokai loaded")
|
|
||||||
(disable-theme 'whiteboard)
|
|
||||||
(enable-theme 'monokai-alt)
|
|
||||||
)
|
|
||||||
|
|
||||||
(global-set-key "\C-ctw" 'mh/load-whiteboard-theme)
|
|
||||||
(global-set-key "\C-ctm" 'mh/load-monokai-theme)
|
|
||||||
'';
|
|
||||||
|
|
||||||
# Configuration for rust development
|
|
||||||
# inspired by
|
|
||||||
# https://github.com/bbatsov/prelude/blob/master/modules/prelude-rust.el
|
|
||||||
#
|
|
||||||
# This requires rls and racer to be installed on the system
|
|
||||||
rustDevelopment = ''
|
|
||||||
(add-hook 'rust-mode-hook #'racer-mode)
|
|
||||||
(add-hook 'rust-mode-hook (lambda()
|
|
||||||
(local-set-key (kbd "C-c C-d") 'racer-describe)
|
|
||||||
(local-set-key (kbd "C-c .") 'racer-find-definition)
|
|
||||||
(local-set-key (kbd "C-c ,") 'pop-tag-mark))
|
|
||||||
)
|
|
||||||
(add-hook 'racer-mode-hook #'eldoc-mode)
|
|
||||||
(add-hook 'racer-mode-hook #'company-mode)
|
|
||||||
(require 'rust-mode)
|
|
||||||
(define-key rust-mode-map (kbd "TAB") #'company-indent-or-complete-common)
|
|
||||||
(setq company-tooltip-align-annotations t)
|
|
||||||
'';
|
|
||||||
|
|
||||||
recentFiles = ''
|
|
||||||
(recentf-mode 1)
|
|
||||||
(setq recentf-max-menu-items 25)
|
|
||||||
(global-set-key "\C-x\ \C-r" 'recentf-open-files)
|
|
||||||
'';
|
|
||||||
|
|
||||||
myFunctionKeys = ''
|
|
||||||
(fset 'kill-actual-buffer
|
|
||||||
[?\C-x ?k return])
|
|
||||||
|
|
||||||
(defun mh/open-term-and-rename (name)
|
|
||||||
"open a new bash and rename it"
|
|
||||||
(interactive "sName of new terminal: ")
|
|
||||||
(term "/run/current-system/sw/bin/bash")
|
|
||||||
(rename-buffer name)
|
|
||||||
)
|
|
||||||
(global-set-key (kbd "M-<f8>") 'kill-actual-buffer)
|
|
||||||
|
|
||||||
(global-set-key (kbd "<f5>") 'mh/open-term-and-rename)
|
|
||||||
(global-set-key (kbd "<f6>") 'other-window)
|
|
||||||
(global-set-key (kbd "<f7>") 'split-window-right)
|
|
||||||
(global-set-key (kbd "<f8>") 'delete-other-windows)
|
|
||||||
'';
|
|
||||||
|
|
||||||
lspMode = ''
|
|
||||||
(require 'lsp-mode)
|
|
||||||
(add-hook 'rust-mode-hook #'lsp)
|
|
||||||
'';
|
|
||||||
|
|
||||||
dotEmacs = pkgs.writeText "dot-emacs" ''
|
|
||||||
${packageRepos}
|
|
||||||
|
|
||||||
${evilMode}
|
|
||||||
${goMode}
|
|
||||||
${helm}
|
|
||||||
${magit}
|
|
||||||
${orgMode}
|
|
||||||
${rustDevelopment}
|
|
||||||
${theme}
|
|
||||||
${windowCosmetics}
|
|
||||||
|
|
||||||
${orgAgendaView}
|
|
||||||
${myFunctionKeys}
|
|
||||||
${lspMode}
|
|
||||||
'';
|
|
||||||
|
|
||||||
#emacsWithCustomPackages
|
|
||||||
emacsPkgs= epkgs: [
|
|
||||||
# testing lsp mode
|
|
||||||
epkgs.melpaPackages.lsp-ui
|
|
||||||
epkgs.melpaPackages.company-lsp
|
|
||||||
epkgs.melpaPackages.lsp-treemacs
|
|
||||||
epkgs.melpaPackages.helm-lsp
|
|
||||||
epkgs.melpaPackages.dap-mode
|
|
||||||
epkgs.melpaPackages.lsp-mode
|
|
||||||
|
|
||||||
|
## org-mode
|
||||||
|
# Org-Mode has several extensions
|
||||||
|
# and can be seen as an application of its own.
|
||||||
|
(with epkgs.melpaPackages ;
|
||||||
# testing
|
# testing
|
||||||
epkgs.melpaPackages.web-mode
|
[ org-super-agenda org-bullets org-ql ] ++
|
||||||
epkgs.melpaPackages.js2-mode
|
# unstable
|
||||||
epkgs.melpaPackages.xref-js2
|
[ smex org-mime orgit ]
|
||||||
|
) ++
|
||||||
|
|
||||||
epkgs.melpaPackages.academic-phrases
|
# stable
|
||||||
|
(with epkgs.orgPackages ;
|
||||||
|
[ org-plus-contrib ]) ++
|
||||||
|
|
||||||
epkgs.melpaPackages.gitlab
|
# stable
|
||||||
epkgs.melpaPackages.helm
|
(with epkgs.elpaPackages ;
|
||||||
epkgs.melpaPackages.weechat
|
[ bbdb which-key ]);
|
||||||
|
|
||||||
# emacs convenience
|
# ## EXWM related (unstable)
|
||||||
epkgs.melpaPackages.ag
|
# epkgs.exwm
|
||||||
epkgs.melpaPackages.company
|
# epkgs.melpaPackages.desktop-environment
|
||||||
epkgs.melpaPackages.direnv
|
# epkgs.melpaPackages.helm-exwm
|
||||||
epkgs.melpaPackages.evil
|
# ];
|
||||||
epkgs.melpaPackages.google-this
|
|
||||||
epkgs.melpaPackages.monokai-alt-theme
|
|
||||||
epkgs.melpaPackages.zenburn-theme
|
|
||||||
|
|
||||||
# development
|
|
||||||
epkgs.melpaPackages.magit
|
|
||||||
epkgs.melpaPackages.nix-mode
|
|
||||||
epkgs.melpaPackages.go-mode
|
|
||||||
epkgs.melpaPackages.haskell-mode
|
|
||||||
# rust
|
|
||||||
epkgs.melpaPackages.rust-mode
|
|
||||||
# epkgs.melpaPackages.flycheck-rust
|
|
||||||
epkgs.melpaPackages.racer
|
|
||||||
|
|
||||||
# python
|
|
||||||
epkgs.melpaPackages.elpy
|
|
||||||
|
|
||||||
# org-mode
|
|
||||||
epkgs.elpaPackages.bbdb
|
|
||||||
epkgs.orgPackages.org-plus-contrib
|
|
||||||
epkgs.melpaPackages.smex
|
|
||||||
epkgs.melpaPackages.org-mime
|
|
||||||
epkgs.melpaPackages.orgit
|
|
||||||
|
|
||||||
|
|
||||||
epkgs.elpaPackages.which-key
|
|
||||||
];
|
|
||||||
|
|
||||||
emacsWithOverlay = pkgsWithOverlay.emacsWithPackagesFromUsePackage {
|
emacsWithOverlay = pkgsWithOverlay.emacsWithPackagesFromUsePackage {
|
||||||
config = builtins.readFile dotEmacs; # builtins.readFile ./emacs.el;
|
config = builtins.readFile ./elisp/init.el;
|
||||||
# Package is optional, defaults to pkgs.emacs
|
# Package is optional, defaults to pkgs.emacs
|
||||||
package = pkgsWithOverlay.emacsGit;
|
package = pkgsWithOverlay.emacsGit;
|
||||||
# Optionally provide extra packages not in the configuration file
|
# Optionally provide extra packages not in the configuration file
|
||||||
@ -245,18 +86,34 @@ let
|
|||||||
};
|
};
|
||||||
|
|
||||||
myEmacs = pkgs.writeDashBin "my-emacs" ''
|
myEmacs = pkgs.writeDashBin "my-emacs" ''
|
||||||
exec ${emacsWithOverlay}/bin/emacs -q -l ${dotEmacs} "$@"
|
exec ${emacsWithOverlay}/bin/emacs -q "$@"
|
||||||
'';
|
'';
|
||||||
|
|
||||||
myEmacsWithDaemon = pkgs.writeDashBin "my-emacs-daemon" ''
|
myEmacsWithDaemon = pkgs.writeDashBin "my-emacs-daemon" ''
|
||||||
exec ${emacsWithOverlay}/bin/emacs -q -l ${dotEmacs} --daemon
|
exec ${emacsWithOverlay}/bin/emacs -q --daemon -l ${./elisp/init.el}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
myEmacsClient = pkgs.writeDashBin "meclient" ''
|
myEmacsClient = pkgs.writeDashBin "meclient" ''
|
||||||
exec ${emacsWithOverlay}/bin/emacsclient --create-frame
|
exec ${emacsWithOverlay}/bin/emacsclient --create-frame "$@"
|
||||||
'';
|
'';
|
||||||
in {
|
in {
|
||||||
environment.systemPackages = [
|
environment.systemPackages = [
|
||||||
myEmacs myEmacsWithDaemon myEmacsClient
|
myEmacs myEmacsWithDaemon myEmacsClient emacsWithOverlay
|
||||||
];
|
];
|
||||||
|
|
||||||
|
## EXWM Config
|
||||||
|
# services.xserver = {
|
||||||
|
# enable = true;
|
||||||
|
# xkbOptions = "caps:super";
|
||||||
|
# exportConfiguration = true;
|
||||||
|
#
|
||||||
|
# displayManager.slim.enable = true;
|
||||||
|
# windowManager.default = "exwm";
|
||||||
|
#
|
||||||
|
# # Set up the login session
|
||||||
|
# windowManager.session = [{
|
||||||
|
# name = "exwm";
|
||||||
|
# start = "${emacsWithOverlay}/bin/emacs -q -l " + builtins.toString ./elisp/init.el;
|
||||||
|
# }];
|
||||||
|
# };
|
||||||
}
|
}
|
||||||
|
19
jeschli/2configs/haskell.nix
Normal file
19
jeschli/2configs/haskell.nix
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
{ config, pkgs, ... }:
|
||||||
|
let
|
||||||
|
all-hies = import (fetchTarball "https://github.com/infinisil/all-hies/tarball/master") {};
|
||||||
|
in
|
||||||
|
{
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
cabal2nix
|
||||||
|
gcc
|
||||||
|
ghc
|
||||||
|
haskellPackages.cabal-install
|
||||||
|
haskellPackages.ghcid
|
||||||
|
haskellPackages.hindent
|
||||||
|
haskellPackages.hlint
|
||||||
|
haskellPackages.hoogle
|
||||||
|
haskellPackages.stack
|
||||||
|
haskellPackages.stylish-haskell
|
||||||
|
(all-hies.selection { selector = p: {inherit (p) ghc864; }; })
|
||||||
|
];
|
||||||
|
}
|
@ -1 +1 @@
|
|||||||
Subproject commit ed9fc6658226b1525bc008205d76276f0054c6c5
|
Subproject commit f1b7112ac3cbe090e96f2c82c525b6db69b82034
|
Loading…
Reference in New Issue
Block a user