2005-10-23 23:30:45 +02:00
|
|
|
#include "cache.h"
|
|
|
|
#include "quote.h"
|
2006-01-11 03:12:17 +01:00
|
|
|
#include "exec_cmd.h"
|
2007-10-09 16:33:25 +02:00
|
|
|
#include "strbuf.h"
|
2005-10-23 23:30:45 +02:00
|
|
|
|
|
|
|
static int do_generic_cmd(const char *me, char *arg)
|
|
|
|
{
|
|
|
|
const char *my_argv[4];
|
|
|
|
|
2005-11-26 05:57:02 +01:00
|
|
|
if (!arg || !(arg = sq_dequote(arg)))
|
2005-10-23 23:30:45 +02:00
|
|
|
die("bad argument");
|
Mechanical conversion to use prefixcmp()
This mechanically converts strncmp() to use prefixcmp(), but only when
the parameters match specific patterns, so that they can be verified
easily. Leftover from this will be fixed in a separate step, including
idiotic conversions like
if (!strncmp("foo", arg, 3))
=>
if (!(-prefixcmp(arg, "foo")))
This was done by using this script in px.perl
#!/usr/bin/perl -i.bak -p
if (/strncmp\(([^,]+), "([^\\"]*)", (\d+)\)/ && (length($2) == $3)) {
s|strncmp\(([^,]+), "([^\\"]*)", (\d+)\)|prefixcmp($1, "$2")|;
}
if (/strncmp\("([^\\"]*)", ([^,]+), (\d+)\)/ && (length($1) == $3)) {
s|strncmp\("([^\\"]*)", ([^,]+), (\d+)\)|(-prefixcmp($2, "$1"))|;
}
and running:
$ git grep -l strncmp -- '*.c' | xargs perl px.perl
Signed-off-by: Junio C Hamano <junkio@cox.net>
2007-02-20 10:53:29 +01:00
|
|
|
if (prefixcmp(me, "git-"))
|
2006-01-11 03:12:17 +01:00
|
|
|
die("bad command");
|
2005-10-23 23:30:45 +02:00
|
|
|
|
2006-01-11 03:12:17 +01:00
|
|
|
my_argv[0] = me + 4;
|
2005-10-23 23:30:45 +02:00
|
|
|
my_argv[1] = arg;
|
|
|
|
my_argv[2] = NULL;
|
|
|
|
|
2006-03-05 11:47:29 +01:00
|
|
|
return execv_git_cmd(my_argv);
|
2005-10-23 23:30:45 +02:00
|
|
|
}
|
|
|
|
|
2007-10-09 16:33:25 +02:00
|
|
|
static int do_cvs_cmd(const char *me, char *arg)
|
|
|
|
{
|
|
|
|
const char *cvsserver_argv[3] = {
|
|
|
|
"cvsserver", "server", NULL
|
|
|
|
};
|
|
|
|
const char *oldpath = getenv("PATH");
|
|
|
|
struct strbuf newpath = STRBUF_INIT;
|
|
|
|
|
|
|
|
if (!arg || strcmp(arg, "server"))
|
|
|
|
die("git-cvsserver only handles server: %s", arg);
|
|
|
|
|
|
|
|
strbuf_addstr(&newpath, git_exec_path());
|
|
|
|
strbuf_addch(&newpath, ':');
|
|
|
|
strbuf_addstr(&newpath, oldpath);
|
|
|
|
|
|
|
|
setenv("PATH", strbuf_detach(&newpath, NULL), 1);
|
|
|
|
|
|
|
|
return execv_git_cmd(cvsserver_argv);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2005-10-23 23:30:45 +02:00
|
|
|
static struct commands {
|
|
|
|
const char *name;
|
|
|
|
int (*exec)(const char *me, char *arg);
|
|
|
|
} cmd_list[] = {
|
|
|
|
{ "git-receive-pack", do_generic_cmd },
|
|
|
|
{ "git-upload-pack", do_generic_cmd },
|
2007-10-09 16:33:25 +02:00
|
|
|
{ "cvs", do_cvs_cmd },
|
2005-10-23 23:30:45 +02:00
|
|
|
{ NULL },
|
|
|
|
};
|
|
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
char *prog;
|
|
|
|
struct commands *cmd;
|
|
|
|
|
2007-10-09 16:33:25 +02:00
|
|
|
if (argc == 2 && !strcmp(argv[1], "cvs server"))
|
|
|
|
argv--;
|
2005-10-23 23:30:45 +02:00
|
|
|
/* We want to see "-c cmd args", and nothing else */
|
2007-10-09 16:33:25 +02:00
|
|
|
else if (argc != 3 || strcmp(argv[1], "-c"))
|
2005-10-23 23:30:45 +02:00
|
|
|
die("What do you think I am? A shell?");
|
|
|
|
|
|
|
|
prog = argv[2];
|
|
|
|
argv += 2;
|
|
|
|
argc -= 2;
|
|
|
|
for (cmd = cmd_list ; cmd->name ; cmd++) {
|
|
|
|
int len = strlen(cmd->name);
|
|
|
|
char *arg;
|
|
|
|
if (strncmp(cmd->name, prog, len))
|
|
|
|
continue;
|
|
|
|
arg = NULL;
|
|
|
|
switch (prog[len]) {
|
|
|
|
case '\0':
|
|
|
|
arg = NULL;
|
|
|
|
break;
|
|
|
|
case ' ':
|
|
|
|
arg = prog + len + 1;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
exit(cmd->exec(cmd->name, arg));
|
|
|
|
}
|
|
|
|
die("unrecognized command '%s'", prog);
|
|
|
|
}
|