Merge branch 'ar/request-pull-phrasofix' into maint
[git.git] / t / helper / test-submodule-config.c
blobc6c57bba0d397e44e8897b05d479a30b53311517
1 #include "cache.h"
2 #include "config.h"
3 #include "submodule-config.h"
4 #include "submodule.h"
6 static void die_usage(int argc, const char **argv, const char *msg)
8 fprintf(stderr, "%s\n", msg);
9 fprintf(stderr, "Usage: %s [<commit> <submodulepath>] ...\n", argv[0]);
10 exit(1);
13 static int git_test_config(const char *var, const char *value, void *cb)
15 return parse_submodule_config_option(var, value);
18 int cmd_main(int argc, const char **argv)
20 const char **arg = argv;
21 int my_argc = argc;
22 int output_url = 0;
23 int lookup_name = 0;
25 arg++;
26 my_argc--;
27 while (arg[0] && starts_with(arg[0], "--")) {
28 if (!strcmp(arg[0], "--url"))
29 output_url = 1;
30 if (!strcmp(arg[0], "--name"))
31 lookup_name = 1;
32 arg++;
33 my_argc--;
36 if (my_argc % 2 != 0)
37 die_usage(argc, argv, "Wrong number of arguments.");
39 setup_git_directory();
40 gitmodules_config();
41 git_config(git_test_config, NULL);
43 while (*arg) {
44 unsigned char commit_sha1[20];
45 const struct submodule *submodule;
46 const char *commit;
47 const char *path_or_name;
49 commit = arg[0];
50 path_or_name = arg[1];
52 if (commit[0] == '\0')
53 hashclr(commit_sha1);
54 else if (get_sha1(commit, commit_sha1) < 0)
55 die_usage(argc, argv, "Commit not found.");
57 if (lookup_name) {
58 submodule = submodule_from_name(commit_sha1, path_or_name);
59 } else
60 submodule = submodule_from_path(commit_sha1, path_or_name);
61 if (!submodule)
62 die_usage(argc, argv, "Submodule not found.");
64 if (output_url)
65 printf("Submodule url: '%s' for path '%s'\n",
66 submodule->url, submodule->path);
67 else
68 printf("Submodule name: '%s' for path '%s'\n",
69 submodule->name, submodule->path);
71 arg += 2;
74 submodule_free();
76 return 0;