Go to file
2020-05-28 23:34:04 +08:00
alacritty Update muh dotfiles 2020-05-21 23:16:15 +08:00
bin Update muh dotfiles 2020-05-21 23:16:15 +08:00
bspwm Update muh dotfiles 2020-05-21 23:16:15 +08:00
docs Finalize the setup for the dotfiles 2020-05-01 21:32:25 +08:00
dunst Finalize the setup for the dotfiles 2020-05-01 21:32:25 +08:00
emacs Update the configs for zsh and Doom Emacs 2020-05-28 23:34:04 +08:00
lf Revise the dotfiles 2020-04-29 23:58:14 +08:00
nvim Update muh dotfiles 2020-05-21 23:16:15 +08:00
pacman Finalize the setup for the dotfiles 2020-05-01 21:32:25 +08:00
picom Revise the dotfiles 2020-04-29 23:58:14 +08:00
polybar Update muh dotfiles 2020-05-21 23:16:15 +08:00
rofi Finalize the setup for the dotfiles 2020-05-01 21:32:25 +08:00
sxhkd Update muh dotfiles 2020-05-21 23:16:15 +08:00
sxiv/exec Finalize the setup for the dotfiles 2020-05-01 21:32:25 +08:00
wal Update muh dotfiles 2020-05-21 23:16:15 +08:00
xorg Finalize the setup for the dotfiles 2020-05-01 21:32:25 +08:00
zsh Update the configs for zsh and Doom Emacs 2020-05-28 23:34:04 +08:00
.editorconfig Create an EditorConfig file for snippets 2019-09-30 09:27:18 +08:00
aur-packages.txt Update muh dotfiles 2020-05-21 23:16:15 +08:00
LICENSE Initial commit 2019-08-08 17:31:28 +08:00
locations.json Finalize the setup for the dotfiles 2020-05-01 21:32:25 +08:00
makefile Update the locations, some scripts, and whatnot 2020-04-05 00:27:13 +08:00
manager.py Update muh dotfiles 2020-05-21 23:16:15 +08:00
packages.txt Update muh dotfiles 2020-05-21 23:16:15 +08:00
README.adoc Update the scripts one last time 2020-05-01 22:45:31 +08:00

My dotfiles for my Linux-based system setup. The structure of this repo is designed to be managed with GNU Stow, a symlinks farm manager.

I dont know what Im doing most of the time in creating this setup so if youre brave (or suicidal) enough to take a look at my stuff, go ahead.

Caution
As they always say: "Dont blindly apply these dotfiles unless you know what youre doing." Review the code first, change the setting accordingly, and apply it on your own if you want.

Screenshots

Want to see how my setup look first? Alright.

bspwm setup with no windows
Figure 1. bspwm setup with no windows
Editors
Figure 2. Editors, lots of editors [1]
The terminals
Figure 3. bspwm with some terminal applications
rofi
Figure 4. rofi, dunst, and lf
vim and zathura (and LaTeX) setup
Figure 5. vim and zathura (and LaTeX) setup
A dropdown terminal
Figure 6. A dropdown terminal (because why not)

Specifications

Here are the main specifications of my machine currently running this (as of 2020-05-01):

Tour of my setup

Heres what the setup should look like (aside from the Stow packages which will be discussed later):

dotfiles
├── docs/
├── aur-packages.txt
├── LICENSE
├── locations.json
├── makefile
├── manager.py
├── packages.txt
└── README.adoc

The big picture for my dotfiles setup have big goals and those are (according to priority):

  • Easy to transfer and/or reproduce.

  • Modularity, @holman-style.

  • Looking cool (but not too cool or else my potato will weep).

The package lists

Starting from the most important of the set, packages.txt and aur-packages.txt are simply a list of installed packages from the official Arch repo and AUR respectively. I prefer the lists to be separated just for ease of maintenance. They are going to be committed at the start of every month (if it works that is).

Since the name of the packages varies between distro to distro, this is only valid for Arch Linux.

How I maintain my dotfiles

