diff options
Diffstat (limited to 'utils/settrans.c')
-rw-r--r-- | utils/settrans.c | 37 |
1 files changed, 21 insertions, 16 deletions
diff --git a/utils/settrans.c b/utils/settrans.c index ff18fee1..c0c21d15 100644 --- a/utils/settrans.c +++ b/utils/settrans.c @@ -37,11 +37,16 @@ static struct argp_option options[] = {"keep-active", 'k', 0, 0, "Keep any currently running active translator" " when setting the passive translator"}, {"create", 'c', 0, 0, "Create NODE if it doesn't exist"}, - {"force", 'f', 0, 0, "Set the translator even if one already exists"}, + {"goaway", 'g', 0, 0, "Make any existing translator go away"}, + {"recursive", 'R', 0, 0, "When killing an old translator, shutdown its children too"}, + {"force", 'f', 0, 0, "If an old active translator doesn't want to die, force it"}, + {"nosync", 'S', 0, 0, "Don't sync any existing translator's state before killing it"}, {"dereference", 'L', 0, 0, "If a translator exists, put the new one on top"}, {0, 0} }; static char *args_doc = "NODE [TRANSLATOR ARG...]"; +static char *doc = "By default, the passive translator is set, and any \ +active translator told to just go away."; /* ---------------------------------------------------------------- */ @@ -64,10 +69,11 @@ main(int argc, char *argv[]) /* Flags to pass to file_set_translator. By default we only set a translator if there's no existing one. */ int flags = FS_TRANS_SET | FS_TRANS_EXCL; + int lookup_flags = O_NOTRANS; + int goaway_flags = 0; /* Various option flags. */ - int passive = 0, active = 0; - int create = 0, force = 0, deref = 0, keep_active = 0; + int passive = 0, active = 0, keep_active = 0; /* Parse our options... */ error_t parse_opt (int key, char *arg, struct argp_state *state) @@ -87,27 +93,30 @@ main(int argc, char *argv[]) case 'a': active = 1; break; case 'p': passive = 1; break; - case 'f': force = 1; break; case 'k': keep_active = 1; break; - case 'c': create = 1; break; - case 'L': deref = 1; break; + + case 'c': lookup_flags |= O_CREAT; break; + case 'L': lookup_flags &= ~O_NOTRANS; break; + + case 'g': flags &= ~FS_TRANS_EXCL; break; + + case 'R': goaway_flags |= FSYS_GOAWAY_RECURSE; break; + case 'S': goaway_flags |= FSYS_GOAWAY_NOSYNC; break; + case 'f': goaway_flags |= FSYS_GOAWAY_FORCE; break; default: return EINVAL; } return 0; } - struct argp argp = {options, parse_opt, args_doc}; + struct argp argp = {options, parse_opt, args_doc, doc}; argp_parse (&argp, argc, argv, 0, 0); if (!active && !passive) passive = 1; - node = - file_name_lookup(node_name, - (deref ? 0 : O_NOTRANS) | (create ? O_CREAT : 0), - 0666); + node = file_name_lookup(node_name, lookup_flags, 0666); if (node == MACH_PORT_NULL) error(1, errno, "%s", node_name); @@ -120,15 +129,11 @@ main(int argc, char *argv[]) error(4, err, "%s", argz); } - if (force) - /* Kill any existing translators. */ - flags &= ~FS_TRANS_EXCL; - err = file_set_translator(node, passive ? flags : 0, (active || !keep_active) ? flags : 0, - 0, + goaway_flags, argz, argz_len, active_control, MACH_MSG_TYPE_MOVE_SEND); if (err) |