From 5eb3624a10eea200ac688da217652d2b8a0bf456 Mon Sep 17 00:00:00 2001 From: Jacob Schantli Date: Mon, 2 Mar 2026 17:14:25 -0800 Subject: [PATCH] Upload files to "/" --- .bashrc | 633 ++++++++++++++++++++++++++++++++++++++++++++++++++ README.md | 121 ++++++++++ config.jsonc | 130 +++++++++++ starship.toml | 279 ++++++++++++++++++++++ uninstall.sh | 156 +++++++++++++ 5 files changed, 1319 insertions(+) create mode 100644 .bashrc create mode 100644 README.md create mode 100644 config.jsonc create mode 100644 starship.toml create mode 100644 uninstall.sh diff --git a/.bashrc b/.bashrc new file mode 100644 index 0000000..7a09fa2 --- /dev/null +++ b/.bashrc @@ -0,0 +1,633 @@ +#!/usr/bin/env bash +iatest=$(expr index "$-" i) +####################################################### +# SOURCED ALIAS'S AND SCRIPTS BY zachbrowne.me +####################################################### +if [ -f /usr/bin/fastfetch ]; then + fastfetch +fi + +# Source global definitions +if [ -f /etc/bashrc ]; then + . /etc/bashrc +fi + +# Enable bash programmable completion features in interactive shells +if [ -f /usr/share/bash-completion/bash_completion ]; then + . /usr/share/bash-completion/bash_completion +elif [ -f /etc/bash_completion ]; then + . /etc/bash_completion +fi + +####################################################### +# EXPORTS +####################################################### + +# Disable the bell +if [[ $iatest -gt 0 ]]; then bind "set bell-style visible"; fi + +# Expand the history size +export HISTFILESIZE=10000 +export HISTSIZE=500 +export HISTTIMEFORMAT="%F %T" # add timestamp to history + +# Don't put duplicate lines in the history and do not add lines that start with a space +export HISTCONTROL=erasedups:ignoredups:ignorespace + +# Check the window size after each command and, if necessary, update the values of LINES and COLUMNS +shopt -s checkwinsize + +# Causes bash to append to history instead of overwriting it so if you start a new terminal, you have old session history +shopt -s histappend +PROMPT_COMMAND='history -a' + +# set up XDG folders +export XDG_DATA_HOME="$HOME/.local/share" +export XDG_CONFIG_HOME="$HOME/.config" +export XDG_STATE_HOME="$HOME/.local/state" +export XDG_CACHE_HOME="$HOME/.cache" + +# Seeing as other scripts will use it might as well export it +export LINUXTOOLBOXDIR="$HOME/linuxtoolbox" + +# Allow ctrl-S for history navigation (with ctrl-R) +[[ $- == *i* ]] && stty -ixon + +# Ignore case on auto-completion +# Note: bind used instead of sticking these in .inputrc +if [[ $iatest -gt 0 ]]; then bind "set completion-ignore-case on"; fi + +# Show auto-completion list automatically, without double tab +if [[ $iatest -gt 0 ]]; then bind "set show-all-if-ambiguous On"; fi + +# Set the default editor +export EDITOR=nvim +export VISUAL=nvim +alias spico='sudo pico' +alias snano='sudo nano' +alias vim='nvim' + +# To have colors for ls and all grep commands such as grep, egrep and zgrep +export CLICOLOR=1 +export LS_COLORS='no=00:fi=00:di=00;34:ln=01;36:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.gz=01;31:*.bz2=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.avi=01;35:*.fli=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.ogg=01;35:*.mp3=01;35:*.wav=01;35:*.xml=00;31:' +#export GREP_OPTIONS='--color=auto' #deprecated + +# Check if ripgrep is installed +if command -v rg &> /dev/null; then + # Alias grep to rg if ripgrep is installed + alias grep='rg' +else + # Alias grep to /usr/bin/grep with GREP_OPTIONS if ripgrep is not installed + alias grep="/usr/bin/grep $GREP_OPTIONS" +fi +unset GREP_OPTIONS + +# Color for manpages in less makes manpages a little easier to read +export LESS_TERMCAP_mb=$'\E[01;31m' +export LESS_TERMCAP_md=$'\E[01;31m' +export LESS_TERMCAP_me=$'\E[0m' +export LESS_TERMCAP_se=$'\E[0m' +export LESS_TERMCAP_so=$'\E[01;44;33m' +export LESS_TERMCAP_ue=$'\E[0m' +export LESS_TERMCAP_us=$'\E[01;32m' + +####################################################### +# MACHINE SPECIFIC ALIAS'S +####################################################### + +# Alias's for SSH +# alias SERVERNAME='ssh YOURWEBSITE.com -l USERNAME -p PORTNUMBERHERE' + +# Alias's to change the directory +alias web='cd /var/www/html' + +# Alias's to mount ISO files +# mount -o loop /home/NAMEOFISO.iso /home/ISOMOUNTDIR/ +# umount /home/NAMEOFISO.iso +# (Both commands done as root only.) + +####################################################### +# GENERAL ALIAS'S +####################################################### +# To temporarily bypass an alias, we precede the command with a \ +# EG: the ls command is aliased, but to use the normal ls command you would type \ls + +# Add an "alert" alias for long running commands. Use like so: +# sleep 10; alert +alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"' + +# Edit this .bashrc file +alias ebrc='edit ~/.bashrc' + +# Show help for this .bashrc file +alias hlp='less ~/.bashrc_help' + +# alias to show the date +alias da='date "+%Y-%m-%d %A %T %Z"' + +# Alias's to modified commands +alias cp='cp -i' +alias mv='mv -i' +alias rm='trash -v' +alias mkdir='mkdir -p' +alias ps='ps auxf' +alias ping='ping -c 10' +alias less='less -R' +alias cls='clear' +alias apt-get='sudo apt-get' +alias multitail='multitail --no-repeat -c' +alias freshclam='sudo freshclam' +alias vi='nvim' +alias svi='sudo vi' +alias vis='nvim "+set si"' +alias yayf="yay -Slq | fzf --multi --preview 'yay -Sii {1}' --preview-window=down:75% | xargs -ro yay -S" + +# Change directory aliases +alias home='cd ~' +alias cd..='cd ..' +alias ..='cd ..' +alias ...='cd ../..' +alias ....='cd ../../..' +alias .....='cd ../../../..' + +# cd into the old directory +alias bd='cd "$OLDPWD"' + +# Remove a directory and all files +alias rmd='/bin/rm --recursive --force --verbose ' + +# Alias's for multiple directory listing commands +alias la='ls -Alh' # show hidden files +alias ls='ls -aFh --color=always' # add colors and file type extensions +alias lx='ls -lXBh' # sort by extension +alias lk='ls -lSrh' # sort by size +alias lc='ls -ltcrh' # sort by change time +alias lu='ls -lturh' # sort by access time +alias lr='ls -lRh' # recursive ls +alias lt='ls -ltrh' # sort by date +alias lm='ls -alh |more' # pipe through 'more' +alias lw='ls -xAh' # wide listing format +alias ll='ls -Fls' # long listing format +alias labc='ls -lap' # alphabetical sort +alias lf="ls -l | egrep -v '^d'" # files only +alias ldir="ls -l | egrep '^d'" # directories only +alias lla='ls -Al' # List and Hidden Files +alias las='ls -A' # Hidden Files +alias lls='ls -l' # List + +# alias chmod commands +alias mx='chmod a+x' +alias 000='chmod -R 000' +alias 644='chmod -R 644' +alias 666='chmod -R 666' +alias 755='chmod -R 755' +alias 777='chmod -R 777' + +# Search command line history +alias h="history | grep " + +# Search running processes +alias p="ps aux | grep " +alias topcpu="/bin/ps -eo pcpu,pid,user,args | sort -k 1 -r | head -10" + +# Search files in the current folder +alias f="find . | grep " + +# Count all files (recursively) in the current folder +alias countfiles="for t in files links directories; do echo \`find . -type \${t:0:1} | wc -l\` \$t; done 2> /dev/null" + +# To see if a command is aliased, a file, or a built-in command +alias checkcommand="type -t" + +# Show open ports +alias openports='netstat -nape --inet' + +# Alias's for safe and forced reboots +alias rebootsafe='sudo shutdown -r now' +alias rebootforce='sudo shutdown -r -n now' + +# Alias's to show disk space and space used in a folder +alias diskspace="du -S | sort -n -r |more" +alias folders='du -h --max-depth=1' +alias folderssort='find . -maxdepth 1 -type d -print0 | xargs -0 du -sk | sort -rn' +alias tree='tree -CAhF --dirsfirst' +alias treed='tree -CAFd' +alias mountedinfo='df -hT' + +# Alias's for archives +alias mktar='tar -cvf' +alias mkbz2='tar -cvjf' +alias mkgz='tar -cvzf' +alias untar='tar -xvf' +alias unbz2='tar -xvjf' +alias ungz='tar -xvzf' + +# Show all logs in /var/log +alias logs="sudo find /var/log -type f -exec file {} \; | grep 'text' | cut -d' ' -f1 | sed -e's/:$//g' | grep -v '[0-9]$' | xargs tail -f" + +# SHA1 +alias sha1='openssl sha1' + +alias clickpaste='sleep 3; xdotool type "$(xclip -o -selection clipboard)"' + +# KITTY - alias to be able to use kitty features when connecting to remote servers(e.g use tmux on remote server) + +alias kssh="kitty +kitten ssh" + +# alias to cleanup unused docker containers, images, networks, and volumes + +alias docker-clean=' \ + docker container prune -f ; \ + docker image prune -f ; \ + docker network prune -f ; \ + docker volume prune -f ' + +####################################################### +# SPECIAL FUNCTIONS +####################################################### +# Extracts any archive(s) (if unp isn't installed) +extract() { + for archive in "$@"; do + if [ -f "$archive" ]; then + case $archive in + *.tar.bz2) tar xvjf $archive ;; + *.tar.gz) tar xvzf $archive ;; + *.bz2) bunzip2 $archive ;; + *.rar) rar x $archive ;; + *.gz) gunzip $archive ;; + *.tar) tar xvf $archive ;; + *.tbz2) tar xvjf $archive ;; + *.tgz) tar xvzf $archive ;; + *.zip) unzip $archive ;; + *.Z) uncompress $archive ;; + *.7z) 7z x $archive ;; + *) echo "don't know how to extract '$archive'..." ;; + esac + else + echo "'$archive' is not a valid file!" + fi + done +} + +# Searches for text in all files in the current folder +ftext() { + # -i case-insensitive + # -I ignore binary files + # -H causes filename to be printed + # -r recursive search + # -n causes line number to be printed + # optional: -F treat search term as a literal, not a regular expression + # optional: -l only print filenames and not the matching lines ex. grep -irl "$1" * + grep -iIHrn --color=always "$1" . | less -r +} + +# Copy file with a progress bar +cpp() { + set -e + strace -q -ewrite cp -- "${1}" "${2}" 2>&1 | + awk '{ + count += $NF + if (count % 10 == 0) { + percent = count / total_size * 100 + printf "%3d%% [", percent + for (i=0;i<=percent;i++) + printf "=" + printf ">" + for (i=percent;i<100;i++) + printf " " + printf "]\r" + } + } + END { print "" }' total_size="$(stat -c '%s' "${1}")" count=0 +} + +# Copy and go to the directory +cpg() { + if [ -d "$2" ]; then + cp "$1" "$2" && cd "$2" + else + cp "$1" "$2" + fi +} + +# Move and go to the directory +mvg() { + if [ -d "$2" ]; then + mv "$1" "$2" && cd "$2" + else + mv "$1" "$2" + fi +} + +# Create and go to the directory +mkdirg() { + mkdir -p "$1" + cd "$1" +} + +# Goes up a specified number of directories (i.e. up 4) +up() { + local d="" + limit=$1 + for ((i = 1; i <= limit; i++)); do + d=$d/.. + done + d=$(echo $d | sed 's/^\///') + if [ -z "$d" ]; then + d=.. + fi + cd $d +} + +# Automatically do an ls after each cd, z, or zoxide +cd () +{ + if [ -n "$1" ]; then + builtin cd "$@" && ls + else + builtin cd ~ && ls + fi +} + +# Returns the last 2 fields of the working directory +pwdtail() { + pwd | awk -F/ '{nlast = NF -1;print $nlast"/"$NF}' +} + +# Show the current distribution +distribution () { + local dtype="unknown" # Default to unknown + + # Use /etc/os-release for modern distro identification + if [ -r /etc/os-release ]; then + source /etc/os-release + case $ID in + fedora|rhel|centos) + dtype="redhat" + ;; + sles|opensuse*) + dtype="suse" + ;; + ubuntu|debian) + dtype="debian" + ;; + gentoo) + dtype="gentoo" + ;; + arch|manjaro) + dtype="arch" + ;; + slackware) + dtype="slackware" + ;; + *) + # Check ID_LIKE only if dtype is still unknown + if [ -n "$ID_LIKE" ]; then + case $ID_LIKE in + *fedora*|*rhel*|*centos*) + dtype="redhat" + ;; + *sles*|*opensuse*) + dtype="suse" + ;; + *ubuntu*|*debian*) + dtype="debian" + ;; + *gentoo*) + dtype="gentoo" + ;; + *arch*) + dtype="arch" + ;; + *slackware*) + dtype="slackware" + ;; + esac + fi + + # If ID or ID_LIKE is not recognized, keep dtype as unknown + ;; + esac + fi + + echo $dtype +} + + +DISTRIBUTION=$(distribution) +if [ "$DISTRIBUTION" = "redhat" ] || [ "$DISTRIBUTION" = "arch" ]; then + alias cat='bat' +else + alias cat='batcat' +fi + +# Show the current version of the operating system +ver() { + local dtype + dtype=$(distribution) + + case $dtype in + "redhat") + if [ -s /etc/redhat-release ]; then + cat /etc/redhat-release + else + cat /etc/issue + fi + uname -a + ;; + "suse") + cat /etc/SuSE-release + ;; + "debian") + lsb_release -a + ;; + "gentoo") + cat /etc/gentoo-release + ;; + "arch") + cat /etc/os-release + ;; + "slackware") + cat /etc/slackware-version + ;; + *) + if [ -s /etc/issue ]; then + cat /etc/issue + else + echo "Error: Unknown distribution" + exit 1 + fi + ;; + esac +} + +# Automatically install the needed support files for this .bashrc file +install_bashrc_support() { + local dtype + dtype=$(distribution) + + case $dtype in + "redhat") + sudo yum install multitail tree zoxide trash-cli fzf bash-completion fastfetch + ;; + "suse") + sudo zypper install multitail tree zoxide trash-cli fzf bash-completion fastfetch + ;; + "debian") + sudo apt-get install multitail tree zoxide trash-cli fzf bash-completion + # Fetch the latest fastfetch release URL for linux-amd64 deb file + FASTFETCH_URL=$(curl -s https://api.github.com/repos/fastfetch-cli/fastfetch/releases/latest | grep "browser_download_url.*linux-amd64.deb" | cut -d '"' -f 4) + + # Download the latest fastfetch deb file + curl -sL $FASTFETCH_URL -o /tmp/fastfetch_latest_amd64.deb + + # Install the downloaded deb file using apt-get + sudo apt-get install /tmp/fastfetch_latest_amd64.deb + ;; + "arch") + sudo paru multitail tree zoxide trash-cli fzf bash-completion fastfetch + ;; + "slackware") + echo "No install support for Slackware" + ;; + *) + echo "Unknown distribution" + ;; + esac +} + +# IP address lookup +alias whatismyip="whatsmyip" +function whatsmyip () { + # Internal IP Lookup. + if command -v ip &> /dev/null; then + echo -n "Internal IP: " + ip addr show wlan0 | grep "inet " | awk '{print $2}' | cut -d/ -f1 + else + echo -n "Internal IP: " + ifconfig wlan0 | grep "inet " | awk '{print $2}' + fi + + # External IP Lookup + echo -n "External IP: " + curl -4 ifconfig.me +} + +# View Apache logs +apachelog() { + if [ -f /etc/httpd/conf/httpd.conf ]; then + cd /var/log/httpd && ls -xAh && multitail --no-repeat -c -s 2 /var/log/httpd/*_log + else + cd /var/log/apache2 && ls -xAh && multitail --no-repeat -c -s 2 /var/log/apache2/*.log + fi +} + +# Edit the Apache configuration +apacheconfig() { + if [ -f /etc/httpd/conf/httpd.conf ]; then + sedit /etc/httpd/conf/httpd.conf + elif [ -f /etc/apache2/apache2.conf ]; then + sedit /etc/apache2/apache2.conf + else + echo "Error: Apache config file could not be found." + echo "Searching for possible locations:" + sudo updatedb && locate httpd.conf && locate apache2.conf + fi +} + +# Edit the PHP configuration file +phpconfig() { + if [ -f /etc/php.ini ]; then + sedit /etc/php.ini + elif [ -f /etc/php/php.ini ]; then + sedit /etc/php/php.ini + elif [ -f /etc/php5/php.ini ]; then + sedit /etc/php5/php.ini + elif [ -f /usr/bin/php5/bin/php.ini ]; then + sedit /usr/bin/php5/bin/php.ini + elif [ -f /etc/php5/apache2/php.ini ]; then + sedit /etc/php5/apache2/php.ini + else + echo "Error: php.ini file could not be found." + echo "Searching for possible locations:" + sudo updatedb && locate php.ini + fi +} + +# Edit the MySQL configuration file +mysqlconfig() { + if [ -f /etc/my.cnf ]; then + sedit /etc/my.cnf + elif [ -f /etc/mysql/my.cnf ]; then + sedit /etc/mysql/my.cnf + elif [ -f /usr/local/etc/my.cnf ]; then + sedit /usr/local/etc/my.cnf + elif [ -f /usr/bin/mysql/my.cnf ]; then + sedit /usr/bin/mysql/my.cnf + elif [ -f ~/my.cnf ]; then + sedit ~/my.cnf + elif [ -f ~/.my.cnf ]; then + sedit ~/.my.cnf + else + echo "Error: my.cnf file could not be found." + echo "Searching for possible locations:" + sudo updatedb && locate my.cnf + fi +} + + +# Trim leading and trailing spaces (for scripts) +trim() { + local var=$* + var="${var#"${var%%[![:space:]]*}"}" # remove leading whitespace characters + var="${var%"${var##*[![:space:]]}"}" # remove trailing whitespace characters + echo -n "$var" +} +# GitHub Titus Additions + +gcom() { + git add . + git commit -m "$1" +} +lazyg() { + git add . + git commit -m "$1" + git push +} + +function hb { + if [ $# -eq 0 ]; then + echo "No file path specified." + return + elif [ ! -f "$1" ]; then + echo "File path does not exist." + return + fi + + uri="http://bin.christitus.com/documents" + response=$(curl -s -X POST -d @"$1" "$uri") + if [ $? -eq 0 ]; then + hasteKey=$(echo $response | jq -r '.key') + echo "http://bin.christitus.com/$hasteKey" + else + echo "Failed to upload the document." + fi +} + +####################################################### +# Set the ultimate amazing command prompt +####################################################### + +alias hug="systemctl --user restart hugo" +alias lanm="systemctl --user restart lan-mouse" + +# Check if the shell is interactive +if [[ $- == *i* ]]; then + # Bind Ctrl+f to insert 'zi' followed by a newline + bind '"\C-f":"zi\n"' +fi + +export PATH=$PATH:"$HOME/.local/bin:$HOME/.cargo/bin:/var/lib/flatpak/exports/bin:/.local/share/flatpak/exports/bin" + +eval "$(starship init bash)" +eval "$(zoxide init bash)" diff --git a/README.md b/README.md new file mode 100644 index 0000000..2bf911f --- /dev/null +++ b/README.md @@ -0,0 +1,121 @@ +# ChrisTitusTech's `.bashrc` Configuration + +## Overview + +This repository provides a comprehensive `.bashrc` configuration along with supporting scripts and configuration files to enhance your terminal experience in Unix-like operating systems. It configures the shell session by setting up aliases, defining functions, customizing the prompt, and more, significantly improving the terminal's usability and power. + +## Table of Contents + +- [Installation](#installation) +- [Uninstallation](#uninstallation) +- [Configuration Files](#configuration-files) + - [.bashrc](#bashrc) + - [starship.toml](#starshiptoml) + - [config.jsonc](#configjsonc) +- [Key Features](#key-features) +- [Advanced Functions](#advanced-functions) +- [System-Specific Configurations](#system-specific-configurations) +- [Conclusion](#conclusion) + +## Installation + +To install the `.bashrc` configuration, execute the following commands in your terminal: + +```sh +git clone --depth=1 https://github.com/dacrab/mybash.git +cd mybash +./setup.sh +``` + +The `setup.sh` script automates the installation process by: + +- Creating necessary directories (`linuxtoolbox/mybash`) +- Cloning the repository +- Installing dependencies (bash-completion, neovim, starship, fzf, zoxide) +- Installing the MesloLGS Nerd Font required for the prompt +- Linking configuration files (`.bashrc` and `starship.toml`) to your home directory +- Setting up additional utilities like `fastfetch` + +Ensure you have the required permissions and a supported package manager before running the script. + +## Uninstallation + +To uninstall the `.bashrc` configuration, run: + +```sh +cd mybash +chmod +x uninstall.sh +./uninstall.sh +``` + +The `uninstall.sh` script reverses the installation process by: + +- Removing installed dependencies +- Uninstalling fonts +- Removing symbolic links to configuration files +- Deleting the `linuxtoolbox` directory +- Cleaning up additional utilities like `starship`, `fzf`, and `zoxide` + +After running the script, it's recommended to restart your shell to apply the changes. + +## Configuration Files + +### `.bashrc` + +The `.bashrc` file defines aliases, functions, and environment variables to enhance your shell experience. Key features include: + +- **Aliases**: Shortcuts for common commands (e.g., `alias cp='cp -i'`) +- **Functions**: Custom functions for tasks like extracting archives and copying files with progress + +### `starship.toml` + +The `starship.toml` file configures the [Starship](https://starship.rs/) prompt, providing a highly customizable and informative shell prompt. It includes: + +- **Theme Settings**: Defines colors and symbols for different prompt segments +- **Module Configurations**: Customizes modules like `python`, `git`, `docker_context`, and various programming languages +- **Format Customization**: Structures the layout and truncation of paths for a cleaner look + +### `config.jsonc` + +The `config.jsonc` file configures [fastfetch](https://github.com/AlexRogalskiy/fastfetch), a system information tool. It includes: + +- **Logo and Display Settings**: Customizes the appearance of system logos and separators +- **Modules**: Defines which system information modules to display, such as CPU, GPU, OS, kernel, and uptime +- **Custom Sections**: Adds custom formatted sections for hardware and software information + +## Key Features + +1. **Aliases and Functions** + - Shortcuts for common commands + - Custom functions for complex operations (e.g., extracting archives, copying with progress) + +2. **Prompt Customization and History Management** + - Configures PROMPT_COMMAND for automatic history saving + - Manages history file size and handles duplicates + +3. **Enhancements and Utilities** + - Improves command output readability with colors + - Introduces safer file operations (e.g., using `trash` instead of `rm`) + - Integrates Zoxide for easy directory navigation + +4. **Installation and Configuration Helpers** + - Auto-installs necessary utilities based on system type + - Provides functions to edit important configuration files + +## Advanced Functions + +- System information display +- Networking utilities (e.g., IP address checks) +- Resource monitoring tools + +## System-Specific Configurations + +- Editor settings (NeoVim as default) +- Conditional aliases based on system type +- Package manager-specific commands + +## Conclusion + +This `.bashrc` configuration offers a powerful and customizable terminal environment suitable for various Unix-like systems. It enhances productivity through smart aliases, functions, and integrated tools while maintaining flexibility for system-specific needs. Whether you're a developer, system administrator, or power user, this setup aims to make your terminal experience more efficient and enjoyable. + +For any issues, suggestions, or contributions, please open an issue or pull request in this repository. We welcome community involvement to make this configuration even better! \ No newline at end of file diff --git a/config.jsonc b/config.jsonc new file mode 100644 index 0000000..15a6182 --- /dev/null +++ b/config.jsonc @@ -0,0 +1,130 @@ + +{ +"$schema": "https://github.com/fastfetch-cli/fastfetch/raw/dev/doc/json_schema.json", +"logo": { +"padding": { +"top": 1 +} +}, +"display": { +"separator": " 󰑃 " +}, +"modules": [ + "break", + { + "type": "os", + "key": " DISTRO", + "keyColor": "yellow" + }, + { + "type": "kernel", + "key": "│ ├", + "keyColor": "yellow" + }, + { + "type": "packages", + "key": "│ ├󰏖", + "keyColor": "yellow" + }, + { + "type": "command", + "key": "│ ├", + "keyColor": "yellow", + "text": "birth_install=$(stat -c %W /); current=$(date +%s); time_progression=$((current - birth_install)); days_difference=$((time_progression / 86400)); echo $days_difference days" + }, + { + "type": "shell", + "key": "│ └", + "keyColor": "yellow" + }, + + { + "type": "wm", + "key": " DE/WM", + "keyColor": "blue" + }, + { + "type": "wmtheme", + "key": "│ ├󰉼", + "keyColor": "blue" + }, + { + "type": "icons", + "key": "│ ├󰀻", + "keyColor": "blue" + }, + { + "type": "cursor", + "key": "│ ├", + "keyColor": "blue", + }, + { + "type": "terminalfont", + "key": "│ ├", + "keyColor": "blue", + }, + { + "type": "terminal", + "key": "│ └", + "keyColor": "blue" + }, + { + "type": "host", + "key": "󰌢 SYSTEM", + "keyColor": "green" + }, + { + "type": "cpu", + "key": "│ ├󰻠", + "keyColor": "green" + }, + { + "type": "gpu", + "key": "│ ├󰻑", + "format": "{2}", + "keyColor": "green" + }, + { + "type": "display", + "key": "│ ├󰍹", + "keyColor": "green", + "compactType": "original-with-refresh-rate" + }, + { + "type": "memory", + "key": "│ ├󰾆", + "keyColor": "green" + }, + { + "type": "swap", + "key": "│ ├󰓡", + "keyColor": "green" + }, + { + "type": "uptime", + "key": "│ ├󰅐", + "keyColor": "green" + }, + { + "type": "sound", + "key": " AUDIO", + "format": "{2}", + "keyColor": "magenta" + }, + { + "type": "player", + "key": "│ ├󰥠", + "keyColor": "magenta" + }, + { + "type": "media", + "key": "│ └󰝚", + "keyColor": "magenta" + }, + { + "type": "custom", + "format": "\u001b[90m \u001b[31m \u001b[32m \u001b[33m \u001b[34m \u001b[35m \u001b[36m \u001b[37m \u001b[38m \u001b[39m \u001b[39m  \u001b[38m \u001b[37m \u001b[36m \u001b[35m \u001b[34m \u001b[33m \u001b[32m \u001b[31m \u001b[90m " + }, + "break", + ] +} diff --git a/starship.toml b/starship.toml new file mode 100644 index 0000000..67b94f4 --- /dev/null +++ b/starship.toml @@ -0,0 +1,279 @@ +"$schema" = 'https://starship.rs/config-schema.json' + +format = """ +[](red)\ +$os\ +$username\ +[](bg:peach fg:red)\ +$directory\ +[](bg:yellow fg:peach)\ +$git_branch\ +$git_status\ +[](fg:yellow bg:green)\ +$c\ +$rust\ +$golang\ +$nodejs\ +$php\ +$java\ +$kotlin\ +$haskell\ +$python\ +[](fg:green bg:sapphire)\ +$conda\ +[](fg:sapphire bg:lavender)\ +$time\ +[ ](fg:lavender)\ +$cmd_duration\ +$line_break\ +$character""" + +palette = 'catppuccin_latte' + +[os] +disabled = false +style = "bg:red fg:crust" + +[os.symbols] +Windows = "" +Ubuntu = "󰕈" +SUSE = "" +Raspbian = "󰐿" +Mint = "󰣭" +Macos = "󰀵" +Manjaro = "" +Linux = "󰌽" +Gentoo = "󰣨" +Fedora = "󰣛" +Alpine = "" +Amazon = "" +Android = "" +AOSC = "" +Arch = "󰣇" +Artix = "󰣇" +CentOS = "" +Debian = "󰣚" +Redhat = "󱄛" +RedHatEnterprise = "󱄛" + +[username] +show_always = true +style_user = "bg:red fg:crust" +style_root = "bg:red fg:crust" +format = '[ $user]($style)' + +[directory] +style = "bg:peach fg:crust" +format = "[ $path ]($style)" +truncation_length = 3 +truncation_symbol = "…/" + +[directory.substitutions] +"Documents" = "󰈙 " +"Downloads" = " " +"Music" = "󰝚 " +"Pictures" = " " +"Developer" = "󰲋 " + +[git_branch] +symbol = "" +style = "bg:yellow" +format = '[[ $symbol $branch ](fg:crust bg:yellow)]($style)' + +[git_status] +style = "bg:yellow" +format = '[[($all_status$ahead_behind )](fg:crust bg:yellow)]($style)' + +[nodejs] +symbol = "" +style = "bg:green" +format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)' + +[c] +symbol = " " +style = "bg:green" +format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)' + +[rust] +symbol = "" +style = "bg:green" +format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)' + +[golang] +symbol = "" +style = "bg:green" +format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)' + +[php] +symbol = "" +style = "bg:green" +format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)' + +[java] +symbol = " " +style = "bg:green" +format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)' + +[kotlin] +symbol = "" +style = "bg:green" +format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)' + +[haskell] +symbol = "" +style = "bg:green" +format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)' + +[python] +symbol = "" +style = "bg:green" +format = '[[ $symbol( $version)(\(#$virtualenv\)) ](fg:crust bg:green)]($style)' + +[docker_context] +symbol = "" +style = "bg:sapphire" +format = '[[ $symbol( $context) ](fg:crust bg:sapphire)]($style)' + +[conda] +symbol = "  " +style = "fg:crust bg:sapphire" +format = '[$symbol$environment ]($style)' +ignore_base = false + +[time] +disabled = false +time_format = "%R" +style = "bg:lavender" +format = '[[  $time ](fg:crust bg:lavender)]($style)' + +[line_break] +disabled = true + +[character] +disabled = false +success_symbol = '[❯](bold fg:green)' +error_symbol = '[❯](bold fg:red)' +vimcmd_symbol = '[❮](bold fg:green)' +vimcmd_replace_one_symbol = '[❮](bold fg:lavender)' +vimcmd_replace_symbol = '[❮](bold fg:lavender)' +vimcmd_visual_symbol = '[❮](bold fg:yellow)' + +[cmd_duration] +show_milliseconds = true +format = " in $duration " +style = "bg:lavender" +disabled = false +show_notifications = true +min_time_to_notify = 45000 + +[palettes.catppuccin_mocha] +rosewater = "#f5e0dc" +flamingo = "#f2cdcd" +pink = "#f5c2e7" +mauve = "#cba6f7" +red = "#f38ba8" +maroon = "#eba0ac" +peach = "#fab387" +yellow = "#f9e2af" +green = "#a6e3a1" +teal = "#94e2d5" +sky = "#89dceb" +sapphire = "#74c7ec" +blue = "#89b4fa" +lavender = "#b4befe" +text = "#cdd6f4" +subtext1 = "#bac2de" +subtext0 = "#a6adc8" +overlay2 = "#9399b2" +overlay1 = "#7f849c" +overlay0 = "#6c7086" +surface2 = "#585b70" +surface1 = "#45475a" +surface0 = "#313244" +base = "#1e1e2e" +mantle = "#181825" +crust = "#11111b" + +[palettes.catppuccin_frappe] +rosewater = "#f2d5cf" +flamingo = "#eebebe" +pink = "#f4b8e4" +mauve = "#ca9ee6" +red = "#e78284" +maroon = "#ea999c" +peach = "#ef9f76" +yellow = "#e5c890" +green = "#a6d189" +teal = "#81c8be" +sky = "#99d1db" +sapphire = "#85c1dc" +blue = "#8caaee" +lavender = "#babbf1" +text = "#c6d0f5" +subtext1 = "#b5bfe2" +subtext0 = "#a5adce" +overlay2 = "#949cbb" +overlay1 = "#838ba7" +overlay0 = "#737994" +surface2 = "#626880" +surface1 = "#51576d" +surface0 = "#414559" +base = "#303446" +mantle = "#292c3c" +crust = "#232634" + +[palettes.catppuccin_latte] +rosewater = "#dc8a78" +flamingo = "#dd7878" +pink = "#ea76cb" +mauve = "#8839ef" +red = "#d20f39" +maroon = "#e64553" +peach = "#fe640b" +yellow = "#df8e1d" +green = "#40a02b" +teal = "#179299" +sky = "#04a5e5" +sapphire = "#209fb5" +blue = "#1e66f5" +lavender = "#7287fd" +text = "#4c4f69" +subtext1 = "#5c5f77" +subtext0 = "#6c6f85" +overlay2 = "#7c7f93" +overlay1 = "#8c8fa1" +overlay0 = "#9ca0b0" +surface2 = "#acb0be" +surface1 = "#bcc0cc" +surface0 = "#ccd0da" +base = "#eff1f5" +mantle = "#e6e9ef" +crust = "#dce0e8" + +[palettes.catppuccin_macchiato] +rosewater = "#f4dbd6" +flamingo = "#f0c6c6" +pink = "#f5bde6" +mauve = "#c6a0f6" +red = "#ed8796" +maroon = "#ee99a0" +peach = "#f5a97f" +yellow = "#eed49f" +green = "#a6da95" +teal = "#8bd5ca" +sky = "#91d7e3" +sapphire = "#7dc4e4" +blue = "#8aadf4" +lavender = "#b7bdf8" +text = "#cad3f5" +subtext1 = "#b8c0e0" +subtext0 = "#a5adcb" +overlay2 = "#939ab7" +overlay1 = "#8087a2" +overlay0 = "#6e738d" +surface2 = "#5b6078" +surface1 = "#494d64" +surface0 = "#363a4f" +base = "#24273a" +mantle = "#1e2030" +crust = "#181926" diff --git a/uninstall.sh b/uninstall.sh new file mode 100644 index 0000000..ae4f51b --- /dev/null +++ b/uninstall.sh @@ -0,0 +1,156 @@ +#!/bin/sh -e + +# Define color codes using tput for better compatibility +RC=$(tput sgr0) +RED=$(tput setaf 1) +YELLOW=$(tput setaf 3) +GREEN=$(tput setaf 2) + +LINUXTOOLBOXDIR="$HOME/linuxtoolbox" +PACKAGER="" +SUDO_CMD="" + +print_colored() { + color=$1 + message=$2 + printf "${color}%s${RC}\n" "$message" +} + +command_exists() { + command -v "$1" >/dev/null 2>&1 +} + +determine_package_manager() { + PACKAGEMANAGER='nala apt dnf yum pacman zypper emerge xbps-install nix-env' + for pgm in $PACKAGEMANAGER; do + if command_exists "$pgm"; then + PACKAGER="$pgm" + printf "Using %s\n" "$pgm" + break + fi + done + + if [ -z "$PACKAGER" ]; then + print_colored "$RED" "Can't find a supported package manager" + exit 1 + fi +} + +determine_sudo_command() { + if command_exists sudo; then + SUDO_CMD="sudo" + elif command_exists doas && [ -f "/etc/doas.conf" ]; then + SUDO_CMD="doas" + else + SUDO_CMD="su -c" + fi + + printf "Using %s as privilege escalation software\n" "$SUDO_CMD" +} + +uninstall_dependencies() { + DEPENDENCIES='bash-completion bat tree multitail fastfetch neovim trash-cli' + + print_colored "$YELLOW" "Uninstalling dependencies..." + if [ "$PACKAGER" = "pacman" ]; then + if command_exists yay; then + yay -Rns --noconfirm ${DEPENDENCIES} + elif command_exists paru; then + paru -Rns --noconfirm ${DEPENDENCIES} + else + ${SUDO_CMD} pacman -Rns --noconfirm ${DEPENDENCIES} + fi + elif [ "$PACKAGER" = "nala" ] || [ "$PACKAGER" = "apt" ]; then + ${SUDO_CMD} ${PACKAGER} purge -y ${DEPENDENCIES} + elif [ "$PACKAGER" = "emerge" ]; then + ${SUDO_CMD} ${PACKAGER} --deselect app-shells/bash-completion sys-apps/bat app-text/tree app-text/multitail app-misc/fastfetch app-editors/neovim app-misc/trash-cli + elif [ "$PACKAGER" = "xbps-install" ]; then + ${SUDO_CMD} xbps-remove -Ry ${DEPENDENCIES} + elif [ "$PACKAGER" = "nix-env" ]; then + ${SUDO_CMD} ${PACKAGER} -e bash-completion bat tree multitail fastfetch neovim trash-cli + elif [ "$PACKAGER" = "dnf" ] || [ "$PACKAGER" = "yum" ]; then + ${SUDO_CMD} ${PACKAGER} remove -y ${DEPENDENCIES} + else + ${SUDO_CMD} ${PACKAGER} remove -y ${DEPENDENCIES} + fi +} + +uninstall_font() { + FONT_NAME="MesloLGS Nerd Font Mono" + FONT_DIR="$HOME/.local/share/fonts/$FONT_NAME" + + if [ -d "$FONT_DIR" ]; then + print_colored "$YELLOW" "Removing font: $FONT_NAME" + rm -rf "$FONT_DIR" + fc-cache -fv + print_colored "$GREEN" "Font removed: $FONT_NAME" + else + print_colored "$YELLOW" "Font not found: $FONT_NAME" + fi +} + +uninstall_starship_and_fzf() { + if command_exists starship; then + print_colored "$YELLOW" "Uninstalling Starship..." + ${SUDO_CMD} rm -f "$(command -v starship)" + print_colored "$GREEN" "Starship uninstalled" + fi + + if [ -d "$HOME/.fzf" ]; then + print_colored "$YELLOW" "Uninstalling fzf..." + "$HOME/.fzf/uninstall" + rm -rf "$HOME/.fzf" + print_colored "$GREEN" "fzf uninstalled" + fi +} + +uninstall_zoxide() { + if command_exists zoxide; then + print_colored "$YELLOW" "Uninstalling Zoxide..." + ${SUDO_CMD} rm -f "$(command -v zoxide)" + print_colored "$GREEN" "Zoxide uninstalled" + fi +} + +remove_configs() { + USER_HOME=$(getent passwd "${SUDO_USER:-$USER}" | cut -d: -f6) + + print_colored "$YELLOW" "Removing configuration files..." + + # Remove .bashrc symlink and restore backup if it exists + if [ -L "$USER_HOME/.bashrc" ]; then + rm "$USER_HOME/.bashrc" + if [ -f "$USER_HOME/.bashrc.bak" ]; then + mv "$USER_HOME/.bashrc.bak" "$USER_HOME/.bashrc" + print_colored "$GREEN" "Restored original .bashrc" + fi + fi + + # Remove starship config + rm -f "$USER_HOME/.config/starship.toml" + + # Remove fastfetch config + rm -f "$USER_HOME/.config/fastfetch/config.jsonc" + + print_colored "$GREEN" "Configuration files removed" +} + +remove_linuxtoolbox() { + if [ -d "$LINUXTOOLBOXDIR" ]; then + print_colored "$YELLOW" "Removing linuxtoolbox directory..." + rm -rf "$LINUXTOOLBOXDIR" + print_colored "$GREEN" "linuxtoolbox directory removed" + fi +} + +# Main execution +determine_package_manager +determine_sudo_command +uninstall_dependencies +uninstall_font +uninstall_starship_and_fzf +uninstall_zoxide +remove_configs +remove_linuxtoolbox + +print_colored "$GREEN" "Uninstallation complete. Please restart your shell for changes to take effect." \ No newline at end of file