On Thu, May 7, 2009 at 06:59, Marc Weber <marco-oweber@gmx.de> wrote:
quoted text > Uwe K,
>
> what do you think. Is there still much to change to include this patch into
> upstream?
I think its a usefull tool, but I haven't tested it yet.
quoted text >
> 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@gmx.de>
> 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@gmx.de>
>
> 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*
no need to repeat yourself. 'tg help push' will print the usage from
tg-push first. And where is the --dry-run option?
quoted text > +
> + $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.
This phrase needs rewording, what about: "its deps, both their tgish
and non-tgish ones."
quoted text > You may add --no-deps and or --tgish-only
> + to change this default behaviour. Probably youn never want
> + to do this
I think a "use these only if you know what you are doing" is better.
quoted text > +
> 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 "" ]; do
> + arg=""; shift
> + case "$arg" in
> + --no-deps)
> + recurse_deps=;;
> + --dry-run)
> + dry_run=1;;
> + --tgish-only)
> + tgish_deps_only=1;;
> + *)
> + remotes="$remotes $arg";;
> + esac
> +done
now i see why you have the Usage: in the README. common practice is to
print the usage if an unknown option was given. see all the other
tg-*.sh scripts.
quoted text > +
> +if [ -z "$remotes" ]; then
> + remotes="$(git config topgit.remote 2>/dev/null)"
> +fi
How effetcts the tg -r REMOTE option this command. Or more exactly why
doesn't have this option an effect here?
quoted text > +
> +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"
the common error message is: "not a TopGit-controlled branch".
quoted text > +
> +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
why not pass the --dry-run option to git remote?
quoted text > +done
Bert
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html