Commit 687ec68b by Carlos Martín Nieto

http: use the new unicode functions

The winhttp branch was based on a version before these existed, so the
build broke on Windows.
parent db066a96
...@@ -114,7 +114,8 @@ static int send_request(transport_http *t, const char *service, void *data, ssiz ...@@ -114,7 +114,8 @@ static int send_request(transport_http *t, const char *service, void *data, ssiz
return 0; return 0;
#else #else
wchar_t *url, *verb, *ct; wchar_t *verb;
wchar_t url[GIT_WIN_PATH], ct[GIT_WIN_PATH];
git_buf buf = GIT_BUF_INIT; git_buf buf = GIT_BUF_INIT;
BOOL ret; BOOL ret;
DWORD flags; DWORD flags;
...@@ -136,12 +137,9 @@ static int send_request(transport_http *t, const char *service, void *data, ssiz ...@@ -136,12 +137,9 @@ static int send_request(transport_http *t, const char *service, void *data, ssiz
if (git_buf_oom(&buf)) if (git_buf_oom(&buf))
return -1; return -1;
url = gitwin_to_utf16(git_buf_cstr(&buf)); git__utf8_to_16(url, GIT_WIN_PATH, git_buf_cstr(&buf));
if (!url)
goto on_error;
t->request = WinHttpOpenRequest(t->connection, verb, url, NULL, WINHTTP_NO_REFERER, types, flags); t->request = WinHttpOpenRequest(t->connection, verb, url, NULL, WINHTTP_NO_REFERER, types, flags);
git__free(url);
if (t->request == NULL) { if (t->request == NULL) {
git_buf_free(&buf); git_buf_free(&buf);
giterr_set(GITERR_OS, "Failed to open request"); giterr_set(GITERR_OS, "Failed to open request");
...@@ -151,9 +149,8 @@ static int send_request(transport_http *t, const char *service, void *data, ssiz ...@@ -151,9 +149,8 @@ static int send_request(transport_http *t, const char *service, void *data, ssiz
git_buf_clear(&buf); git_buf_clear(&buf);
if (git_buf_printf(&buf, "Content-Type: application/x-git-%s-request", service) < 0) if (git_buf_printf(&buf, "Content-Type: application/x-git-%s-request", service) < 0)
goto on_error; goto on_error;
ct = gitwin_to_utf16(git_buf_cstr(&buf));
if (!ct) git__utf8_to_16(ct, GIT_WIN_PATH, git_buf_cstr(&buf));
goto on_error;
if (WinHttpAddRequestHeaders(t->request, ct, (ULONG) -1L, WINHTTP_ADDREQ_FLAG_ADD) == FALSE) { if (WinHttpAddRequestHeaders(t->request, ct, (ULONG) -1L, WINHTTP_ADDREQ_FLAG_ADD) == FALSE) {
giterr_set(GITERR_OS, "Failed to add a header to the request"); giterr_set(GITERR_OS, "Failed to add a header to the request");
...@@ -205,7 +202,7 @@ static int do_connect(transport_http *t) ...@@ -205,7 +202,7 @@ static int do_connect(transport_http *t)
return 0; return 0;
#else #else
wchar_t *ua = L"git/1.0 (libgit2 " WIDEN(LIBGIT2_VERSION) L")"; wchar_t *ua = L"git/1.0 (libgit2 " WIDEN(LIBGIT2_VERSION) L")";
wchar_t *host; wchar_t host[GIT_WIN_PATH];
int32_t port; int32_t port;
t->session = WinHttpOpen(ua, WINHTTP_ACCESS_TYPE_DEFAULT_PROXY, t->session = WinHttpOpen(ua, WINHTTP_ACCESS_TYPE_DEFAULT_PROXY,
...@@ -216,15 +213,12 @@ static int do_connect(transport_http *t) ...@@ -216,15 +213,12 @@ static int do_connect(transport_http *t)
goto on_error; goto on_error;
} }
host = gitwin_to_utf16(t->host); git__utf8_to_16(host, GIT_WIN_PATH, t->host);
if (host == NULL)
goto on_error;
if (git__strtol32(&port, t->port, NULL, 10) < 0) if (git__strtol32(&port, t->port, NULL, 10) < 0)
goto on_error; goto on_error;
t->connection = WinHttpConnect(t->session, host, port, 0); t->connection = WinHttpConnect(t->session, host, port, 0);
git__free(host);
if (t->connection == NULL) { if (t->connection == NULL) {
giterr_set(GITERR_OS, "Failed to connect to host"); giterr_set(GITERR_OS, "Failed to connect to host");
goto on_error; goto on_error;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment