1

reorg everything to not need dotbot

This commit is contained in:
Evan Pratten 2023-10-19 10:30:32 -04:00
parent 1725e8682e
commit ea6968019c
34 changed files with 212 additions and 254 deletions

5
.vscode/tasks.json vendored
View File

@ -6,7 +6,10 @@
{
"label": "Run install script",
"type": "shell",
"command": "./install",
"command": "sh",
"args": [
"./install-linux.sh"
],
"problemMatcher": []
}
]

View File

@ -16,5 +16,10 @@ Install and link everything with:
mkdir -p ~/.config && cd ~/.config
git clone https://github.com/ewpratten/ewconfig
cd ewconfig
./install
```
# Linux
sh ./install-linux.sh
# Windows, with GIT BASH
sh ./install-windows.sh
```

View File

@ -1,157 +0,0 @@
[Desktop Entry]
Hidden=true
Type=Application
Name[af]=SSH-sleutelagent
Name[ar]=عميل مفاتيح SSH
Name[as]=SSH ি
Name[ast]=Axente de claves SSH
Name[be]=SSH-агент ключоў
Name[bg]=Агентът на SSH за ключове
Name[bn]=SSH
Name[bn_IN]=SSH ি
Name[bs]=Agent za SSH ključeve
Name[ca]=Agent de claus SSH
Name[ca@valencia]=Agent de claus SSH
Name[cs]=Agent klíčů SSH
Name[da]=SSH-nøgleagent
Name[de]=SSH-Schlüsselagent
Name[el]=Πράκτορας κλειδιού SSH
Name[en_GB]=SSH Key Agent
Name[eo]=SSH-ŝlosila agento
Name[es]=Agente de claves SSH
Name[et]=SSH-võtmete agent
Name[eu]=SSH gako-agentea
Name[fa]=عامل کلید SSH
Name[fi]=SSH-avainten agentti
Name[fr]=Agent de clés SSH
Name[fur]=Agjent clâfs SSH
Name[gd]=Àidseant iuchair SSH
Name[gl]=Axente de chave SSH
Name[gu]=SSH
Name[he]=סוכן מפתחות SSH
Name[hi]=AFS ििि
Name[hr]=Agent SSH ključa
Name[hu]=SSH-kulcs ügynök
Name[id]=Agen Kunci SSH
Name[it]=Agente chiavi SSH
Name[ja]=SSH
Name[kk]=SSH кілттер агенті
Name[km]= SSH
Name[kn]=SSH ಿ ಿ
Name[ko]=SSH
Name[lt]=SSH raktų tarnyba
Name[lv]=SSH atslēgu aģents
Name[mjw]=SSH Key Agent
Name[mk]=Агент за SSH клучеви
Name[ml]=
Name[mr]=SSH ि
Name[ms]=Ejen Kunci SSH
Name[nb]=SSH-nøkkelagent
Name[nl]=SSH-sleutelagent
Name[nn]=Nøkkelagent for SSH
Name[oc]=Agent de claus SSH
Name[or]=SSH ି
Name[pa]=SSH
Name[pl]=Agent kluczy SSH
Name[pt]=Agente de chaves SSH
Name[pt_BR]=Agente de chaves SSH
Name[ro]=Agent pentru chei SSH
Name[ru]=Агент ключей SSH
Name[sk]=Agent kľúčov SSH
Name[sl]=Agent ključev SSH
Name[sr]=Агент за ССХ кључеве
Name[sr@latin]=Agent za SSH ključeve
Name[sv]=SSH-nyckelagent
Name[ta]=SSH
Name[te]=SSH
Name[th]= SSH
Name[tr]=SSH Anahtar Aracı
Name[ug]=SSH ئاچقۇچ ياردەمچىسى
Name[uk]=Агент ключів SSH
Name[vi]=Đi din khóa SSH
Name[zh_CN]=SSH
Name[zh_HK]=SSH
Name[zh_TW]=SSH
Name=SSH Key Agent
Comment[af]=GNOME-sleutelring: SSH-agent
Comment[ar]=حلقة مفاتيح جنوم: عميل SSH
Comment[as]=GNOME Keyring: SSH
Comment[ast]=Depósitu de claves de GNOME: axente SSH
Comment[be]=Вязкі ключоў GNOME: SSH-агент
Comment[bg]=Ключодържател на GNOME: агент на SSH
Comment[bn]=GNOME ি: SSH
Comment[bn_IN]=GNOME Keyring: SSH
Comment[bs]=Gnomovi privjesci: SSH agent
Comment[ca]=Anell de claus del GNOME: agent SSH
Comment[ca@valencia]=Anell de claus del GNOME: agent SSH
Comment[cs]=Klíčenka GNOME: Agent SSH
Comment[da]=GNOME-nøgleringsdæmon: SSH-agent
Comment[de]=GNOME-Schlüsselbunddienst: SSH-Agent
Comment[el]=Κλειδοθήκη GNOME: Πράκτορας SSH
Comment[en_GB]=GNOME Keyring: SSH Agent
Comment[eo]=GNOME Ŝlosilaro: SSH-agento
Comment[es]=Depósito de claves de GNOME: agente SSH
Comment[et]=GNOME võtmerõngas: SSH-agent
Comment[eu]=GNOMEren gako-sorta: SSH agentea
Comment[fa]=دستهکلید گنوم: عامل SSH
Comment[fi]=Gnomen avainnippu: SSH-agentti
Comment[fr]=Trousseau de clés de GNOME : agent SSH
Comment[fur]=Puarteclâfs di GNOME: agjent SSH
Comment[gd]=Dul-iuchrach: Àidseant SSH
Comment[gl]=GNOME Keyring: Axente SSH
Comment[gu]=GNOME : SSH
Comment[he]=קבוצת מפתחות של GNOME: סוכן SSH
Comment[hi]= ि: SSH ििि
Comment[hr]=GNOME skup ključeva: SSH agent
Comment[hu]=GNOME kulcstartó SSH-ügynök
Comment[id]=Ring Kunci GNOME: Agen SSH
Comment[it]=Portachiavi di GNOME: agente SSH
Comment[ja]=GNOME : SSH
Comment[kk]=GNOME Keyring: SSH агенті
Comment[km]=GNOME Keyring SSH
Comment[kn]=GNOME ಿ: SSH ಿ
Comment[ko]= : SSH
Comment[lt]=GNOME raktinė: SSH tarnyba
Comment[lv]=GNOME atslēgu saišķis SSH aģents
Comment[mjw]=GNOME Keyring: SSH Agent
Comment[mk]=Приврзок на GNOME: SSH агент
Comment[ml]= ി:
Comment[mr]=GNOME िि: SSH
Comment[ms]=Gelang Kunci GNOME: Ejen SSH
Comment[nb]=GNOME nøkkelring: SSH-agent
Comment[ne]=ि िि : SSH
Comment[nl]=Sleutelbos-service: SSH-agent
Comment[nn]=GNOME Nøkkelring: SSH-agent
Comment[oc]=Trossèl de claus GNOME : agent SSH
Comment[or]=GNOME ି ି: SSH
Comment[pa]= ਿ: SSH
Comment[pl]=Baza kluczy dla środowiska GNOME: agent SSH
Comment[pt]=GNOME Keyring: agente SSH
Comment[pt_BR]=Chaveiro do GNOME: Agente SSH
Comment[ro]=Inelul de chei GNOME: Agent SSH
Comment[ru]=Связка ключей GNOME: SSH-агент
Comment[sk]=SSH agent zväzku kľúčov GNOME
Comment[sl]=Zbirka ključev GNOME: agent SSH
Comment[sr]=Гномови привесци: ССХ агент
Comment[sr@latin]=Gnomovi privesci: SSH agent
Comment[sv]=GNOME-nyckelring: SSH-agent
Comment[ta]=GNOME ி: SSH
Comment[te]=GNOME ి: SSH
Comment[th]= GNOME: SSH
Comment[tr]=GNOME Anahtarlığı: SSH Aracı
Comment[ug]=گىنوم ئاچقۇچ ھالقىسىSSH ياردەمچىسى
Comment[uk]=Служба в'язки ключів GNOME: агент SSH
Comment[vi]=Chùm chìa khóa GNOME: Đi din SSH
Comment[zh_CN]=GNOME SSH
Comment[zh_HK]=GNOME SSH
Comment[zh_TW]=GNOME SSH
Comment=GNOME Keyring: SSH Agent
Exec=/usr/bin/gnome-keyring-daemon --start --components=ssh
OnlyShowIn=GNOME;Unity;MATE;
X-GNOME-Autostart-Phase=PreDisplayServer
X-GNOME-AutoRestart=false
X-GNOME-Autostart-Notify=true
X-GNOME-Bugzilla-Bugzilla=GNOME
X-GNOME-Bugzilla-Product=gnome-keyring
X-GNOME-Bugzilla-Component=general
X-GNOME-Bugzilla-Version=42.1

