1
0
Fork 0
dotfiles/.local/bin/dotsync

50 lines
1.2 KiB
Text
Raw Normal View History

2023-03-28 14:24:58 +02:00
#!/bin/sh
GREEN='\033[1;32m'
BLUE='\033[1;34m'
RED='\033[1;30m'
NC='\033[0m'
2023-03-28 19:13:13 +02:00
dotfiles="${1:-$HOME/.dotfiles}"
2023-03-28 14:24:58 +02:00
2023-03-28 19:16:12 +02:00
echo "${BLUE}Changing directory to $dotfiles${NC}"
2023-03-28 19:13:13 +02:00
if ! cd "$dotfiles"; then
2023-03-28 19:16:12 +02:00
echo "${RED}Could not CD into $dotfiles${NC}"
exit
2023-03-28 19:13:13 +02:00
fi
echo
2023-03-28 14:24:58 +02:00
echo "${BLUE}Stashing existing changes...${NC}"
2023-03-28 14:24:58 +02:00
stash_result=$(git stash push -m "sync-dotfiles: Before syncing dotfiles")
needs_pop=1
if [ "$stash_result" = "No local changes to save" ]; then
2023-03-28 19:16:12 +02:00
needs_pop=0
2023-03-28 14:24:58 +02:00
fi
2023-03-28 19:13:13 +02:00
echo
2023-03-28 14:24:58 +02:00
echo "${BLUE}Pulling updates from dotfiles repo...${NC}"
2023-03-28 14:24:58 +02:00
git pull origin main
2023-03-28 20:58:23 +02:00
git submodule update --remote --recursive --init
2023-03-28 14:24:58 +02:00
echo
if [ $needs_pop -eq 1 ]; then
2023-03-28 19:16:12 +02:00
echo "${BLUE}Popping stashed changes...${NC}"
git stash pop
2023-03-28 14:24:58 +02:00
fi
2023-03-28 19:13:13 +02:00
echo
2023-03-28 14:24:58 +02:00
unmerged_files=$(git diff --name-only --diff-filter=U)
if [ -n "$unmerged_files" ]; then
2023-03-28 19:16:12 +02:00
echo "${RED}The following files have merge conflicts after popping the stash:${NC}"
echo
printf %"s\n" "$unmerged_files"
2023-03-28 14:24:58 +02:00
else
2023-03-28 22:11:54 +02:00
stow -t "$HOME" . || echo "${RED}Stow uninstalled or not in path!${NC}"
2023-03-28 14:24:58 +02:00
fi
2023-03-28 19:13:13 +02:00
echo "${BLUE}Generating librewolf profiles...${NC}"
2023-03-28 19:16:12 +02:00
envsubst <.librewolf/installs.template >$HOME/.librewolf/installs.ini
envsubst <.librewolf/profiles.template >$HOME/.librewolf/profiles.ini
2023-03-28 19:13:13 +02:00
echo
echo "${GREEN}Dotfiles Synced Successfully!${NC}"