summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSlávek Banko <slavek.banko@axis.cz>2012-12-04 03:44:32 +0100
committerSlávek Banko <slavek.banko@axis.cz>2012-12-04 03:44:32 +0100
commit95dd4739aa62188f6ffbfdf80b6537357559a7ec (patch)
treefa3730e7ea8f71643e57b69fcb488bb32921a57c
parent5ead2a2d3b029dbdc616c282d7aa6b6fc7ea7907 (diff)
downloadscripts-95dd4739aa62188f6ffbfdf80b6537357559a7ec.tar.gz
scripts-95dd4739aa62188f6ffbfdf80b6537357559a7ec.zip
Updating git scripts
+ add support for gitfile (submodules with git >= 1.7.8) + add gituser detection from git configuration + add support for branches + various optimizations
-rwxr-xr-xcommit_all_submodules28
-rwxr-xr-xswitch_all_submodules_to_head_and_clean32
-rwxr-xr-xupdate_all_submodules57
3 files changed, 81 insertions, 36 deletions
diff --git a/commit_all_submodules b/commit_all_submodules
index 2ade46f..c754640 100755
--- a/commit_all_submodules
+++ b/commit_all_submodules
@@ -1,26 +1,40 @@
#!/bin/bash
-if [[ ! -d .git ]]; then
+if [[ ! -e .git ]] ||
+ [[ -z "`git rev-parse --git-dir 2>/dev/null`" ]]; then
echo "This script can only be run from a top level git directory. Exiting..."
exit 1
fi
+branch=`git symbolic-ref -q HEAD | sed "s|^refs/heads/||"`
+if [[ -z "$branch" ]] ||
+ [[ -z "`git rev-parse --symbolic-full-name --remotes=\"*/$branch\"`" ]]; then
+ echo "There is not active upstream branch. Exiting..."
+ exit 1
+fi
+
echo "Preparing $PWD for development use"
if [[ $1 == "" ]]; then
- read -p "Enter your TDE GIT username []: " -e gituser
+ gituser=`sed -n "/^\[remote \"origin\"\]/,/url/s/\turl = http:\/\/\([^@]*\)@.*/\1/p" <\`git rev-parse --git-dir\`/config | grep -v "\(anonymous\|system\)"`
else
gituser=$1
fi
if [[ $gituser == "" ]]; then
+ read -p "Enter your TDE GIT username []: " -e gituser
+fi
+
+if [[ $gituser == "" ]]; then
gituser="anonymous"
fi
read -p "Enter your commit message []: " -e commitmessage
git submodule foreach "git commit -a -m \"$commitmessage\" || true"
-git submodule foreach "sed -i \"s/system@scm\.trinitydesktop\.org/$gituser@scm\.trinitydesktop\.org/g\" .git/config"
-git submodule foreach "git pull && git push origin master"
+git submodule foreach "sed -i \"s/system@scm\.trinitydesktop\.org/$gituser@scm\.trinitydesktop\.org/g\" \`git rev-parse --git-dir\`/config"
+git submodule foreach "git pull &&\
+ [[ \"\`git rev-parse HEAD\`\" == \"\`git rev-parse origin/$branch\`\" ]] ||\
+ git push origin HEAD"
RETCODE=$?
if [[ $RETCODE != 0 ]]; then
echo "Something went wrong"
@@ -28,5 +42,7 @@ if [[ $RETCODE != 0 ]]; then
fi
git commit -a -m "$commitmessage" || true
-sed -i "s/system@scm\.trinitydesktop\.org/$gituser@scm\.trinitydesktop\.org/g" .git/config
-git pull && git push origin master || true
+sed -i "s/system@scm\.trinitydesktop\.org/$gituser@scm\.trinitydesktop\.org/g" `git rev-parse --git-dir`/config
+git pull &&\
+ [[ "`git rev-parse HEAD`" == "`git rev-parse origin/$branch`" ]] ||\
+ git push origin HEAD || true
diff --git a/switch_all_submodules_to_head_and_clean b/switch_all_submodules_to_head_and_clean
index c395e62..0171537 100755
--- a/switch_all_submodules_to_head_and_clean
+++ b/switch_all_submodules_to_head_and_clean
@@ -1,18 +1,30 @@
#!/bin/bash
-if [[ ! -d .git ]]; then
+if [[ ! -e .git ]] ||
+ [[ -z "`git rev-parse --git-dir 2>/dev/null`" ]]; then
echo "This script can only be run from a top level git directory. Exiting..."
exit 1
fi
+branch=`git symbolic-ref -q HEAD | sed "s|^refs/heads/||"`
+if [[ -z "$branch" ]] ||
+ [[ -z "`git rev-parse --symbolic-full-name --remotes=\"*/$branch\"`" ]]; then
+ echo "There is not active upstream branch. Exiting..."
+ exit 1
+fi
+
echo "Preparing $PWD for development use"
if [[ $1 == "" ]]; then
- read -p "Enter your TDE GIT username []: " -e gituser
+ gituser=`sed -n "/^\[remote \"origin\"\]/,/url/s/\turl = http:\/\/\([^@]*\)@.*/\1/p" <\`git rev-parse --git-dir\`/config | grep -v "\(anonymous\|system\)"`
else
gituser=$1
fi
if [[ $gituser == "" ]]; then
+ read -p "Enter your TDE GIT username []: " -e gituser
+fi
+
+if [[ $gituser == "" ]]; then
gituser="anonymous"
fi
@@ -23,11 +35,15 @@ if [[ ! -e "$THISSCRIPT" ]]; then
exit 1
fi
-git reset --hard HEAD
-git clean -dxf
+if [[ ! -z "`git status --porcelain --ignore-submodules`" ]]; then
+ git reset --hard HEAD
+ git clean -dxff
+fi
git pull
-git reset --hard HEAD
-git clean -dxf
+if [[ ! -z "`git status --porcelain --ignore-submodules`" ]]; then
+ git reset --hard HEAD
+ git clean -dxff
+fi
if [[ -e .gitmodules ]]; then
if [[ $gituser == "anonymous" ]]; then
@@ -38,9 +54,7 @@ if [[ -e .gitmodules ]]; then
git submodule init
git submodule update
- git submodule foreach "git checkout master"
- git submodule foreach "git pull"
- git submodule foreach "$THISSCRIPT $gituser"
+ git submodule foreach "git checkout $branch && $THISSCRIPT $gituser"
git checkout -- .gitmodules
fi
diff --git a/update_all_submodules b/update_all_submodules
index d0bf837..8e6668f 100755
--- a/update_all_submodules
+++ b/update_all_submodules
@@ -6,17 +6,28 @@ if [[ -e /var/lock/update-tde-git-submodules ]]; then
exit 0
fi
+if [[ ! -e .git ]] ||
+ [[ -z "`git rev-parse --git-dir 2>/dev/null`" ]]; then
+ echo "Current directory does not contain a .git folder. Exiting..."
+ exit 1
+fi
+
+branch=`git symbolic-ref -q HEAD | sed "s|^refs/heads/||"`
+if [[ -z "$branch" ]] ||
+ [[ -z "`git rev-parse --symbolic-full-name --remotes=\"*/$branch\"`" ]]; then
+ echo "There is not active upstream branch. Exiting..."
+ exit 1
+fi
+
touch /var/lock/update-tde-git-submodules
PARENTDIR=$PWD
echo "Working in $PARENTDIR"
-if [[ ! -d .git ]]; then
- echo "Current directory does not contain a .git folder. Exiting..."
- exit 1
-fi
git pull
-git reset --hard HEAD
-git clean -d -x -f
+if [[ ! -z "`git status --porcelain --ignore-submodules`" ]]; then
+ git reset --hard HEAD
+ git clean -dxff
+fi
exec 3< submodules
while read <&3
@@ -26,25 +37,29 @@ do
if [[ $DIR2UPDATE != "" ]]; then
echo "Attempting to reset submodule $DIR2UPDATE"
cd $PARENTDIR/$DIR2UPDATE/..
- while [[ ! -d .git ]]; do
- cd ../
- done
- git submodule init
- git submodule update
+ cd `git rev-parse --show-toplevel`
+ if [[ -z "`grep \"^Updated: $PWD$\" /var/lock/update-tde-git-submodules`" ]]; then
+ echo "Updated: $PWD" >>/var/lock/update-tde-git-submodules
+ git submodule init
+ git submodule update
+ fi
cd $PARENTDIR/$DIR2UPDATE
- git reset --hard HEAD
- git clean -d -x -f
- git checkout master
+ if [[ ! -z "`git status --porcelain --ignore-submodules`" ]]; then
+ git reset --hard HEAD
+ git clean -dxff
+ fi
+ git checkout $branch
git pull
cd ..
- while [[ ! -d .git ]]; do
- cd ../
- done
+ cd `git rev-parse --show-toplevel`
echo "Committing changes to $PWD"
-# git commit -a -m "Reset submodule to latest HEAD"
- git add $PARENTDIR/$DIR2UPDATE
- git commit $PARENTDIR/$DIR2UPDATE -m "Reset submodule $DIR2UPDATE to latest HEAD"
- git push origin master
+ if [[ ! -z "`git status --porcelain $PARENTDIR/$DIR2UPDATE`" ]]; then
+ git add $PARENTDIR/$DIR2UPDATE
+ git commit $PARENTDIR/$DIR2UPDATE -m "Reset submodule $DIR2UPDATE to latest HEAD"
+ fi
+ if [[ "`git rev-parse HEAD`" != "`git rev-parse origin/$branch`" ]]; then
+ git push origin HEAD
+ fi
fi
done
exec 3>&-