[tor-commits] [tor/master] Whoops; make or_state_validate conform to validate_fn_t.

nickm at torproject.org nickm at torproject.org
Fri Sep 13 16:56:29 UTC 2013


commit ccbf1cfacde2327505afb69cb5443facb4065544
Author: Nick Mathewson <nickm at torproject.org>
Date:   Mon Sep 2 15:00:09 2013 -0400

    Whoops; make or_state_validate conform to validate_fn_t.
    
    Bugfix on 1293835440dd4debf6fbfc66e755d9b9384aa362, which implemented
    6752: Not in any released tor.
---
 src/or/statefile.c |   33 +++++++++++++++++++++------------
 1 file changed, 21 insertions(+), 12 deletions(-)

diff --git a/src/or/statefile.c b/src/or/statefile.c
index db9091c..8ab0476 100644
--- a/src/or/statefile.c
+++ b/src/or/statefile.c
@@ -91,8 +91,11 @@ static config_var_t state_vars_[] = {
 #undef VAR
 #undef V
 
-static int or_state_validate(or_state_t *old_options, or_state_t *options,
-                             int from_setconf, char **msg);
+static int or_state_validate(or_state_t *state, char **msg);
+
+static int or_state_validate_cb(void *old_options, void *options,
+                                void *default_options,
+                                int from_setconf, char **msg);
 
 /** Magic value for or_state_t. */
 #define OR_STATE_MAGIC 0x57A73f57
@@ -110,7 +113,7 @@ static const config_format_t state_format = {
   STRUCT_OFFSET(or_state_t, magic_),
   state_abbrevs_,
   state_vars_,
-  (validate_fn_t)or_state_validate,
+  or_state_validate_cb,
   &state_extra_var,
 };
 
@@ -195,21 +198,27 @@ validate_transports_in_state(or_state_t *state)
   return 0;
 }
 
-/** Return 0 if every setting in <b>state</b> is reasonable, and a
- * permissible transition from <b>old_state</b>.  Else warn and return -1.
- * Should have no side effects, except for normalizing the contents of
- * <b>state</b>.
- */
-/* XXX from_setconf is here because of bug 238 */
 static int
-or_state_validate(or_state_t *old_state, or_state_t *state,
-                  int from_setconf, char **msg)
+or_state_validate_cb(void *old_state, void *state, void *default_state,
+                     int from_setconf, char **msg)
 {
   /* We don't use these; only options do. Still, we need to match that
    * signature. */
   (void) from_setconf;
+  (void) default_state;
   (void) old_state;
 
+  return or_state_validate(state, msg);
+}
+
+/** Return 0 if every setting in <b>state</b> is reasonable, and a
+ * permissible transition from <b>old_state</b>.  Else warn and return -1.
+ * Should have no side effects, except for normalizing the contents of
+ * <b>state</b>.
+ */
+static int
+or_state_validate(or_state_t *state, char **msg)
+{
   if (entry_guards_parse_state(state, 0, msg)<0)
     return -1;
 
@@ -324,7 +333,7 @@ or_state_load(void)
     }
   }
 
-  if (!badstate && or_state_validate(NULL, new_state, 1, &errmsg) < 0)
+  if (!badstate && or_state_validate(new_state, &errmsg) < 0)
     badstate = 1;
 
   if (errmsg) {



More information about the tor-commits mailing list