manager.py (named Very Tiny Stow Manager or VTSM for short) is a tiny GNU Stow-like manager created for this setup. VTSM takes inspiration from GNU Stow (obviously) and how Zach Holmans dotfiles are set. When managing your dotfiles, VTSM is going to be your friend/workmate. (Nonetheless, I tried to make it generic for other cases.) [2] [3]

Note
Using this script is optional and feel free to discard this and exclusively use GNU Stow or something else.

Using VTSM should be simple and it is nothing special, really. All it needs is a directory containing a file named locations.json with the name of the packages and their target path. VTSM will simply run commands with those packages. In short, its just a shell runner set by a data file.

An example of what locations.json could be
{
    "alacritty": "$HOME/.config/alacritty/",
    "bin": "$HOME/bin/",
    "bspwm": "$HOME/.config/bspwm/",
    "dunst": "$HOME/.config/dunst/",
    "emacs": "$HOME/.config/doom",
    "lf": "$HOME/.config/lf",
    "nvim": "$HOME/.config/nvim/",
    "picom": "$HOME/.config/picom",
    "polybar": "$HOME/.config/polybar",
    "rofi": "$HOME/.config/rofi/",
    "sxiv": "$HOME/.config/sxiv",
    "sxhkd": "$HOME/.config/sxhkd/",
    "wal": "$HOME/.config/wal",
    "xorg": "$HOME",
    "zsh": "$HOME"
}

With the tiny manager and the package list, we can then execute commands with all of the packages and its target path with one go. For the command string, it is a Python template with package and location as the available objects.

# Take the setup as the filesystem structure.
# See the JSON file (locations.json) to see what packages to be installed and where to install them.

# Running the program without any arguments for a test run.
# There should be a bunch of `echo` commands being ran for all of the listed packages.
./manager.py

# Create the directories of the target path and install them with GNU Stow.
# Bada-bing, bada-boom, you have installed your setup or something.
./manager.py --commands "mkdir -p {location} && stow {package} --target {location}"

# (You could also use the makefile for this.)

Custom scripts

Next are more custom scripts! Theyre located in bin/ and ideally should be linked in $HOME/.local/bin. [4]

Heres a list of the top most useful scripts (at least for me):

Aside from the scripts, there are also some details and files that are not committed to this setup for privacy and security reasons. A few examples of which is my cron setups where it is tasked with updating and committing the package lists to the Git repo, updating the packages, cleaning the cache, and so much more.

Configured programs

Heres a list of the programs with details on the config found in this repo. Each of the listed directory is designed to be used/managed with GNU Stow at the indicated target path.

Each of my configuration also tries to be visually consistent but it is only a secondary priority. For a color scheme, my main preference is Nord.

Alacritty

Similar to Kitty , its a GPU-based terminal emulator. Its documentation for the configuration can be viewed at the config file itself being filled with comments.

  • Config located at alacritty/ directory.

  • The usual target path for a user is at $HOME/.config/alacritty/.

  • Minimum version (from alacritty --version):

    • alacritty 0.3.3

  • Contains a single alacritty.yaml as the config file. Not much has changed except for the color scheme and the font being used.

bspwm

A minimalist window manager. Only provides a window manager and nothing else.

  • Config located at bspwm/ directory.

  • The usual target path for a user is at $HOME/.config/bspwm/.

  • Minimum version (from bspwm --version):

    • 0.9.7-10-g2ffd9c1

  • Simply contains bspwmrc which is an executable setting up bspwm-related settings and and starting up some applications. However, the "true" version is stored as a template file for pywal (located at wal/templates/bspwmrc).

  • This allows for a modular setup. For using keybindings, it uses sxhkd (Simple X Hotkey Daemon). For something similar to i3-bar, polybar serves as the replacement.

To control the window manager, you should use bspc.

Dunst

Its a notification daemon used to display notifications sent by notifiers (programs that send messages/notifications).

  • Config location is at dunst/.

  • The usual target path for a user is at $HOME/.config/dunst/.

  • Minimum version (from dunst --version):

    • Dunst - A customizable and lightweight notification-daemon 1.4.1 (2019-07-03)

  • Simply contains a dunstrc configuring appearance of the notifications. Though, the "true" version of the config is located at wal/templates/dunstrc.

Look out for the related manual entry (i.e., man dunst) and the Arch Wiki entry.

