Skip to content

Latest commit

 

History

History
182 lines (138 loc) · 8.32 KB

README.md

File metadata and controls

182 lines (138 loc) · 8.32 KB

rusty-pets

About

Have you heard of pet containers?

Stop Distro Hopping! Use this AWESOME tool on Linux

Here are recipes for creating your perfect supercharged container images for use with toolbx/distrobox. What is the special ingredient that goes into these powerful images? The Chemical X - it's Rust!

Forged in fires of cargo these containers go through an intense build process, supercharging them with sparkling Rust utils. Some of them enhance your regular shell experience and others unlock new abilities.
You too wish to discover these oxidised powers, yes ;) ? See instruction below to find out how.

Tip

TL;DR: This repo provides Toolbox/Distrobox compatible distro images featuring Rust powered tools.

How to play

Installation

You can use these container images with Docker or Podman directly. But you'll have a much better experience with tools like distrobox/toolbx which neatly wrap the former for convenient local pet container usage.

Install distrobox or toolbx according to install instructions on respective project page. We recommend distrobox, since it is supported on various host distributions and is easier to customize.
Links: {Distrobox install} {Toolbx install}

Example usage

Using provided distrobox.ini files (recommended)

## Assemble container with latest rusty-pets oxidised image (only need to do this once)
distrobox assemble create --file pets/ubuntu-oxidised.distrobox.ini

## Enter the created container (whenever you please)
distrobox enter ubuntu-oxidised

Using distrobox-create manually

## Create a container with any rusty-pets oxidised image (only need to do this once)
distrobox create --image ghcr.io/nain-f49ff806/rusty-pets/fedora-oxidized.toolbox:latest --name fedoraX

## Enter the created container (whenever you please)
distrobox enter fedoraX

You can also assign custom home directory for your pets, to keep separate dotfiles for example.

## Create a rusty-pets distrobox with separate home
mkdir -p ~/Distroboxes/storage/archX
distrobox create --home ~/Distroboxes/storage/archX --name archX --image ghcr.io/nain-f49ff806/rusty-pets/arch-oxidized.toolbox:latest

## Enter the created container (whenever you please)
distrobox enter archX

Tip

Terminal emulators like Ptyxis make entering your pet containers much easier.
Alternatively, if your terminal emulator supports profiles, you can manually configure it
to run the distrobox enter .. command at start of session.

What is included?

Rust Tool Like Aliased Notes Category
bat cat, less cat viewer/navigation
eza ls ls viewer/navigation
zoxide (zd) cd viewer/navigation
Yazi-fm (yazi) nnn Blazing fast terminal file manager, based on async I/O viewer/navigation
hexyl hexdump hexdump viewer/navigation
bingrep ? Cross-platform binary parsing viewer viewer/navigation
bottom (btm) top, htop top process/system
du-dust (dust) du du process/system
hyperfine time time process/system
zellij tmux A terminal workspace with batteries included process/system
fd-find (fd) find find file manipulation
ouch tar,gz,xz,zstd Obvious Unified Compression (and decompression) Helper file manipulation
ripgrep (rg) grep grep file manipulation
xsv csvkit A fast CSV command line toolkit written in Rust file manipulation
rage age A simple, modern and secure file encryption tool file manipulation
git-delta (delta) diff diff Syntax-highlighting pager for git, diff, and grep output CVS
gitui ? Blazing 💥 fast terminal-ui for git CVS
nu bash,zsh,fish New type of shell, with structured data pipelines
starship Liquid-prompt Customizable prompt for any shell!
watchexec-cli watchman Executes commands in response to file modifications

Inclusion Criteria

Spirit Measurement
Wide appeal Have many stars. ~1K+ is good rule of thumb but new or niche-popular tools may also be considered
Maintained Update in last year. Either in code repo or a statement by author on any channel
FOSS Free and Open Source Licence (Either OSI list or FSF list)

Note

Measurements can be falliable, let the spirit of the criteria guide us.

Further Todo / Wishlist

  • Popular distro triad
    • Image for Fedora
    • Image for Ubuntu
    • Image for Arch
  • More Rust tools
    • Helix editor [Issue]
    • Rage
    • Zellij
    • Starship with custom config
    • tealdeer/tlrc (prefer distro package for autocompletions)
    • procs
    • rust uutils?
    • navi?
    • ?
  • More aliases
    • time?
    • grep?
    • hexdump?
    • find?
    • diff?
    • watchman

License

Licensed under either of

at your option.

SPDX-License-Identifier: Apache-2.0 OR MIT

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.