X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=surf.c;h=8b57a856995373e85ae926e40986caf16cbf240f;hb=9a3c48389301917fb3e71c21fe87a074a0c2a164;hp=37d457ea1b6a94e8ca73cb48040a25b171278420;hpb=bdfa30bf335f0e728e222d9fd9d137605c535abe;p=surf.git diff --git a/surf.c b/surf.c index 37d457e..8b57a85 100644 --- a/surf.c +++ b/surf.c @@ -73,6 +73,7 @@ static char *progname; static const char *autouri(Client *c); static char *buildpath(const char *path); +static void changecookie(SoupCookieJar *jar, SoupCookie *o, SoupCookie *n, gpointer p); static void cleanup(void); static void clipboard(Client *c, const Arg *arg); static void context(WebKitWebView *v, GtkMenu *m, Client *c); @@ -155,6 +156,18 @@ buildpath(const char *path) { return apath; } +void +changecookie(SoupCookieJar *jar, SoupCookie *oc, SoupCookie *c, gpointer p) { + SoupDate *e; + + if(c && c->expires == NULL) { + e = soup_date_new_from_time_t(time(NULL) + sessiontime); + c = soup_cookie_copy(c); + soup_cookie_set_expires(c, e); + soup_cookie_jar_add_cookie(cookiejar, c); + } +} + void cleanup(void) { while(clients) @@ -670,7 +683,7 @@ setup(void) { dpy = GDK_DISPLAY(); session = webkit_get_default_session(); - uriprop = XInternAtom(dpy, "_SURF_uri", False); + uriprop = XInternAtom(dpy, "_SURF_URI", False); /* create dirs and files */ cookiefile = buildpath(cookiefile); @@ -682,6 +695,7 @@ setup(void) { s = webkit_get_default_session(); cookiejar = soup_cookie_jar_text_new(cookiefile, FALSE); soup_session_add_feature(s, SOUP_SESSION_FEATURE(cookiejar)); + g_signal_connect(cookiejar, "changed", G_CALLBACK(changecookie), NULL); } void