summaryrefslogtreecommitdiff
path: root/utils/settrans.c
diff options
context:
space:
mode:
Diffstat (limited to 'utils/settrans.c')
-rw-r--r--utils/settrans.c71
1 files changed, 26 insertions, 45 deletions
diff --git a/utils/settrans.c b/utils/settrans.c
index e5f79847..10a05dba 100644
--- a/utils/settrans.c
+++ b/utils/settrans.c
@@ -53,7 +53,6 @@ usage(status)
-k, --keep-active Keep any currently running active translator\n\
when setting the passive translator\n\
-L, --dereference If a translator exists, put the new one on top\n\
- -t, --list Show FILE's passive translator\n\
--help Give this help list\n\
");
}
@@ -71,7 +70,6 @@ static struct option options[] =
{"create", no_argument, 0, 'c'},
{"force", no_argument, 0, 'f'},
{"dereference", no_argument, 0, 'L'},
- {"list", no_argument, 0, 't'},
{"help", no_argument, 0, '?'},
{0, 0, 0, 0}
};
@@ -100,8 +98,8 @@ main(int argc, char *argv[])
int flags = FS_TRANS_SET | FS_TRANS_EXCL;
/* Various option flags. */
- int passive = 0, active = 0, create = 0, force = 0, deref = 0, list = 0;
- int keep_active = 0;
+ int passive = 0, active = 0;
+ int create = 0, force = 0, deref = 0, keep_active = 0;
/* Parse our options... */
while ((opt = getopt_long(argc, argv, "+" SHORT_OPTIONS, options, 0)) != EOF)
@@ -113,16 +111,15 @@ main(int argc, char *argv[])
case 'k': keep_active = 1; break;
case 'c': create = 1; break;
case 'L': deref = 1; break;
- case 't': list = 1; break;
case '?': usage(0);
- default: usage(1);
+ default: usage(-1);
}
if (optind == argc)
{
fprintf(stderr,
"%s: Missing filename argument\n", program_invocation_name);
- usage(1);
+ usage(-1);
}
node_name = argv[optind++];
@@ -137,44 +134,28 @@ main(int argc, char *argv[])
if (node == MACH_PORT_NULL)
error(1, errno, "%s", node_name);
- if (list)
- /* Print out NODE's translator instead of setting it. */
- {
- char buf[1024], *trans = buf;
- int len = sizeof(buf);
-
- err = file_get_translator(node, &trans, &len);
- if (err)
- error(2, err, "%s", node_name);
-
- argz_stringify(trans, len);
- printf("%s\n", trans);
- }
- else
- {
- err = argz_create(argv + optind, &argz, &argz_len);
- if (err)
- error(3, err, "Can't create argz vector");
-
- if (active && argz_len > 0)
- err = start_translator(node, argz, argz_len, 60000, &active_control);
- if (err)
- 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,
- argz, argz_len,
- active_control, MACH_MSG_TYPE_MOVE_SEND);
- if (err)
- error(5, err, "%s", node_name);
- }
+ err = argz_create(argv + optind, &argz, &argz_len);
+ if (err)
+ error(3, err, "Can't create argz vector");
+
+ if (active && argz_len > 0)
+ err = start_translator(node, argz, argz_len, 60000, &active_control);
+ if (err)
+ 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,
+ argz, argz_len,
+ active_control, MACH_MSG_TYPE_MOVE_SEND);
+ if (err)
+ error(5, err, "%s", node_name);
exit(0);
}