summaryrefslogtreecommitdiffstats
path: root/src/error.c
diff options
context:
space:
mode:
authorAndreas Schneider <asn@cryptomilk.org>2011-09-17 10:28:39 +0200
committerAndreas Schneider <asn@cryptomilk.org>2011-09-17 10:38:08 +0200
commitc19c638d740d31928601d51e0a87459d35d7adbe (patch)
treeb311ef82db5e9b080fe204c30da7e886bdecb3ca /src/error.c
parentafa56e0102e84459e33e7f46544f1a4d843633d2 (diff)
downloadlibssh-c19c638d740d31928601d51e0a87459d35d7adbe.tar.gz
libssh-c19c638d740d31928601d51e0a87459d35d7adbe.tar.xz
libssh-c19c638d740d31928601d51e0a87459d35d7adbe.zip
error: Use macros for error functions.
Diffstat (limited to 'src/error.c')
-rw-r--r--src/error.c42
1 files changed, 28 insertions, 14 deletions
diff --git a/src/error.c b/src/error.c
index 46d6382..f4a2af0 100644
--- a/src/error.c
+++ b/src/error.c
@@ -48,14 +48,24 @@
*
* @param ... The arguments for the format string.
*/
-void ssh_set_error(void *error, int code, const char *descr, ...) {
- struct ssh_common_struct *err = error;
- va_list va;
- va_start(va, descr);
- vsnprintf(err->error.error_buffer, ERROR_BUFFERLEN, descr, va);
- va_end(va);
- err->error.error_code = code;
- ssh_log_common(err,SSH_LOG_RARE,"Error : %s",err->error.error_buffer);
+void _ssh_set_error(void *error,
+ int code,
+ const char *function,
+ const char *descr, ...)
+{
+ struct ssh_common_struct *err = error;
+ va_list va;
+
+ va_start(va, descr);
+ vsnprintf(err->error.error_buffer, ERROR_BUFFERLEN, descr, va);
+ va_end(va);
+
+ err->error.error_code = code;
+ ssh_log_common(err,
+ SSH_LOG_WARN,
+ function,
+ "Error: %s",
+ err->error.error_buffer);
}
/**
@@ -66,11 +76,13 @@ void ssh_set_error(void *error, int code, const char *descr, ...) {
* @param error The place to store the error.
*
*/
-void ssh_set_error_oom(void *error) {
- struct error_struct *err = error;
+void _ssh_set_error_oom(void *error, const char *function)
+{
+ struct error_struct *err = error;
- strcpy(err->error_buffer, "Out of memory");
- err->error_code = SSH_FATAL;
+ snprintf(err->error_buffer, sizeof(err->error_buffer),
+ "%s: Out of memory", function);
+ err->error_code = SSH_FATAL;
}
/**
@@ -83,8 +95,10 @@ void ssh_set_error_oom(void *error) {
* @param function The function the error happened in.
*
*/
-void ssh_set_error_invalid(void *error, const char *function) {
- ssh_set_error(error, SSH_FATAL, "Invalid argument in %s", function);
+void _ssh_set_error_invalid(void *error, const char *function)
+{
+ _ssh_set_error(error, SSH_FATAL, function,
+ "Invalid argument in %s", function);
}
/**