GNU Emacs

Another text editor, of course. I finally bit the bullet with this one with the native support for Org Mode as the biggest reason. (Is this going to be start of something sinister?)

  • This package is really a Doom Emacs-based configuration more than the vanilla config so you need to install it first before touching the config with your grubby hands. Just run the following command git clone https://github.com/hlissner/doom-emacs ~/.emacs.d && ~/.emacs.d/bin/doom install and it should take care of the rest.

  • Config located at emacs/.

  • The ideal target path for a user is at $HOME/.config/doom.

  • Minium version (from emacs --version):

    • GNU Emacs 26.3

    • For Doom Emacs, its not particularly important since its in rolling release but for future references, it is from the develop branch at commit efa599f076c3a140c6b4006c352fdba3361abebd accessed at 2020-04-24.

  • The Doom configs are just the default config so theres not much to go through here. I may also add snippet files in there.

  • Regarding theming Doom Emacs, Ive found mainly two ways.

    • First is simply using ewal but the resulting colors are not pretty IMO and I havent found a way to customize it aside from forking and modifying the package itself.

    • Second is simply generating the Doom Emacs theme file myself; I have a small script that is generates one from the Pywal color scheme.

    • Or simply dont and use modus-themes instead for that light customization options.

lf

A ranger-inspired terminal file manager. Heres the documentation for it.

  • Config located at lf/ directory.

  • The usual target path for a user is at $HOME/.config/lf/.

  • Minimum version (from lf --version):

    • r14

  • All of the config files are basically default config files except with a few personal changes.

Neovim

A modern version of Vim, a modal text editor. [5]

  • Config located at nvim/ directory.

  • The usual target path for a user is at $HOME/.config/nvim.

  • Minimum version (from nvim --version):

    • NVIM v0.4.3

  • Uses vim-plug as the plugin manager.

  • Contains my plugin list and editor configurations in init.vim.

  • There are also some UltiSnips snippets stored in own-snippets folder (since snippets is a reserved folder name).

  • One of the largest snippet file is the snippets for LaTeX files. It is based on Gilles Castel's UltiSnips LaTeX snippets.

pacman

The default package manager for Arch Linux.

  • Config location is at pacman/

  • The usual target path is at /etc/pacman.d.

  • Minimum version (from pacman --version):

    • Pacman v5.1.3 - libalpm v11.0.3

  • Contains the configuration file, a mirrorlist file, and some pacman hooks.

  • For the mirrorlist, change it accordingly or generate another one. It is also monthly updated from a cron job.

  • Since this requires root privilege, this is not included in the installation script. Simply copy it (i.e., sudo cp pacman/ /etc/pacman.d/) and youre done.

  • The dotfiles repo also contains two package lists (i.e., packages.txt and aur-packages.txt) in the root of the project folder.

  • The setup also uses yay as the AUR helper tool.

picom

A window compositor forked from compton that adds off-screen buffers and additional effects and animations to the window. Can be used for adding style to your setup.

This is formerly the Compton configuration.

  • Config found at picom/ directory.

  • The usual target path for a user is at $HOME/.config/picom.

  • Minimum version (from picom --version):

    • v7.2

  • The config is copied from /etc/xorg/picom.conf and edited a few parameters.

For documentation, check out the manual entry (i.e., man picom) and the related Arch Wiki entry. The default configuration (located at /etc/xdg/picom.conf assuming at Arch Linux) can be helpful as well as it is filled with comments.

polybar

A tool for creating status bars.

This is the replacement bar from my previous i3-based setup.

  • Config located at polybar/.

  • The usual target path for a user is at $HOME/.config/polybar.

  • Minimum version (from polybar --version):

    • polybar 3.4.1

    • Features: +alsa +curl +i3 +mpd +network(libnl) +pulseaudio +xkeyboard

  • There is only the standalone config (might decide to make it modular) and the launch script which is copied from the related Arch Wiki entry. The theme is dynamically used with the Xresources file (by using xrdb).

For documentation, check out the already linked Arch Wiki entry and the official documentation from GitHub.

Pywal

