about summary refs log tree commit diff
diff options
context:
space:
mode:
authorChristoph Lohmann <20h@r-36.net>2012-11-25 22:31:46 +0100
committerChristoph Lohmann <20h@r-36.net>2012-11-25 22:31:46 +0100
commit6cd54e4a3119bd201d95f5d67ffb4bfe28aac653 (patch)
tree6f36762e081398e5a30ce72020590e131bb86da1
parentThe control of the toggles is now Ctrl-Shift-$character. That's easier for new (diff)
downloadsurf-6cd54e4a3119bd201d95f5d67ffb4bfe28aac653.tar.gz
surf-6cd54e4a3119bd201d95f5d67ffb4bfe28aac653.tar.bz2
surf-6cd54e4a3119bd201d95f5d67ffb4bfe28aac653.zip
Surf now can handle absolute file paths. This allows better local HTML
reading.
-rw-r--r--config.mk2
-rw-r--r--surf.c16
2 files changed, 14 insertions, 4 deletions
diff --git a/config.mk b/config.mk
index e62e033..ee05292 100644
--- a/config.mk
+++ b/config.mk
@@ -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}
 
diff --git a/surf.c b/surf.c
index a090dc8..78698b8 100644
--- a/surf.c
+++ b/surf.c
@@ -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);