diff options
author | Carlos Martín Nieto <cmn@elego.de> | 2011-05-17 12:12:59 +0200 |
---|---|---|
committer | Carlos Martín Nieto <cmn@elego.de> | 2011-05-17 12:12:59 +0200 |
commit | 94711cad3b83445dfcf45a6e0b29b045e06a29f6 (patch) | |
tree | c0b5560d53aac94756a4d9759fdcf25f1582c40f /src/errors.c | |
parent | c0335005495c1b49986d19031557f9df6bf49922 (diff) | |
parent | 335d6c998041f7c44dce48d3bb087c52136d970f (diff) | |
download | libgit2-94711cad3b83445dfcf45a6e0b29b045e06a29f6.tar.gz |
Merge upstream/development
Diffstat (limited to 'src/errors.c')
-rw-r--r-- | src/errors.c | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/src/errors.c b/src/errors.c index 1ef2baadb..1fb68ee65 100644 --- a/src/errors.c +++ b/src/errors.c @@ -1,6 +1,35 @@ +/* + * This file is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License, version 2, + * as published by the Free Software Foundation. + * + * In addition to the permissions in the GNU General Public License, + * the authors give you unlimited permission to link the compiled + * version of this file into combinations with other programs, + * and to distribute those combinations without any restriction + * coming from the use of this file. (The General Public License + * restrictions do apply in other respects; for example, they cover + * modification of the file, and distribution when not linked into + * a combined executable.) + * + * This file is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; see the file COPYING. If not, write to + * the Free Software Foundation, 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. + */ #include "common.h" +#include "git2/thread-utils.h" /* for GIT_TLS */ #include "thread-utils.h" /* for GIT_TLS */ +#include <stdarg.h> + +static GIT_TLS char g_last_error[1024]; + static struct { int num; const char *str; @@ -46,3 +75,38 @@ const char *git_strerror(int num) return "Unknown error"; } + +int git__rethrow(int error, const char *msg, ...) +{ + char new_error[1024]; + char *old_error = NULL; + + va_list va; + + va_start(va, msg); + vsnprintf(new_error, sizeof(new_error), msg, va); + va_end(va); + + old_error = strdup(g_last_error); + snprintf(g_last_error, sizeof(g_last_error), "%s \n - %s", new_error, old_error); + free(old_error); + + return error; +} + +int git__throw(int error, const char *msg, ...) +{ + va_list va; + + va_start(va, msg); + vsnprintf(g_last_error, sizeof(g_last_error), msg, va); + va_end(va); + + return error; +} + +const char *git_lasterror(void) +{ + return g_last_error; +} + |