diff options
author | Karel Kočí <cynerd@email.cz> | 2018-11-05 23:04:32 +0100 |
---|---|---|
committer | Karel Kočí <cynerd@email.cz> | 2018-11-05 23:04:32 +0100 |
commit | d7f641d5dd6c099d4a9274a18fcfb89df00d4b4c (patch) | |
tree | fa46c7ec3902a9549393df154f24b25ef7517875 /libsurf-webext.c | |
parent | 78d9d66ad6ce6455690670173623ad420d12170d (diff) | |
parent | 2b71a22755bae132a639fe10475a0d42e582d244 (diff) | |
download | surf-bda5433e84b99470681e1e3f67b7abd929750236.tar.gz surf-bda5433e84b99470681e1e3f67b7abd929750236.tar.bz2 surf-bda5433e84b99470681e1e3f67b7abd929750236.zip |
Merge branch 'surf-webkit2' into mysurfv2.0.7
Diffstat (limited to 'libsurf-webext.c')
-rw-r--r-- | libsurf-webext.c | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/libsurf-webext.c b/libsurf-webext.c new file mode 100644 index 0000000..684d4a5 --- /dev/null +++ b/libsurf-webext.c @@ -0,0 +1,123 @@ +#include <sys/stat.h> +#include <fcntl.h> +#include <limits.h> +#include <stdlib.h> + +#include <gio/gio.h> +#include <webkit2/webkit-web-extension.h> +#include <webkitdom/webkitdom.h> +#include <webkitdom/WebKitDOMDOMWindowUnstable.h> + +#include "common.h" + +#define LENGTH(x) (sizeof(x) / sizeof(x[0])) + +typedef struct Page { + guint64 id; + WebKitWebPage *webpage; + struct Page *next; +} Page; + +static int pipein, pipeout; +static Page *pages; + +Page * +newpage(WebKitWebPage *page) +{ + Page *p; + + if (!(p = calloc(1, sizeof(Page)))) + die("Cannot malloc!\n"); + + p->next = pages; + pages = p; + + p->id = webkit_web_page_get_id(page); + p->webpage = page; + + return p; +} + +static void +msgsurf(Page *p, const char *s) +{ + char msg[MSGBUFSZ]; + int ret; + + msg[0] = p ? p->id : 0; + ret = snprintf(&msg[1], sizeof(msg) - 1, "%s", s); + if (ret >= sizeof(msg)) { + fprintf(stderr, "webext: message too long: %d\n", ret); + return; + } + + if (pipeout) { + if (write(pipeout, msg, sizeof(msg)) < 0) + fprintf(stderr, "webext: error sending: %s\n", msg); + } +} + +static gboolean +readpipe(GIOChannel *s, GIOCondition c, gpointer unused) +{ + char msg[MSGBUFSZ]; + gsize msgsz; + WebKitDOMDOMWindow *view; + GError *gerr = NULL; + glong wh, ww; + Page *p; + + if (g_io_channel_read_chars(s, msg, LENGTH(msg), &msgsz, &gerr) != + G_IO_STATUS_NORMAL) { + fprintf(stderr, "webext: error reading pipe: %s\n", + gerr->message); + g_error_free(gerr); + return TRUE; + } + msg[msgsz] = '\0'; + + for (p = pages; p; p = p->next) { + if (p->id == msg[0]) + break; + } + if (!p || !(view = webkit_dom_document_get_default_view( + webkit_web_page_get_dom_document(p->webpage)))) + return TRUE; + + switch (msg[1]) { + case 'h': + ww = webkit_dom_dom_window_get_inner_width(view); + webkit_dom_dom_window_scroll_by(view, + (ww / 100) * msg[2], 0); + break; + case 'v': + wh = webkit_dom_dom_window_get_inner_height(view); + webkit_dom_dom_window_scroll_by(view, + 0, (wh / 100) * msg[2]); + break; + } + + return TRUE; +} + +static void +webpagecreated(WebKitWebExtension *e, WebKitWebPage *wp, gpointer unused) +{ + Page *p = newpage(wp); +} + +G_MODULE_EXPORT void +webkit_web_extension_initialize_with_user_data(WebKitWebExtension *e, GVariant *gv) +{ + GIOChannel *gchanpipe; + + g_signal_connect(e, "page-created", G_CALLBACK(webpagecreated), NULL); + + g_variant_get(gv, "(ii)", &pipein, &pipeout); + msgsurf(NULL, "i"); + + gchanpipe = g_io_channel_unix_new(pipein); + g_io_channel_set_encoding(gchanpipe, NULL, NULL); + g_io_channel_set_close_on_unref(gchanpipe, TRUE); + g_io_add_watch(gchanpipe, G_IO_IN, readpipe, NULL); +} |