commit a114df9a040dbdedfc89f7d2ff777476e204a2cf
parent a91ed23403ae28974639a9bdb67530c5c07a0ce6
Author: Nick Mathewson <nickm@torproject.org>
Date: Wed, 19 Jun 2019 16:06:15 -0400
Add a function to make sure all values in a config object are ok
Diffstat:
2 files changed, 20 insertions(+), 0 deletions(-)
diff --git a/src/app/config/confparse.c b/src/app/config/confparse.c
@@ -673,3 +673,21 @@ config_dump(const config_format_t *fmt, const void *default_options,
}
return result;
}
+
+/**
+ * Return true if every member of <b>options</b> is in-range and well-formed.
+ * Return false otherwise. Log errors at level <b>severity</b>.
+ */
+bool
+config_check_ok(const config_format_t *fmt, const void *options, int severity)
+{
+ bool all_ok = true;
+ for (int i=0; fmt->vars[i].member.name; ++i) {
+ if (!struct_var_ok(options, &fmt->vars[i].member)) {
+ log_fn(severity, LD_BUG, "Invalid value for %s",
+ fmt->vars[i].member.name);
+ all_ok = false;
+ }
+ }
+ return all_ok;
+}
diff --git a/src/app/config/confparse.h b/src/app/config/confparse.h
@@ -138,6 +138,8 @@ void *config_dup(const config_format_t *fmt, const void *old);
char *config_dump(const config_format_t *fmt, const void *default_options,
const void *options, int minimal,
int comment_defaults);
+bool config_check_ok(const config_format_t *fmt, const void *options,
+ int severity);
int config_assign(const config_format_t *fmt, void *options,
struct config_line_t *list,
unsigned flags, char **msg);