Uwe K, what do you think. Is there still much to change to include this patch into upstream? new patch version. adding small comment saying that the two options --ne-deps and --tgish-only will seldomly used.. Sincerly Marc Weber commit c1cff518e3f70e9bd6cb4f2119b86e506ab43776 Author: Marc Weber <marco-oweber@xxxxxx> Date: Thu May 7 06:46:28 2009 +0200 t/tg-push add tg-push pushing the branch, its deps and their bases Usage: tg push [(--no-deps | --tgish-only)] remote* Signed-off-by: Marc Weber <marco-oweber@xxxxxx> diff --git a/README b/README index d2f095d..6f2b2bc 100644 --- a/README +++ b/README @@ -480,6 +480,19 @@ tg update TODO: tg update -a for updating all topic branches +tg push + Usage: tg push [(--no-deps | --tgish-only)] remote* + + $git push remote branch # this doesn't push the base. + $git push remote # pushes all branches (and bases) + You use + + $tg push remote + to push the current branch, its deps and their both tgish + and non-tgish deps. You may add --no-deps and or --tgish-only + to change this default behaviour. Probably youn never want + to do this + TODO: tg rename diff --git a/tg-push.sh b/tg-push.sh new file mode 100644 index 0000000..49124e6 --- /dev/null +++ b/tg-push.sh @@ -0,0 +1,69 @@ +#!/bin/sh +# TopGit - A different patch queue manager +# GPLv2 + +remotes= + +## Parse options see README + +recurse_deps=1 +tgish_deps_only= + +while [ -n "$1" ]; do + arg="$1"; shift + case "$arg" in + --no-deps) + recurse_deps=;; + --dry-run) + dry_run=1;; + --tgish-only) + tgish_deps_only=1;; + *) + remotes="$remotes $arg";; + esac +done + +if [ -z "$remotes" ]; then + remotes="$(git config topgit.remote 2>/dev/null)" +fi + +if [ -z "$remotes" ]; then + die "no remote location given. Either add a remote as additional argument or set topgit.remote" +fi + +name="$(git symbolic-ref HEAD | sed 's#^refs/heads/##')" +ref_exists "$name" || die "detached HEAD? Can't push that" + +push_branch(){ + # don't push remotes + [ -z "${_dep##refs/remotes/*}" ] && return 0 + # if so desired omit non tgish deps + [ -z "$tgish_deps_only" ] || [ -n "$_dep_is_tgish" ] || return 0 + + echo "$_dep" + local base="top-bases/$_dep" + if ref_exists "$base"; then + echo "top-bases/$_dep" + else + echo "warning, no base found $base" 1>&2 + fi +} + +for remote in $remotes; do + list="$( + # deps + if [ -n "$recurse_deps" ]; then + recurse_deps push_branch "$name" + fi + # current branch + _dep="$name" + _dep_is_tgish=1 + push_branch "$name" + )" + echo "pushing:"; echo $list + if [ -n "$dry_run" ]; then + echo git push $remote $list + else + git push $remote $list + fi +done -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html