summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2013-07-07 22:03:08 +0000
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2013-07-07 22:03:08 +0000
commitad8a2eab60a733fafb3b381a9604a623f2a75762 (patch)
treee2da6b915a8a92345366379fb1a90a67b7fb74bc
parentfa9f3b3566f8b3c792072472e3230fabf46407f2 (diff)
parente03fc07ab9285a8aaf0d801fc8f1f86d203f6129 (diff)
Merge remote-tracking branch 'procfs/master' into procfs-jkoenig
-rw-r--r--main.c42
1 files changed, 28 insertions, 14 deletions
diff --git a/main.c b/main.c
index 3a976ccc..1b19c013 100644
--- a/main.c
+++ b/main.c
@@ -42,36 +42,45 @@ argp_parser (int key, char *arg, struct argp_state *state)
{
struct passwd *pw;
char *endp;
+ long int v;
switch (key)
{
case 'h':
- opt_clk_tck = strtol (arg, &endp, 0);
- if (*endp || ! *arg || opt_clk_tck <= 0)
- error (1, 0, "--clk-tck: HZ should be a positive integer");
+ v = strtol (arg, &endp, 0);
+ if (*endp || ! *arg || v <= 0)
+ argp_error (state, "--clk-tck: HZ should be a positive integer");
+ else
+ opt_clk_tck = v;
break;
case 's':
- opt_stat_mode = strtol (arg, &endp, 8);
- if (*endp || ! *arg || opt_stat_mode & ~07777)
- error (1, 0, "--stat-mode: MODE should be an octal mode");
+ v = strtol (arg, &endp, 8);
+ if (*endp || ! *arg || (mode_t) v & ~07777)
+ argp_error (state, "--stat-mode: MODE should be an octal mode");
+ else
+ opt_stat_mode = v;
break;
case 'S':
if (arg)
{
- opt_fake_self = strtol (arg, &endp, 0);
+ v = strtol (arg, &endp, 0);
if (*endp || ! *arg)
- error (1, 0, "--fake-self: PID must be an integer");
+ argp_error (state, "--fake-self: PID must be an integer");
+ else
+ opt_fake_self = v;
}
else
opt_fake_self = 1;
break;
case 'k':
- opt_kernel_pid = strtol (arg, &endp, 0);
+ v = strtol (arg, &endp, 0);
if (*endp || ! *arg || (signed) opt_kernel_pid < 0)
- error (1, 0, "--kernel-process: PID must be a positive integer");
+ argp_error (state, "--kernel-process: PID must be a positive integer");
+ else
+ opt_kernel_pid = v;
break;
case 'c':
@@ -88,10 +97,12 @@ argp_parser (int key, char *arg, struct argp_state *state)
break;
}
- opt_anon_owner = strtol (arg, &endp, 0);
- if (*endp || ! *arg || (signed) opt_anon_owner < 0)
- error(1, 0, "--anonymous-owner: USER should be the a user name "
- "or a numeric UID.");
+ v = strtol (arg, &endp, 0);
+ if (*endp || ! *arg || v < 0)
+ argp_error (state, "--anonymous-owner: USER should be "
+ "a user name or a numeric UID.");
+ else
+ opt_anon_owner = v;
break;
}
@@ -135,6 +146,9 @@ struct argp argp = {
},
};
+/* Used by netfs_set_options to handle runtime option parsing. */
+struct argp *netfs_runtime_argp = &argp;
+
error_t
root_make_node (struct ps_context *pc, struct node **np)
{