diff options
author | Enno Boland (tox) <tox@s01.de> | 2010-05-09 19:37:46 +0200 |
---|---|---|
committer | Enno Boland (tox) <tox@s01.de> | 2010-05-09 19:37:46 +0200 |
commit | 168da3730fcaabf56f9cb7508cbff1699e5b33b1 (patch) | |
tree | e729cff92f2b8a102780477986ca0bf28f56ebd7 /surf.c | |
parent | 602eb616231b4606ca09dc2f98b1c3d22b8538d5 (diff) | |
download | surf-168da3730fcaabf56f9cb7508cbff1699e5b33b1.tar.gz surf-168da3730fcaabf56f9cb7508cbff1699e5b33b1.tar.bz2 surf-168da3730fcaabf56f9cb7508cbff1699e5b33b1.zip |
added js-fix by Troels Henriksen. Thanks :)
Diffstat (limited to 'surf.c')
-rw-r--r-- | surf.c | 26 |
1 files changed, 17 insertions, 9 deletions
@@ -151,6 +151,19 @@ cleanup(void) { } void +runscript(WebKitWebFrame *frame, JSContextRef js) { + JSStringRef jsscript; + char *script; + JSValueRef exception = NULL; + GError *error; + + if(g_file_get_contents(scriptfile, &script, NULL, &error)) { + jsscript = JSStringCreateWithUTF8CString(script); + JSEvaluateScript(js, jsscript, JSContextGetGlobalObject(js), NULL, 0, &exception); + } +} + +void clipboard(Client *c, const Arg *arg) { gboolean paste = *(gboolean *)arg; @@ -470,6 +483,7 @@ newclient(void) { int i; Client *c; WebKitWebSettings *settings; + WebKitWebFrame *frame; GdkGeometry hints = { 1, 1 }; char *uri, *ua; @@ -556,6 +570,8 @@ newclient(void) { gdk_window_set_events(GTK_WIDGET(c->win)->window, GDK_ALL_EVENTS_MASK); gdk_window_add_filter(GTK_WIDGET(c->win)->window, processx, c); webkit_web_view_set_full_content_zoom(c->view, TRUE); + frame = webkit_web_view_get_main_frame(c->view); + runscript(frame, webkit_web_frame_get_global_context(frame)); settings = webkit_web_view_get_settings(c->view); if(!(ua = getenv("SURF_USERAGENT"))) ua = useragent; @@ -860,15 +876,7 @@ usage(void) { void windowobjectcleared(GtkWidget *w, WebKitWebFrame *frame, JSContextRef js, JSObjectRef win, Client *c) { - JSStringRef jsscript; - char *script; - JSValueRef exception = NULL; - GError *error; - - if(g_file_get_contents(scriptfile, &script, NULL, &error)) { - jsscript = JSStringCreateWithUTF8CString(script); - JSEvaluateScript(js, jsscript, JSContextGetGlobalObject(js), NULL, 0, &exception); - } + runscript(frame, js); } void |