diff options
author | Nick Mathewson <nickm@torproject.org> | 2017-03-13 16:43:30 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-03-13 16:43:30 -0400 |
commit | dc37ea8b9815e75905a6b8b606947866afc9b27b (patch) | |
tree | 73053e434184e8725c3f25ff07eedbee0aadddb3 | |
parent | d9cd4b7072f6292680c188ccb9fe8d2c5be4f610 (diff) | |
download | tor-dc37ea8b9815e75905a6b8b606947866afc9b27b.tar.gz tor-dc37ea8b9815e75905a6b8b606947866afc9b27b.zip |
Add a null statement to prevent some SMARTLIST_FOREACH() bugs.
So we require that SMARTLIST_FOREACH_END() have the name of the loop
variable in it. But right now the only enforcement for that is to
clear the variable at the end of the loop, which is really not
sufficient: I spent 45 minutes earlier today debugging an issue
where I had said:
SMARTLIST_FOREACH_BEGIN(spool, spooled_resource_t *, spooled) {
...
} SMARTLIST_FOREACH_END(spool);
This patch makes it so that ONLY loop variables can be used, by
referring to the _sl_idx variable.
-rw-r--r-- | src/common/container.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/common/container.h b/src/common/container.h index 00c3ca81ad..826b5d1be3 100644 --- a/src/common/container.h +++ b/src/common/container.h @@ -224,6 +224,7 @@ char *smartlist_join_strings2(smartlist_t *sl, const char *join, #define SMARTLIST_FOREACH_END(var) \ var = NULL; \ + (void) var ## _sl_idx; \ } STMT_END /** |