Caution
While this repo is public and licensed under MIT you probably do NOT want to just clone it and use it as a template for your own project. Feel free to look around and take inspiration as I did with plenty of dotfile repository before me. This is my personal setup and it works for me. If you have questions or suggestions (or find me adding my own private keys to this repo) feel free to contact me or peruse the issues section.
See the note above. If you are still here, then you probably are interested in how I optimize my daily work with my system and these files are the result of that. I try to abide by some rules and principles to make my life easier:
-
I use GNU Bash (on my system currently v5.2+). I don't use any fancy new and better shell, just
/bin/bash
. I use it because it is the most widely used shell and it is the default shell on my system. I use it because all my linting tools and subscripts are written or configured for bash. I am not required to reinvent the wheel. (The last sentence is something I repeat to myself once a day or more often.) -
If functionality is available within Bash itself, I will use this functionality, not an additional program or package that needs to be installed and might not be available on other systems.
-
Speed is subjective. 1 second is not slow. 5 seconds is not slow. I will not optimize my scripts to save nanoseconds and will enjoy the time spent waiting for my scripts to finish.
-
I will document most of the features within the scripts themselves. I will not document the features in the README.md file or only mention them in a drive-by.
Caution
Again: You do not want to directly set up this repository on your own system. Clone it to learn, then create your own .dotfiles setup.
Clone with submodules:
git clone --recurse-submodules [email protected]:davidsneighbour/dotfiles.git
Install dependencies:
npm install
Run initial setup:
./dotbot.sh install
wget -qO- <https://github.com/davidsneighbour/dotfiles/blob/main/install.sh> | bash
Run consecutive updates:
git pull
./dotbot.sh
./dotbot.sh protected
git submodule update --recursive --remote --merge --force
Dotfiles set up adds a cronjob that exports the keybindings at 6pm daily to etc/keybindings.csv
. This file is imported when running dotbot.sh.
SUPER+R = rofi -show run
SUPER+W = vscode workspaces