X-Git-Url: https://git.danieliu.xyz/?p=surf.git;a=blobdiff_plain;f=surf.c;h=78698b83d56bb17a58bdb77452d333064d24934b;hp=a090dc879b2e43dc7d539134d331ae9e4934cacd;hb=6cd54e4a3119bd201d95f5d67ffb4bfe28aac653;hpb=ad794e0f00f56065f4e8d7e4cd1e4b8873938993 diff --git a/surf.c b/surf.c index a090dc8..78698b8 100644 --- a/surf.c +++ b/surf.c @@ -13,6 +13,7 @@ #include #include #include +#include #include #include #include @@ -497,14 +498,23 @@ loadstatuschange(WebKitWebView *view, GParamSpec *pspec, Client *c) { void loaduri(Client *c, const Arg *arg) { - char *u; + char *u, *rp; const char *uri = (char *)arg->v; Arg a = { .b = FALSE }; if(strcmp(uri, "") == 0) return; - u = g_strrstr(uri, "://") ? g_strdup(uri) - : g_strdup_printf("http://%s", uri); + + /* In case it's a file path. */ + if(uri[0] == '/') { + rp = realpath(uri, NULL); + u = g_strdup_printf("file://%s", rp); + free(rp); + } else { + u = g_strrstr(uri, "://") ? g_strdup(uri) + : g_strdup_printf("http://%s", uri); + } + /* prevents endless loop */ if(c->uri && strcmp(u, c->uri) == 0) { reload(c, &a);