1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
|
#include "xdo_cmd.h"
int cmd_windowunmap(context_t *context) {
int ret = 0;
char *cmd = *context->argv;
const char *window_arg = "%1";
int opsync;
int c;
typedef enum {
opt_unused, opt_help, opt_sync, opt_verbose
} optlist_t;
static struct option longopts[] = {
{ "help", no_argument, NULL, opt_help },
{ "sync", no_argument, NULL, opt_sync },
{ 0, 0, 0, 0 },
};
static const char *usage =
"Usage: %s [--sync] [window=%1]\n"
"--sync - only exit once the window has been unmapped (is hidden)\n"
HELP_SEE_WINDOW_STACK;
int option_index;
while ((c = getopt_long_only(context->argc, context->argv, "+h",
longopts, &option_index)) != -1) {
switch (c) {
case 'h':
case opt_help:
printf(usage, cmd);
consume_args(context, context->argc);
return EXIT_SUCCESS;
break;
case opt_sync:
opsync = 1;
break;
default:
fprintf(stderr, usage, cmd);
return EXIT_FAILURE;
}
}
consume_args(context, optind);
if (!window_get_arg(context, 0, 0, &window_arg)) {
fprintf(stderr, usage, cmd);
return EXIT_FAILURE;
}
window_each(context, window_arg, {
ret = xdo_window_unmap(context->xdo, window);
if (ret) {
fprintf(stderr, "xdo_window_unmap reported an error\n");
}
if (opsync) {
xdo_window_wait_for_map_state(context->xdo, window, IsUnmapped);
}
}); /* window_each(...) */
return ret;
}
|