A theme generator written in Python. It is mostly used for ricing to get them consistent colors throughout your setup.

  • Config located at wal/.

  • The usual target path for a user is at $HOME/.config/wal. It is ideal that youve already have your own color schemes saved in there as well.

  • Minimum version (from wal --version):

    • wal 3.3.0

  • Due to the nature of my setup where I want those consistent colors, most of the configurations are tucked away as template files but it should be easy to identify which is which. Certain applications such as for dunst and bspwm are in here and should be considered as the real version of the config.

For additional information, check out the documentation from the GitHub page.

Rofi

The application switcher and launcher. Also serves as a replacement for dmenu.

  • Config located at rofi/.

  • The usual target path for a user is at $HOME/.config/rofi/.

  • Minimum version (from rofi -version):

    • Version: 1.5.4

  • Main config is config.rasi.

  • Contains the config and my custom Rofi themes.

To see the documentation, check out the manual entry for rofi. For creating or editing Rofi themes, read the manual entry of rofi-theme. Also, view the related Arch Wiki entry.

sxhkd

Stands for "Simple X Hotkey Daemon". It is a hotkey daemon detecting certain X events primarily from the keyboard and mouse.

It is also very useful since it enables modular setup. Can be used independent of the desktop environment (DE) or the window manager (WM).

  • Config located at sxhkd/ folder.

  • The usual target path is at $HOME/.config/sxhkd.

  • Minimum version (from sxhkd --version):

    • 0.6.0-3-g7124055

  • Contains a config file (sxhkdrc) for the keybindings. There are some keybindings specifically used for bspwm.

sxiv

A simple developer-oriented X image viewer with a lot of options for customization.

  • Config located at sxiv/ directory.

  • The usual target path is at $HOME/.config/sxiv.

  • Minimum version (from sxiv -v):

    • sxiv 26

  • Contains custom keybindings (with exec/key-handler) and a configuration for the status bar (with exec/image-info).

sxiv has a manual (i.e., man sxiv) so thats convenient. I also recommend Luke Smiths video introducing it. Thats where I also heard of it.

Xorg

A display server implementing X window system.

  • Config found at xorg/ directory.

  • The usual target path for a user is at $HOME/.

  • Minimum version (from Xorg -version):

    • X.Org X Server 1.20.5

    • X Protocol Version 11, Revision 0

  • The configuration is found at .Xresources containing the colors (0 to 15, foreground, and the background). It may be bound to be an automatically generated file from Pywal soon.

Zsh

A Unix shell and an alternative to the Bash. Mostly chosen due to its wide options for customization compared to GNU Bash.

  • Config found at zsh/ directory.

  • The usual target path for a user is at $HOME/.

  • Minimum version (from zsh --version):

    • zsh 5.7.1 (x86_64-pc-linux-gnu)

  • Contains .zprofile and .zshrc. The primary file to look for is the .profile to set environment variables independent of the shell setups.

  • Previously relied on oh-my-zsh. Eventually, the config became independent and can work without it.

For the documentation, check out the manual entry for zsh to gain an overview of the shell. The documentation itself is massive and comprehensive. The main manual explains some things such as the startup/shutdown files and compatibility with other shells. It also lays out the sections of the manual which you can check it out.

Since the manual has been split into multiple sections, it can be daunting to navigate. The most referred sections by far are zshmisc where it gives details on the miscellanea of zsh such as the prompt and special variables you might want to know. The other section is zshbuiltins where it explains built-in commands of zsh.

For coding with Zsh, look into the Zsh Manual.

Additional programs used

As much as possible, I use free and open source software (FOSS) for all of my needs. Not all of the items listed are FOSS, though. [6]

Browser extensions

  • Bitwarden - An open source password manager. Comes with a browser extension or a desktop version of the app.

  • Internet Archive Web Extension (Chrome and Firefox version) - A browser extension for tracking down the saved versions of a page. Very useful extension for tracking old resources that has been moved or deleted.

  • uBlock Origin - A security tool for blocking known trackers.

  • OneTab extension - An extension to enable grouping of tabs into one tab. Convenient for preventing a lot of tabs opened at one time.

  • Privacy Badger - A security tool for blocking trackers. Unlike the other blockers like uBlock Origin, Privacy Badger learns with more usage.

