t / helper / test-tool.con commit t/helper: merge test-prio-queue into test-tool (15b7581)
   1#include "git-compat-util.h"
   2#include "test-tool.h"
   3
   4struct test_cmd {
   5        const char *name;
   6        int (*fn)(int argc, const char **argv);
   7};
   8
   9static struct test_cmd cmds[] = {
  10        { "chmtime", cmd__chmtime },
  11        { "config", cmd__config },
  12        { "ctype", cmd__ctype },
  13        { "date", cmd__date },
  14        { "delta", cmd__delta },
  15        { "drop-caches", cmd__drop_caches },
  16        { "dump-cache-tree", cmd__dump_cache_tree },
  17        { "dump-split-index", cmd__dump_split_index },
  18        { "example-decorate", cmd__example_decorate },
  19        { "genrandom", cmd__genrandom },
  20        { "hashmap", cmd__hashmap },
  21        { "index-version", cmd__index_version },
  22        { "lazy-init-name-hash", cmd__lazy_init_name_hash },
  23        { "match-trees", cmd__match_trees },
  24        { "mergesort", cmd__mergesort },
  25        { "mktemp", cmd__mktemp },
  26        { "online-cpus", cmd__online_cpus },
  27        { "path-utils", cmd__path_utils },
  28        { "prio-queue", cmd__prio_queue },
  29        { "sha1", cmd__sha1 },
  30};
  31
  32int cmd_main(int argc, const char **argv)
  33{
  34        int i;
  35
  36        if (argc < 2)
  37                die("I need a test name!");
  38
  39        for (i = 0; i < ARRAY_SIZE(cmds); i++) {
  40                if (!strcmp(cmds[i].name, argv[1])) {
  41                        argv++;
  42                        argc--;
  43                        return cmds[i].fn(argc, argv);
  44                }
  45        }
  46        die("There is no test named '%s'", argv[1]);
  47}