* [PATCH] git-submodule.sh: Add Long Usage instead of simple usage @ 2008-05-05 8:44 imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add recurse subcommand with basic options imyousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add Long Usage instead of simple usage Imran M Yousuf 0 siblings, 2 replies; 10+ messages in thread From: imyousuf @ 2008-05-05 8:44 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf From: Imran M Yousuf <imyousuf@smartitengineering.com> With the already available commands the synopsis is quite hard to read; thus converted it to Long usage instead. In process also updated the file comment. Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> --- git-submodule.sh | 13 +++++++++---- 1 files changed, 9 insertions(+), 4 deletions(-) diff --git a/git-submodule.sh b/git-submodule.sh index ce0f00c..a5ee2e5 100755 --- a/git-submodule.sh +++ b/git-submodule.sh @@ -1,12 +1,17 @@ #!/bin/sh # -# git-submodules.sh: add, init, update or list git submodules +# git-submodules.sh: add, init, update, summary or status git submodules # # Copyright (c) 2007 Lars Hjemli -USAGE="[--quiet] [--cached] \ -[add <repo> [-b branch]|status|init|update|summary [-n|--summary-limit <n>] [<commit>]] \ -[--] [<path>...]" +USAGE="<command> <options> +Use $0 -h for more details" +# Did not use '\' at the end of the lines to ensure that each synopsis +# are in a separate line +LONG_USAGE="$0 add [-q|--quiet] [-b|--branch branch] <repository> [<path>] +$0 [status] [-q|--quiet] [-c|--cached] [--] [<path>...] +$0 init|update [-q|--quiet] [--] [<path>...] +$0 summary [--cached] [-n|--summary-limit <n>] [<commit>]" OPTIONS_SPEC= . git-sh-setup require_work_tree -- 1.5.4.2 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* [PATCH] git-submodule.sh: Add recurse subcommand with basic options 2008-05-05 8:44 [PATCH] git-submodule.sh: Add Long Usage instead of simple usage imyousuf @ 2008-05-05 8:44 ` imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add Custom argument input support to git submodule recurse subcommand imyousuf 2008-05-05 9:08 ` [PATCH] git-submodule.sh: Add recurse subcommand with basic options Imran M Yousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add Long Usage instead of simple usage Imran M Yousuf 1 sibling, 2 replies; 10+ messages in thread From: imyousuf @ 2008-05-05 8:44 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf From: Imran M Yousuf <imyousuf@smartitengineering.com> The purpose of the recurse command in the git submodule is to recurse a command in its submodule. For example if one wants to do a diff on its project with submodules at once, one can simply do git-submodule recurse diff HEAD and would see the diff for all the modules it contains. The recurse commands behavior can be customized with several arguments that it accepts. The synopsis for the recurse command is: git-submodule recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] <git command> [<arguments> ...] There are commands that can fail for a certain submodule but succeed for others; if one wants to stop execution once the top level module's execution fails, one can specify [-e|--exit-after-error]. It will ensure that once execution of git <command> fails in the top level module it will not recurse into its submodules. If the project has submodule hierarchy upto n depth and we want to restrict recursion to (n-p) depth; we can use the [-d|--depth <recursion depth>] option. Value has to be greater than 0 and command will at least recurse into the first depth. If depth is specified to p than all depths <= p will be recursed over. While discussion on the recurse command one thing which was put forward in several occassions is that there might be scenario where a command should be executed over the child module before the parent module. For such scenario [-b|--breadth-first] option can be used; one use case in particular presented as an example is git commit; where almost everybody mentioned that they prefer to commit the child module before the parent and default will enable just that. E.g. p -> a, b, c, e; a ->d is a module structure. If the following command is used, git submodule recurse commit -a it will execute git commit -a in the following sequence - d, a, b, c, e, p. Now if one want to instead go in a breadth first manner then one can specify -b option. E.g. if the above command is - git submodule recurse -b commit -a it will execute git commit -a in the following sequence - p, a, d, b, c, e. Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> --- git-submodule.sh | 132 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 130 insertions(+), 2 deletions(-) diff --git a/git-submodule.sh b/git-submodule.sh index a5ee2e5..8161d51 100755 --- a/git-submodule.sh +++ b/git-submodule.sh @@ -11,7 +11,8 @@ Use $0 -h for more details" LONG_USAGE="$0 add [-q|--quiet] [-b|--branch branch] <repository> [<path>] $0 [status] [-q|--quiet] [-c|--cached] [--] [<path>...] $0 init|update [-q|--quiet] [--] [<path>...] -$0 summary [--cached] [-n|--summary-limit <n>] [<commit>]" +$0 summary [--cached] [-n|--summary-limit <n>] [<commit>] +$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] <git command> [<args> ...]" OPTIONS_SPEC= . git-sh-setup require_work_tree @@ -20,6 +21,10 @@ command= branch= quiet= cached= +depth=0 +current_depth=0 +depth_first=1 +on_error= # # print stuff on stdout unless -q was specified @@ -580,6 +585,129 @@ cmd_status() done } +# Check whether the submodule is initialized or not +initialize_sub_module() +{ + if test ! -d "$1"/.git + then + say "Submodule $1 is not initialized and skipped" + return 1 + # Returns true if submodule is already initialized + elif test -d "$1"/.git + then + return 0 + fi +} + +# This function simply checks whether the depth is traverseable in terms of +# depth and if so then it sequentially traverses its submodules +traverse_submodules() +{ + # If current depth is the range specified than it will continue + # else return with success + if test "$depth" -gt 0 && + test "$current_depth" -ge "$depth" + then + return 0; + fi + # If submodules exists than it will traverse over them + if test -f .gitmodules + then + # Incrementing the depth for the next level of submodules + current_depth=$(($current_depth + 1)) + for mod_path in `sed -n -e 's/path = //p' .gitmodules`; do + traverse_module "$mod_path" "$@" + done + # Decremented the depth to bring it back to the depth of + # the current submodule + current_depth=$(($current_depth - 1)) + fi +} + +# This actually traverses a submodule; checks whether the its initialized +# or not, does nothing if not initialized. +traverse_module() +{ + # Will work in the submodule if and only if its initialized + initialize_sub_module "$1" && + ( + submod_path="$1" + shift + cd "$submod_path" + # If depth-first is specified in that case submodules are + # are traversed before executing the command on this submodule + test -n "$depth_first" && traverse_submodules "$@" + # pwd is mentioned in order to enable the ser to distinguish + # between same name modules, e.g. a/lib and b/lib. + say "git submodule recurse $submod_path $*" + git "$@" + # if exit on error is specifed than script will exit if any + # command fails. As there is no transaction there will be + # no rollback either + # TODO - If possible facilitate transaction + if test "$?" -ne 0 && test -n "$on_error" + then + die "FAILED: git submodule $submod_path $*" + fi + # If depth-first is not specified in that case submodules are + # are traversed after executing the command on this submodule + test -z "$depth_first" && traverse_submodules "$@" + ) +} + +# Propagates or recurses over all the submodules at any depth with any +# git command, e.g. git-clone, git-status, git-commit etc., with the +# arguments supplied exactly as it would have been supplied to the command +# otherwise. This actually starts the recursive propagation. +cmd_recurse() { + while : + do + case "$1" in + -q|--quiet) + quiet=1 + ;; + -d|--depth) + shift + if test -z "$1" + then + echo "No <recursion depth> specified" + usage + # Arithmatic operation will give an error if depth is not number + # thus chose to check intergerness with regular expression. + # $1 is underquoted becuase the expr is in quotation + elif test "$(expr $1 : '[1-9][0-9]*')" -eq "$(expr $1 : '.*')" + then + depth="$1" + else + echo "<recursion depth> not an integer" + usage + fi + ;; + -b|--breadth-first) + depth_first= + ;; + -e|--exit-after-error) + on_error=1 + ;; + -*) + usage + ;; + *) + break + ;; + esac + shift + done + test "$#" -le 0 && die "No git command specified" + project_home="$(pwd)" + if test -d "$project_home"/.git/ + then + traverse_module . "$@" + else + die "$project_home not a git repo thus exiting" + fi +} + # This loop parses the command line arguments to find the # subcommand name to dispatch. Parsing of the subcommand specific # options are primarily done by the subcommand implementations. @@ -589,7 +717,7 @@ cmd_status() while test $# != 0 && test -z "$command" do case "$1" in - add | init | update | status | summary) + add | init | update | status | summary |recurse) command=$1 ;; -q|--quiet) -- 1.5.4.2 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* [PATCH] git-submodule.sh: Add Custom argument input support to git submodule recurse subcommand 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add recurse subcommand with basic options imyousuf @ 2008-05-05 8:44 ` imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add pre command argument " imyousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add Custom argument input support " Imran M Yousuf 2008-05-05 9:08 ` [PATCH] git-submodule.sh: Add recurse subcommand with basic options Imran M Yousuf 1 sibling, 2 replies; 10+ messages in thread From: imyousuf @ 2008-05-05 8:44 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf From: Imran M Yousuf <imyousuf@smartitengineering.com> There is a scenario which has been put forward several times in discussion over the recurse subcommand and it is that commands chould have different arguments for different modules. For example, one module could want to checkout 'master', while another might want to checkout 'work'. The [-a|--customized-argument] argument provides platform just for that. Consider the following command and its followup for further info: git submodule recurse -a checkout Submodule b is not initialized and skipped git submodule recurse a checkout Please provide an argument: master Press y to provide another arg... git checkout master Already on branch "master" Submodule d is not initialized and skipped git submodule recurse . checkout Please provide an argument: master Press y to provide another arg... git checkout master Already on branch "master" This command would also come in handy for diffs and other commands. Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> --- git-submodule.sh | 53 +++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 49 insertions(+), 4 deletions(-) diff --git a/git-submodule.sh b/git-submodule.sh index 8161d51..314652d 100755 --- a/git-submodule.sh +++ b/git-submodule.sh @@ -12,7 +12,7 @@ LONG_USAGE="$0 add [-q|--quiet] [-b|--branch branch] <repository> [<path>] $0 [status] [-q|--quiet] [-c|--cached] [--] [<path>...] $0 init|update [-q|--quiet] [--] [<path>...] $0 summary [--cached] [-n|--summary-limit <n>] [<commit>] -$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] <git command> [<args> ...]" +$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] [-a|--customized-argument] <git command> [<args> ...]" OPTIONS_SPEC= . git-sh-setup require_work_tree @@ -25,6 +25,8 @@ depth=0 current_depth=0 depth_first=1 on_error= +use_custom_args= +custom_args= # # print stuff on stdout unless -q was specified @@ -585,6 +587,40 @@ cmd_status() done } +# Take arguments from user to pass as custom arguments and execute the command +exec_with_custom_args() +{ + input= + arg_index=0 + eval_str="set " + while test $# -gt 0 + do + arg_index=$(($arg_index + 1)) + var='$'"$arg_index" + input="$1" + eval_str="$eval_str $var \"$input\"" + shift + done + while : + do + arg_index=$(($arg_index + 1)) + printf "Please provide an argument: " + read input + var='$'"$arg_index" + eval_str="$eval_str $var \"$input\"" + printf "Press y to provide another arg... " + read keypress + if test "$keypress" != "y" && + test "$keypress" != "Y" + then + break + fi + done + eval $eval_str + say "$*" + "$@" +} + # Check whether the submodule is initialized or not initialize_sub_module() { @@ -637,10 +673,16 @@ traverse_module() # If depth-first is specified in that case submodules are # are traversed before executing the command on this submodule test -n "$depth_first" && traverse_submodules "$@" - # pwd is mentioned in order to enable the ser to distinguish - # between same name modules, e.g. a/lib and b/lib. say "git submodule recurse $submod_path $*" - git "$@" + if test -n "$use_custom_args" + then + # Execute the commands after taking the arguments + # Please note that one input is for one argument + # only. + exec_with_custom_args git "$@" + else + git "$@" + fi # if exit on error is specifed than script will exit if any # command fails. As there is no transaction there will be # no rollback either @@ -689,6 +731,9 @@ cmd_recurse() { -e|--exit-after-error) on_error=1 ;; + -a|--customized-argument) + use_custom_args=1 + ;; -*) usage ;; -- 1.5.4.2 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* [PATCH] git-submodule.sh: Add pre command argument to git submodule recurse subcommand 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add Custom argument input support to git submodule recurse subcommand imyousuf @ 2008-05-05 8:44 ` imyousuf 2008-05-05 8:44 ` [PATCH] Documentation/git-submodule.txt: Add documentation for the " imyousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add pre command argument to git submodule " Imran M Yousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add Custom argument input support " Imran M Yousuf 1 sibling, 2 replies; 10+ messages in thread From: imyousuf @ 2008-05-05 8:44 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf From: Imran M Yousuf <imyousuf@smartitengineering.com> I usually feel that when typing a command, being able to see some options come in handy. For example if I can see the available branches before checking out a branch that would be useful, IOW, if I could do 'git branch' before git checkout it would be helpful. It is now possible using the [-p|--pre-command] option. Using this subcommand command argument one can actually execute another command before specifying the arguments or the original command getting executed. git submodule recurse -a -p checkout it will prompt the user for the pre command until one is satisfied and later the original command with the custom argument will get executed. Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> --- git-submodule.sh | 29 ++++++++++++++++++++++++++++- 1 files changed, 28 insertions(+), 1 deletions(-) diff --git a/git-submodule.sh b/git-submodule.sh index 314652d..dd80850 100755 --- a/git-submodule.sh +++ b/git-submodule.sh @@ -12,7 +12,7 @@ LONG_USAGE="$0 add [-q|--quiet] [-b|--branch branch] <repository> [<path>] $0 [status] [-q|--quiet] [-c|--cached] [--] [<path>...] $0 init|update [-q|--quiet] [--] [<path>...] $0 summary [--cached] [-n|--summary-limit <n>] [<commit>] -$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] [-a|--customized-argument] <git command> [<args> ...]" +$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] [-a|--customized-argument] [-p|--pre-command] <git command> [<args> ...]" OPTIONS_SPEC= . git-sh-setup require_work_tree @@ -27,6 +27,7 @@ depth_first=1 on_error= use_custom_args= custom_args= +pre_cmd= # # print stuff on stdout unless -q was specified @@ -587,6 +588,28 @@ cmd_status() done } +# Take command from user and execute it until user wants to discontinue +do_pre_command() +{ + say "Starting pre-comamnd execution!" + while : + do + ( + printf "Please provide a command: " + read pre_command + test -z "$pre_command" || + eval "$pre_command" + ) + printf "Press y to continue with another shell command... " + read keypress + if test "$keypress" != "y" && + test "$keypress" != "Y" + then + break + fi + done +} + # Take arguments from user to pass as custom arguments and execute the command exec_with_custom_args() { @@ -673,6 +696,7 @@ traverse_module() # If depth-first is specified in that case submodules are # are traversed before executing the command on this submodule test -n "$depth_first" && traverse_submodules "$@" + test -n "$pre_cmd" && do_pre_command say "git submodule recurse $submod_path $*" if test -n "$use_custom_args" then @@ -734,6 +758,9 @@ cmd_recurse() { -a|--customized-argument) use_custom_args=1 ;; + -p|--pre-command) + pre_cmd=1 + ;; -*) usage ;; -- 1.5.4.2 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* [PATCH] Documentation/git-submodule.txt: Add documentation for the recurse subcommand 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add pre command argument " imyousuf @ 2008-05-05 8:44 ` imyousuf 2008-05-05 9:07 ` Imran M Yousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add pre command argument to git submodule " Imran M Yousuf 1 sibling, 1 reply; 10+ messages in thread From: imyousuf @ 2008-05-05 8:44 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf From: Imran M Yousuf <imyousuf@smartitengineering.com> Documentation with brief description is added for the recurse sucommand along with its arguments and their nature. Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> --- Documentation/git-submodule.txt | 35 +++++++++++++++++++++++++++++++++++ 1 files changed, 35 insertions(+), 0 deletions(-) diff --git a/Documentation/git-submodule.txt b/Documentation/git-submodule.txt index 6ffd896..9a95522 100644 --- a/Documentation/git-submodule.txt +++ b/Documentation/git-submodule.txt @@ -13,6 +13,10 @@ SYNOPSIS 'git-submodule' [--quiet] status [--cached] [--] [<path>...] 'git-submodule' [--quiet] [init|update] [--] [<path>...] 'git-submodule' [--quiet] summary [--summary-limit <n>] [commit] [--] [<path>...] +'git-submodule' recurse [-q|--quiet] [-e|--exit-after-error] + [-d|--depth <recursion depth>] [-b|--breadth-first] + [-a|--customized-argument] [-p|--pre-command] + <git command> [<arg> ...]" COMMANDS @@ -54,6 +58,10 @@ summary:: in the submodule between the given super project commit and the index or working tree (switched by --cached) are shown. +recurse:: + Recurse, IOW propagate, command to its submodules if they are + initialized. + OPTIONS ------- -q, --quiet:: @@ -78,6 +86,33 @@ OPTIONS Path to submodule(s). When specified this will restrict the command to only operate on the submodules found at the specified paths. +-e, --exit-after-error:: + This option is only valid for the recurse command. If its provided then + then command will not be recursed into any other module once a command + has failed +-d, --depth <recursion depth>:: + This option is only valid for the recurse command. If its provided then + then the command will be recursed upto <recursion depth> only. +-b, --breadth-first:: + This option is only valid for the recurse command. If its provided then + the command will execute in the current node before traversing to its + child, else it will first traverse the children before executing in the + current node. +-a, --customized-argument:: + This option is only valid for the recurse command. If its provided then + user will be prompted for an argument for the <git command> specified. + Its particularly useful when one wants to supply different arguments + for the same <git command> for different submodules; for example, + checking out a branch, one might want branch to differ from submodule + to submodule +-p, --pre-command:: + This option is only valid for the recurse command. If its provided then + user will be prompted for a shell command, e.g. 'ls -al', 'pwd' etc. +<git command> [<arg>...]:: + Any git command and their argument. For example, to get the status use + 'status' as <git command> and '-s' or '-o' or any other 'git status' + arguments as <arg> + FILES ----- When initializing submodules, a .gitmodules file in the top-level directory -- 1.5.4.2 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH] Documentation/git-submodule.txt: Add documentation for the recurse subcommand 2008-05-05 8:44 ` [PATCH] Documentation/git-submodule.txt: Add documentation for the " imyousuf @ 2008-05-05 9:07 ` Imran M Yousuf 0 siblings, 0 replies; 10+ messages in thread From: Imran M Yousuf @ 2008-05-05 9:07 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf Sorry for the inconvenience, but please ignore this patch as it was not generated with -n and version number :(. - best regards, Imran On Mon, May 5, 2008 at 2:44 PM, <imyousuf@gmail.com> wrote: > From: Imran M Yousuf <imyousuf@smartitengineering.com> > > Documentation with brief description is added for the recurse > sucommand along with its arguments and their nature. > > Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> > --- > Documentation/git-submodule.txt | 35 +++++++++++++++++++++++++++++++++++ > 1 files changed, 35 insertions(+), 0 deletions(-) > > diff --git a/Documentation/git-submodule.txt b/Documentation/git-submodule.txt > index 6ffd896..9a95522 100644 > --- a/Documentation/git-submodule.txt > +++ b/Documentation/git-submodule.txt > @@ -13,6 +13,10 @@ SYNOPSIS > 'git-submodule' [--quiet] status [--cached] [--] [<path>...] > 'git-submodule' [--quiet] [init|update] [--] [<path>...] > 'git-submodule' [--quiet] summary [--summary-limit <n>] [commit] [--] [<path>...] > +'git-submodule' recurse [-q|--quiet] [-e|--exit-after-error] > + [-d|--depth <recursion depth>] [-b|--breadth-first] > + [-a|--customized-argument] [-p|--pre-command] > + <git command> [<arg> ...]" > > > COMMANDS > @@ -54,6 +58,10 @@ summary:: > in the submodule between the given super project commit and the > index or working tree (switched by --cached) are shown. > > +recurse:: > + Recurse, IOW propagate, command to its submodules if they are > + initialized. > + > OPTIONS > ------- > -q, --quiet:: > @@ -78,6 +86,33 @@ OPTIONS > Path to submodule(s). When specified this will restrict the command > to only operate on the submodules found at the specified paths. > > +-e, --exit-after-error:: > + This option is only valid for the recurse command. If its provided then > + then command will not be recursed into any other module once a command > + has failed > +-d, --depth <recursion depth>:: > + This option is only valid for the recurse command. If its provided then > + then the command will be recursed upto <recursion depth> only. > +-b, --breadth-first:: > + This option is only valid for the recurse command. If its provided then > + the command will execute in the current node before traversing to its > + child, else it will first traverse the children before executing in the > + current node. > +-a, --customized-argument:: > + This option is only valid for the recurse command. If its provided then > + user will be prompted for an argument for the <git command> specified. > + Its particularly useful when one wants to supply different arguments > + for the same <git command> for different submodules; for example, > + checking out a branch, one might want branch to differ from submodule > + to submodule > +-p, --pre-command:: > + This option is only valid for the recurse command. If its provided then > + user will be prompted for a shell command, e.g. 'ls -al', 'pwd' etc. > +<git command> [<arg>...]:: > + Any git command and their argument. For example, to get the status use > + 'status' as <git command> and '-s' or '-o' or any other 'git status' > + arguments as <arg> > + > FILES > ----- > When initializing submodules, a .gitmodules file in the top-level directory > -- > 1.5.4.2 > > -- Imran M Yousuf Entrepreneur & Software Engineer Smart IT Engineering Dhaka, Bangladesh Email: imran@smartitengineering.com Mobile: +880-1711402557 ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] git-submodule.sh: Add pre command argument to git submodule recurse subcommand 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add pre command argument " imyousuf 2008-05-05 8:44 ` [PATCH] Documentation/git-submodule.txt: Add documentation for the " imyousuf @ 2008-05-05 9:07 ` Imran M Yousuf 1 sibling, 0 replies; 10+ messages in thread From: Imran M Yousuf @ 2008-05-05 9:07 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf Sorry for the inconvenience, but please ignore this patch as it was not generated with -n and version number :(. - best regards, Imran On Mon, May 5, 2008 at 2:44 PM, <imyousuf@gmail.com> wrote: > From: Imran M Yousuf <imyousuf@smartitengineering.com> > > I usually feel that when typing a command, being able to see some options > come in handy. For example if I can see the available branches before checking > out a branch that would be useful, IOW, if I could do 'git branch' before git > checkout it would be helpful. > > It is now possible using the [-p|--pre-command] option. Using this > subcommand command argument one can actually execute another command before > specifying the arguments or the original command getting executed. > > git submodule recurse -a -p checkout > > it will prompt the user for the pre command until one is satisfied and later > the original command with the custom argument will get executed. > > Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> > --- > git-submodule.sh | 29 ++++++++++++++++++++++++++++- > 1 files changed, 28 insertions(+), 1 deletions(-) > > diff --git a/git-submodule.sh b/git-submodule.sh > index 314652d..dd80850 100755 > --- a/git-submodule.sh > +++ b/git-submodule.sh > @@ -12,7 +12,7 @@ LONG_USAGE="$0 add [-q|--quiet] [-b|--branch branch] <repository> [<path>] > $0 [status] [-q|--quiet] [-c|--cached] [--] [<path>...] > $0 init|update [-q|--quiet] [--] [<path>...] > $0 summary [--cached] [-n|--summary-limit <n>] [<commit>] > -$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] [-a|--customized-argument] <git command> [<args> ...]" > +$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] [-a|--customized-argument] [-p|--pre-command] <git command> [<args> ...]" > OPTIONS_SPEC= > . git-sh-setup > require_work_tree > @@ -27,6 +27,7 @@ depth_first=1 > on_error= > use_custom_args= > custom_args= > +pre_cmd= > > # > # print stuff on stdout unless -q was specified > @@ -587,6 +588,28 @@ cmd_status() > done > } > > +# Take command from user and execute it until user wants to discontinue > +do_pre_command() > +{ > + say "Starting pre-comamnd execution!" > + while : > + do > + ( > + printf "Please provide a command: " > + read pre_command > + test -z "$pre_command" || > + eval "$pre_command" > + ) > + printf "Press y to continue with another shell command... " > + read keypress > + if test "$keypress" != "y" && > + test "$keypress" != "Y" > + then > + break > + fi > + done > +} > + > # Take arguments from user to pass as custom arguments and execute the command > exec_with_custom_args() > { > @@ -673,6 +696,7 @@ traverse_module() > # If depth-first is specified in that case submodules are > # are traversed before executing the command on this submodule > test -n "$depth_first" && traverse_submodules "$@" > + test -n "$pre_cmd" && do_pre_command > say "git submodule recurse $submod_path $*" > if test -n "$use_custom_args" > then > @@ -734,6 +758,9 @@ cmd_recurse() { > -a|--customized-argument) > use_custom_args=1 > ;; > + -p|--pre-command) > + pre_cmd=1 > + ;; > -*) > usage > ;; > -- > 1.5.4.2 > > -- Imran M Yousuf Entrepreneur & Software Engineer Smart IT Engineering Dhaka, Bangladesh Email: imran@smartitengineering.com Mobile: +880-1711402557 ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] git-submodule.sh: Add Custom argument input support to git submodule recurse subcommand 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add Custom argument input support to git submodule recurse subcommand imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add pre command argument " imyousuf @ 2008-05-05 9:07 ` Imran M Yousuf 1 sibling, 0 replies; 10+ messages in thread From: Imran M Yousuf @ 2008-05-05 9:07 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf Sorry for the inconvenience, but please ignore this patch as it was not generated with -n and version number :(. - best regards, Imran On Mon, May 5, 2008 at 2:44 PM, <imyousuf@gmail.com> wrote: > From: Imran M Yousuf <imyousuf@smartitengineering.com> > > There is a scenario which has been put forward several times in > discussion over the recurse subcommand and it is that commands chould have > different arguments for different modules. > > For example, one module could want to checkout 'master', while another might want > to checkout 'work'. The [-a|--customized-argument] argument provides platform > just for that. Consider the following command and its followup for further info: > > git submodule recurse -a checkout > > Submodule b is not initialized and skipped > git submodule recurse a checkout > Please provide an argument: master > Press y to provide another arg... > git checkout master > Already on branch "master" > Submodule d is not initialized and skipped > git submodule recurse . checkout > Please provide an argument: master > Press y to provide another arg... > git checkout master > Already on branch "master" > > This command would also come in handy for diffs and other commands. > > Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> > --- > git-submodule.sh | 53 +++++++++++++++++++++++++++++++++++++++++++++++++---- > 1 files changed, 49 insertions(+), 4 deletions(-) > > diff --git a/git-submodule.sh b/git-submodule.sh > index 8161d51..314652d 100755 > --- a/git-submodule.sh > +++ b/git-submodule.sh > @@ -12,7 +12,7 @@ LONG_USAGE="$0 add [-q|--quiet] [-b|--branch branch] <repository> [<path>] > $0 [status] [-q|--quiet] [-c|--cached] [--] [<path>...] > $0 init|update [-q|--quiet] [--] [<path>...] > $0 summary [--cached] [-n|--summary-limit <n>] [<commit>] > -$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] <git command> [<args> ...]" > +$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] [-a|--customized-argument] <git command> [<args> ...]" > OPTIONS_SPEC= > . git-sh-setup > require_work_tree > @@ -25,6 +25,8 @@ depth=0 > current_depth=0 > depth_first=1 > on_error= > +use_custom_args= > +custom_args= > > # > # print stuff on stdout unless -q was specified > @@ -585,6 +587,40 @@ cmd_status() > done > } > > +# Take arguments from user to pass as custom arguments and execute the command > +exec_with_custom_args() > +{ > + input= > + arg_index=0 > + eval_str="set " > + while test $# -gt 0 > + do > + arg_index=$(($arg_index + 1)) > + var='$'"$arg_index" > + input="$1" > + eval_str="$eval_str $var \"$input\"" > + shift > + done > + while : > + do > + arg_index=$(($arg_index + 1)) > + printf "Please provide an argument: " > + read input > + var='$'"$arg_index" > + eval_str="$eval_str $var \"$input\"" > + printf "Press y to provide another arg... " > + read keypress > + if test "$keypress" != "y" && > + test "$keypress" != "Y" > + then > + break > + fi > + done > + eval $eval_str > + say "$*" > + "$@" > +} > + > # Check whether the submodule is initialized or not > initialize_sub_module() > { > @@ -637,10 +673,16 @@ traverse_module() > # If depth-first is specified in that case submodules are > # are traversed before executing the command on this submodule > test -n "$depth_first" && traverse_submodules "$@" > - # pwd is mentioned in order to enable the ser to distinguish > - # between same name modules, e.g. a/lib and b/lib. > say "git submodule recurse $submod_path $*" > - git "$@" > + if test -n "$use_custom_args" > + then > + # Execute the commands after taking the arguments > + # Please note that one input is for one argument > + # only. > + exec_with_custom_args git "$@" > + else > + git "$@" > + fi > # if exit on error is specifed than script will exit if any > # command fails. As there is no transaction there will be > # no rollback either > @@ -689,6 +731,9 @@ cmd_recurse() { > -e|--exit-after-error) > on_error=1 > ;; > + -a|--customized-argument) > + use_custom_args=1 > + ;; > -*) > usage > ;; > -- > 1.5.4.2 > > -- Imran M Yousuf Entrepreneur & Software Engineer Smart IT Engineering Dhaka, Bangladesh Email: imran@smartitengineering.com Mobile: +880-1711402557 ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] git-submodule.sh: Add recurse subcommand with basic options 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add recurse subcommand with basic options imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add Custom argument input support to git submodule recurse subcommand imyousuf @ 2008-05-05 9:08 ` Imran M Yousuf 1 sibling, 0 replies; 10+ messages in thread From: Imran M Yousuf @ 2008-05-05 9:08 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf Sorry for the inconvenience, but please ignore this patch as it was not generated with -n and version number :(. - best regards, Imran On Mon, May 5, 2008 at 2:44 PM, <imyousuf@gmail.com> wrote: > From: Imran M Yousuf <imyousuf@smartitengineering.com> > > The purpose of the recurse command in the git submodule is to recurse > a command in its submodule. For example if one wants to do a diff on its > project with submodules at once, one can simply do > git-submodule recurse diff HEAD > and would see the diff for all the modules it contains. > > The recurse commands behavior can be customized with several arguments > that it accepts. The synopsis for the recurse command is: > > git-submodule recurse [-q|--quiet] [-e|--exit-after-error] > [-d|--depth <recursion depth>] [-b|--breadth-first] > <git command> [<arguments> ...] > > There are commands that can fail for a certain submodule but succeed for > others; if one wants to stop execution once the top level module's execution > fails, one can specify [-e|--exit-after-error]. It will ensure that once > execution of git <command> fails in the top level module it will not recurse > into its submodules. > > If the project has submodule hierarchy upto n depth and we want to restrict > recursion to (n-p) depth; we can use the [-d|--depth <recursion depth>] option. > Value has to be greater than 0 and command will at least recurse into the first > depth. If depth is specified to p than all depths <= p will be recursed over. > > While discussion on the recurse command one thing which was put forward > in several occassions is that there might be scenario where a command should be > executed over the child module before the parent module. > > For such scenario [-b|--breadth-first] option can be used; one use case > in particular presented as an example is git commit; where almost everybody > mentioned that they prefer to commit the child module before the parent and > default will enable just that. > > E.g. p -> a, b, c, e; a ->d is a module structure. If the following command is > used, > > git submodule recurse commit -a > > it will execute git commit -a in the following sequence - d, a, b, c, e, p. > > Now if one want to instead go in a breadth first manner then one can > specify -b option. E.g. if the above command is - > > git submodule recurse -b commit -a > > it will execute git commit -a in the following sequence - p, a, d, b, c, e. > > Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> > --- > git-submodule.sh | 132 +++++++++++++++++++++++++++++++++++++++++++++++++++++- > 1 files changed, 130 insertions(+), 2 deletions(-) > > diff --git a/git-submodule.sh b/git-submodule.sh > index a5ee2e5..8161d51 100755 > --- a/git-submodule.sh > +++ b/git-submodule.sh > @@ -11,7 +11,8 @@ Use $0 -h for more details" > LONG_USAGE="$0 add [-q|--quiet] [-b|--branch branch] <repository> [<path>] > $0 [status] [-q|--quiet] [-c|--cached] [--] [<path>...] > $0 init|update [-q|--quiet] [--] [<path>...] > -$0 summary [--cached] [-n|--summary-limit <n>] [<commit>]" > +$0 summary [--cached] [-n|--summary-limit <n>] [<commit>] > +$0 recurse [-q|--quiet] [-e|--exit-after-error] [-d|--depth <recursion depth>] [-b|--breadth-first] <git command> [<args> ...]" > OPTIONS_SPEC= > . git-sh-setup > require_work_tree > @@ -20,6 +21,10 @@ command= > branch= > quiet= > cached= > +depth=0 > +current_depth=0 > +depth_first=1 > +on_error= > > # > # print stuff on stdout unless -q was specified > @@ -580,6 +585,129 @@ cmd_status() > done > } > > +# Check whether the submodule is initialized or not > +initialize_sub_module() > +{ > + if test ! -d "$1"/.git > + then > + say "Submodule $1 is not initialized and skipped" > + return 1 > + # Returns true if submodule is already initialized > + elif test -d "$1"/.git > + then > + return 0 > + fi > +} > + > +# This function simply checks whether the depth is traverseable in terms of > +# depth and if so then it sequentially traverses its submodules > +traverse_submodules() > +{ > + # If current depth is the range specified than it will continue > + # else return with success > + if test "$depth" -gt 0 && > + test "$current_depth" -ge "$depth" > + then > + return 0; > + fi > + # If submodules exists than it will traverse over them > + if test -f .gitmodules > + then > + # Incrementing the depth for the next level of submodules > + current_depth=$(($current_depth + 1)) > + for mod_path in `sed -n -e 's/path = //p' .gitmodules`; do > + traverse_module "$mod_path" "$@" > + done > + # Decremented the depth to bring it back to the depth of > + # the current submodule > + current_depth=$(($current_depth - 1)) > + fi > +} > + > +# This actually traverses a submodule; checks whether the its initialized > +# or not, does nothing if not initialized. > +traverse_module() > +{ > + # Will work in the submodule if and only if its initialized > + initialize_sub_module "$1" && > + ( > + submod_path="$1" > + shift > + cd "$submod_path" > + # If depth-first is specified in that case submodules are > + # are traversed before executing the command on this submodule > + test -n "$depth_first" && traverse_submodules "$@" > + # pwd is mentioned in order to enable the ser to distinguish > + # between same name modules, e.g. a/lib and b/lib. > + say "git submodule recurse $submod_path $*" > + git "$@" > + # if exit on error is specifed than script will exit if any > + # command fails. As there is no transaction there will be > + # no rollback either > + # TODO - If possible facilitate transaction > + if test "$?" -ne 0 && test -n "$on_error" > + then > + die "FAILED: git submodule $submod_path $*" > + fi > + # If depth-first is not specified in that case submodules are > + # are traversed after executing the command on this submodule > + test -z "$depth_first" && traverse_submodules "$@" > + ) > +} > + > +# Propagates or recurses over all the submodules at any depth with any > +# git command, e.g. git-clone, git-status, git-commit etc., with the > +# arguments supplied exactly as it would have been supplied to the command > +# otherwise. This actually starts the recursive propagation. > +cmd_recurse() { > + while : > + do > + case "$1" in > + -q|--quiet) > + quiet=1 > + ;; > + -d|--depth) > + shift > + if test -z "$1" > + then > + echo "No <recursion depth> specified" > + usage > + # Arithmatic operation will give an error if depth is not number > + # thus chose to check intergerness with regular expression. > + # $1 is underquoted becuase the expr is in quotation > + elif test "$(expr $1 : '[1-9][0-9]*')" -eq "$(expr $1 : '.*')" > + then > + depth="$1" > + else > + echo "<recursion depth> not an integer" > + usage > + fi > + ;; > + -b|--breadth-first) > + depth_first= > + ;; > + -e|--exit-after-error) > + on_error=1 > + ;; > + -*) > + usage > + ;; > + *) > + break > + ;; > + esac > + shift > + done > + test "$#" -le 0 && die "No git command specified" > + project_home="$(pwd)" > + if test -d "$project_home"/.git/ > + then > + traverse_module . "$@" > + else > + die "$project_home not a git repo thus exiting" > + fi > +} > + > # This loop parses the command line arguments to find the > # subcommand name to dispatch. Parsing of the subcommand specific > # options are primarily done by the subcommand implementations. > @@ -589,7 +717,7 @@ cmd_status() > while test $# != 0 && test -z "$command" > do > case "$1" in > - add | init | update | status | summary) > + add | init | update | status | summary |recurse) > command=$1 > ;; > -q|--quiet) > -- > 1.5.4.2 > > -- Imran M Yousuf Entrepreneur & Software Engineer Smart IT Engineering Dhaka, Bangladesh Email: imran@smartitengineering.com Mobile: +880-1711402557 ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] git-submodule.sh: Add Long Usage instead of simple usage 2008-05-05 8:44 [PATCH] git-submodule.sh: Add Long Usage instead of simple usage imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add recurse subcommand with basic options imyousuf @ 2008-05-05 9:07 ` Imran M Yousuf 1 sibling, 0 replies; 10+ messages in thread From: Imran M Yousuf @ 2008-05-05 9:07 UTC (permalink / raw) To: git; +Cc: gitster, Imran M Yousuf Sorry for the inconvenience, but please ignore this patch as it was not generated with -n and version number :(. - best regards, Imran On Mon, May 5, 2008 at 2:44 PM, <imyousuf@gmail.com> wrote: > From: Imran M Yousuf <imyousuf@smartitengineering.com> > > With the already available commands the synopsis is quite hard to > read; thus converted it to Long usage instead. In process also > updated the file comment. > > Signed-off-by: Imran M Yousuf <imyousuf@smartitengineering.com> > --- > git-submodule.sh | 13 +++++++++---- > 1 files changed, 9 insertions(+), 4 deletions(-) > > diff --git a/git-submodule.sh b/git-submodule.sh > index ce0f00c..a5ee2e5 100755 > --- a/git-submodule.sh > +++ b/git-submodule.sh > @@ -1,12 +1,17 @@ > #!/bin/sh > # > -# git-submodules.sh: add, init, update or list git submodules > +# git-submodules.sh: add, init, update, summary or status git submodules > # > # Copyright (c) 2007 Lars Hjemli > > -USAGE="[--quiet] [--cached] \ > -[add <repo> [-b branch]|status|init|update|summary [-n|--summary-limit <n>] [<commit>]] \ > -[--] [<path>...]" > +USAGE="<command> <options> > +Use $0 -h for more details" > +# Did not use '\' at the end of the lines to ensure that each synopsis > +# are in a separate line > +LONG_USAGE="$0 add [-q|--quiet] [-b|--branch branch] <repository> [<path>] > +$0 [status] [-q|--quiet] [-c|--cached] [--] [<path>...] > +$0 init|update [-q|--quiet] [--] [<path>...] > +$0 summary [--cached] [-n|--summary-limit <n>] [<commit>]" > OPTIONS_SPEC= > . git-sh-setup > require_work_tree > -- > 1.5.4.2 > > ^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2008-05-05 9:09 UTC | newest] Thread overview: 10+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2008-05-05 8:44 [PATCH] git-submodule.sh: Add Long Usage instead of simple usage imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add recurse subcommand with basic options imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add Custom argument input support to git submodule recurse subcommand imyousuf 2008-05-05 8:44 ` [PATCH] git-submodule.sh: Add pre command argument " imyousuf 2008-05-05 8:44 ` [PATCH] Documentation/git-submodule.txt: Add documentation for the " imyousuf 2008-05-05 9:07 ` Imran M Yousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add pre command argument to git submodule " Imran M Yousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add Custom argument input support " Imran M Yousuf 2008-05-05 9:08 ` [PATCH] git-submodule.sh: Add recurse subcommand with basic options Imran M Yousuf 2008-05-05 9:07 ` [PATCH] git-submodule.sh: Add Long Usage instead of simple usage Imran M Yousuf
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).