summaryrefslogtreecommitdiff
path: root/surf.c
diff options
context:
space:
mode:
authorQuentin Rameau <quinq@fifth.space>2019-09-07 13:20:09 +0200
committerQuentin Rameau <quinq@fifth.space>2020-11-01 16:59:12 +0100
commite92fd1aa5f38c399f8fc5d263026fbd9d34ddfbb (patch)
tree503b3b6966537d2f77d802d506c8e1e1ac354593 /surf.c
parentf61cfc720c598491d7a93c9f314ceae349e00450 (diff)
Communicate through a Unix socket instead of a pipe pair
Diffstat (limited to 'surf.c')
-rw-r--r--surf.c62
1 files changed, 32 insertions, 30 deletions
diff --git a/surf.c b/surf.c
index edaf348..171c3a6 100644
--- a/surf.c
+++ b/surf.c
@@ -3,6 +3,7 @@
* To understand surf, start reading main().
*/
#include <sys/file.h>
+#include <sys/socket.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <glib.h>
@@ -187,7 +188,7 @@ static gboolean buttonreleased(GtkWidget *w, GdkEvent *e, Client *c);
static GdkFilterReturn processx(GdkXEvent *xevent, GdkEvent *event,
gpointer d);
static gboolean winevent(GtkWidget *w, GdkEvent *e, Client *c);
-static gboolean readpipe(GIOChannel *s, GIOCondition ioc, gpointer unused);
+static gboolean readsock(GIOChannel *s, GIOCondition ioc, gpointer unused);
static void showview(WebKitWebView *v, Client *c);
static GtkWidget *createwindow(Client *c);
static gboolean loadfailedtls(WebKitWebView *v, gchar *uri,
@@ -253,7 +254,7 @@ static char *stylefile;
static const char *useragent;
static Parameter *curconfig;
static int modparams[ParameterLast];
-static int pipein[2], pipeout[2];
+static int spair[2];
char *argv0;
static ParamName loadtransient[] = {
@@ -359,13 +360,15 @@ setup(void)
gdkkb = gdk_seat_get_keyboard(gdk_display_get_default_seat(gdpy));
- if (pipe(pipeout) < 0 || pipe(pipein) < 0) {
- fputs("Unable to create pipes\n", stderr);
+ if (socketpair(AF_UNIX, SOCK_DGRAM, 0, spair) < 0) {
+ fputs("Unable to create sockets\n", stderr);
+ spair[0] = spair[1] = -1;
} else {
- gchanin = g_io_channel_unix_new(pipein[0]);
+ gchanin = g_io_channel_unix_new(spair[0]);
g_io_channel_set_encoding(gchanin, NULL, NULL);
+ g_io_channel_set_flags(gchanin, G_IO_FLAG_NONBLOCK, NULL);
g_io_channel_set_close_on_unref(gchanin, TRUE);
- g_io_add_watch(gchanin, G_IO_IN, readpipe, NULL);
+ g_io_add_watch(gchanin, G_IO_IN, readsock, NULL);
}
@@ -1054,8 +1057,8 @@ spawn(Client *c, const Arg *a)
if (fork() == 0) {
if (dpy)
close(ConnectionNumber(dpy));
- close(pipein[0]);
- close(pipeout[1]);
+ close(spair[0]);
+ close(spair[1]);
setsid();
execvp(((char **)a->v)[0], (char **)a->v);
fprintf(stderr, "%s: execvp %s", argv0, ((char **)a->v)[0]);
@@ -1089,8 +1092,8 @@ cleanup(void)
while (clients)
destroyclient(clients);
- close(pipein[0]);
- close(pipeout[1]);
+ close(spair[0]);
+ close(spair[1]);
g_free(cookiefile);
g_free(scriptfile);
g_free(stylefile);
@@ -1233,30 +1236,26 @@ newview(Client *c, WebKitWebView *rv)
}
static gboolean
-readpipe(GIOChannel *s, GIOCondition ioc, gpointer unused)
+readsock(GIOChannel *s, GIOCondition ioc, gpointer unused)
{
- static char msg[MSGBUFSZ], msgsz;
+ static char msg[MSGBUFSZ];
GError *gerr = NULL;
+ gsize msgsz;
- if (g_io_channel_read_chars(s, msg, sizeof(msg), NULL, &gerr) !=
+ if (g_io_channel_read_chars(s, msg, sizeof(msg), &msgsz, &gerr) !=
G_IO_STATUS_NORMAL) {
- fprintf(stderr, "surf: error reading pipe: %s\n",
- gerr->message);
- g_error_free(gerr);
+ if (gerr) {
+ fprintf(stderr, "surf: error reading socket: %s\n",
+ gerr->message);
+ g_error_free(gerr);
+ }
return TRUE;
}
- if ((msgsz = msg[0]) < 3) {
+ if (msgsz < 2) {
fprintf(stderr, "surf: message too short: %d\n", msgsz);
return TRUE;
}
- switch (msg[2]) {
- case 'i':
- close(pipein[1]);
- close(pipeout[0]);
- break;
- }
-
return TRUE;
}
@@ -1265,10 +1264,10 @@ initwebextensions(WebKitWebContext *wc, Client *c)
{
GVariant *gv;
- if (!pipeout[0] || !pipein[1])
+ if (spair[1] < 0)
return;
- gv = g_variant_new("(ii)", pipeout[0], pipein[1]);
+ gv = g_variant_new("i", spair[1]);
webkit_web_context_set_web_extensions_initialization_user_data(wc, gv);
webkit_web_context_set_web_extensions_directory(wc, WEBEXTDIR);
@@ -1874,15 +1873,18 @@ msgext(Client *c, char type, const Arg *a)
static char msg[MSGBUFSZ];
int ret;
- if ((ret = snprintf(msg, sizeof(msg), "%c%c%c%c",
- 4, c->pageid, type, a->i))
+ if (spair[0] < 0)
+ return;
+
+ if ((ret = snprintf(msg, sizeof(msg), "%c%c%c", c->pageid, type, a->i))
>= sizeof(msg)) {
fprintf(stderr, "surf: message too long: %d\n", ret);
return;
}
- if (pipeout[1] && write(pipeout[1], msg, sizeof(msg)) < 0)
- fprintf(stderr, "surf: error sending: %.*s\n", ret-2, msg+2);
+ if (send(spair[0], msg, ret, 0) != ret)
+ fprintf(stderr, "surf: error sending: %d%c%d (%dB)\n",
+ c->pageid, type, a->i, ret);
}
void