View File

@ -1,7 +0,0 @@
[Desktop Entry]
Name = Logid
GenericName = Logid
Comment = Logitech Mouse Driver
Exec = logid -v -c $HOME/.config/logid/logid.cfg
Type = Application
X-GNOME-Autostart-enabled = false

View File

@ -1,10 +1,9 @@
[include]
path = ~/.config/git/features/enable-signing.gitconfig
[user]
email = evan@ewpratten.com
name = Evan Pratten
signingkey = ~/.ssh/id_ed25519_sk_rk_yk20572395
# NOTE: These paths are imported if they exist and ignored if they don't
# This allows us to have a single config file for all our machines
# and control the specifics by symlinking the relevant files per-machine
path = ~/.config/git/config-fragments/personal-info.gitconfig
path = ~/.config/git/config-fragments/enable-signing.gitconfig
[init]
defaultBranch = master
@ -39,11 +38,5 @@
helper =
helper = !/usr/bin/gh auth git-credential
[sendemail]
smtpserver = smtp.migadu.com
smtpuser = evan@ewpratten.com
smtpencryption = tls
smtpserverport = 587
[mailmap]
file = ~/.config/git/.mailmap

View File

@ -0,0 +1,10 @@
[user]
email = evan@ewpratten.com
name = Evan Pratten
signingkey = ~/.ssh/id_ed25519_sk_rk_yk20572395
[sendemail]
smtpserver = smtp.migadu.com
smtpuser = evan@ewpratten.com
smtpencryption = tls
smtpserverport = 587

