aboutsummaryrefslogtreecommitdiff
path: root/test-config.c
diff options
context:
space:
mode:
authorNguyễn Thái Ngọc Duy <pclouds@gmail.com>2016-04-13 20:22:42 +0700
committerJunio C Hamano <gitster@pobox.com>2016-04-15 10:12:19 -0700
commite6e7530d10b74d763b4311ea93e0a831b810d6c2 (patch)
tree7ac83d3fecd39d6076f24eaddd6719a24c3b6ce8 /test-config.c
parent7897d84b8240720352e23030c35db461581b68e3 (diff)
downloadgit-e6e7530d10b74d763b4311ea93e0a831b810d6c2.tar.gz
git-e6e7530d10b74d763b4311ea93e0a831b810d6c2.tar.xz
test helpers: move test-* to t/helper/ subdirectory
This keeps top dir a bit less crowded. And because these programs are for testing purposes, it makes sense that they stay somewhere in t/ Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'test-config.c')
-rw-r--r--test-config.c152
1 files changed, 0 insertions, 152 deletions
diff --git a/test-config.c b/test-config.c
deleted file mode 100644
index 6a7755221..000000000
--- a/test-config.c
+++ /dev/null
@@ -1,152 +0,0 @@
-#include "cache.h"
-#include "string-list.h"
-
-/*
- * This program exposes the C API of the configuration mechanism
- * as a set of simple commands in order to facilitate testing.
- *
- * Reads stdin and prints result of command to stdout:
- *
- * get_value -> prints the value with highest priority for the entered key
- *
- * get_value_multi -> prints all values for the entered key in increasing order
- * of priority
- *
- * get_int -> print integer value for the entered key or die
- *
- * get_bool -> print bool value for the entered key or die
- *
- * get_string -> print string value for the entered key or die
- *
- * configset_get_value -> returns value with the highest priority for the entered key
- * from a config_set constructed from files entered as arguments.
- *
- * configset_get_value_multi -> returns value_list for the entered key sorted in
- * ascending order of priority from a config_set
- * constructed from files entered as arguments.
- *
- * Examples:
- *
- * To print the value with highest priority for key "foo.bAr Baz.rock":
- * test-config get_value "foo.bAr Baz.rock"
- *
- */
-
-
-int main(int argc, char **argv)
-{
- int i, val;
- const char *v;
- const struct string_list *strptr;
- struct config_set cs;
- git_configset_init(&cs);
-
- if (argc < 2) {
- fprintf(stderr, "Please, provide a command name on the command-line\n");
- goto exit1;
- } else if (argc == 3 && !strcmp(argv[1], "get_value")) {
- if (!git_config_get_value(argv[2], &v)) {
- if (!v)
- printf("(NULL)\n");
- else
- printf("%s\n", v);
- goto exit0;
- } else {
- printf("Value not found for \"%s\"\n", argv[2]);
- goto exit1;
- }
- } else if (argc == 3 && !strcmp(argv[1], "get_value_multi")) {
- strptr = git_config_get_value_multi(argv[2]);
- if (strptr) {
- for (i = 0; i < strptr->nr; i++) {
- v = strptr->items[i].string;
- if (!v)
- printf("(NULL)\n");
- else
- printf("%s\n", v);
- }
- goto exit0;
- } else {
- printf("Value not found for \"%s\"\n", argv[2]);
- goto exit1;
- }
- } else if (argc == 3 && !strcmp(argv[1], "get_int")) {
- if (!git_config_get_int(argv[2], &val)) {
- printf("%d\n", val);
- goto exit0;
- } else {
- printf("Value not found for \"%s\"\n", argv[2]);
- goto exit1;
- }
- } else if (argc == 3 && !strcmp(argv[1], "get_bool")) {
- if (!git_config_get_bool(argv[2], &val)) {
- printf("%d\n", val);
- goto exit0;
- } else {
- printf("Value not found for \"%s\"\n", argv[2]);
- goto exit1;
- }
- } else if (argc == 3 && !strcmp(argv[1], "get_string")) {
- if (!git_config_get_string_const(argv[2], &v)) {
- printf("%s\n", v);
- goto exit0;
- } else {
- printf("Value not found for \"%s\"\n", argv[2]);
- goto exit1;
- }
- } else if (!strcmp(argv[1], "configset_get_value")) {
- for (i = 3; i < argc; i++) {
- int err;
- if ((err = git_configset_add_file(&cs, argv[i]))) {
- fprintf(stderr, "Error (%d) reading configuration file %s.\n", err, argv[i]);
- goto exit2;
- }
- }
- if (!git_configset_get_value(&cs, argv[2], &v)) {
- if (!v)
- printf("(NULL)\n");
- else
- printf("%s\n", v);
- goto exit0;
- } else {
- printf("Value not found for \"%s\"\n", argv[2]);
- goto exit1;
- }
- } else if (!strcmp(argv[1], "configset_get_value_multi")) {
- for (i = 3; i < argc; i++) {
- int err;
- if ((err = git_configset_add_file(&cs, argv[i]))) {
- fprintf(stderr, "Error (%d) reading configuration file %s.\n", err, argv[i]);
- goto exit2;
- }
- }
- strptr = git_configset_get_value_multi(&cs, argv[2]);
- if (strptr) {
- for (i = 0; i < strptr->nr; i++) {
- v = strptr->items[i].string;
- if (!v)
- printf("(NULL)\n");
- else
- printf("%s\n", v);
- }
- goto exit0;
- } else {
- printf("Value not found for \"%s\"\n", argv[2]);
- goto exit1;
- }
- }
-
- die("%s: Please check the syntax and the function name", argv[0]);
-
-exit0:
- git_configset_clear(&cs);
- return 0;
-
-exit1:
- git_configset_clear(&cs);
- return 1;
-
-exit2:
- git_configset_clear(&cs);
- return 2;
-}