diff options
| author | Vicent Marti <tanoku@gmail.com> | 2011-10-01 13:10:29 +0200 | 
|---|---|---|
| committer | Vicent Marti <tanoku@gmail.com> | 2011-10-01 13:10:29 +0200 | 
| commit | 10063aeb41bdbdf8f887cbb93c8cc456b809aafb (patch) | |
| tree | 817bdad85193f536dd42c65d1b68022780d1a65b /src | |
| parent | 657ce4b5b6616967a17b7d4cc40c3ed02f01126e (diff) | |
| download | libgit2-10063aeb41bdbdf8f887cbb93c8cc456b809aafb.tar.gz | |
transport-git: Encapsulation ist gut
Diffstat (limited to 'src')
| -rw-r--r-- | src/transport_git.c | 27 | 
1 files changed, 11 insertions, 16 deletions
| diff --git a/src/transport_git.c b/src/transport_git.c index 8529fd47a..b9fe658cb 100644 --- a/src/transport_git.c +++ b/src/transport_git.c @@ -36,13 +36,12 @@ typedef struct {   *   * For example: 0035git-upload-pack /libgit2/libgit2\0host=github.com\0   */ -static int gen_proto(char **out, int *outlen, const char *cmd, const char *url) +static int gen_proto(git_buf *request, const char *cmd, const char *url)  {  	char *delim, *repo;  	char default_command[] = "git-upload-pack";  	char host[] = "host=";  	int len; -	git_buf buf = GIT_BUF_INIT;  	delim = strchr(url, '/');  	if (delim == NULL) @@ -59,31 +58,27 @@ static int gen_proto(char **out, int *outlen, const char *cmd, const char *url)  	len = 4 + strlen(cmd) + 1 + strlen(repo) + 1 + strlen(host) + (delim - url) + 1 + 1; -	git_buf_grow(&buf, len); +	git_buf_grow(request, len); +	git_buf_printf(request, "%04x%s %s%c%s", len, cmd, repo, 0, host); +	git_buf_put(request, url, delim - url); +	git_buf_putc(request, '\0'); -	git_buf_printf(&buf, "%04x%s %s%c%s", len, cmd, repo, 0, host); -	git_buf_put(&buf, url, delim - url); -	git_buf_putc(&buf, '\0'); - -	*outlen = len; -	*out = buf.ptr; - -	return GIT_SUCCESS; +	return git_buf_oom(request);  }  static int send_request(GIT_SOCKET s, const char *cmd, const char *url)  { -	int error, len; -	char *msg = NULL; +	int error; +	git_buf request = GIT_BUF_INIT; -	error = gen_proto(&msg, &len, cmd, url); +	error = gen_proto(&request, cmd, url);  	if (error < GIT_SUCCESS)  		goto cleanup; -	error = gitno_send(s, msg, len, 0); +	error = gitno_send(s, request.ptr, request.size, 0);  cleanup: -	free(msg); +	git_buf_free(&request);  	return error;  } | 
