Applying Nibbles download patch. Thanks!
This commit is contained in:
parent
7d3d996a3d
commit
7330d0e261
|
@ -12,9 +12,15 @@ static time_t sessiontime = 0;
|
||||||
"prop=\"`xprop -id $2 $0 | cut -d '\"' -f 2 | dmenu`\" &&" \
|
"prop=\"`xprop -id $2 $0 | cut -d '\"' -f 2 | dmenu`\" &&" \
|
||||||
"xprop -id $2 -f $1 8s -set $1 \"$prop\"", \
|
"xprop -id $2 -f $1 8s -set $1 \"$prop\"", \
|
||||||
p, q, winid, NULL } }
|
p, q, winid, NULL } }
|
||||||
|
#define DOWNLOAD(p) { \
|
||||||
|
.v = (char *[]){ "/bin/sh", "-c", \
|
||||||
|
"prop=\"`xprop -id $1 $0 | cut -d '\"' -f 2`\";" \
|
||||||
|
"xterm -e \"wget --load-cookies ~/.surf/cookies.txt $prop;\"", \
|
||||||
|
p, winid, NULL } }
|
||||||
#define MODKEY GDK_CONTROL_MASK
|
#define MODKEY GDK_CONTROL_MASK
|
||||||
static Key keys[] = {
|
static Key keys[] = {
|
||||||
/* modifier keyval function arg Focus */
|
/* modifier keyval function arg Focus */
|
||||||
|
{ MODKEY, GDK_s, spawn, DOWNLOAD("_SURF_HILIGHT") },
|
||||||
{ MODKEY|GDK_SHIFT_MASK,GDK_r, reload, { .b = TRUE } },
|
{ MODKEY|GDK_SHIFT_MASK,GDK_r, reload, { .b = TRUE } },
|
||||||
{ MODKEY, GDK_r, reload, { .b = FALSE } },
|
{ MODKEY, GDK_r, reload, { .b = FALSE } },
|
||||||
{ MODKEY|GDK_SHIFT_MASK,GDK_p, print, { 0 } },
|
{ MODKEY|GDK_SHIFT_MASK,GDK_p, print, { 0 } },
|
||||||
|
|
14
surf.c
14
surf.c
|
@ -81,6 +81,7 @@ static const char *getatom(Client *c, int a);
|
||||||
static const char *getcookies(SoupURI *uri);
|
static const char *getcookies(SoupURI *uri);
|
||||||
static char *geturi(Client *c);
|
static char *geturi(Client *c);
|
||||||
void gotheaders(SoupMessage *msg, gpointer user_data);
|
void gotheaders(SoupMessage *msg, gpointer user_data);
|
||||||
|
static gboolean initdownload(WebKitWebView *v, WebKitDownload *o, Client *c);
|
||||||
static gboolean keypress(GtkWidget *w, GdkEventKey *ev, Client *c);
|
static gboolean keypress(GtkWidget *w, GdkEventKey *ev, Client *c);
|
||||||
static void linkhover(WebKitWebView *v, const char* t, const char* l, Client *c);
|
static void linkhover(WebKitWebView *v, const char* t, const char* l, Client *c);
|
||||||
static void loadstatuschange(WebKitWebView *view, GParamSpec *pspec, Client *c);
|
static void loadstatuschange(WebKitWebView *view, GParamSpec *pspec, Client *c);
|
||||||
|
@ -328,6 +329,16 @@ gotheaders(SoupMessage *msg, gpointer v) {
|
||||||
soup_cookies_free(l);
|
soup_cookies_free(l);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
initdownload(WebKitWebView *view, WebKitDownload *o, Client *c) {
|
||||||
|
Arg arg;
|
||||||
|
|
||||||
|
updatewinid(c);
|
||||||
|
cmd = (Arg)DOWNLOAD("_SURF_HILIGHT");
|
||||||
|
spawn(c, &cmg);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
keypress(GtkWidget* w, GdkEventKey *ev, Client *c) {
|
keypress(GtkWidget* w, GdkEventKey *ev, Client *c) {
|
||||||
guint i;
|
guint i;
|
||||||
|
@ -454,6 +465,7 @@ newclient(void) {
|
||||||
g_signal_connect(G_OBJECT(c->view), "window-object-cleared", G_CALLBACK(windowobjectcleared), c);
|
g_signal_connect(G_OBJECT(c->view), "window-object-cleared", G_CALLBACK(windowobjectcleared), c);
|
||||||
g_signal_connect(G_OBJECT(c->view), "notify::load-status", G_CALLBACK(loadstatuschange), c);
|
g_signal_connect(G_OBJECT(c->view), "notify::load-status", G_CALLBACK(loadstatuschange), c);
|
||||||
g_signal_connect(G_OBJECT(c->view), "notify::progress", G_CALLBACK(progresschange), c);
|
g_signal_connect(G_OBJECT(c->view), "notify::progress", G_CALLBACK(progresschange), c);
|
||||||
|
g_signal_connect(G_OBJECT(c->view), "download-requested", G_CALLBACK(initdownload), c);
|
||||||
|
|
||||||
/* Indicator */
|
/* Indicator */
|
||||||
c->indicator = gtk_drawing_area_new();
|
c->indicator = gtk_drawing_area_new();
|
||||||
|
@ -495,6 +507,7 @@ newclient(void) {
|
||||||
|
|
||||||
setatom(c, AtomFind, "");
|
setatom(c, AtomFind, "");
|
||||||
setatom(c, AtomUri, "about:blank");
|
setatom(c, AtomUri, "about:blank");
|
||||||
|
setatom(c, AtomHiLight, "about:blank");
|
||||||
if(NOBACKGROUND)
|
if(NOBACKGROUND)
|
||||||
webkit_web_view_set_transparent(c->view, TRUE);
|
webkit_web_view_set_transparent(c->view, TRUE);
|
||||||
|
|
||||||
|
@ -750,6 +763,7 @@ update(Client *c) {
|
||||||
t = g_strdup(c->linkhover);
|
t = g_strdup(c->linkhover);
|
||||||
else
|
else
|
||||||
t = g_strdup(c->title);
|
t = g_strdup(c->title);
|
||||||
|
setatom(c, AtomHiLight, c->linkhover ? c->linkhover : geturi(c));
|
||||||
drawindicator(c);
|
drawindicator(c);
|
||||||
gtk_window_set_title(GTK_WINDOW(c->win), t);
|
gtk_window_set_title(GTK_WINDOW(c->win), t);
|
||||||
g_free(t);
|
g_free(t);
|
||||||
|
|
Loading…
Reference in New Issue