Skip to content

myTerminal/dotfiles

Repository files navigation

dotfiles

My replicable personal computing setup

Init

Simply run the below command on the new computer to be adopted:

/bin/bash -c "$(curl https://raw.githubusercontent.com/myTerminal/dotfiles/master/bootstrap)"

OR the lazy version

/bin/bash -c "$(curl https://gh.myterminal.me/setup)"

For macOS, the shell needs to be changed from Zsh to Bash and there needs to be a sudo xcode-select --install before anything else.

Setup

Software setup for multiple operating platforms is included and it is performed if a known OS is detected.

To start the setup, run the following command in a terminal running bash: (provided forge was fetched as a part of the init)

.setup/start

Software selection

Core packages

VoidmacOS
BaseVoidMacOS
Package managersxbps, flatpak(native), Homebrew, Cask
Bootloadergrub, os-prober(native)
Encryptioncryptsetup, cryfs–, cryfs
Process authorizationpolkit(native)
Message bus systemdbus
UEFI managementefibootmgr
Interfacetmuxtmux
Shellfishfish
File system toolsfd, lsd, bat, ncdufd, lsd, bat, ncdu
Text Searcherripgrepripgrep
Fuzzy finderfzffzf
Text editorGNU Emacs, vimGNU Emacs^
Audio playermpvmpv
Spell checkerAspellAspell
GNU Makemakemake
SCMGit, TigGit*, Tig
File manager
Archive managerszip, unzip, 7zip, unrar(native), 7zip, unrar
Process managementbtop, psmiscbtop
Disk managementudisks, smartmontoolsudisks, smartmontools
Network toolsnetworkmanager, bind-utils, tailscale
Communication toolWeeChatWeeChat
Language runtimesNode.js, sbclNode.js, sbcl
Hardwarebrightnessctl, acpi, fprintd
System clockchrony
Filesystem toolsbtrfs-progs, ntfs-3g, dosfstools, mtools, exfat-utils
Mobile deviceandroid-platform-toolsandroid-platform-tools
Cron daemoncronie(native)
TTSpiperpiper
Large-Language modelollama, fabricollama, fabric
Miscrlwrap, sed, jq, fastfetch, wget, curl, socat, ssh, avahirlwrap, sed, jq, curl, socat, fastfetch, avahi

Graphical packages

Void (Xorg)Void (Wayland)macOS
Desktop utilsxdg-utils, xdg-desktop-portalxdg-utils, xdg-desktop-portal
Display serverXorg(native)
Display drivers(machine-dependent)(machine-dependent)(native)
Display manager(native)
Screen color temperaturesctgammastep(native)
Onscreen keyboardonboard??
Compositorpicom(native)
Graphical environmentsi3sway(native)
Status bari3statuswaybar(native)
Output managerxrandrwlr-randr, wdisplays(native)
Lockscreeni3lock, xs-lockswaylock(native)
Wallpaper managerfehswaybg(native)
Application launcherRofifuzzel(native)
Dock(native)
Desktop widgets[pending][pending](native)
Desktop themeObsidianObsidian(native)
Icon packsObsidianObsidian(native)
Mouse cursorBibataBibata(native)
TerminalrxvtfootTerminal (native), Alacritty
Clipboard helperxselwl-clipboardpbcopy/pbpaste (native)
Notification daemondunstmako(native)
Disk managementudiskie, GPartedudiskie, GParted^, gsmartcontrolDisk Utility (native), Mounty, gsmartcontrol
File managersthunar (with gvfs)thunar (with gvfs)Finder (native)
File sync clientSyncthingSyncthingSyncthing
File/folder compareMeldMeldMeld
Note-taking interfacelogseqlogseqlogseq
Web browsersLibreWolf, Chromium, Mullvad Browser, Tor BrowserLibreWolf, Chromium, Mullvad Browser, Tor BrowserLibreWolf, Chromium, Mullvad Browser, Tor Browser
Password managerKeePassXCKeePassXCKeePassXC
Email clientsBetterbirdBetterbird^Mail (native)
eBook readercalibrecalibrecalibre
MessengersSchildi, signal, telegram-desktopSchildi^, signal, telegram-desktopSchildi, signal, telegram-desktop
Cloud storage clientspCloudpCloud^pCloud
Torrent clientTransmissionTransmissionTransmission
REST clientPostmanPostman^Postman
VirtualizationVirt-ManagerVirt-ManagerVirtualBox
Office suiteLibreOfficeLibreOfficeLibreOffice
Bluetooth interfacebluemanblueman(native)
Drawing toolkritakritakrita
Picture viewersShotwellShotwellPreview (native), XNView MP
Picture editorGIMP, darktableGIMP, darktable^GIMP, darktable
Audio playerClementineClementineClementine
Audio frontendpavucontrolpavucontrol(native)
Audio backendGStreamer, pipewire, easyeffectsGStreamer, pipewire, easyeffectsLAME, FFmpeg
Audio editorAudacityAudacityAudacity
Video playerVLCVLC^VLC
Video editorHandBrake, BlenderHandBrake, BlenderHandBrake, Blender
YouTube video downloaderyt-dlpyt-dlpyt-dlp
Multimedia toolKODIKODIKODI
Screenshot toolflameshotgrim, slurp, swappy(native)
Screencast toolOBS Studio, peekOBS Studio^, ??OBS Studio, LICEcap
Keystroke echoing tool??keycastr
Startup disk creatorsbalenaEtcherbalenaEtcher^balenaEtcher
Gaming clientsSteam, lutrisSteam^, lutrisSteam, Origin, Sony Remote Play
Miscnumlockx, qFlippernumlockx, qFlipper^qFlipper

