소스 검색

Add update.sh, a wip

andryyy 8 년 전
부모
커밋
a9fc66b956
1개의 변경된 파일29개의 추가작업 그리고 0개의 파일을 삭제
  1. 29 0
      update.sh

+ 29 - 0
update.sh

@@ -0,0 +1,29 @@
+#!/bin/bash
+
+set -o pipefail
+export LC_ALL=C
+DATE=$(date)
+BRANCH=$(git rev-parse --abbrev-ref HEAD)
+
+# Silently fixing remote url from andryyy to mailcow
+git remote set-url origin https://github.com/mailcow/mailcow-dockerized
+echo -e "\e[32mCommitting current status...\e[90m"
+git add -u
+git commit -am "Before update on ${DATE}" > /dev/null
+echo -e "\e[32mFetching updated code from remote...\e[90m"
+git fetch origin ${BRANCH}
+echo -e "\e[32mMerging local with remote code...\e[90m"
+git merge -Xtheirs -Xpatience -m "After update on ${DATE}"
+
+if [[ $? == 1 ]]; then
+  echo -e "\e[31mRun into conflict, trying to fix...\e[90m"
+  git status --porcelain | grep -E "UD|DU" | awk '{print $2}' | xargs rm -v
+  git add -A
+  git commit -m "After update on ${DATE}" > /dev/null
+  git checkout .
+  echo -e "\e[32mRemoved and recreated files if necessary.\e[90m"
+fi
+echo -e "\e[32mDone!\e[0m"
+
+# TODO: Menu, select hard reset etc.
+#git reset --hard origin/${BRANCH}