This is my dotfiles repo to quickly clone and get started on a new computer and to hold my settings in case I lose anything or my computer dies. There is void-installer.sh (or installer.sh in other branches) to simplify the install process and make it less manual.
- Void Linux distro
- i3 window manager
- Fish shell (intuitive, with vim-keys support)
- Dvorak keyboard layout
- Neovim editor
- ulauncher for app launching (Ctrl-Space)
- Kitty terminal (Ctrl-Enter)
- Thunderbird for email
- Document Reader aka evince PDF reader. Small, intuitive, supports vim bindings.
- Files aka nautilus file manager (Ctrl-N)
- Firefox browser (http) and amfora client (gemini)
- lxdm display manager
Void linux + i3. on left: neovim in Terminology. neofetch in kitty. on right, Falkon browser
Screenshot of Terminology terminal, showing this document being edited, with :Goyo focuswriter on
I run this same system on my laptop, my studio alienware desktop, and on my test raspberry pi, which is a testament to Void Linux's flexibility, efficiency and stability. The i3 config and installed software could be dropped in to another Linux distro. For example, I previously ran Regolith Linux, a Ubuntu + Gnome + i3 spin of Ubuntu, until I found it too difficult to make customizations. Also, I wanted a stable rolling release distro. For newbies to Linux, I do recommend Ubuntu/Debian. I run alpine linux on iOS in a VM. But everything else I run Void.
- Autocomplete on by default. Tab/press right to accept.
fish_config
to launch web browser to select Terminal fonts, colors, prompts, functions, etc.- I'm using the fisher plugin manager, primarily to install z jump command. Also useful installing various powerline bars, prompts.
- Built-in syntax highlighting of commands.
- I have vimkeys on in Fish option. Fish shows what mode you are in and works well with autocomplete. Set
fish_vi_key_bindings
inside config.fish - Any newly opened terminal will autostart inside the last used directory. See
.config/fish/conf.d/starting_dir.fish
for details.
nvim
the Neovim text editor.z
directory jumping navigation. I use this instead ofcd
much of the time. infotldr
command line helper which lists how to use most command line software. infovimwiki
which I use to create and edit a huge personal wiki file for notes, brainstorming, copying down info, listing movies to watch, books I've read, etc etc. infopyradio
which I use to stream music. See my article.git
version control system. I use GitHub, Tildegit and Keybase Git.vpm
- the "void package manager" which wraps around xbps
The PATH tells your computer where your custom software is located, so that you can launch it by typing its name instead of having to execute it from its specific directory. (i.e. You can type my-program
instead of ./my-program.sh
for example.
In fish, you add to your PATH in config.fish
, located at ~/.config/fish/config.fish
, not in your bashrc or .bash_profile.
Custom programs can be placed in the bin folder, which is in the path.
Rather than bash aliases, fish shell uses functions, stored in ~/.config/fish/functions/
Current-ish list:
ansiweather
- simplifies the command to grab the weather and display a 5 day local weather forecast one-linerbackitup
- wrapper around rsync for backing up my computersbandcamp
- specify url of bandcamp album to play on the commandline via player. no error handling at this point. PgUp/PgDown to navigate tracks.battery
- current battery state and percentagecalm
- plays some brown noise with sox, sounds like calm ocean wavescopy <filename>
- Copies contents of file to the computer's clipboarddirsize
- Lists current directory size and size of any enclosed sub-directoriesdither <filename>
- Resizes, converts to grayscale, and turns image into a dithered gifdvorak
- switches keyboard map to dvorakimg <image_file>
- opens specified image file in the CLI using w3m-img, inspired by fffepubmobile url
- downloads specified article (html link) to Bookmobile's epubs folder and saves in proper formatfilecount
- basically a one-liner that uses wordcount to count the number of files in your current folder.filesize
- lists size of all files in current directoryfisher
- installed when you install fisher Fish package manager.fisher add [packagename]
. Find packages here.fisher ls
to list installed.newbackground
- change desktop to random background image, via fehopen
- mimics the Mac open command. Essentially just an alias to Linux equivalentxdg-open
.pdfsplit <input.pdf> <starting-page-num> <ending-page-num> <output.pdf>
- Using ghostscript, this oneliner can excerpt any subsection out of a pdf doc.thesaurus <word>
- wrapper around moby offline thesaurus dictionaryqwerty
- switches keyboard map to qwertyrm
- this adds an extra confirmation prompt when I try to delete anything in the Terminal. Can be over-ridden withrm -rf
if I'm really surely sure.vim
- remap so instead launches Neovim.weather
- runs curl to pull down the weather from wttr.in - location i think determined via ip address?z [directory]
- this essential function is actually installed through fisher. It lets you typez homework
and it autocd
jumps you into the proper folder, based on recency.
The config files in this repo are inside config, but should be titled .config with the dot and located at ~/.config
.
Instead of vim's vimrc I have an init.vim (update: I converted my viml script to lua) init.lua file at ~/.config/nvim. The file is fairly minimal and fully commented. I am using the Plug plugin manager. I set neovim (nvim) as my $EDITOR in the .fish_config file. I have a function that launches nvim when I type vim.
Rather than tmux multiplexer or properly managing buffers in Vim/Neovim I just open new tabs in my terminal, switch between them with the Alt keys, and can copy and paste between them using the normal y/ank and p/aste because of a setting I added to my Neovim config that lets me paste text from anywhere on my computer inside Neovim now. This relies (on my computer) on the installed program xclip.
I type in Dvorak on my computer and I've found Dvorak is fine for Vim without any need for remapping keys. Have used this setup for 9+ years and have no complaints.
- Goyo - minimalist writing app.
:Goyo
to toggle it on/off. - Vimwiki - a vim-based personal wiki / knowledge repository. I use this extensively but it's for internal use only on my own machine.
\ww
(aka 'leader-w-w') to turn on, or my shortcut functionvimwiki
to jump into it. - vim-sensible - provides sensible basic defaults in vim. Includes: backspace in insert mode, begin search while typing out match string, make whitespace prettier, show at least one line above cursor, autoload file changes, improve finding matching open and close tags
- Nerd-Tree - make vim work more like an IDE with left-side file view. I added a shortcut so Control-N toggles the filetree open and closed. Without that you have to type
NERDTreeToggle
(case-sensitive). - Markdown Preview - Runs very fast. Starts a local server and opens your browser to preview Markdown as you're writing it live. As you move in your markdown file it scrolls to your location in the browser.
:MarkdownPreview
to begin or end. - Prettier - Auto tidy up my code
- fff - use fff as a file opener
When I want to add a new plugin I simply add a single line to my init.lua, then run :PlugInstall
and it downloads into the proper folder.
lxdm is the default display manager on Void, though can be switched. To edit the login display, run sudo lxdm-config
.
Can't remember how to do something in the terminal but know the name of the app? Then use TLDR.
Example: tldr ls
Lists the most common uses for a command.
i3 is a nice window manager but there's a trick to configuring it for use on Dvorak. I compiled a short walkthrough to setup i3 with Dvorak. My config file is in i3 directory. Adds keyboard volume controls, muting, tap to click, Dvorak.
My Dvorak input settings and remapping of caps-lock to escape are here.