This is my command line configuration. Everything necessary to setup the command line tools and anything related the way I like it is either backed up or described here.
This is tailored to an Arch-based install (EndeavourOS, currently), so will need some tweaks for any other distro.
A significant amount of my setup is automated. While you may want to experiment with a different order, you are safe to follow these steps in the order they are documented in here.
The first thing to do is to setup git. This and the cloning of the dotfiles can be done with a script. Run the commands below and that script will walk you through the steps of registering this machine with GitHub (ssh-key) and will take care of everything else.
[@authentication requires GitHub Username, Password and 2FA]
cd /tmp
wget https://raw.githubusercontent.com/SonkeWohler/.vim/master/git-setup.bash
chmod +x git-setup.bash
./git-setup.bash
This should drop you inside the setup/
folder containing the remaining
scripts. First you should run pacman.bash
and make sure everything installs
fine. Sometimes package-names change and packages move. Last time I had my
nerd-fonts fail to install for this reason.
./pacman.bash
Now the configuration related scripts, as you should be able to test these without restarting first.
./config.bash
./script.bash
And finally the remaining scripts for DE settings and docker. These require a restart to test.
On Plasma this is also the point when I download the system theme Desert-Global from the settings. This should be in place before a restart as without it the settings revert and you have to change them back manually.
When testing whether docker works, there are some notes below on common issues.
./kde.bash
./docker.bash
./desktop.bash
These scripts take care of, in the above order:
- software, like nvim, kubernetes etc.
- note: Docker Desktop might not work quite right, see below.
- this doesn't just cover pacman, but also yay, pip and npm, but it is Arch-specific
- dotfiles like ~/.bashrc
- this also runs installs for anything that requires this config to be in place for the installation to work properly, like tmux and neovim.
- useful scripts for keyboard remaps and terminal autostarts
- kde files
- the most important things this takes care of are:
- keyboard shortcuts
- plasma widgets
- this is still somewhat experimental, so a few things don't work quite the way you might expect. Stuff like the search preferences in Dolphin, which change somewhat regularly.
- the most important things this takes care of are:
- setting up docker-desktop to run
- After restart you can test with
docker info
. Consult the arch wiki on common problems like:- Bios not allowing hardware virtualisation
- rootless docker working correctly
- is
docker.socket
running (systemctl enable --now docker.socket
)
- After restart you can test with
- place some files on desktop for convenience.
Make sure everything works as intended before moving on to:
There are some things that you still have to setup manually:
- For any Nvidia cards you have to install drivers. EndeavourOS has
nvidia-inst
for that which works well in my experience to cover steps 1.* in the Arch Wiki instructions fully automated. - Start and setup Vivaldi
- Log into my Vivaldi Account to get extensions and their settings [@authentication requires Vivaldi Password and Username]
- You can skip the passwords, as these are managed by KeePassXC, see Nextcloud below
- this step is kind of annoying. Even after logging into my account two
things are not set up:
- keyboard shortcuts are the most annoying. They need to be set up manually until I figure out where the damn file is to copy/sync
- theming and other appearance settings also don't seem to sync. They are less problematic.
- Nextcloud
- go to cloud.sonki.codes and log in as
sonki
[@authentication requires Nextcloud Password and Username] - open your local nextcloud and use your browser to authenticate it
- sync files to
~/nextcloud
- decrypt the password database in
~/nextcloud/sync/passwords.kdbx
[@authentication requires keepass-phrase etc] - connect the KeePassXC browser extension to the database
- In KeePassXC go to Tools > Settings > Browser and Enable for Vivaldi
- In the Browser Extension connect to the database
- In KeePassXC name the connection and allow it
- optionally, use another machine to add the public ssh key for this new machine to the trusted keys on the server [@authentication requires ssh access to nextcloud server]
- go to cloud.sonki.codes and log in as
- Obsidian
- open the obsidian vault under
~/nextcloud/sync/vault/
. You can trust the author, since it's me, and install any plugins. - this is somewhat experimental right now, but looks very promising. I intuitively enjoy this better than other systems/software I have tried - which begs the question why that is and I will eventually figure that out.
- open the obsidian vault under
- Docker Desktop settings. You have to wait for it to start up and then restart
after you adjust the settings:
- Enable the Kubernetes extension
- CPU and RAM below 4 sometimes causes problems, but you can experiment with that. On my current I have 4 and 3.8 respectively.
- you will want to copy over any k8s config to
~/.kube/config
- this may contain access keys and stuff, similar to
~/.ssh
[@authentication requires kubernetes access keys]
- this may contain access keys and stuff, similar to
- consider running
systemctl --user enable docker-desktop
- Anything work related:
[@authentication requires KeePassXC running and GitHub login]
- clone repos and follow setup instructions there
- add work directories to
~/locationsForCD.bash
- change
/bin/start_alacritty.bash
to open the work directory - consider adding
git -C $workCD pull
to/bin/sonke_system_startup.bash
- KDE has a tendency to make changes to the version controlled files after restarts, not just the first time you set this up. Often they are not really functionally different, so you can often just commit those changes.
- Some of the time you may wish to setup conflicting KDE settings on different
computers, while still sharing the remaining configuration. This is currently
annoying, you can play with
~/.gitignore
and that's the end of my ideas so far. I will work on this, at some point.- KDE seems to be working on making their dotfiles more dotfile friendly. I noticed Dolphin history not being saved to the same files anymore, and hence not being synch-ed across devices.
Depending on the machine this is set up on you may want to adjust some things,
perhaps specific to this machine only. A common example is to adjust
/bin/start_alacritty.bash
with --option font.size=12.0
for laptops - since
the screen I use on my desk is a lot bigger than that on my laptop.
Now it is time to clone work repos and set that stuff up. Obviously, that is not part of my dotfiles anymore.
I have switched to keeping all my main machines on the master branch. Every now and then I may update the stable branch, but I don't really have a use for that yet, since I probably won't be updating it regularly enough. It is simply easier to rebase the local branch regularly and sort out conflicts as they arise than to put off merging branches and inviting merge conflicts in this way.
I try to stick to conventional
commits most of the time.
Sometimes you will find commits with the message chore(kde): no functional changes
, these are about my kde settings. Because kde is not designed to be
backed up the way I do sometimes there are changes to the dotfiles without me
doing anything, and without that having any effect on the kde setup (that I can
tell). But I still commit them just in case and so they are out of the way.
Beyond this the scope of the conventional commit message can be:
bash
, which is anything under./bash/*
. This is stuff that gets loaded via the~/.bashrc
, I just have it split up into multiple files for cleanliness.setup
, scripts used in the above installation instructions.config
, most things not included in neovim or the above go in here. Mostly these are dotfiles that go under~/.config/*
, but not exclusively.- stuff related to neovim I split up, since I commit to this quite often:
map
, is./neovim/lua/mappings.lua
. As you can imagine, this is any remaps, which in vimscript would bennoremap
and stuff.plug
,./neovim/lua/plugin.lua
, all the plugins that I have collected in this time, plus configuration that doesn't belong in the other files.cmd
,./neovim/lua/commands.lua
, anything I call with:
.
readme
, this file- anything not listed above I don't commit often enough, so there is not
standard that I try to keep myself to. For example, tmux stuff you may see
under
tmux
or you may see underconfig
.
The action is usually fix
and feat
- which are obvious - new
when I add
something new, like a new neovim plugin new(plug)
or a new file to my bashrc
new(bash)
, you get the idea. Sometimes I do ref
for refactors, doc
for
documentation (which may also just be feat(readme)
) and I think clean
, when
it's not really refactoring but more like formatting and the like.
The Issues on GitHub are pretty much dead now and the PRs probably won't be used anymore either. The latter used to be convenient when I wanted to merge across machines while on my phone, but since I don't use different branches for different machines anymore that won't really be a thing.
I used to use git submodules to maintain vim plugins, since I was managing my plugins manually as this blog suggested. This will be fine for if and when I decide to contribute to plugins, but outside of that it is just so much easier to just use a package manager.