forked from jordansissel/xdotool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcmd_windowunmap.c
62 lines (53 loc) · 1.48 KB
/
cmd_windowunmap.c
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
#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_unmap_window(context->xdo, window);
if (ret) {
fprintf(stderr, "xdo_unmap_window reported an error\n");
}
if (opsync) {
xdo_wait_for_window_map_state(context->xdo, window, IsUnmapped);
}
}); /* window_each(...) */
return ret;
}