Command line tools

I still use GNU coreutils and common Unix tools (e.g., cURL) but it could be good to find some alternatives. If you want to look for some alternatives or just feeling adventurous yourself, I recommend starting with this awesome list and this one, too.

  • bat - Basically cat(1) with wings.

  • Buku - A developer-oriented (i.e., easy to integrate with your own programs) browser-independent bookmark manager for the command line.

  • exa - A user-friendly replacement for ls(1).

  • fd - A user-friendly alternative to find(1) from GNU findutils.

  • feh - A minimal image viewer.

  • fzf - A fuzzy command line finder.

  • hexyl - A hex viewer on the command line.

  • lf - A terminal file manager mainly inspired by Ranger.

  • maim - A simple screenshot utility.

  • neofetch - A program for getting information for your hardware and software setup. [7]

  • Neovim - A modern fork of Vim.

  • ripgrep - A fast alternative to GNU grep.

  • Weechat - An IRC client on the command line.

  • youtube-dl - A utility for downloading YouTube videos (and also others).

Design

  • Blender - A top-notch 3D modelling program.

  • draw.io - A drawing board for your flowcharts and other charts, maybe.

  • FreeCAD - A general purpose 3D computer-aided design program.

  • Inkscape - A vector illustration/editing program. Alternative to Adobe Illustrator.

  • KiCad - An electronic design automation suite.

  • Krita - A painting/illustration program.

Desktop user experience

  • tmux - A terminal multiplexer useful for managing multiple sessions.

  • tdrop - A modular dropdown creator.

  • pywal - An automation tool for generating color schemes from images and applying them to your programs.

Device drivers and servers

Documents

  • Asciidoctor - A text formatting language suitable for creating books, documentations, and writings. Highlights a heavier feature set compared to Markdown.

  • Hugo - A static site generator for creating websites and personal wikis.

  • Jupyter - Similar to R Markdown except with a stronger emphasis for literate programming. This is closely associated with the Anaconda distribution. Useful for a variety of document formats to be converted into a website especially with the (bare) support for Pandoc converter.

  • LibreOffice - An office productivity suite and serves as a free alternative to Microsoft Office suite.

  • LuaTeX - The TeX engine I primarily use for my LaTeX documents.

  • Org-mode - A lightweight text formatting language that offers a variety of export options, literate programming, and reproducible of stuff similar to Jupyter Notebooks.

  • Pandoc - A universal document converter that supports a wide variety of document formats. Primarily used for converting Markdown documents into Asciidoctor text.

  • R Markdown - A text formatting language that comes with executing programs with live output in the notebook.

  • TeX Live - A cross-platform LaTeX distribution for compiling LaTeX files.

Fonts

  • Fantasque Sans Mono - A serif-style monospace font for fancy occasions.

  • Fira Code - A programmer-oriented font that supports ligatures.

  • Font Awesome - A set of icons for your user interface and stuff.

  • Iosevka - A monospace text that features ligatures and provides a wide variety of symbols. It is currently my terminal font.

  • Jetbrains Mono - A free and open source font featuring ligatures by Jetbrains.

  • Latin Modern Math - A serif font specifically for mathematical and scientific work. It is based from Computer Modern Math (the default typeface for LaTeX documents). It is also my go-to font for mathematical fonts.

  • Nerd Fonts - A suite of font tools. Also offers 40+ patched fonts of the popular fonts such as Iosevka, Fira Code, and many others.

  • Noto Fonts - A font family provided by Google. Features a wide support for a variety of languages and styles.

  • Plex - The font family of IBM. Offers a wide variety of styles from the serif, sans, and monospace. [8]

  • Source Serif Pro - A free and open source serif font by Frank Grießhammer for Adobe. Part of the Adobes Source Pro open source font family. It is also my go-to serif font for my documents (e.g., LaTeX documents).

  • Source Sans Pro - Another one of the Adobes Source Pro open source font family. I use it when paired with Source Serif Pro. The go-to sans font for my go-to serif font.

  • STIX - A mathematical font based from the Times New Roman font. This is my second math font of choice.

