gitweb: use new Git::Repo API, and add optional caching
[git/gitweb-caching.git] / alias.c
blobccb1108c94436035d0da8b1d6f08f859b68294a3
1 #include "cache.h"
3 static const char *alias_key;
4 static char *alias_val;
6 static int alias_lookup_cb(const char *k, const char *v, void *cb)
8 if (!prefixcmp(k, "alias.") && !strcmp(k+6, alias_key)) {
9 if (!v)
10 return config_error_nonbool(k);
11 alias_val = xstrdup(v);
12 return 0;
14 return 0;
17 char *alias_lookup(const char *alias)
19 alias_key = alias;
20 alias_val = NULL;
21 git_config(alias_lookup_cb, NULL);
22 return alias_val;
25 int split_cmdline(char *cmdline, const char ***argv)
27 int src, dst, count = 0, size = 16;
28 char quoted = 0;
30 *argv = xmalloc(sizeof(char*) * size);
32 /* split alias_string */
33 (*argv)[count++] = cmdline;
34 for (src = dst = 0; cmdline[src];) {
35 char c = cmdline[src];
36 if (!quoted && isspace(c)) {
37 cmdline[dst++] = 0;
38 while (cmdline[++src]
39 && isspace(cmdline[src]))
40 ; /* skip */
41 if (count >= size) {
42 size += 16;
43 *argv = xrealloc(*argv, sizeof(char*) * size);
45 (*argv)[count++] = cmdline + dst;
46 } else if (!quoted && (c == '\'' || c == '"')) {
47 quoted = c;
48 src++;
49 } else if (c == quoted) {
50 quoted = 0;
51 src++;
52 } else {
53 if (c == '\\' && quoted != '\'') {
54 src++;
55 c = cmdline[src];
56 if (!c) {
57 free(*argv);
58 *argv = NULL;
59 return error("cmdline ends with \\");
62 cmdline[dst++] = c;
63 src++;
67 cmdline[dst] = 0;
69 if (quoted) {
70 free(*argv);
71 *argv = NULL;
72 return error("unclosed quote");
75 return count;