X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=surf.c;h=ec3bee6c5a39d0735546c36a2dadfa3e4cc739b4;hb=d6bbef74fefaf4f5b9943a821867d99a7200f7ed;hp=2465fd15ead964f54168032325691a16a32a7e0f;hpb=d911219554e1b51f02ac29aaf200f15f083c9dee;p=surf.git diff --git a/surf.c b/surf.c index 2465fd1..ec3bee6 100644 --- a/surf.c +++ b/surf.c @@ -79,6 +79,7 @@ static GdkNativeWindow embed = 0; static gboolean showxid = FALSE; static char winid[64]; static gboolean loadimage = 1, plugin = 1, script = 1, using_proxy = 0; +static char togglestat[5]; static char *buildpath(const char *path); static gboolean buttonrelease(WebKitWebView *web, GdkEventButton *e, GList *gl); @@ -127,6 +128,7 @@ static void eval(Client *c, const Arg *arg); static void stop(Client *c, const Arg *arg); static void titlechange(WebKitWebView *v, WebKitWebFrame* frame, const char* title, Client *c); static void toggle(Client *c, const Arg *arg); +static void gettogglestat(Client *c); static void update(Client *c); static void updatewinid(Client *c); static void usage(void); @@ -447,6 +449,7 @@ keypress(GtkWidget* w, GdkEventKey *ev, Client *c) { processed = TRUE; } } + return processed; } @@ -529,12 +532,13 @@ newclient(void) { if(!(c = calloc(1, sizeof(Client)))) die("Cannot malloc!\n"); + /* Window */ if(embed) { c->win = gtk_plug_new(embed); - } - else { + } else { c->win = gtk_window_new(GTK_WINDOW_TOPLEVEL); + /* TA: 20091214: Despite what the GNOME docs say, the ICCCM * is always correct, so we should still call this function. * But when doing so, we *must* differentiate between a @@ -599,6 +603,7 @@ 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); settings = webkit_web_view_get_settings(c->view); @@ -610,13 +615,13 @@ newclient(void) { g_object_set(G_OBJECT(settings), "auto-load-images", loadimage, NULL); g_object_set(G_OBJECT(settings), "enable-plugins", plugin, NULL); g_object_set(G_OBJECT(settings), "enable-scripts", script, NULL); - g_object_set(G_OBJECT(settings), "enable-spatial-navigation", SPATIAL_BROWSING, NULL); + g_object_set(G_OBJECT(settings), "enable-spatial-navigation", spatialbrowsing, NULL); g_free(uri); setatom(c, AtomFind, ""); setatom(c, AtomUri, "about:blank"); - if(HIDE_BACKGROUND) + if(hidebackground) webkit_web_view_set_transparent(c->view, TRUE); c->title = NULL; @@ -891,7 +896,7 @@ titlechange(WebKitWebView *v, WebKitWebFrame *f, const char *t, Client *c) { } void -toggle(Client *c, const Arg *arg) { +toggle(Client *c, const Arg *arg) { WebKitWebSettings *settings; char *name = (char *)arg->v; gboolean value; @@ -904,19 +909,40 @@ toggle(Client *c, const Arg *arg) { reload(c,&a); } +void +gettogglestat(Client *c){ + gboolean value; + WebKitWebSettings *settings = webkit_web_view_get_settings(c->view); + + togglestat[4] = '\0'; + g_object_get(G_OBJECT(settings), "auto-load-images", &value, NULL); + togglestat[0] = value?'I':'i'; + g_object_get(G_OBJECT(settings), "enable-scripts", &value, NULL); + togglestat[1] = value?'S':'s'; + g_object_get(G_OBJECT(settings), "enable-plugins", &value, NULL); + togglestat[2] = value?'V':'v'; + g_object_get(G_OBJECT(settings), "enable-caret-browsing", + &value, NULL); + togglestat[3] = value?'C':'c'; +} + + void update(Client *c) { char *t; + gettogglestat(c); + if(c->linkhover) { - t = g_strdup(c->linkhover); + t = g_strdup_printf("%s| %s", togglestat, c->linkhover); } else if(c->progress != 100) { drawindicator(c); gtk_widget_show(c->indicator); - t = g_strdup_printf("[%i%%] %s", c->progress, c->title); + t = g_strdup_printf("[%i%%] %s| %s", c->progress, togglestat, + c->title); } else { gtk_widget_hide_all(c->indicator); - t = g_strdup(c->title); + t = g_strdup_printf("%s| %s", togglestat, c->title); } gtk_window_set_title(GTK_WINDOW(c->win), t);