diff options
author | Andreas Ericsson <ae@op5.se> | 2008-11-18 22:20:15 +0100 |
---|---|---|
committer | Shawn O. Pearce <spearce@spearce.org> | 2008-11-22 12:08:00 -0800 |
commit | ae23486285f4e16896afd53b20dd11180d26381a (patch) | |
tree | 4a65039859952e2ffe776d2e1afbe0c7ea02d14c /src | |
parent | 3a2aabdce127a367aa27a4c27025199230e26c15 (diff) | |
download | libgit2-ae23486285f4e16896afd53b20dd11180d26381a.tar.gz |
Add an embryo of a TLS-aware error handling system
This adds the per-thread global variable git_errno to the
system, which callers can examine to get information about
an error.
Two helper functions are added to reduce LoC-count for the
library code itself.
Also, some exceptions are made for running sparse on GIT_TLS
definitions, since it doesn't grok thread-local variables at
all.
Signed-off-by: Andreas Ericsson <ae@op5.se>
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Diffstat (limited to 'src')
-rw-r--r-- | src/common.h | 1 | ||||
-rw-r--r-- | src/errors.c | 23 | ||||
-rw-r--r-- | src/errors.h | 17 | ||||
-rw-r--r-- | src/git/errors.h | 25 | ||||
-rw-r--r-- | src/git/thread-utils.h | 7 |
5 files changed, 73 insertions, 0 deletions
diff --git a/src/common.h b/src/common.h index 5a6fa6e57..1a2e9c0f1 100644 --- a/src/common.h +++ b/src/common.h @@ -3,6 +3,7 @@ #include "cc-compat.h" #include "util.h" +#include "errors.h" #include <errno.h> #include <stdlib.h> #include <unistd.h> diff --git a/src/errors.c b/src/errors.c new file mode 100644 index 000000000..b3e014dd4 --- /dev/null +++ b/src/errors.c @@ -0,0 +1,23 @@ +#include "common.h" +#include "thread-utils.h" /* for GIT_TLS */ + +/* compile-time constant initialization required */ +GIT_TLS int git_errno = 0; + +static struct { + int num; + const char *str; +} error_codes[] = { + { GIT_ENOTOID, "Not a git oid" }, + { GIT_ENOTFOUND, "Object does not exist in the scope searched" }, +}; + +const char *git_strerror(int num) +{ + int i; + for (i = 0; i < ARRAY_SIZE(error_codes); i++) + if (num == error_codes[i].num) + return error_codes[i].str; + + return "Unknown error"; +} diff --git a/src/errors.h b/src/errors.h new file mode 100644 index 000000000..e323fc511 --- /dev/null +++ b/src/errors.h @@ -0,0 +1,17 @@ +#ifndef INCLUDE_errors_h__ +#define INCLUDE_errors_h__ +#include "git/errors.h" + +/* convenience functions */ +static inline int git_int_error(int code) +{ + git_errno = code; + return code; +} + +static inline void *git_ptr_error(int code) +{ + git_errno = code; + return NULL; +} +#endif diff --git a/src/git/errors.h b/src/git/errors.h new file mode 100644 index 000000000..d0a0d6308 --- /dev/null +++ b/src/git/errors.h @@ -0,0 +1,25 @@ +#ifndef INCLUDE_git_errors_h__ +#define INCLUDE_git_errors_h__ +/** + * @file git/errors.h + * @brief Git error handling routines and variables + * @ingroup Git + * @{ + */ + +#include "common.h" +#include "thread-utils.h" +GIT_BEGIN_DECL + +/** The git errno. */ +GIT_EXTERN(int) GIT_TLS git_errno; + +/** + * strerror() for the Git library + * @param num The error code to explain + * @return a string explaining the error code + */ +GIT_EXTERN(const char *) git_strerror(int num); +/** @} */ +GIT_END_DECL +#endif diff --git a/src/git/thread-utils.h b/src/git/thread-utils.h index f2ddf1eec..7ce66fdc1 100644 --- a/src/git/thread-utils.h +++ b/src/git/thread-utils.h @@ -22,4 +22,11 @@ # define GIT_TLS /* nothing: tls vars are thread-global */ #endif +/* sparse doesn't grok thread-local variables */ +#ifdef SPARSE_IS_RUNNING +# undef GIT_HAS_TLS +# undef GIT_TLS +# define GIT_TLS +#endif + #endif /* INCLUDE_git_thread_utils_h__ */ |