diff options
| -rw-r--r-- | config.mk | 2 | ||||
| -rw-r--r-- | surf.c | 16 | 
2 files changed, 14 insertions, 4 deletions
| @@ -19,7 +19,7 @@ LIBS = -L/usr/lib -lc -L${X11LIB} -lX11 ${GTKLIB} -lgthread-2.0 \         -ljavascriptcoregtk-1.0  # flags -CPPFLAGS = -DVERSION=\"${VERSION}\" +CPPFLAGS = -DVERSION=\"${VERSION}\" -D_BSD_SOURCE  CFLAGS = -std=c99 -pedantic -Wall -Os ${INCS} ${CPPFLAGS}  LDFLAGS = -g ${LIBS} @@ -13,6 +13,7 @@  #include <sys/types.h>  #include <sys/wait.h>  #include <unistd.h> +#include <limits.h>  #include <stdlib.h>  #include <stdio.h>  #include <webkit/webkit.h> @@ -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); | 
