openbsd-ports/x11/i3/patches/patch-src_main_c
dcoppa a6cc1eb92f Fixes, fixes, fixes:
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)
2012-12-27 19:58:05 +00:00

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);