1
configs/nvim/pack/pack Symbolic link
View File

@ -0,0 +1 @@
/home/ewpratten/.config/ewconfig/configs/nvim/pack

1
configs/nvim/third_party/third_party vendored Symbolic link
View File

@ -0,0 +1 @@
/home/ewpratten/.config/ewconfig/configs/nvim/third_party

1
configs/rofi/rofi Symbolic link
View File

@ -0,0 +1 @@
/home/ewpratten/.config/ewconfig/configs/rofi/

View File

@ -1,18 +1,13 @@
# This is a somewhat hacky bashrc that is used to provide some of the conveniences from my zshrc on machines that I can't get zsh on
export EWCONFIG_ROOT="$HOME/.config/ewconfig"
# Load macros
. $EWCONFIG_ROOT/configs/shells/bash/macros.sh
# I always want my ~/bin to be in my PATH
export PATH="$HOME/bin:$PATH"
export PATH="$EWCONFIG_ROOT/configs/scripts:$PATH"
export PATH="$HOME/.local/bin:$PATH"
# Makes a directory, then moves into it
mkcd() {
if [ $# != 1 ]; then
echo "Usage: mkcd <dir>"
else
mkdir -p $1 && cd $1
fi
}
# A basic prompt to display user@host dir sign
export PS1="(bash) \[\e[0;32m\]\u@\h \[\e[0;36m\]\w \[\e[0;36m\]\$ \[\e[0m\]"

View File

@ -158,15 +158,6 @@ wg-cat() {
fi
}
# Search for a process
proc-grep() {
if [ $# != 1 ]; then
echo "Usage: proc-grep <regex>"
else
ps aux | { head -1; grep $1 }
fi
}
# Updates ewconfig
ewconfig-pull() {
cwd=$(pwd)

View File

@ -3,21 +3,22 @@
export EWCONFIG_ROOT="$HOME/.config/ewconfig"
# Load my custom prompt and macros
. $EWCONFIG_ROOT/configs/zsh/prompt.sh
. $EWCONFIG_ROOT/configs/zsh/macros.sh
. $EWCONFIG_ROOT/configs/zsh/keybinds.sh
. $EWCONFIG_ROOT/configs/zsh/autocomplete.sh
. $EWCONFIG_ROOT/configs/shells/zsh/prompt.sh
. $EWCONFIG_ROOT/configs/shells/zsh/macros.sh
. $EWCONFIG_ROOT/configs/shells/zsh/keybinds.sh
. $EWCONFIG_ROOT/configs/shells/zsh/autocomplete.sh
# Load per-host configuration
if [ -f $EWCONFIG_ROOT/configs/zsh/by_host/$HOSTNAME.sh ]; then
. $EWCONFIG_ROOT/configs/zsh/by_host/$HOSTNAME.sh
. $EWCONFIG_ROOT/configs/shells/zsh/by_host/$HOSTNAME.sh
fi
# Show some host info
. $EWCONFIG_ROOT/configs/zsh/info.sh
. $EWCONFIG_ROOT/configs/shells/zsh/info.sh
# I always want my ~/bin to be in my PATH
export PATH="$HOME/bin:$PATH"
export PATH="$EWCONFIG_ROOT/configs/scripts:$PATH"
export PATH="$HOME/.local/bin:$PATH"
# Configure a sane default editor

View File

@ -0,0 +1,11 @@
# We are compatible with bash, so first load the bash-specific macros
. $EWCONFIG_ROOT/configs/shells/bash/macros.sh
# Search for a process
proc-grep() {
if [ $# != 1 ]; then
echo "Usage: proc-grep <regex>"
else
ps aux | { head -1; grep $1 }
fi
}

1
configs/tabset/tabset Symbolic link
View File

@ -0,0 +1 @@
/home/ewpratten/.config/ewconfig/configs/tabset/

View File

@ -1,16 +0,0 @@
#! /bin/bash
# Various custom-compiled libs live here
export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
# SDKMAN!
export SDKMAN_DIR="$HOME/.sdkman"
[[ -s "$HOME/.sdkman/bin/sdkman-init.sh" ]] && source "$HOME/.sdkman/bin/sdkman-init.sh"
# NVM
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion
# Flutter
export PATH="$PATH:$HOME/development/flutter/bin"

View File

@ -1,7 +0,0 @@
#! /bin/bash
set -e
if [[ "$HOSTNAME" == "fedora" ]] || [[ "$HOSTNAME" == "ewpratten-laptop" ]]; then
mkdir -p $HOME/.config/git/features
ln -sf $EWCONFIG_ROOT/configs/git/features/enable-signing.gitconfig $HOME/.config/git/features/enable-signing.gitconfig
fi

View File

@ -1,13 +0,0 @@
#! /bin/sh
# Installs the SSH config file
set -e
# Link the SSH config file
echo "Linking SSH config file..."
mkdir -p "$HOME/.ssh"
ln -sf "$(pwd)/configs/ssh/config" "$HOME/.ssh/config"
# Set the correct permissions
echo "Setting SSH config file permissions..."
chmod 644 "$HOME/.ssh/config"
chown "$USER:$USER" "$HOME/.ssh/config"

15
install
View File

@ -1,15 +0,0 @@
#!/usr/bin/env bash
set -e
CONFIG="install.conf.yaml"
DOTBOT_DIR="dotbot"
DOTBOT_BIN="bin/dotbot"
BASEDIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
cd "${BASEDIR}"
git -C "${DOTBOT_DIR}" submodule sync --quiet --recursive
git submodule update --init --recursive "${DOTBOT_DIR}"
"${BASEDIR}/${DOTBOT_DIR}/${DOTBOT_BIN}" -d "${BASEDIR}" -c "${CONFIG}" "${@}"

120
install-linux.sh Normal file
View File

@ -0,0 +1,120 @@
#! /bin/sh
set -e
export EWCONFIG_ROOT=$(dirname $(readlink -f $0))
# -- Ensure that deps exist --
# Pull git submodules if needed
if type -p git > /dev/null; then
echo "Syncing git submodules..."
git submodule update --init --recursive
fi
# Make sure scripts are all executable
chmod +x $EWCONFIG_ROOT/configs/scripts/*
chmod +x $EWCONFIG_ROOT/configs/nautilus/scripts/*
# -- Directory Setup --
set -x
# Ensure that needed directories exist
mkdir -p ~/Downloads # For downloads
mkdir -p ~/bin # Personal bin dir. Reduces the risk of breaking ~/.local/bin
mkdir -p ~/projects # For my projects
mkdir -p ~/src # For compiling other people's projects
mkdir -p ~/services # Service dir for servers mostly
# Build the directory structure if ~/.config
mkdir -p ~/.config/nvim
mkdir -p ~/.config/termux
mkdir -p ~/.config/logid
mkdir -p ~/.config/systemd/user
mkdir -p ~/.config/git
mkdir -p ~/.config/git/config-fragments
mkdir -p ~/.config/user-tmpfiles.d
mkdir -p ~/.cargo
mkdir -p ~/.ssh
# Build directory structure for program plugins
mkdir -p ~/.local/share/nautilus/scripts/
# -- Config Linking --
# Configure the shell
ln -sf $EWCONFIG_ROOT/configs/shells/zsh/.zshrc ~/.zshrc
ln -sf $EWCONFIG_ROOT/configs/shells/bash/.bashrc ~/.bashrc
# Configure Git
ln -sf $EWCONFIG_ROOT/configs/git/.gitconfig ~/.gitconfig
ln -sf $EWCONFIG_ROOT/configs/sssh/allowed_signers ~/.ssh/allowed_signers
ln -sf $EWCONFIG_ROOT/configs/git/.mailmap ~/.config/git/.mailmap
# Check if GIT is installed > 2.34
set +x
if type -p git > /dev/null; then
# If GIT has SSH signing support, enable it
git_version=$(git --version | cut -d' ' -f3 | cut -d'.' -f1-2)
minimum_version=2.34
if [ "$(printf '%s\n' "$minimum_version" "$git_version" | sort -V | head -n1)" = "$minimum_version" ]; then
set -x
ln -sf $EWCONFIG_ROOT/configs/git/config-fragments/enable-signing.gitconfig ~/.config/git/config-fragments/enable-signing.gitconfig
fi
fi
# Configure SSH
ln -sf $EWCONFIG_ROOT/configs/ssh/config ~/.ssh/config
chmod 644 "$HOME/.ssh/config"
chown "$USER:$USER" "$HOME/.ssh/config"
# Configure (neo)Vim
ln -sf $EWCONFIG_ROOT/configs/nvim/init.vim ~/.config/nvim/init.vim
ln -sf $EWCONFIG_ROOT/configs/nvim/pack ~/.config/nvim/pack
ln -sf $EWCONFIG_ROOT/configs/nvim/third_party ~/.config/nvim/third_party
# Nautilus right-click scripts
ln -sf $EWCONFIG_ROOT/configs/nautilus/scripts/* ~/.local/share/nautilus/scripts/
# Tabset configs
ln -sf $EWCONFIG_ROOT/configs/tabset/ ~/.config/tabset
# Rofi configs
ln -sf $EWCONFIG_ROOT/configs/rofi/ ~/.config/rofi
# Cargo
ln -sf $EWCONFIG_ROOT/configs/cargo/config.toml ~/.cargo/config.toml
# Termux
ln -sf $EWCONFIG_ROOT/configs/termux/termux.properties ~/.config/termux/termux.properties
# Set up user-tempfiles configs
ln -sf $EWCONFIG_ROOT/configs/user-tmpfiles.d/* ~/.config/user-tmpfiles.d/
# Logid config
ln -sf $EWCONFIG_ROOT/configs/logid/logid.cfg ~/.config/logid/logid.cfg
# -- Optional Configs --
set +x
# If ~/.config/git/config-fragments/personal-info.gitconfig does not exist
if [ ! -f ~/.config/git/config-fragments/personal-info.gitconfig ]; then
# Ask if the user wants to install personal GIT config
echo "Do you want to install the personal GIT config? (y/n)"
read -r install_git_config
if [ "$install_git_config" = "y" ]; then
ln -sf $EWCONFIG_ROOT/configs/git/config-fragments/personal-info.gitconfig ~/.config/git/config-fragments/personal-info.gitconfig
fi
fi
# Link houdini scripts for appropriate versions
if [ -d ~/houdini19.5 ]; then mkdir -p ~/houdini19.5/scripts; ln -sf $EWCONFIG_ROOT/configs/houdini19.5/scripts/* ~/houdini19.5/scripts; fi
# Link blender scripts for appropriate versions
if [ -d ~/.config/blender/3.6 ]; then ln -sf $EWCONFIG_ROOT/configs/blender/3.x/scripts/addons/* ~/.config/blender/3.6/scripts/addons/; fi
# -- Finalization --
# On systems that need it, configure Gnome
sh ./helpers/configure-gnome.sh
# Attempt to force a termux settings reload on Android devices
termux-reload-settings || true

40
install-windows.sh Normal file
View File

@ -0,0 +1,40 @@
#! /bin/sh
set -e
export EWCONFIG_ROOT=$(dirname $(readlink -f $0))
# Pull git submodules if needed
echo "Syncing git submodules..."
git submodule update --init --recursive
# Make sure scripts are all executable
chmod +x $EWCONFIG_ROOT/configs/scripts/*
chmod +x $EWCONFIG_ROOT/configs/nautilus/scripts/*
# -- Directory Setup --
set -x
# Ensure that needed directories exist
mkdir -p ~/bin # Personal bin dir. Reduces the risk of breaking ~/.local/bin
mkdir -p ~/projects # For my projects
# Build the directory structure if ~/.config
mkdir -p ~/.config/git
mkdir -p ~/.config/git/config-fragments
mkdir -p ~/.cargo
mkdir -p ~/.ssh
# -- Config Linking --
# Configure the shell
ln -sf $EWCONFIG_ROOT/configs/shells/zsh/.zshrc ~/.zshrc
ln -sf $EWCONFIG_ROOT/configs/shells/bash/.bashrc ~/.bashrc
# Configure Git
ln -sf $EWCONFIG_ROOT/configs/git/.gitconfig ~/.gitconfig
ln -sf $EWCONFIG_ROOT/configs/sssh/allowed_signers ~/.ssh/allowed_signers
ln -sf $EWCONFIG_ROOT/configs/git/.mailmap ~/.config/git/.mailmap
# Configure SSH
ln -sf $EWCONFIG_ROOT/configs/ssh/config ~/.ssh/config
chmod 644 "$HOME/.ssh/config"
chown "$USER:$USER" "$HOME/.ssh/config"