ports/irc/scrollz/files/patch-source-screen.c
Bryan Drewery dd09542eda - Fix build with clang due to missing return value
Submitted by:	M. de Vries <mdv@unsavoury.net> (maintainer via email)
Obtained from:	125c004122
2013-07-13 12:53:08 +00:00

56 lines
1.6 KiB
C

--- ./source/screen.c.orig 2011-04-29 03:21:18.000000000 -0500
+++ ./source/screen.c 2013-07-13 07:45:53.092133202 -0500
@@ -2000,7 +2000,10 @@
{
puts(incoming);
fflush(stdout);
- return;
+/**************************** PATCHED by Flier ******************************/
+ /*return;*/
+ return NULL;
+/****************************************************************************/
}
/* Handles output redirection first */
if (!in_redirect && current_screen->redirect_name &&
@@ -2416,6 +2419,10 @@
{
screen_type = ST_SCREEN;
}
+ else if (0 != getenv("TMUX"))
+ {
+ screen_type = ST_TMUX;
+ }
else if ((char *) 0 != (displayvar = getenv("DISPLAY")))
{
if ((char *) 0 == (termvar = getenv("TERM")))
@@ -2454,6 +2461,7 @@
say("Opening new %s...",
screen_type == ST_XTERM ? "window" :
screen_type == ST_SCREEN ? "screen" :
+ screen_type == ST_TMUX ? "tmux window" :
"wound" );
snprintf(sock.sun_path, sizeof sock.sun_path, "/tmp/irc_%08d_%x", (int) pid, mycycle);
sock.sun_family = AF_UNIX;
@@ -2569,6 +2577,22 @@
args[i] = NULL;
execvp(xterm, args);
}
+ else if (screen_type == ST_TMUX)
+ {
+ char *args[64],
+ *ss,
+ *t,
+ opts[BIG_BUFFER_SIZE];
+
+ Debug((3, "going to execvp screen wserv..."));
+ args[i++] = "tmux";
+ args[i++] = "new-window";
+ snprintf(opts, BIG_BUFFER_SIZE-1, "%s %s %s", WSERV_PATH, sockaddr->sun_path, error_sockaddr->sun_path);
+ args[i++] = opts;
+ Debug((3, "added: %s %s '%s'", args[i-3], args[i-2], args[i-1]));
+ args[i++] = NULL;
+ execvp("tmux", args);
+ }
perror("execve");
unlink(sockaddr->sun_path);
unlink(error_sockaddr->sun_path);