Fonts

Font
Font Awesome
Open Sans
Inconsolata
Roboto Mono
Droid
Fira Code
Liberation

Legend

* - in-built, ** - through web-client, ^ - through XWayland

Background

What started as a home for my Emacs config, collided with a spreadsheet containing a collection of software packages, quickly began to shift its shape, soon turning into a comprehensive dotfiles project to host configuration for much more than just Emacs. The majority of it still mostly comprised of Emacs configuration, so to make things simpler, I decided to extract it into an independent project of its own. At one point, I even extracted the setup scripts into their separate projects here and then later here. Maintaining it was still tricky with its complex arrangement of configuration files for four operating platforms at once at one point in time! What you see now is an attempt to keep only what is relevant to my primary setup across all my active workstation. This helps make updates less painful and effortless.

I still keep scripts around macOS around as it gave me a fresh perspective during my four years exclusively using an Apple computer. It also serves as a reference for work computers that barely align with my preferred setup. Finally, it also allows me to continuously compare my custom setup with a fully functional operating system like macOS and fill in the gaps iteratively.

There still is some inseparable residue related to other platforms. This might either eventually disappear, or otherwise bring in more complexity in the future, leading to another project branching out of this one.

Design Principles

This setup also follows the following principles:

  1. Lean: It should contain only the software that I need, with minimal to no tolerance for bloat. There’s only one software for one thing, with exceptions, of course, and I run regular optimizations to make sure that is the case. It could be either replacing a tool with a better alternative, or one from within the operating system itself, or dropping it altogether.
  2. Reproducible: I should be able to reproduce the same setup on as many machines as I need to, at any point in time, as many times as I need or want, with minimal to no manual configuration. This means not only the fetching of software is scripted, but also configuration and often execution.
  3. Composable: The elements of the setup should be interchangeable with other alternatives when a better-suited one is identified. Usually, following the UNIX philosophy (which is to have a tool for one job only) helps, with exceptions like Emacs.
  4. Portable: The setup should be portable such that (a) it should self-contain all other assets like code libraries, multimedia files, etc., with minimal to no external dependency, and (b) it should not contain elements bound to a particular Linux distribution, potentially preventing it from working elsewhere.
  5. Well-Documented: The entire setup should contain sufficient documentation for my future self.

Open Gaps

  • Missing alternative for peek in Wayland
  • onboard doesn’t work in Wayland
  • No screen recording tools in Wayland
  • Broken sharing in Wayland
  • No way to set Numlock for Wayland
  • Wallpaper doesn’t randomize after Wayland load
  • Need to set shell colors in Wayland?

About

My replicable personal computing setup

Topics

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors