diff options
author | Christian Grothoff <christian@grothoff.org> | 2017-10-17 14:04:08 +0200 |
---|---|---|
committer | Christian Grothoff <christian@grothoff.org> | 2017-10-17 19:53:44 +0200 |
commit | 0346e37504745d75a6fc90c404d1c9400960af2a (patch) | |
tree | 37d2b2b01be326fb30c56679dba9b780290a93f7 /src | |
parent | e4fe0dc87eb484f045919a441cacfee3d5c94c31 (diff) |
actually properly implement API wrt return value handling, even if not used today
Diffstat (limited to 'src')
-rw-r--r-- | src/exchangedb/exchangedb_auditorkeys.c | 36 |
1 files changed, 27 insertions, 9 deletions
diff --git a/src/exchangedb/exchangedb_auditorkeys.c b/src/exchangedb/exchangedb_auditorkeys.c index 880e186fa..a84d06084 100644 --- a/src/exchangedb/exchangedb_auditorkeys.c +++ b/src/exchangedb/exchangedb_auditorkeys.c @@ -1,6 +1,6 @@ /* This file is part of TALER - Copyright (C) 2014, 2015, 2016 Inria & GNUnet e.V. + Copyright (C) 2014, 2015, 2016, 2017 Inria & GNUnet e.V. TALER is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software @@ -40,6 +40,11 @@ struct AuditorIterateContext * Closure for @e it. */ void *it_cls; + + /** + * Status of the iteration. + */ + int status; }; @@ -94,6 +99,7 @@ auditor_iter (void *cls, const char *auditor_url; unsigned int dki_len; size_t url_len; + int iret; if (GNUNET_OK != GNUNET_DISK_file_size (filename, &size, @@ -160,14 +166,22 @@ auditor_iter (void *cls, GNUNET_free (af); return GNUNET_OK; } - /*Ignoring return value to not interrupt the iteration*/ - aic->it (aic->it_cls, - &af->apub, - auditor_url, - &af->mpub, - dki_len, - sigs, - dki); + /* Ignoring return value to not interrupt the iteration */ + if (GNUNET_OK != + (iret = aic->it (aic->it_cls, + &af->apub, + auditor_url, + &af->mpub, + dki_len, + sigs, + dki))) + { + GNUNET_free (af); + if (GNUNET_SYSERR == iret) + aic->status = GNUNET_SYSERR; + return GNUNET_SYSERR; + } + aic->status++; GNUNET_free (af); return GNUNET_OK; } @@ -201,10 +215,14 @@ TALER_EXCHANGEDB_auditor_iterate (const struct GNUNET_CONFIGURATION_Handle *cfg, return -1; aic.it = it; aic.it_cls = it_cls; + aic.status = 0; ret = GNUNET_DISK_directory_scan (auditor_base_dir, &auditor_iter, &aic); GNUNET_free (auditor_base_dir); + if ( (0 != aic.status) || + (GNUNET_OK == ret) ) + return aic.status; return ret; } |