On Mon, Aug 31, 2015 at 8:40 PM, Stefan Beller <[email protected]> wrote:
> This implements the helper `module_name` in C instead of shell,
> yielding a nice performance boost.
>
> Before this patch, I measured a time (best out of three):
>
> $ time ./t7400-submodule-basic.sh >/dev/null
> real 0m11.066s
> user 0m3.348s
> sys 0m8.534s
>
> With this patch applied I measured (also best out of three)
>
> $ time ./t7400-submodule-basic.sh >/dev/null
> real 0m10.063s
> user 0m3.044s
> sys 0m7.487s
>
> Signed-off-by: Stefan Beller <[email protected]>
> ---
> diff --git a/builtin/submodule--helper.c b/builtin/submodule--helper.c
> index 44310f5..91bd420 100644
> --- a/builtin/submodule--helper.c
> +++ b/builtin/submodule--helper.c
> @@ -102,16 +105,38 @@ static int module_list(int argc, const char **argv,
> const char *prefix)
> +static int module_name(int argc, const char **argv, const char *prefix)
> +{
> + const struct submodule *sub;
> +
> + if (argc != 1)
> + usage("git submodule--helper module_name <path>\n");
usage(_("..."));
s/module_name/module-name/
I think you also need to drop the newline from the usage() argument.
> + gitmodules_config();
> + sub = submodule_from_path(null_sha1, argv[0]);
> +
> + if (!sub)
> + die(N_("No submodule mapping found in .gitmodules for path
> '%s'"),
> + argv[0]);
> +
> + printf("%s\n", sub->name);
> +
> + return 0;
> +}
> +
> int cmd_submodule__helper(int argc, const char **argv, const char *prefix)
> {
> if (argc < 2)
> die(N_("fatal: submodule--helper subcommand must be called
> with "
> - "a subcommand, which is module-list\n"));
> + "a subcommand, which are module-list, module-name\n"));
Manually maintaining this list is likely to become a maintenance issue
pretty quickly. Isn't there an OPT_CMDMODE for this sort of thing?
Also, it would like be more readable if the possible commands were
printed one per line rather than all squashed together.
> if (!strcmp(argv[1], "module-list"))
> return module_list(argc - 1, argv + 1, prefix);
>
> + if (!strcmp(argv[1], "module-name"))
> + return module_name(argc - 2, argv + 2, prefix);
> +
> die(N_("fatal: '%s' is not a valid submodule--helper subcommand, "
> - "which is module-list\n"),
> + "which are module-list, module-name\n"),
And, it's duplicated here, making it even more of a maintenance problem.
> argv[1]);
> }
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html