summaryrefslogtreecommitdiff
path: root/src/errors.c
diff options
context:
space:
mode:
authorVicent Martí <vicent@github.com>2013-02-01 15:57:31 -0800
committerVicent Martí <vicent@github.com>2013-02-01 15:57:31 -0800
commite963166019de3dca72d18bd4ee8f81519e97fdf3 (patch)
treedd79c4cc5fdadd74665014881abe337681d5d872 /src/errors.c
parentdb37d3de7957a9189d29c64dfc0830e93084202e (diff)
parentc70455c75e30bf2a4cc5abdf4229d12d0e6cf159 (diff)
downloadlibgit2-e963166019de3dca72d18bd4ee8f81519e97fdf3.tar.gz
Merge pull request #1303 from csware/win32_consistent_error_encoding
Win32: Make sure error messages are consistently UTF-8 encoded
Diffstat (limited to 'src/errors.c')
-rw-r--r--src/errors.c17
1 files changed, 5 insertions, 12 deletions
diff --git a/src/errors.c b/src/errors.c
index d9827fb2b..3aa1757b2 100644
--- a/src/errors.c
+++ b/src/errors.c
@@ -51,18 +51,11 @@ void giterr_set(int error_class, const char *string, ...)
if (error_class == GITERR_OS) {
#ifdef GIT_WIN32
- if (win32_error_code) {
- char *lpMsgBuf;
-
- if (FormatMessageA(
- FORMAT_MESSAGE_ALLOCATE_BUFFER |
- FORMAT_MESSAGE_FROM_SYSTEM |
- FORMAT_MESSAGE_IGNORE_INSERTS,
- NULL, win32_error_code, 0, (LPSTR)&lpMsgBuf, 0, NULL)) {
- git_buf_PUTS(&buf, ": ");
- git_buf_puts(&buf, lpMsgBuf);
- LocalFree(lpMsgBuf);
- }
+ char * win32_error = git_win32_get_error_message(win32_error_code);
+ if (win32_error) {
+ git_buf_PUTS(&buf, ": ");
+ git_buf_puts(&buf, win32_error);
+ git__free(win32_error);
SetLastError(0);
}