I have rewritten and cleaned up the recursive submodule on-demand push patch from Fredrik. Since this involved changing large parts of it I have taken over the ownership. To pay credit that this is built upon Fredriks work I have left the signed-off and mentored-by footers the same. I hope that this is the proper way to handle such cases. If someone comes up with a better idea I am happy to change things. Cheers Heiko The first iteration of this patch series can be found here: http://thread.gmane.org/gmane.comp.version-control.git/176328/focus=176327 The second iteration of this patch series can be found here: http://thread.gmane.org/gmane.comp.version-control.git/177992 The third iteration of this patch series can be found here: http://thread.gmane.org/gmane.comp.version-control.git/179037/focus=179048 The fourth iteration of this patch series can be found here: http://thread.gmane.org/gmane.comp.version-control.git/179731 Heiko Voigt (3): Teach revision walking machinery to walk multiple times sequencially Refactor submodule push check to use string list instead of integer push: teach --recurse-submodules the on-demand option .gitignore | 1 + Documentation/git-push.txt | 14 +++- Documentation/technical/api-revision-walking.txt | 5 + Makefile | 1 + builtin/push.c | 7 ++ object.c | 11 +++ object.h | 2 + revision.c | 5 + revision.h | 1 + submodule.c | 70 ++++++++++++++--- submodule.h | 4 +- t/t0062-revision-walking.sh | 33 ++++++++ t/t5531-deep-submodule-push.sh | 94 ++++++++++++++++++++++ test-revision-walking.c | 66 +++++++++++++++ transport.c | 41 +++++++++- transport.h | 1 + 16 files changed, 338 insertions(+), 18 deletions(-) create mode 100755 t/t0062-revision-walking.sh create mode 100644 test-revision-walking.c -- 1.7.9.114.gead08 -- 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