1
0
Fork 0

set up bare repo dotfile management (untested)

This commit is contained in:
Luca Bilke 2024-05-23 18:26:13 +02:00
parent f0ccabc626
commit 85f394fd24
3 changed files with 92 additions and 28 deletions

View File

@ -46,14 +46,11 @@ cmd trash-restore ${{
cmd lazygit %{{ cmd lazygit %{{
dir=$(dirname "$(realpath "${f:-_}")"}) dir=$(dirname "$(realpath "${f:-_}")"})
if ! git --noglob-pathspecs -C $dir status >/dev/null 2>&1; then if git --noglob-pathspecs -C $dir status >/dev/null 2>&1; then
echo "Initialize git repo in '${dir}' [Y/n]:" && read yn && lf -remote "send $id \$cd '$dir' && lazygit"
case $yn in else
"" | [Yy]*) git -C ${dir} init >/dev/null 2>&1; break ;; lazygit --git-dir "$XDG_DATA_HOME/dots" --work-tree "$HOME"
[Nn]*) ;;
esac
fi fi
lf -remote "send $id \$cd '$dir' && lazygit"
}} }}
cmd link &{{ cmd link &{{

View File

@ -53,8 +53,11 @@ zle -N edit-command-line
# Lazygit # Lazygit
function lg() { function lg() {
[ ! -d "$(pwd)/.git" ] && [[ $(read -erk "?Not in a git repository. Create a new git repository? (y/n): ") =~ ^[Yy]$ ]] && git init if git --noglob-pathspecs -C $dir status >/dev/null 2>&1; then
[ -d "$(pwd)/.git" ] && lazygit -p "$(pwd)" lf -remote "send $id \$cd '$dir' && lazygit"
return
fi
lazygit --git-dir "$XDG_DATA_HOME/dots" --work-tree "$HOME"
zle reset-prompt zle reset-prompt
} }
zle -N lg zle -N lg

View File

@ -6,42 +6,106 @@ GREEN="$(tput setaf 2)"
BLUE="$(tput setaf 4)" BLUE="$(tput setaf 4)"
NC="$(tput sgr0)" NC="$(tput sgr0)"
dgit() { target=$HOME
git -C "$STOW_DIR/$DOTS_PACKAGE" "$@" gitdir=$target/.local/share/dots
mkdir -p "$(dirname "$gitdir")"
baregit() {
git --git-dir="$gitdir" --work-tree="$target" "$@"
} }
printf "%b" "${BOLD}${BLUE}Removing dotfile symlinks...$NC\n\n" [ -e "$gitdir" ] || {
stow -D -d "$STOW_DIR" -t "$HOME" "$DOTS_PACKAGE" || printf "%b" "${RED}Failed to run stow!$NC\n" printf "%b" "${BOLD}${BLUE}Cloning dotfiles...$NC\n"
git clone --bare git@git.snaile.de:luca/dotfiles "$gitdir"
baregit checkout
baregit config status.showUntrackedFiles no
cd "$target" || exit
for f in *; do
[ "$f" = ".config" ] || [ "$f" = ".local" ] && {
echo "$f" >>"$gitdir/info/exclude"
rm -rf "$f"
}
done
cd - || exit
echo ".local/share/dots" >>"$gitdir/info/exclude"
}
printf "%b" "${BOLD}${BLUE}Stashing existing changes...$NC\n" printf "%b" "${BOLD}${BLUE}Stashing existing changes...$NC\n"
stash_result=$(dgit stash push) stash_result=$(baregit stash push)
needs_pop=1 needs_pop=1
if [ "$stash_result" = "No local changes to save" ]; then if [ "$stash_result" = "No local changes to save" ]; then
needs_pop=0 needs_pop=0
fi fi
printf "\n" printf "\n"
printf "%b" "${BOLD}${BLUE}Pulling updates from dotfiles repo...$NC\n" printf "%b" "${BOLD}${BLUE}Pulling updates from dotfiles repo...$NC\n"
old_commit="$(dgit rev-parse HEAD)" old_commit="$(baregit rev-parse HEAD)"
dgit pull origin main baregit pull origin main
dgit submodule update --remote --merge baregit submodule update --remote --merge
printf "\n" printf "\n"
if [ $needs_pop -eq 1 ]; then if [ $needs_pop -eq 1 ]; then
printf "%b" "${BOLD}${BLUE}Popping stashed changes...$NC\n" printf "%b" "${BOLD}${BLUE}Popping stashed changes...$NC\n"
dgit stash pop baregit stash pop
fi fi
printf "\n" printf "\n"
unmerged_files=$(dgit diff --name-only --diff-filter=U) unmerged_files=$(baregit diff --name-only --diff-filter=U)
if [ -n "$unmerged_files" ]; then if [ -n "$unmerged_files" ]; then
printf "%b" "${RED}The following files have merge conflicts after popping the stash:$NC\n\n" printf "%b" "${RED}The following files have merge conflicts after popping the stash:$NC\n\n"
printf "%s" "$unmerged_files\n\n" printf "%s" "$unmerged_files\n\n"
printf "%s" "${BOLD}${BLUE}Reverting to previous commit...$NC" printf "%s" "${BOLD}${BLUE}Reverting to previous commit...$NC"
dgit checkout "$old_commit" baregit checkout "$old_commit"
fi fi
printf "%b" "${BOLD}${BLUE}Symlinking dotfiles...$NC\n\n"
stow -d "$STOW_DIR" -t "$HOME" "$DOTS_PACKAGE" || printf "%b" "${RED}Failed to run stow!$NC\n"
printf "%b" "${BOLD}${GREEN}Dotfiles synced successfully!$NC\n" printf "%b" "${BOLD}${GREEN}Dotfiles synced successfully!$NC\n"
# BOLD="$(tput bold)"
# RED="$(tput setaf 1)"
# GREEN="$(tput setaf 2)"
# BLUE="$(tput setaf 4)"
# NC="$(tput sgr0)"
#
# dgit() {
# git -C "$STOW_DIR/$DOTS_PACKAGE" "$@"
# }
#
# printf "%b" "${BOLD}${BLUE}Removing dotfile symlinks...$NC\n\n"
# stow -D -d "$STOW_DIR" -t "$HOME" "$DOTS_PACKAGE" || printf "%b" "${RED}Failed to run stow!$NC\n"
#
# printf "%b" "${BOLD}${BLUE}Stashing existing changes...$NC\n"
# stash_result=$(dgit stash push)
# needs_pop=1
# if [ "$stash_result" = "No local changes to save" ]; then
# needs_pop=0
# fi
# printf "\n"
#
# printf "%b" "${BOLD}${BLUE}Pulling updates from dotfiles repo...$NC\n"
# old_commit="$(dgit rev-parse HEAD)"
# dgit pull origin main
# dgit submodule update --remote --merge
# printf "\n"
#
# if [ $needs_pop -eq 1 ]; then
# printf "%b" "${BOLD}${BLUE}Popping stashed changes...$NC\n"
# dgit stash pop
# fi
# printf "\n"
#
# unmerged_files=$(dgit diff --name-only --diff-filter=U)
# if [ -n "$unmerged_files" ]; then
# printf "%b" "${RED}The following files have merge conflicts after popping the stash:$NC\n\n"
# printf "%s" "$unmerged_files\n\n"
# printf "%s" "${BOLD}${BLUE}Reverting to previous commit...$NC"
# dgit checkout "$old_commit"
# fi
#
# printf "%b" "${BOLD}${BLUE}Symlinking dotfiles...$NC\n\n"
# stow -d "$STOW_DIR" -t "$HOME" "$DOTS_PACKAGE" || printf "%b" "${RED}Failed to run stow!$NC\n"
#
# printf "%b" "${BOLD}${GREEN}Dotfiles synced successfully!$NC\n"