X-Git-Url: https://git.danieliu.xyz/?p=surf.git;a=blobdiff_plain;f=surf.c;h=81bd03e76647f369cdb366ca1cb14a2eb6789fe6;hp=a06fe408cc210432433083dc69b28c21b5ea03b9;hb=690118133dff7797a58cacdf9fe1e9e73ca99d7f;hpb=82abf5154f0ab94716223f556638f073f01dbc11 diff --git a/surf.c b/surf.c index a06fe40..81bd03e 100644 --- a/surf.c +++ b/surf.c @@ -108,7 +108,7 @@ static Window embed = 0; static gboolean showxid = FALSE; static char winid[64]; static char togglestat[9]; -static char pagestat[3]; +static char pagestats[2]; static GTlsDatabase *tlsdb; static int cookiepolicy; static char *stylefile = NULL; @@ -143,7 +143,7 @@ static gboolean permissionrequested(WebKitWebView *v, WebKitPermissionRequest *r, Client *c); static const char *getatom(Client *c, int a); static void gettogglestat(Client *c); -static void getpagestat(Client *c); +static void getpagestats(Client *c); static char *geturi(Client *c); static const gchar *getstyle(const char *uri); static void setstyle(Client *c, const char *stylefile); @@ -162,8 +162,9 @@ static gboolean keypress(GtkAccelGroup *group, GObject *obj, guint key, static void mousetargetchanged(WebKitWebView *v, WebKitHitTestResult *h, guint modifiers, Client *c); static void loadchanged(WebKitWebView *v, WebKitLoadEvent e, Client *c); -static void loaduri(Client *c, const Arg *arg); +static void loaduri(Client *c, const Arg *a); static void navigate(Client *c, const Arg *a); +static void clicknavigate(Client *c, const Arg *a, WebKitHitTestResult *h); static Client *newclient(Client *c); static WebKitWebView *newview(Client *c, WebKitWebView *rv); static void showview(WebKitWebView *v, Client *c); @@ -175,8 +176,7 @@ static GdkFilterReturn processx(GdkXEvent *xevent, GdkEvent *event, gpointer d); static gboolean winevent(GtkWidget *w, GdkEvent *e, Client *c); static void progresschanged(WebKitWebView *v, GParamSpec *ps, Client *c); -static void linkopen(Client *c, const Arg *arg); -static void linkopenembed(Client *c, const Arg *arg); +static void clicknewwindow(Client *c, const Arg *a, WebKitHitTestResult *h); static void reload(Client *c, const Arg *arg); static void scroll_h(Client *c, const Arg *a); static void scroll_v(Client *c, const Arg *a); @@ -825,38 +825,35 @@ loadchanged(WebKitWebView *v, WebKitLoadEvent e, Client *c) } void -loaduri(Client *c, const Arg *arg) +loaduri(Client *c, const Arg *a) { - char *u = NULL, *rp; - const char *uri = (char *)arg->v; - Arg a = { .b = FALSE }; struct stat st; + char *url, *path; + const char *uri = (char *)a->v; - if (strcmp(uri, "") == 0) + if (g_strcmp0(uri, "") == 0) return; - /* In case it's a file path. */ - if (stat(uri, &st) == 0) { - rp = realpath(uri, NULL); - u = g_strdup_printf("file://%s", rp); - free(rp); + if (g_strrstr(uri, "://") || g_str_has_prefix(uri, "about:")) { + url = g_strdup(uri); + } else if (!stat(uri, &st) && (path = realpath(uri, NULL))) { + url = g_strdup_printf("file://%s", path); + free(path); } else { - u = g_strrstr(uri, "://") ? g_strdup(uri) - : g_strdup_printf("http://%s", uri); + url = g_strdup_printf("http://%s", uri); } - setatom(c, AtomUri, uri); + setatom(c, AtomUri, url); - /* prevents endless loop */ - if (strcmp(u, geturi(c)) == 0) { - reload(c, &a); + if (strcmp(url, geturi(c)) == 0) { + reload(c, a); } else { - webkit_web_view_load_uri(c->view, u); - c->progress = 0; - c->title = copystr(&c->title, u); + webkit_web_view_load_uri(c->view, url); + c->title = geturi(c); updatetitle(c); } - g_free(u); + + g_free(url); } void @@ -868,6 +865,12 @@ navigate(Client *c, const Arg *a) webkit_web_view_go_forward(c->view); } +void +clicknavigate(Client *c, const Arg *a, WebKitHitTestResult *h) +{ + navigate(c, a); +} + Client * newclient(Client *rc) { @@ -1171,15 +1174,12 @@ progresschanged(WebKitWebView *v, GParamSpec *ps, Client *c) } void -linkopen(Client *c, const Arg *arg) +clicknewwindow(Client *c, const Arg *a, WebKitHitTestResult *h) { - newwindow(NULL, arg, 1); -} + Arg arg; -void -linkopenembed(Client *c, const Arg *arg) -{ - newwindow(NULL, arg, 0); + arg.v = webkit_hit_test_result_get_link_uri(h); + newwindow(c, &arg, a->b); } void @@ -1420,13 +1420,11 @@ gettogglestat(Client *c) } void -getpagestat(Client *c) +getpagestats(Client *c) { - const char *uri = geturi(c); - pagestats[0] = c->tlsflags > G_TLS_CERTIFICATE_VALIDATE_ALL ? '-' : c->tlsflags > 0 ? 'U' : 'T'; - pagestat[1] = '\0'; + pagestats[1] = '\0'; } void @@ -1436,17 +1434,17 @@ updatetitle(Client *c) if (showindicators) { gettogglestat(c); - getpagestat(c); + getpagestats(c); if (c->linkhover) { - t = g_strdup_printf("%s:%s | %s", togglestat, pagestat, + t = g_strdup_printf("%s:%s | %s", togglestat, pagestats, c->linkhover); } else if (c->progress != 100) { t = g_strdup_printf("[%i%%] %s:%s | %s", c->progress, - togglestat, pagestat, + togglestat, pagestats, c->title == NULL ? "" : c->title); } else { - t = g_strdup_printf("%s:%s | %s", togglestat, pagestat, + t = g_strdup_printf("%s:%s | %s", togglestat, pagestats, c->title == NULL ? "" : c->title); }