summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSven Strickroth <email@cs-ware.de>2013-02-01 22:22:26 +0100
committerSven Strickroth <email@cs-ware.de>2013-02-02 00:52:23 +0100
commitbd25a302d3232dea375f226602fdcdb3a83abcdc (patch)
tree625d5f261a6d37629ab8cc255761ae2ad44f0be7
parent89ad1c57a351809d3173e22a26c84e7a16adbe6b (diff)
downloadlibgit2-bd25a302d3232dea375f226602fdcdb3a83abcdc.tar.gz
Improved error handling
Signed-off-by: Sven Strickroth <email@cs-ware.de>
-rw-r--r--src/errors.c11
-rw-r--r--src/netops.c12
2 files changed, 19 insertions, 4 deletions
diff --git a/src/errors.c b/src/errors.c
index 1ab2894ed..56f07b624 100644
--- a/src/errors.c
+++ b/src/errors.c
@@ -64,8 +64,15 @@ void giterr_set(int error_class, const char *string, ...)
int utf8_size = WideCharToMultiByte(CP_UTF8, 0, lpMsgBuf, -1, NULL, 0, NULL, NULL);
char *lpMsgBuf_utf8 = git__malloc(utf8_size * sizeof(char));
- GITERR_CHECK_ALLOC(lpMsgBuf_utf8);
- WideCharToMultiByte(CP_UTF8, 0, lpMsgBuf, -1, lpMsgBuf_utf8, utf8_size, NULL, NULL);
+ if (lpMsgBuf_utf8 == NULL) {
+ LocalFree(lpMsgBuf);
+ return;
+ }
+ if (!WideCharToMultiByte(CP_UTF8, 0, lpMsgBuf, -1, lpMsgBuf_utf8, utf8_size, NULL, NULL)) {
+ LocalFree(lpMsgBuf);
+ git__free(lpMsgBuf_utf8);
+ return;
+ }
git_buf_PUTS(&buf, ": ");
git_buf_puts(&buf, lpMsgBuf_utf8);
diff --git a/src/netops.c b/src/netops.c
index c5554ef86..86579c7f2 100644
--- a/src/netops.c
+++ b/src/netops.c
@@ -48,8 +48,16 @@ static void net_set_error(const char *str)
int utf8_size = WideCharToMultiByte(CP_UTF8, 0, err_str, -1, NULL, 0, NULL, NULL);
char * err_str_utf8 = git__malloc(utf8_size * sizeof(char));
- GITERR_CHECK_ALLOC(err_str_utf8);
- WideCharToMultiByte(CP_UTF8, 0, err_str, -1, err_str_utf8, utf8_size, NULL, NULL);
+ if (err_str_utf8 == NULL) {
+ LocalFree(err_str);
+ return;
+ }
+
+ if (!WideCharToMultiByte(CP_UTF8, 0, err_str, -1, err_str_utf8, utf8_size, NULL, NULL)) {
+ LocalFree(err_str);
+ git__free(err_str_utf8);
+ return;
+ }
giterr_set(GITERR_NET, "%s: %s", str, err_str_utf8);
LocalFree(err_str);