summaryrefslogtreecommitdiff
path: root/repo-config.c
diff options
context:
space:
mode:
authorPetr Baudis <pasky@suse.cz>2006-04-25 00:59:25 +0200
committerJunio C Hamano <junkio@cox.net>2006-04-24 22:29:33 -0700
commitde791f15a1b01e63f3c870c8497c594c47452fab (patch)
tree547caae879f03fc937b473bdd0f71ec7e4e04792 /repo-config.c
parent36932eab772dc621e79d615fda425ecf87e6d74e (diff)
downloadgit-de791f15a1b01e63f3c870c8497c594c47452fab.tar.gz
git-repo-config --list support
This adds git-repo-config --list (or git-repo-config -l) support, similar to what git-var -l does now (to be phased out so that we have a single sane interface to the config file instead of fragmented and confused API). Signed-off-by: Petr Baudis <pasky@suse.cz>
Diffstat (limited to 'repo-config.c')
-rw-r--r--repo-config.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/repo-config.c b/repo-config.c
index c5ebb7668a..fa8aba7a1b 100644
--- a/repo-config.c
+++ b/repo-config.c
@@ -2,7 +2,7 @@
#include <regex.h>
static const char git_config_set_usage[] =
-"git-repo-config [ --bool | --int ] [--get | --get-all | --replace-all | --unset | --unset-all] name [value [value_regex]]";
+"git-repo-config [ --bool | --int ] [--get | --get-all | --replace-all | --unset | --unset-all] name [value [value_regex]] | --list";
static char* key = NULL;
static char* value = NULL;
@@ -12,6 +12,15 @@ static int do_not_match = 0;
static int seen = 0;
static enum { T_RAW, T_INT, T_BOOL } type = T_RAW;
+static int show_all_config(const char *key_, const char *value_)
+{
+ if (value_)
+ printf("%s=%s\n", key_, value_);
+ else
+ printf("%s\n", key_);
+ return 0;
+}
+
static int show_config(const char* key_, const char* value_)
{
if (value_ == NULL)
@@ -67,7 +76,7 @@ static int get_value(const char* key_, const char* regex_)
}
}
- i = git_config(show_config);
+ git_config(show_config);
if (value) {
printf("%s\n", value);
free(value);
@@ -99,6 +108,9 @@ int main(int argc, const char **argv)
argv++;
}
+ if (!strcmp(argv[1], "--list") || !strcmp(argv[1], "-l"))
+ return git_config(show_all_config);
+
switch (argc) {
case 2:
return get_value(argv[1], NULL);