Commit 60bc2d20 by Vicent Martí

error-handling: Add new routines

Obviously all the old throw routines are still in place, so we can
gradually port over.
parent 845f8314
...@@ -113,8 +113,23 @@ typedef enum { ...@@ -113,8 +113,23 @@ typedef enum {
/** The buffer is too short to satisfy the request */ /** The buffer is too short to satisfy the request */
GIT_ESHORTBUFFER = -32, GIT_ESHORTBUFFER = -32,
} git_error_t;
typedef struct {
char *message;
int klass;
} git_error; } git_error;
typedef enum {
GITERR_NOMEMORY,
} git_error_class;
GIT_EXTERN(void) giterr_set(git_error **error_out, int error_class, const char *string, ...);
GIT_EXTERN(void) giterr_set_oom(git_error **error);
GIT_EXTERN(void) giterr_free(git_error *error);
GIT_EXTERN(void) giterr_clear(git_error **error);
/** /**
* Return a detailed error string with the latest error * Return a detailed error string with the latest error
* that occurred in the library. * that occurred in the library.
......
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
*/ */
#include "common.h" #include "common.h"
#include "global.h" #include "global.h"
#include "posix.h"
#include <stdarg.h> #include <stdarg.h>
static struct { static struct {
...@@ -102,3 +103,66 @@ void git_clearerror(void) ...@@ -102,3 +103,66 @@ void git_clearerror(void)
char *last_error = GIT_GLOBAL->error.last; char *last_error = GIT_GLOBAL->error.last;
last_error[0] = '\0'; last_error[0] = '\0';
} }
/********************************************
* New error handling
********************************************/
void giterr_set(git_error **error_out, int error_class, const char *string, ...)
{
char error_str[1024];
va_list arglist;
git_error *error;
if (error_out == NULL)
return;
error = git__malloc(sizeof(git_error));
if (!error) {
giterr_set_oom(error_out);
return;
}
va_start(arglist, string);
p_vsnprintf(error_str, sizeof(error_str), string, arglist);
va_end(arglist);
error->message = git__strdup(error_str);
error->klass = error_class;
if (error->message == NULL) {
free(error);
giterr_set_oom(error_out);
return;
}
*error_out = error;
}
static git_error g_git_oom_error = {
"Out of memory",
GITERR_NOMEMORY
};
void giterr_set_oom(git_error **error)
{
if (error != NULL)
*error = &g_git_oom_error;
}
void giterr_free(git_error *error)
{
if (error == NULL || error == &g_git_oom_error)
return;
free(error->message);
free(error);
}
void giterr_clear(git_error **error)
{
if (error != NULL) {
giterr_free(*error);
*error = NULL;
}
}
...@@ -341,8 +341,12 @@ done: ...@@ -341,8 +341,12 @@ done:
int p_vsnprintf(char *buffer, size_t count, const char *format, va_list argptr) int p_vsnprintf(char *buffer, size_t count, const char *format, va_list argptr)
{ {
#ifdef _MSC_VER #ifdef _MSC_VER
int len = _vsnprintf(buffer, count, format, argptr); int len;
return (len < 0) ? _vscprintf(format, argptr) : len;
if (count == 0 || (len = _vsnprintf(buffer, count, format, argptr)) < 0)
return p_vscprintf(format, argptr);
return len;
#else /* MinGW */ #else /* MinGW */
return vsnprintf(buffer, count, format, argptr); return vsnprintf(buffer, count, format, argptr);
#endif #endif
......
...@@ -24,7 +24,7 @@ void test_object_tree_frompath__cleanup(void) ...@@ -24,7 +24,7 @@ void test_object_tree_frompath__cleanup(void)
cl_fixture_cleanup("testrepo.git"); cl_fixture_cleanup("testrepo.git");
} }
static void assert_tree_from_path(git_tree *root, const char *path, git_error expected_result, const char *expected_raw_oid) static void assert_tree_from_path(git_tree *root, const char *path, int expected_result, const char *expected_raw_oid)
{ {
git_tree *containing_tree = NULL; git_tree *containing_tree = NULL;
......
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