summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2005-09-10 04:40:27 +0000
committerRoger Dingledine <arma@torproject.org>2005-09-10 04:40:27 +0000
commitcfe34812eba0d4a1e8beeab64e60b6fcf760391c (patch)
tree9790669a45dc098a9471b1dce522e3cb40c51eae /src/or
parente782ee344ac10a6541a48fe551065c0229130e5d (diff)
downloadtor-cfe34812eba0d4a1e8beeab64e60b6fcf760391c.tar.gz
tor-cfe34812eba0d4a1e8beeab64e60b6fcf760391c.zip
bugfix: if you gave tor an odd number of command-line arguments,
we were silently ignoring the last one. now we complain and fail. svn:r4988
Diffstat (limited to 'src/or')
-rw-r--r--src/or/config.c26
1 files changed, 18 insertions, 8 deletions
diff --git a/src/or/config.c b/src/or/config.c
index cf8b07be7f..7d4b77320c 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -592,16 +592,18 @@ expand_abbrev(config_format_t *fmt, const char *option, int command_line)
return option;
}
-/** Helper: Read a list of configuration options from the command line. */
-static config_line_t *
-config_get_commandlines(int argc, char **argv)
+/** Helper: Read a list of configuration options from the command line.
+ * If successful, put them in *<b>result</b> and return 0, and return
+ * -1 and leave *<b>result</b> alone. */
+static int
+config_get_commandlines(int argc, char **argv, config_line_t **result)
{
config_line_t *front = NULL;
config_line_t **new = &front;
char *s;
int i = 1;
- while (i < argc-1) {
+ while (i < argc) {
if (!strcmp(argv[i],"-f") ||
!strcmp(argv[i],"--hash-password")) {
i += 2; /* command-line option with argument. ignore them. */
@@ -613,6 +615,12 @@ config_get_commandlines(int argc, char **argv)
i += 1;
continue;
}
+ if (i == argc-1) {
+ log_fn(LOG_WARN,"Command-line option '%s' with no value. Failing.",
+ argv[i]);
+ config_free_lines(front);
+ return -1;
+ }
*new = tor_malloc_zero(sizeof(config_line_t));
s = argv[i];
@@ -629,7 +637,8 @@ config_get_commandlines(int argc, char **argv)
new = &((*new)->next);
i += 2;
}
- return front;
+ *result = front;
+ return 0;
}
/** Helper: allocate a new configuration option mapping 'key' to 'val',
@@ -2225,7 +2234,7 @@ options_init_from_torrc(int argc, char **argv)
newoptions->_magic = OR_OPTIONS_MAGIC;
options_init(newoptions);
- /* learn config file name, get config lines, assign them */
+ /* learn config file name */
fname = NULL;
using_default_torrc = 1;
newoptions->command = CMD_RUN_TOR;
@@ -2248,7 +2257,6 @@ options_init_from_torrc(int argc, char **argv)
newoptions->command = CMD_VERIFY_CONFIG;
}
}
-
if (using_default_torrc) {
/* didn't find one, try CONFDIR */
const char *dflt = get_default_conf_file();
@@ -2272,6 +2280,7 @@ options_init_from_torrc(int argc, char **argv)
tor_assert(fname);
log(LOG_DEBUG, "Opening config file \"%s\"", fname);
+ /* get config lines, assign them */
if (file_status(fname) != FN_FILE ||
!(cf = read_file_to_str(fname,0))) {
if (using_default_torrc == 1) {
@@ -2295,7 +2304,8 @@ options_init_from_torrc(int argc, char **argv)
}
/* Go through command-line variables too */
- cl = config_get_commandlines(argc, argv);
+ if (config_get_commandlines(argc, argv, &cl) < 0)
+ goto err;
retval = config_assign(&options_format, newoptions, cl, 0);
config_free_lines(cl);
if (retval < 0)