# Clone ~/.emacs.d/ if it doesn't exist, fast-forward pull EMACS_DIR="$HOME/.emacs.d/" if [ ! -d "$EMACS_DIR" ]; then git clone "https://git.xenia.me.uk/pixelifytica/emacs.git" "$EMACS_DIR" fi git -C "$EMACS_DIR" pull --ff --ff-only # Sync common directories, setting url to ensure it's up-to-date first SYNC_DIRS=( "$HOME/.password-store/" "$HOME/Documents/org/" "$HOME/Documents/library/" "$HOME/Documents/notebooks/" "$HOME/Documents/presentations/" ) SYNC_URLS=( "https://git.xenia.me.uk/pixelifytica/pass.git" "https://git.xenia.me.uk/pixelifytica/org.git" "https://git.xenia.me.uk/pixelifytica/library.git" "git@git.ccfe.ac.uk:elitherl/notebooks.git" "git@git.ccfe.ac.uk:elitherl/presentations.git" ) for i in "${!SYNC_DIRS[@]}"; do DIRECTORY="${SYNC_DIRS[$i]}" URL="${SYNC_URLS[$i]}" echo "--- sync: $DIRECTORY ---" if [ ! -d "$DIRECTORY" ]; then git clone "$URL" "$DIRECTORY" fi ( cd "$DIRECTORY" || exit git remote set-url origin "$URL" if [ "$(git branch --show-current)" = "main" ]; then git branch --set-upstream-to=origin/main main fi git pull --ff --ff-only git submodule update --remote --recursive git-sync -ns git status --porcelain ) done