| surf-0.7-webkit2-searchengines.diff - sites - public wiki contents of suckless.… | |
| git clone git://git.suckless.org/sites | |
| Log | |
| Files | |
| Refs | |
| --- | |
| surf-0.7-webkit2-searchengines.diff (1749B) | |
| --- | |
| 1 diff --git a/surf.c b/surf.c | |
| 2 index 9b4dbb9..bf54d84 100644 | |
| 3 --- a/surf.c | |
| 4 +++ b/surf.c | |
| 5 @@ -92,6 +92,12 @@ typedef struct { | |
| 6 } Button; | |
| 7 | |
| 8 typedef struct { | |
| 9 + char *token; | |
| 10 + char *uri; | |
| 11 +} SearchEngine; | |
| 12 + | |
| 13 + | |
| 14 +typedef struct { | |
| 15 char *regex; | |
| 16 char *style; | |
| 17 regex_t re; | |
| 18 @@ -124,6 +130,7 @@ static void newwindow(Client *c, const Arg *a, int n… | |
| 19 static void spawn(Client *c, const Arg *a); | |
| 20 static void destroyclient(Client *c); | |
| 21 static void cleanup(void); | |
| 22 +static gchar *parseuri(const gchar *uri); | |
| 23 | |
| 24 /* GTK/WebKit */ | |
| 25 static WebKitWebView *newview(Client *c, WebKitWebView *rv); | |
| 26 @@ -350,13 +357,13 @@ loaduri(Client *c, const Arg *a) | |
| 27 if (g_strcmp0(uri, "") == 0) | |
| 28 return; | |
| 29 | |
| 30 - if (g_strrstr(uri, "://") || g_str_has_prefix(uri, "about:")) { | |
| 31 + if (g_str_has_prefix(uri, "about:")) { | |
| 32 url = g_strdup(uri); | |
| 33 } else if (!stat(uri, &st) && (path = realpath(uri, NULL))) { | |
| 34 url = g_strdup_printf("file://%s", path); | |
| 35 free(path); | |
| 36 } else { | |
| 37 - url = g_strdup_printf("http://%s", uri); | |
| 38 + url = parseuri(uri); | |
| 39 } | |
| 40 | |
| 41 setatom(c, AtomUri, url); | |
| 42 @@ -1205,6 +1212,21 @@ destroywin(GtkWidget* w, Client *c) | |
| 43 gtk_main_quit(); | |
| 44 } | |
| 45 | |
| 46 +static gchar * | |
| 47 +parseuri(const gchar *uri) { | |
| 48 + guint i; | |
| 49 + | |
| 50 + for (i = 0; i < LENGTH(searchengines); i++) { | |
| 51 + if (searchengines[i].token == NULL || searchengines[i].uri == NU… | |
| 52 + *(uri + strlen(searchengines[i].token)) != ' ') | |
| 53 + continue; | |
| 54 + if (g_str_has_prefix(uri, searchengines[i].token)) | |
| 55 + return g_strdup_printf(searchengines[i].uri, uri + strlen(se… | |
| 56 + } | |
| 57 + | |
| 58 + return g_strrstr(uri, "://") ? g_strdup(uri) : g_strdup_printf("http… | |
| 59 +} | |
| 60 + | |
| 61 void | |
| 62 pasteuri(GtkClipboard *clipboard, const char *text, gpointer d) | |
| 63 { |