i3-input: restore input focus on exit() (upstream git commit 5779f573e7316664e4bff9d3ff17a234edc9d337) Repect AR environment variable (upstream git commit ef81bd183b579688b9f1a46a41c817b577d0b39e) Fix scrolling on a tabbed titlebar which contains split cons (upstream git commit 721fa7bdadac6d7f0c78f8c1eac0e66252ba2dc6) Bugfix: ignore ConfigureRequests for scratchpad windows (upstream git commit 36b106a9d39727b06909113e3f11552f2f1b6abe) Bugfix: handle MapRequests sent between i3 registering as a wm and handling events (upstream git commit 625401d1628757a67a2ab4eeaa68be965683889c) Bugfix: draw right tab border for split containers (upstream git commit ae605bdd394bdf83a8015ac626b222fd40e35b04)
121 lines
4.5 KiB
Plaintext
121 lines
4.5 KiB
Plaintext
$OpenBSD: patch-src_main_c,v 1.7 2012/12/27 19:58:05 dcoppa Exp $
|
|
|
|
OpenBSD lacks POSIX shared memory support (shm_open() and friends)
|
|
|
|
Bugfix: handle MapRequests sent between i3 registering as a wm and
|
|
handling events
|
|
(upstream git commit 625401d1628757a67a2ab4eeaa68be965683889c)
|
|
|
|
--- src/main.c.orig Wed Dec 12 00:08:17 2012
|
|
+++ src/main.c Thu Dec 27 19:02:25 2012
|
|
@@ -219,11 +219,13 @@ static void i3_exit(void) {
|
|
ev_loop_destroy(main_loop);
|
|
#endif
|
|
|
|
+#if !defined(__OpenBSD__)
|
|
if (*shmlogname != '\0') {
|
|
fprintf(stderr, "Closing SHM log \"%s\"\n", shmlogname);
|
|
fflush(stderr);
|
|
shm_unlink(shmlogname);
|
|
}
|
|
+#endif
|
|
}
|
|
|
|
/*
|
|
@@ -233,9 +235,11 @@ static void i3_exit(void) {
|
|
*
|
|
*/
|
|
static void handle_signal(int sig, siginfo_t *info, void *data) {
|
|
+#if !defined(__OpenBSD__)
|
|
if (*shmlogname != '\0') {
|
|
shm_unlink(shmlogname);
|
|
}
|
|
+#endif
|
|
raise(sig);
|
|
}
|
|
|
|
@@ -263,8 +267,10 @@ int main(int argc, char *argv[]) {
|
|
{"force-xinerama", no_argument, 0, 0},
|
|
{"force_xinerama", no_argument, 0, 0},
|
|
{"disable-signalhandler", no_argument, 0, 0},
|
|
+#if !defined(__OpenBSD__)
|
|
{"shmlog-size", required_argument, 0, 0},
|
|
{"shmlog_size", required_argument, 0, 0},
|
|
+#endif
|
|
{"get-socketpath", no_argument, 0, 0},
|
|
{"get_socketpath", no_argument, 0, 0},
|
|
{"fake_outputs", required_argument, 0, 0},
|
|
@@ -290,8 +296,10 @@ int main(int argc, char *argv[]) {
|
|
* (file) logging. */
|
|
init_logging();
|
|
|
|
+#if !defined(__OpenBSD__)
|
|
/* On non-release builds, disable SHM logging by default. */
|
|
shmlog_size = (is_debug_build() ? 25 * 1024 * 1024 : 0);
|
|
+#endif
|
|
|
|
start_argv = argv;
|
|
|
|
@@ -355,6 +363,7 @@ int main(int argc, char *argv[]) {
|
|
}
|
|
|
|
exit(EXIT_FAILURE);
|
|
+#if !defined(__OpenBSD__)
|
|
} else if (strcmp(long_options[option_index].name, "shmlog-size") == 0 ||
|
|
strcmp(long_options[option_index].name, "shmlog_size") == 0) {
|
|
shmlog_size = atoi(optarg);
|
|
@@ -363,6 +372,7 @@ int main(int argc, char *argv[]) {
|
|
init_logging();
|
|
LOG("Limiting SHM log size to %d bytes\n", shmlog_size);
|
|
break;
|
|
+#endif
|
|
} else if (strcmp(long_options[option_index].name, "restart") == 0) {
|
|
FREE(layout_path);
|
|
layout_path = sstrdup(optarg);
|
|
@@ -399,11 +409,13 @@ int main(int argc, char *argv[]) {
|
|
fprintf(stderr, "\t--get-socketpath\n"
|
|
"\tRetrieve the i3 IPC socket path from X11, print it, then exit.\n");
|
|
fprintf(stderr, "\n");
|
|
+#if !defined(__OpenBSD__)
|
|
fprintf(stderr, "\t--shmlog-size <limit>\n"
|
|
"\tLimits the size of the i3 SHM log to <limit> bytes. Setting this\n"
|
|
"\tto 0 disables SHM logging entirely.\n"
|
|
"\tThe default is %d bytes.\n", shmlog_size);
|
|
fprintf(stderr, "\n");
|
|
+#endif
|
|
fprintf(stderr, "If you pass plain text arguments, i3 will interpret them as a command\n"
|
|
"to send to a currently running i3 (like i3-msg). This allows you to\n"
|
|
"use nice and logical commands, such as:\n"
|
|
@@ -473,8 +485,10 @@ int main(int argc, char *argv[]) {
|
|
return 0;
|
|
}
|
|
|
|
+#if !defined(__OpenBSD__)
|
|
/* Enable logging to handle the case when the user did not specify --shmlog-size */
|
|
init_logging();
|
|
+#endif
|
|
|
|
/* Try to enable core dumps by default when running a debug build */
|
|
if (is_debug_build()) {
|
|
@@ -777,6 +791,20 @@ int main(int argc, char *argv[]) {
|
|
xcb_aux_sync(conn);
|
|
xcb_generic_event_t *event;
|
|
while ((event = xcb_poll_for_event(conn)) != NULL) {
|
|
+ if (event->response_type == 0) {
|
|
+ free(event);
|
|
+ continue;
|
|
+ }
|
|
+
|
|
+ /* Strip off the highest bit (set if the event is generated) */
|
|
+ int type = (event->response_type & 0x7F);
|
|
+
|
|
+ /* We still need to handle MapRequests which are sent in the
|
|
+ * timespan starting from when we register as a window manager and
|
|
+ * this piece of code which drops events. */
|
|
+ if (type == XCB_MAP_REQUEST)
|
|
+ handle_event(type, event);
|
|
+
|
|
free(event);
|
|
}
|
|
manage_existing_windows(root);
|