mirror of
https://github.com/sebaschi/dotfiles.git
synced 2026-04-01 07:05:14 +02:00
Compare commits
14 Commits
a4f2cff5f3
...
clevo-sl
| Author | SHA1 | Date | |
|---|---|---|---|
| 7986022558 | |||
| 638a6503f1 | |||
| a2ac456f72 | |||
| 04a07210a4 | |||
| 8ef6a87ba1 | |||
| 7c30e64c4b | |||
| 6475b15d70 | |||
| 36a3766aef | |||
| 0a392b6252 | |||
| 3540c154e6 | |||
| 45b952f37a | |||
| 4a425ec8f1 | |||
| 4b3a47a17f | |||
| 84b20638f3 |
@@ -1,4 +0,0 @@
|
||||
# Changes
|
||||
|
||||
## Monday June 16, 2025
|
||||
Started to reorganize the repo for use with GNU stow. I'm thinking why develop and maintain a system myself, when such a good tool for symlink farming, and thus also my use case of dotfiles management, already exists.
|
||||
49
README.md
49
README.md
@@ -1,51 +1,38 @@
|
||||
# Dotfiles
|
||||
|
||||
A collection of configuration files for various tools and applications I use, with an installation script to easily set them up on new systems.
|
||||
Personal dotfiles and more
|
||||
|
||||
## Installation
|
||||
|
||||
### Clone the repository
|
||||
Install [GNU stow](https://gnu.org/software/stow/).
|
||||
You **will** want a version >= 8. September 2024! See [here](https://cgit.git.savannah.gnu.org/cgit/stow.git/tree/NEWS).
|
||||
This is so `dot-*` named files (or dirs) are handled correctly!
|
||||
|
||||
See `run.sh`. Use it as taskfile to install stow.
|
||||
|
||||
Then, to make sure that stow is correctly handling `dot-*` named dirs, run
|
||||
|
||||
```bash
|
||||
git clone git@github.com:sebaschi/dotfiles.git ~/.dotfiles
|
||||
stow --dotfiles --verbose stow
|
||||
```
|
||||
{
|
||||
This installs the `dot-stowrc` and global ignore list.
|
||||
|
||||
### Install configurations
|
||||
|
||||
The `dot-install` script can be used to install specific configurations or all of them at once:
|
||||
|
||||
```bash
|
||||
# Install everything
|
||||
~/.dotfiles/dot-install all
|
||||
|
||||
# Install specific configurations
|
||||
~/.dotfiles/dot-install git nvim tmux
|
||||
|
||||
# Install only bash aliases
|
||||
~/.dotfiles/dot-install bash:aliases
|
||||
## Installing configs
|
||||
```sh
|
||||
stow <config-pkg-name>
|
||||
```
|
||||
|
||||
Run `~/.dotfiles/dot-install` without arguments to see all available options.
|
||||
|
||||
## Testing
|
||||
|
||||
A test script is included to verify the installation script works correctly:
|
||||
|
||||
```bash
|
||||
~/.dotfiles/test-dot-install
|
||||
`<config-pkg-name>` is just one of the directories of this repo.
|
||||
To see what the effect would be without applying anything (dry-run):
|
||||
```sh
|
||||
stow -n <config-pkg-name>
|
||||
```
|
||||
|
||||
This runs the installation in an isolated environment to ensure all symlinks are correctly created.
|
||||
Nothing fancy, just creates mock home in `/tmp` and changes some envars used by the install script.
|
||||
The "Testing" amounts to check symlinks exist. This is mostly usefull once extended to detect config packages (just the directories containing an a config), to remind me to add a function for it in `dot-install`.
|
||||
|
||||
## Included Configurations
|
||||
|
||||
* **Shells**: Bash, Fish, Zsh
|
||||
* **Terminal**: Tmux, Zellij, Ghostty
|
||||
* **Editors**: Vim, Neovim (with lazy.nvim)
|
||||
* **Tools**: Git, Starship prompt, Borg backup
|
||||
* **Tools**: Git, Starship prompt, Borg backup, Fossil (**TODO**)
|
||||
* **Utilities**: Rsync filters
|
||||
|
||||
## Tools Tools
|
||||
|
||||
@@ -1,2 +0,0 @@
|
||||
export PATH="$HOME/scripts:$PATH"
|
||||
|
||||
7
bash/dot-bash_logout
Normal file
7
bash/dot-bash_logout
Normal file
@@ -0,0 +1,7 @@
|
||||
# ~/.bash_logout: executed by bash(1) when login shell exits.
|
||||
|
||||
# when leaving the console clear the screen to increase privacy
|
||||
|
||||
if [ "$SHLVL" = 1 ]; then
|
||||
[ -x /usr/bin/clear_console ] && /usr/bin/clear_console -q
|
||||
fi
|
||||
206
bash/dot-bashrc
Normal file
206
bash/dot-bashrc
Normal file
@@ -0,0 +1,206 @@
|
||||
# ~/.bashrc: executed by bash(1) for non-login shells.
|
||||
# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc)
|
||||
# for examples
|
||||
|
||||
# If not running interactively, don't do anything
|
||||
case $- in
|
||||
*i*) ;;
|
||||
*) return;;
|
||||
esac
|
||||
|
||||
# don't put duplicate lines or lines starting with space in the history.
|
||||
# See bash(1) for more options
|
||||
HISTCONTROL=ignoreboth
|
||||
|
||||
# append to the history file, don't overwrite it
|
||||
shopt -s histappend
|
||||
|
||||
# for setting history length see HISTSIZE and HISTFILESIZE in bash(1)
|
||||
HISTSIZE=1000
|
||||
HISTFILESIZE=2000
|
||||
|
||||
# check the window size after each command and, if necessary,
|
||||
# update the values of LINES and COLUMNS.
|
||||
shopt -s checkwinsize
|
||||
|
||||
# If set, the pattern "**" used in a pathname expansion context will
|
||||
# match all files and zero or more directories and subdirectories.
|
||||
#shopt -s globstar
|
||||
|
||||
# make less more friendly for non-text input files, see lesspipe(1)
|
||||
[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)"
|
||||
|
||||
# set variable identifying the chroot you work in (used in the prompt below)
|
||||
if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then
|
||||
debian_chroot=$(cat /etc/debian_chroot)
|
||||
fi
|
||||
|
||||
# set a fancy prompt (non-color, unless we know we "want" color)
|
||||
case "$TERM" in
|
||||
xterm-color|*-256color) color_prompt=yes;;
|
||||
esac
|
||||
# uncomment for a colored prompt, if the terminal has the capability; turned
|
||||
# off by default to not distract the user: the focus in a terminal window
|
||||
# should be on the output of commands, not on the prompt
|
||||
#force_color_prompt=yes
|
||||
|
||||
if [ -n "$force_color_prompt" ]; then
|
||||
if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
|
||||
# We have color support; assume it's compliant with Ecma-48
|
||||
# (ISO/IEC-6429). (Lack of such support is extremely rare, and such
|
||||
# a case would tend to support setf rather than setaf.)
|
||||
color_prompt=yes
|
||||
else
|
||||
color_prompt=
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ "$color_prompt" = yes ]; then
|
||||
PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
|
||||
else
|
||||
PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
|
||||
fi
|
||||
unset color_prompt force_color_prompt
|
||||
|
||||
# If this is an xterm set the title to user@host:dir
|
||||
case "$TERM" in
|
||||
xterm*|rxvt*)
|
||||
PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1"
|
||||
;;
|
||||
*)
|
||||
;;
|
||||
esac
|
||||
|
||||
# enable color support of ls and also add handy aliases
|
||||
if [ -x /usr/bin/dircolors ]; then
|
||||
test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)"
|
||||
alias ls='eza --color'
|
||||
alias dir='dir --color'
|
||||
alias vdir='vdir --color'
|
||||
|
||||
# using ugrep instead of grep
|
||||
alias grep='ug -G --color'
|
||||
alias fgrep='ug -F --color'
|
||||
alias egrep='ug -E --color'
|
||||
fi
|
||||
|
||||
# colored GCC warnings and errors
|
||||
export GCC_COLORS='error=01;31:warning=01;35:note=01;36:caret=01;32:locus=01:quote=01'
|
||||
|
||||
# some more ls aliases
|
||||
alias ll='ls -alF'
|
||||
alias la='ls -A'
|
||||
alias l='ls -hF'
|
||||
|
||||
# Add an "alert" alias for long running commands. Use like so:
|
||||
# sleep 10; alert
|
||||
alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"'
|
||||
|
||||
# Alias definitions.
|
||||
# You may want to put all your additions into a separate file like
|
||||
# ~/.bash_aliases, instead of adding them here directly.
|
||||
# See /usr/share/doc/bash-doc/examples in the bash-doc package.
|
||||
|
||||
if [ -f ~/.bash_aliases ]; then
|
||||
. ~/.bash_aliases
|
||||
fi
|
||||
|
||||
# Source bash env list
|
||||
source $HOME/.local/share/bash/bash_env
|
||||
|
||||
# Pet snippet manager
|
||||
# register previous command
|
||||
function prev() {
|
||||
PREV=$(echo $(history | tail -n2 | head -n1) | sed 's/[0-9]* //')
|
||||
sh -c "pet new $(printf %q "$PREV")"
|
||||
}
|
||||
|
||||
# TODO if [ -d ~/.bashrc.d ]; then
|
||||
|
||||
# enable programmable completion features (you don't need to enable
|
||||
# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
|
||||
# sources /etc/bash.bashrc).
|
||||
if ! shopt -oq posix; then
|
||||
if [ -f /usr/share/bash-completion/bash_completion ]; then
|
||||
. /usr/share/bash-completion/bash_completion
|
||||
elif [ -f /etc/bash_completion ]; then
|
||||
. /etc/bash_completion
|
||||
fi
|
||||
fi
|
||||
. "$HOME/.cargo/env"
|
||||
|
||||
|
||||
# Starship init
|
||||
eval "$(starship init bash)"
|
||||
|
||||
# Homebrew
|
||||
eval "$(/home/linuxbrew/.linuxbrew/bin/brew shellenv)"
|
||||
|
||||
# Pagers
|
||||
export PAGER="less"
|
||||
export LESS="-FIRX"
|
||||
# export MANPAGER="$PAGER"
|
||||
|
||||
# Github CLI aliases
|
||||
alias ghce="gh copilot explain"
|
||||
alias ghcs="gh copilot suggest"
|
||||
|
||||
# Util Aliases
|
||||
# broot does this now
|
||||
# alias fcd='cd "$(dirname "$(fzf)")"'
|
||||
alias st='systemctl-tui'
|
||||
alias task='./task.py'
|
||||
|
||||
# BEGIN hcloud
|
||||
source <(hcloud completion bash)
|
||||
# END hcloud
|
||||
|
||||
source /home/seb/.config/broot/launcher/bash/br
|
||||
|
||||
[ -f "/home/seb/.ghcup/env" ] && . "/home/seb/.ghcup/env" # ghcup-env
|
||||
|
||||
alias nodeman='ssh hwsec nodeman'
|
||||
|
||||
# >>> conda initialize >>>
|
||||
# !! Contents within this block are managed by 'conda init' !!
|
||||
__conda_setup="$('/home/seb/miniforge3/bin/conda' 'shell.bash' 'hook' 2> /dev/null)"
|
||||
if [ $? -eq 0 ]; then
|
||||
eval "$__conda_setup"
|
||||
else
|
||||
if [ -f "/home/seb/miniforge3/etc/profile.d/conda.sh" ]; then
|
||||
. "/home/seb/miniforge3/etc/profile.d/conda.sh"
|
||||
else
|
||||
export PATH="/home/seb/miniforge3/bin:$PATH"
|
||||
fi
|
||||
fi
|
||||
unset __conda_setup
|
||||
# <<< conda initialize <<<
|
||||
|
||||
|
||||
# >>> mamba initialize >>>
|
||||
# !! Contents within this block are managed by 'mamba shell init' !!
|
||||
export MAMBA_EXE='/home/seb/miniforge3/bin/mamba';
|
||||
export MAMBA_ROOT_PREFIX='/home/seb/miniforge3';
|
||||
__mamba_setup="$("$MAMBA_EXE" shell hook --shell bash --root-prefix "$MAMBA_ROOT_PREFIX" 2> /dev/null)"
|
||||
if [ $? -eq 0 ]; then
|
||||
eval "$__mamba_setup"
|
||||
else
|
||||
alias mamba="$MAMBA_EXE" # Fallback on help from mamba activate
|
||||
fi
|
||||
unset __mamba_setup
|
||||
# <<< mamba initialize <<<
|
||||
|
||||
# >>> juliaup initialize >>>
|
||||
|
||||
# !! Contents within this block are managed by juliaup !!
|
||||
|
||||
case ":$PATH:" in
|
||||
*:/home/seb/.juliaup/bin:*)
|
||||
;;
|
||||
|
||||
*)
|
||||
export PATH=/home/seb/.juliaup/bin${PATH:+:${PATH}}
|
||||
;;
|
||||
esac
|
||||
|
||||
# <<< juliaup initialize <<<
|
||||
4
bash/dot-local/share/bash/bash_env
Normal file
4
bash/dot-local/share/bash/bash_env
Normal file
@@ -0,0 +1,4 @@
|
||||
export PATH="$HOME/scripts:$PATH"
|
||||
export PATH="$HOME/.config/emacs/bin:$PATH"
|
||||
export PAGER="less"
|
||||
export LESS="-FIRX"
|
||||
75
doom/dot-config/doom/config.el
Normal file
75
doom/dot-config/doom/config.el
Normal file
@@ -0,0 +1,75 @@
|
||||
;;; $DOOMDIR/config.el -*- lexical-binding: t; -*-
|
||||
|
||||
;; Place your private configuration here! Remember, you do not need to run 'doom
|
||||
;; sync' after modifying this file!
|
||||
|
||||
|
||||
;; Some functionality uses this to identify you, e.g. GPG configuration, email
|
||||
;; clients, file templates and snippets. It is optional.
|
||||
;; (setq user-full-name "John Doe"
|
||||
;; user-mail-address "john@doe.com")
|
||||
|
||||
;; Doom exposes five (optional) variables for controlling fonts in Doom:
|
||||
;;
|
||||
;; - `doom-font' -- the primary font to use
|
||||
;; - `doom-variable-pitch-font' -- a non-monospace font (where applicable)
|
||||
;; - `doom-big-font' -- used for `doom-big-font-mode'; use this for
|
||||
;; presentations or streaming.
|
||||
;; - `doom-symbol-font' -- for symbols
|
||||
;; - `doom-serif-font' -- for the `fixed-pitch-serif' face
|
||||
;;
|
||||
;; See 'C-h v doom-font' for documentation and more examples of what they
|
||||
;; accept. For example:
|
||||
;;
|
||||
;;(setq doom-font (font-spec :family "Fira Code" :size 12 :weight 'semi-light)
|
||||
;; doom-variable-pitch-font (font-spec :family "Fira Sans" :size 13))
|
||||
;;
|
||||
;; If you or Emacs can't find your font, use 'M-x describe-font' to look them
|
||||
;; up, `M-x eval-region' to execute elisp code, and 'M-x doom/reload-font' to
|
||||
;; refresh your font settings. If Emacs still can't find your font, it likely
|
||||
;; wasn't installed correctly. Font issues are rarely Doom issues!
|
||||
|
||||
;; There are two ways to load a theme. Both assume the theme is installed and
|
||||
;; available. You can either set `doom-theme' or manually load a theme with the
|
||||
;; `load-theme' function. This is the default:
|
||||
(setq doom-theme 'doom-one)
|
||||
|
||||
;; This determines the style of line numbers in effect. If set to `nil', line
|
||||
;; numbers are disabled. For relative line numbers, set this to `relative'.
|
||||
(setq display-line-numbers-type t)
|
||||
|
||||
;; If you use `org' and don't want your org files in the default location below,
|
||||
;; change `org-directory'. It must be set before org loads!
|
||||
(setq org-directory "~/org/")
|
||||
|
||||
|
||||
;; Whenever you reconfigure a package, make sure to wrap your config in an
|
||||
;; `with-eval-after-load' block, otherwise Doom's defaults may override your
|
||||
;; settings. E.g.
|
||||
;;
|
||||
;; (with-eval-after-load 'PACKAGE
|
||||
;; (setq x y))
|
||||
;;
|
||||
;; The exceptions to this rule:
|
||||
;;
|
||||
;; - Setting file/directory variables (like `org-directory')
|
||||
;; - Setting variables which explicitly tell you to set them before their
|
||||
;; package is loaded (see 'C-h v VARIABLE' to look them up).
|
||||
;; - Setting doom variables (which start with 'doom-' or '+').
|
||||
;;
|
||||
;; Here are some additional functions/macros that will help you configure Doom.
|
||||
;;
|
||||
;; - `load!' for loading external *.el files relative to this one
|
||||
;; - `add-load-path!' for adding directories to the `load-path', relative to
|
||||
;; this file. Emacs searches the `load-path' when you load packages with
|
||||
;; `require' or `use-package'.
|
||||
;; - `map!' for binding new keys
|
||||
;;
|
||||
;; To get information about any of these functions/macros, move the cursor over
|
||||
;; the highlighted symbol at press 'K' (non-evil users must press 'C-c c k').
|
||||
;; This will open documentation for it, including demos of how they are used.
|
||||
;; Alternatively, use `C-h o' to look up a symbol (functions, variables, faces,
|
||||
;; etc).
|
||||
;;
|
||||
;; You can also try 'gd' (or 'C-c c d') to jump to their definition and see how
|
||||
;; they are implemented.
|
||||
198
doom/dot-config/doom/init.el
Normal file
198
doom/dot-config/doom/init.el
Normal file
@@ -0,0 +1,198 @@
|
||||
;;;init.el -*- lexical-binding: t; -*-
|
||||
;;
|
||||
;; This file controls what Doom modules are enabled and what order they load
|
||||
;; in. Remember to run 'doom sync' after modifying it!
|
||||
;;
|
||||
;; NOTE Press 'SPC h d h' (or 'C-h d h' for non-vim users) to access Doom's
|
||||
;; documentation. There you'll find a link to Doom's Module Index where all
|
||||
;; of our modules are listed, including what flags they support.
|
||||
;;
|
||||
;; NOTE Move your cursor over a module's name (or its flags) and press 'K' (or
|
||||
;; 'C-c c k' for non-vim users) to view its documentation. This works on
|
||||
;; flags as well (those symbols that start with a plus).
|
||||
;;
|
||||
;; Alternatively, press 'gd' (or 'C-c c d') on a module to browse its
|
||||
;; directory (for easy access to its source code).
|
||||
;;
|
||||
(doom! :input
|
||||
;;bidi ; (tfel ot) thgir etirw uoy gnipleh
|
||||
;;chinese
|
||||
;;japanese
|
||||
;;layout ; auie,ctsrnm is the superior home row
|
||||
|
||||
:completion
|
||||
;;company ; the ultimate code completion backend
|
||||
(corfu +orderless) ; complete with cap(f), cape and a flying feather!
|
||||
;;helm ; the *other* search engine for love and life
|
||||
;;ido ; the other *other* search engine...
|
||||
;;ivy ; a search engine for love and life
|
||||
vertico ; the search engine of the future
|
||||
|
||||
:ui
|
||||
;;deft ; notational velocity for Emacs
|
||||
doom ; what makes DOOM look the way it does
|
||||
doom-dashboard ; a nifty splash screen for Emacs
|
||||
;;doom-quit ; DOOM quit-message prompts when you quit Emacs
|
||||
;;(emoji +unicode) ; 🙂
|
||||
hl-todo ; highlight TODO/FIXME/NOTE/DEPRECATED/HACK/REVIEW
|
||||
;;indent-guides ; highlighted indent columns
|
||||
;;ligatures ; ligatures and symbols to make your code pretty again
|
||||
;;minimap ; show a map of the code on the side
|
||||
modeline ; snazzy, Atom-inspired modeline, plus API
|
||||
;;nav-flash ; blink cursor line after big motions
|
||||
;;neotree ; a project drawer, like NERDTree for vim
|
||||
ophints ; highlight the region an operation acts on
|
||||
(popup +defaults) ; tame sudden yet inevitable temporary windows
|
||||
;;smooth-scroll ; So smooth you won't believe it's not butter
|
||||
;;tabs ; a tab bar for Emacs
|
||||
;;treemacs ; a project drawer, like neotree but cooler
|
||||
;;unicode ; extended unicode support for various languages
|
||||
(vc-gutter +pretty) ; vcs diff in the fringe
|
||||
;; vi-tilde-fringe ; fringe tildes to mark beyond EOB
|
||||
;;window-select ; visually switch windows
|
||||
workspaces ; tab emulation, persistence & separate workspaces
|
||||
;;zen ; distraction-free coding or writing
|
||||
|
||||
:editor
|
||||
(evil +everywhere); come to the dark side, we have cookies
|
||||
;; file-templates ; auto-snippets for empty files
|
||||
fold ; (nigh) universal code folding
|
||||
;;(format +onsave) ; automated prettiness
|
||||
;;god ; run Emacs commands without modifier keys
|
||||
;;lispy ; vim for lisp, for people who don't like vim
|
||||
;;multiple-cursors ; editing in many places at once
|
||||
;;objed ; text object editing for the innocent
|
||||
;;parinfer ; turn lisp into python, sort of
|
||||
;;rotate-text ; cycle region at point between text candidates
|
||||
snippets ; my elves. They type so I don't have to
|
||||
(whitespace +guess +trim) ; a butler for your whitespace
|
||||
;;word-wrap ; soft wrapping with language-aware indent
|
||||
|
||||
:emacs
|
||||
dired ; making dired pretty [functional]
|
||||
electric ; smarter, keyword-based electric-indent
|
||||
;;eww ; the internet is gross
|
||||
;;ibuffer ; interactive buffer management
|
||||
tramp ; remote files at your arthritic fingertips
|
||||
undo ; persistent, smarter undo for your inevitable mistakes
|
||||
vc ; version-control and Emacs, sitting in a tree
|
||||
|
||||
:term
|
||||
;;eshell ; the elisp shell that works everywhere
|
||||
;;shell ; simple shell REPL for Emacs
|
||||
;;term ; basic terminal emulator for Emacs
|
||||
;;vterm ; the best terminal emulation in Emacs
|
||||
|
||||
:checkers
|
||||
syntax ; tasing you for every semicolon you forget
|
||||
;;(spell +flyspell) ; tasing you for misspelling mispelling
|
||||
;;grammar ; tasing grammar mistake every you make
|
||||
|
||||
:tools
|
||||
;;ansible
|
||||
;;biblio ; Writes a PhD for you (citation needed)
|
||||
;;collab ; buffers with friends
|
||||
;;debugger ; FIXME stepping through code, to help you add bugs
|
||||
;;direnv
|
||||
;;docker
|
||||
;;editorconfig ; let someone else argue about tabs vs spaces
|
||||
;;ein ; tame Jupyter notebooks with emacs
|
||||
(eval +overlay) ; run code, run (also, repls)
|
||||
lookup ; navigate your code and its documentation
|
||||
;;llm ; when I said you needed friends, I didn't mean...
|
||||
(lsp +eglot) ; M-x vscode
|
||||
magit ; a git porcelain for Emacs
|
||||
;;make ; run make tasks from Emacs
|
||||
;;pass ; password manager for nerds
|
||||
;;pdf ; pdf enhancements
|
||||
;;terraform ; infrastructure as code
|
||||
;;tmux ; an API for interacting with tmux
|
||||
tree-sitter ; syntax and parsing, sitting in a tree...
|
||||
;;upload ; map local to remote projects via ssh/ftp
|
||||
|
||||
:os
|
||||
(:if (featurep :system 'macos) macos) ; improve compatibility with macOS
|
||||
;;tty ; improve the terminal Emacs experience
|
||||
|
||||
:lang
|
||||
;;ada ; In strong typing we (blindly) trust
|
||||
;;agda ; types of types of types of types...
|
||||
;;beancount ; mind the GAAP
|
||||
(cc +lsp) ; C > C++ == 1
|
||||
;;clojure ; java with a lisp
|
||||
;;common-lisp ; if you've seen one lisp, you've seen them all
|
||||
;;coq ; proofs-as-programs
|
||||
;;crystal ; ruby at the speed of c
|
||||
;;csharp ; unity, .NET, and mono shenanigans
|
||||
data ; config/data formats
|
||||
;;(dart +flutter) ; paint ui and not much else
|
||||
;;dhall
|
||||
;;elixir ; erlang done right
|
||||
;;elm ; care for a cup of TEA?
|
||||
emacs-lisp ; drown in parentheses
|
||||
;;erlang ; an elegant language for a more civilized age
|
||||
;;ess ; emacs speaks statistics
|
||||
;;factor
|
||||
;;faust ; dsp, but you get to keep your soul
|
||||
;;fortran ; in FORTRAN, GOD is REAL (unless declared INTEGER)
|
||||
;;fsharp ; ML stands for Microsoft's Language
|
||||
;;fstar ; (dependent) types and (monadic) effects and Z3
|
||||
;;gdscript ; the language you waited for
|
||||
(go +lsp) ; the hipster dialect
|
||||
;;(graphql +lsp) ; Give queries a REST
|
||||
;;(haskell +lsp) ; a language that's lazier than I am
|
||||
;;hy ; readability of scheme w/ speed of python
|
||||
;;idris ; a language you can depend on
|
||||
;;json ; At least it ain't XML
|
||||
;;janet ; Fun fact: Janet is me!
|
||||
(java +lsp) ; the poster child for carpal tunnel syndrome
|
||||
;;javascript ; all(hope(abandon(ye(who(enter(here))))))
|
||||
;;julia ; a better, faster MATLAB
|
||||
;;kotlin ; a better, slicker Java(Script)
|
||||
;;latex ; writing papers in Emacs has never been so fun
|
||||
;;lean ; for folks with too much to prove
|
||||
;;ledger ; be audit you can be
|
||||
;;lua ; one-based indices? one-based indices
|
||||
markdown ; writing docs for people to ignore
|
||||
;;nim ; python + lisp at the speed of c
|
||||
;;nix ; I hereby declare "nix geht mehr!"
|
||||
;;ocaml ; an objective camel
|
||||
org ; organize your plain life in plain text
|
||||
;;php ; perl's insecure younger brother
|
||||
;;plantuml ; diagrams for confusing people more
|
||||
;;graphviz ; diagrams for confusing yourself even more
|
||||
;;purescript ; javascript, but functional
|
||||
python ; beautiful is better than ugly
|
||||
;;qt ; the 'cutest' gui framework ever
|
||||
;;racket ; a DSL for DSLs
|
||||
;;raku ; the artist formerly known as perl6
|
||||
;;rest ; Emacs as a REST client
|
||||
;;rst ; ReST in peace
|
||||
;;(ruby +rails) ; 1.step {|i| p "Ruby is #{i.even? ? 'love' : 'life'}"}
|
||||
(rust +lsp) ; Fe2O3.unwrap().unwrap().unwrap().unwrap()
|
||||
;;scala ; java, but good
|
||||
;;(scheme +guile) ; a fully conniving family of lisps
|
||||
sh ; she sells {ba,z,fi}sh shells on the C xor
|
||||
;;sml
|
||||
;;solidity ; do you need a blockchain? No.
|
||||
;;swift ; who asked for emoji variables?
|
||||
;;terra ; Earth and Moon in alignment for performance.
|
||||
;;web ; the tubes
|
||||
;;yaml ; JSON, but readable
|
||||
;;zig ; C, but simpler
|
||||
|
||||
:email
|
||||
;;(mu4e +org +gmail)
|
||||
;;notmuch
|
||||
;;(wanderlust +gmail)
|
||||
|
||||
:app
|
||||
;;calendar
|
||||
;;emms
|
||||
;;everywhere ; *leave* Emacs!? You must be joking
|
||||
;;irc ; how neckbeards socialize
|
||||
;;(rss +org) ; emacs as an RSS reader
|
||||
|
||||
:config
|
||||
;;literate
|
||||
(default +bindings +smartparens))
|
||||
54
doom/dot-config/doom/packages.el
Normal file
54
doom/dot-config/doom/packages.el
Normal file
@@ -0,0 +1,54 @@
|
||||
;; -*- no-byte-compile: t; -*-
|
||||
;;; $DOOMDIR/packages.el
|
||||
|
||||
;; To install a package:
|
||||
;;
|
||||
;; 1. Declare them here in a `package!' statement,
|
||||
;; 2. Run 'doom sync' in the shell,
|
||||
;; 3. Restart Emacs.
|
||||
;;
|
||||
;; Use 'C-h f package\!' to look up documentation for the `package!' macro.
|
||||
|
||||
|
||||
;; To install SOME-PACKAGE from MELPA, ELPA or emacsmirror:
|
||||
;; (package! some-package)
|
||||
|
||||
;; To install a package directly from a remote git repo, you must specify a
|
||||
;; `:recipe'. You'll find documentation on what `:recipe' accepts here:
|
||||
;; https://github.com/radian-software/straight.el#the-recipe-format
|
||||
;; (package! another-package
|
||||
;; :recipe (:host github :repo "username/repo"))
|
||||
|
||||
;; If the package you are trying to install does not contain a PACKAGENAME.el
|
||||
;; file, or is located in a subdirectory of the repo, you'll need to specify
|
||||
;; `:files' in the `:recipe':
|
||||
;; (package! this-package
|
||||
;; :recipe (:host github :repo "username/repo"
|
||||
;; :files ("some-file.el" "src/lisp/*.el")))
|
||||
|
||||
;; If you'd like to disable a package included with Doom, you can do so here
|
||||
;; with the `:disable' property:
|
||||
;; (package! builtin-package :disable t)
|
||||
|
||||
;; You can override the recipe of a built in package without having to specify
|
||||
;; all the properties for `:recipe'. These will inherit the rest of its recipe
|
||||
;; from Doom or MELPA/ELPA/Emacsmirror:
|
||||
;; (package! builtin-package :recipe (:nonrecursive t))
|
||||
;; (package! builtin-package-2 :recipe (:repo "myfork/package"))
|
||||
|
||||
;; Specify a `:branch' to install a package from a particular branch or tag.
|
||||
;; This is required for some packages whose default branch isn't 'master' (which
|
||||
;; our package manager can't deal with; see radian-software/straight.el#279)
|
||||
;; (package! builtin-package :recipe (:branch "develop"))
|
||||
|
||||
;; Use `:pin' to specify a particular commit to install.
|
||||
;; (package! builtin-package :pin "1a2b3c4d5e")
|
||||
|
||||
|
||||
;; Doom's packages are pinned to a specific commit and updated from release to
|
||||
;; release. The `unpin!' macro allows you to unpin single packages...
|
||||
;; (unpin! pinned-package)
|
||||
;; ...or multiple packages
|
||||
;; (unpin! pinned-package another-pinned-package)
|
||||
;; ...Or *all* packages (NOT RECOMMENDED; will likely break things)
|
||||
;; (unpin! t)
|
||||
@@ -7,7 +7,7 @@ window-width = 140
|
||||
window-height = 35
|
||||
window-save-state = always
|
||||
auto-update = download
|
||||
command = /home/linuxbrew/.linuxbrew/bin/nu
|
||||
# command = /home/linuxbrew/.linuxbrew/bin/nu
|
||||
keybind = ctrl+shift+l=goto_split:right
|
||||
keybind = ctrl+shift+h=goto_split:left
|
||||
keybind = ctrl+shift+j=goto_split:bottom
|
||||
|
||||
@@ -1,10 +1,9 @@
|
||||
[user]
|
||||
email = 74497638+sebaschi@users.noreply.github.com
|
||||
name = Sebastian Lenzlinger
|
||||
[http]
|
||||
sslVerify = false
|
||||
[filter "lfs"]
|
||||
clean = git-lfs clean -- %f
|
||||
smudge = git-lfs smudge -- %f
|
||||
process = git-lfs filter-process
|
||||
required = true
|
||||
name = Sebastian Lenzlinger
|
||||
email = s.m.lenzlinger@student.vu.nl
|
||||
[init]
|
||||
defaultBranch = devel
|
||||
[core]
|
||||
editor = nvim
|
||||
[gpg "ssh"]
|
||||
allowedSignersFile = /home/seb/.ssh/allowed_signers
|
||||
|
||||
17
git/dot-config/git/ignore
Normal file
17
git/dot-config/git/ignore
Normal file
@@ -0,0 +1,17 @@
|
||||
.claude/
|
||||
.claude
|
||||
.claude/**
|
||||
Claude.md
|
||||
*.o
|
||||
*.log
|
||||
cache/
|
||||
logs/
|
||||
build/
|
||||
|
||||
# Python stuff
|
||||
__pycache__/
|
||||
*.pyc
|
||||
|
||||
|
||||
# Environement/ 12 Factor
|
||||
.env
|
||||
8
helix/dot-config/helix/config.toml
Normal file
8
helix/dot-config/helix/config.toml
Normal file
@@ -0,0 +1,8 @@
|
||||
theme = "yellowed"
|
||||
|
||||
[editor.cursor-shape]
|
||||
insert = "bar"
|
||||
|
||||
[editor.soft-wrap]
|
||||
enable = true
|
||||
|
||||
5
pet/dot-config/pet/notes.md
Normal file
5
pet/dot-config/pet/notes.md
Normal file
@@ -0,0 +1,5 @@
|
||||
# IMPORTANT
|
||||
The two `prev.{bash, zsh}` functions need to go into `.bashrc` or `.zshrc` respectively.
|
||||
The `pet-slect.*` need to be put in the rc EXACTLY AS IS!!!. Else the keys aren't rebound.
|
||||
Those files are taken from [this](https://github.com/knqyf263/pet) Readme. As such,
|
||||
that repos license might apply!
|
||||
2073
pet/dot-config/pet/pet-repo-README.md
Normal file
2073
pet/dot-config/pet/pet-repo-README.md
Normal file
File diff suppressed because one or more lines are too long
6
pet/dot-config/pet/pre-select.bash
Normal file
6
pet/dot-config/pet/pre-select.bash
Normal file
@@ -0,0 +1,6 @@
|
||||
function pet-select() {
|
||||
BUFFER=$(pet search --query "$READLINE_LINE")
|
||||
READLINE_LINE=$BUFFER
|
||||
READLINE_POINT=${#BUFFER}
|
||||
}
|
||||
bind -x '"\C-x\C-r": pet-select'
|
||||
8
pet/dot-config/pet/pre-select.zsh
Normal file
8
pet/dot-config/pet/pre-select.zsh
Normal file
@@ -0,0 +1,8 @@
|
||||
function pet-select() {
|
||||
BUFFER=$(pet search --query "$LBUFFER")
|
||||
CURSOR=$#BUFFER
|
||||
zle redisplay
|
||||
}
|
||||
zle -N pet-select
|
||||
stty -ixon
|
||||
bindkey '^s' pet-select
|
||||
4
pet/dot-config/pet/prev.bash
Normal file
4
pet/dot-config/pet/prev.bash
Normal file
@@ -0,0 +1,4 @@
|
||||
function prev() {
|
||||
PREV=$(echo `history | tail -n2 | head -n1` | sed 's/[0-9]* //')
|
||||
sh -c "pet new `printf %q "$PREV"`"
|
||||
}
|
||||
4
pet/dot-config/pet/prev.zsh
Normal file
4
pet/dot-config/pet/prev.zsh
Normal file
@@ -0,0 +1,4 @@
|
||||
function prev() {
|
||||
PREV=$(fc -lrn | head -n 1)
|
||||
sh -c "pet new `printf %q "$PREV"`"
|
||||
}
|
||||
@@ -4,3 +4,9 @@
|
||||
Output = ""
|
||||
Tag = ["superuser", "bash", "sh", "envvar"]
|
||||
command = "sudo -E --shell"
|
||||
|
||||
[[Snippets]]
|
||||
Description = "Preprocess slabinfo header so that columns align correctly"
|
||||
Output = ""
|
||||
Tag = []
|
||||
command = "sed 's/# //' /proc/slabinfo | column -t"
|
||||
|
||||
@@ -40,3 +40,6 @@ install_gnu_stow() {
|
||||
install_stow_latest_from_source
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
"@"
|
||||
12
shellib/dot-local/lib/shellib/libseb.sh
Normal file
12
shellib/dot-local/lib/shellib/libseb.sh
Normal file
@@ -0,0 +1,12 @@
|
||||
log() {
|
||||
# Write msg to stderr.
|
||||
# Taken from https://github.com/oils-for-unix/oils/blob/master/stdlib/osh/two.sh
|
||||
echo "$@" >&2
|
||||
}
|
||||
|
||||
die() {
|
||||
# Write error msg with script name and exit with status 1.
|
||||
# Taken from https://github.com/oils-for-unix/oils/blob/master/stdlib/osh/two.sh
|
||||
log "$@: fatal $@"
|
||||
exit 1
|
||||
}
|
||||
Reference in New Issue
Block a user