mirror of
https://github.com/git/git.git
synced 2025-01-10 01:23:41 +08:00
b7ce24d095
The `git serve` built-in was introduced in ed10cb952d
(serve:
introduce git-serve, 2018-03-15) as a backend to serve Git protocol v2,
probably originally intended to be spawned by `git upload-pack`.
However, in the version that the protocol v2 patches made it into core
Git, `git upload-pack` calls the `serve()` function directly instead of
spawning `git serve`; The only reason in life for `git serve` to survive
as a built-in command is to provide a way to test the protocol v2
functionality.
Meaning that it does not even have to be a built-in that is installed
with end-user facing Git installations, but it can be a test helper
instead.
Let's make it so.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
32 lines
823 B
C
32 lines
823 B
C
#include "test-tool.h"
|
|
#include "cache.h"
|
|
#include "parse-options.h"
|
|
#include "serve.h"
|
|
|
|
static char const * const serve_usage[] = {
|
|
N_("test-tool serve-v2 [<options>]"),
|
|
NULL
|
|
};
|
|
|
|
int cmd__serve_v2(int argc, const char **argv)
|
|
{
|
|
struct serve_options opts = SERVE_OPTIONS_INIT;
|
|
|
|
struct option options[] = {
|
|
OPT_BOOL(0, "stateless-rpc", &opts.stateless_rpc,
|
|
N_("quit after a single request/response exchange")),
|
|
OPT_BOOL(0, "advertise-capabilities", &opts.advertise_capabilities,
|
|
N_("exit immediately after advertising capabilities")),
|
|
OPT_END()
|
|
};
|
|
const char *prefix = setup_git_directory();
|
|
|
|
/* ignore all unknown cmdline switches for now */
|
|
argc = parse_options(argc, argv, prefix, options, serve_usage,
|
|
PARSE_OPT_KEEP_DASHDASH |
|
|
PARSE_OPT_KEEP_UNKNOWN);
|
|
serve(&opts);
|
|
|
|
return 0;
|
|
}
|