Graphical programs

  • Discord - A certain police PSA said Discord users are hackers and I want to be one so I joined.

  • Firefox - One of the major web browser second to Chrome.

  • Thunar - A file manager and a part of the XFCE package. [9]

  • Thunderbird - An email client. [10]

  • Qbittorrent - A torrent manager for sailing the web (or the seven seas).

Icon sets

  • Font Awesome - An extensive collection of general icons with various styles.

  • Material Design - A community-led icon set derived from Googles own Material icons.

  • Powerline fonts - A font specifically made for them powerline status bars.

  • Simple Icons - A collection of popular brand icons.

Mathematical tools

  • Anaconda - A mathematical environment distribution.

  • Octave - A mathematical computational environment similar to Matlab.

  • R - Similar to Octave.

  • Audacious - An audio player with various listening options. [11]

  • ffmpeg - A multimedia codec including for MP4, FLV, and more. Also can be used as a recorder.

  • ImageMagick - A software suite for graphics.

  • OBS Studio - A facility for streaming and recording videos.

  • Shotcut - A video editor built with the MLT Framework.

  • sxiv - Self-explaining-ly named "Simple X Image Viewer".

  • VLC Media Player - A multimedia player.

Music production

You can find my crappy soundtracks primarily in my YouTube channel (may consider a SoundCloud account or similar).

  • Cadence - A set of audio tools.

  • Carla - An audio plug-in host supporting various audio plug-in formats such as VST2/3, SF2, and SFZ. Part of the KX Studio project.

  • LMMS - A digital audio workstation for beat production.

  • Musescore - A music composition and notation software.

  • SuperCollider - A platform for audio synthesis and algorithmic composition.

Software development

  • Docker - An application for virtualizing your environments with containers.

  • entr - A utility for running commands for certain filesystem events. Useful for not fiddling with inotify.

  • GCC - A set of compilers from GNU; I mainly use it for developing and compiling C and C++ languages.

  • Git - My one and only version control system.

  • Godot Engine - A game engine with its own interface.

  • LLVM - A set of compilers similar to GCC; mainly used it for testing other C/C++ stuff.

  • Make - A build automation system.

  • Vagrant - A virtual machine manager with a focus for developer environments.

  • Visual Studio Code - A text editor that comes with lightweight IDE features.

  • Whatever runtimes/toolchains for programming languages I have (e.g., Oracle Java, Rust, Go, LLVM).

System administration

Tip
I recommend to start at this list especially if youre starting with a bare minimum of a Linux installation.
  • htop - A process viewer and manager.

  • lxsession - A session manager and an authentication agent for Polkit; very useful if youre usually using with a user-level account.

  • Polkit - A program for bridging unprivileged processes to privileged access.

  • systemd-boot - The UEFI boot manager.

  • udisks - A manager for mounting filesystems.

  • udiskie - An automounter for removable media.

Inspirations

Wallpapers

Heres a list of some of the best wallpapers Ive used throughout my ricing journey. Ive also tried to get the creators to show appreciation for their work.

Sources

My personal recommendations for looking out for more cool-looking photos.


1. For this who are curious for the editors, its Neovim, Doom Emacs, and Visual Studio Code.
2. You need Python installed for this. For future references, the version by the time first writing the script is at v3.8.1. That said, I may rewrite this in Bash instead or even just a makefile.
3. I may have made my life harder when I can use something like yadm or a bare git repo instead.
4. This is a part of the package list but I think its appropriate to create a dedicated subsection for this.
5. Migrated after Ive seen Luke-senpai used it in his recent videos. Seriously though, I find nvim to be way better for configuration.
6. You can also view the package lists at the project root for a detailed list.
7. You can also take a look at pfetch (created by the same author) which can be an excellent reference for getting system information between Unix-based systems. Seriously though, its insane; the guys a wizard.
8. There is a plan to extend the fonts to include mathematical symbols but as of 2020-03-27, its not yet complete.
9. Im mainly using lf, dont fret.
10. Im sorry Im not using a based command line tool like Neomutt yet. Please dont crucify me, Im on my way to be cool, I swear.
11. Dont worry, Im trying to be cool by considering ncmpcpp.