# Push current commits to all remotes and fetch from all remotes. Then display
# unmerged commits and changes in the repositories.
#
+# If --local is given as option, no fetching/pushing is performed.
+#
# If an argument is given cd to this directory before running the commands.
#
# Very useful to sync multiple remotes.
+LOCAL=
+if [ x$1 = x--local ];then
+ LOCAL=1
+ shift
+fi
+
if [ x$1 != x ]; then
echo $1
cd "$1"
fi
-# Get all remote changes.
-git remote update 2>&1 | grep -v Fetching
-# Push all local changes to remote(s).
-for remote in `git remote`; do
- git push $remote 2>&1 | grep -v 'Everything up-to-date'
-done
+if [ x$LOCAL = x ]; then
+ # Get all remote changes.
+ git remote update 2>&1 | grep -v Fetching
+ # Push all local changes to remote(s).
+ for remote in `git remote`; do
+ git push $remote 2>&1 | grep -v 'Everything up-to-date'
+ done
+fi
# Show unmerged changes.
git branch -rv --color --no-merged
# Show uncommitted changes.