summaryrefslogtreecommitdiff
path: root/src/or/router.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-02-24 19:49:35 +0000
committerNick Mathewson <nickm@torproject.org>2007-02-24 19:49:35 +0000
commit501659e67cb246945f936db10cbb6ef7ff6fea90 (patch)
tree86c1e025a665dde8040b635fbf73a1e7b117034d /src/or/router.c
parent4147952f0a78e71525d4585275a8cc851a5e175a (diff)
downloadtor-501659e67cb246945f936db10cbb6ef7ff6fea90.tar.gz
tor-501659e67cb246945f936db10cbb6ef7ff6fea90.zip
r11927@catbus: nickm | 2007-02-24 14:49:31 -0500
Make sure every error case of router_dump_router_to_string warns about what actually went wrong. svn:r9642
Diffstat (limited to 'src/or/router.c')
-rw-r--r--src/or/router.c27
1 files changed, 20 insertions, 7 deletions
diff --git a/src/or/router.c b/src/or/router.c
index 5856988b6d..556bb431f1 100644
--- a/src/or/router.c
+++ b/src/or/router.c
@@ -1242,16 +1242,20 @@ router_dump_router_to_string(char *s, size_t maxlen, routerinfo_t *router,
tor_free(identity_pkey);
tor_free(bandwidth_usage);
- if (result < 0)
+ if (result < 0) {
+ log_warn(LD_BUG,"descriptor snprintf #1 ran out of room!");
return -1;
+ }
/* From now on, we use 'written' to remember the current length of 's'. */
written = result;
if (options->ContactInfo && strlen(options->ContactInfo)) {
result = tor_snprintf(s+written,maxlen-written, "contact %s\n",
options->ContactInfo);
- if (result<0)
+ if (result<0) {
+ log_warn(LD_BUG,"descriptor snprintf #2 ran out of room!");
return -1;
+ }
written += result;
}
@@ -1265,24 +1269,31 @@ router_dump_router_to_string(char *s, size_t maxlen, routerinfo_t *router,
}
for ( ; tmpe; tmpe=tmpe->next) {
result = policy_write_item(s+written, maxlen-written, tmpe);
- if (result < 0)
+ if (result < 0) {
+ log_warn(LD_BUG,"descriptor policy_write_item ran out of room!");
return -1;
+ }
tor_assert(result == (int)strlen(s+written));
written += result;
- if (written+2 > maxlen)
+ if (written+2 > maxlen) {
+ log_warn(LD_BUG,"descriptor policy_write_item ran out of room (2)!");
return -1;
+ }
s[written++] = '\n';
}
- if (written+256 > maxlen) /* Not enough room for signature. */
+ if (written+256 > maxlen) { /* Not enough room for signature. */
+ log_warn(LD_BUG,"not enough room left in descriptor for signature!");
return -1;
+ }
/* Sign the directory */
strlcpy(s+written, "router-signature\n", maxlen-written);
written += strlen(s+written);
s[written] = '\0';
- if (router_get_router_hash(s, digest) < 0)
+ if (router_get_router_hash(s, digest) < 0) {
return -1;
+ }
note_crypto_pk_op(SIGN_RTR);
if (router_append_dirobj_signature(s+written,maxlen-written,
@@ -1292,8 +1303,10 @@ router_dump_router_to_string(char *s, size_t maxlen, routerinfo_t *router,
}
written += strlen(s+written);
- if (written+2 > maxlen)
+ if (written+2 > maxlen) {
+ log_warn(LD_BUG,"Not enough room to finish descriptor.");
return -1;
+ }
/* include a last '\n' */
s[written] = '\n';
s[written+1] = 0;