1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

Bug 887: save_cookies reports errors if requested by the user.

This commit is contained in:
Kalle Olavi Niemitalo 2006-12-09 18:27:40 +02:00 committed by Kalle Olavi Niemitalo
parent 7551be3194
commit e815e07179
3 changed files with 51 additions and 13 deletions

View File

@ -802,7 +802,7 @@ static void
resave_cookies_bottom_half(void *always_null) resave_cookies_bottom_half(void *always_null)
{ {
if (get_cookies_save() && get_cookies_resave()) if (get_cookies_save() && get_cookies_resave())
save_cookies(0); /* checks cookies_dirty */ save_cookies(NULL); /* checks cookies_dirty */
} }
/* Note that the cookies have been modified, and register a bottom /* Note that the cookies have been modified, and register a bottom
@ -822,27 +822,58 @@ set_cookies_dirty(void)
register_bottom_half(resave_cookies_bottom_half, NULL); register_bottom_half(resave_cookies_bottom_half, NULL);
} }
/* @interactive is 1 if the user told ELinks to save cookies, or 0 if /* @term is non-NULL if the user told ELinks to save cookies, or NULL
* ELinks decided that on its own. In the latter case, this function * if ELinks decided that on its own. In the former case, this
* does not save the cookies if it thinks the file is already up to * function reports errors to @term, unless CONFIG_SMALL is defined.
* date. */ * In the latter case, this function does not save the cookies if it
* thinks the file is already up to date. */
void void
save_cookies(int interactive) { save_cookies(struct terminal *term) {
struct cookie *c; struct cookie *c;
unsigned char *cookfile; unsigned char *cookfile;
struct secure_save_info *ssi; struct secure_save_info *ssi;
time_t now; time_t now;
if (cookies_nosave || !elinks_home || !(cookies_dirty || interactive) #ifdef CONFIG_SMALL
|| get_cmd_opt_bool("anonymous")) # define CANNOT_SAVE_COOKIES(message)
#else
# define CANNOT_SAVE_COOKIES(flags, message) \
do { \
if (term) \
info_box(term, flags, N_("Cannot save cookies"),\
ALIGN_LEFT, message); \
} while (0)
#endif
if (cookies_nosave) {
assert(term == NULL);
if_assert_failed {}
return; return;
}
if (!elinks_home) {
CANNOT_SAVE_COOKIES(0, N_("ELinks was started without a home directory."));
return;
}
if (!cookies_dirty && !term)
return;
if (get_cmd_opt_bool("anonymous")) {
CANNOT_SAVE_COOKIES(0, N_("ELinks was started with the -anonymous option."));
return;
}
cookfile = straconcat(elinks_home, COOKIES_FILENAME, NULL); cookfile = straconcat(elinks_home, COOKIES_FILENAME, NULL);
if (!cookfile) return; if (!cookfile) {
CANNOT_SAVE_COOKIES(0, N_("Out of memory"));
return;
}
ssi = secure_open(cookfile); ssi = secure_open(cookfile);
mem_free(cookfile); mem_free(cookfile);
if (!ssi) return; if (!ssi) {
CANNOT_SAVE_COOKIES(MSGBOX_NO_TEXT_INTL,
secsave_strerror(secsave_errno, term));
return;
}
now = time(NULL); now = time(NULL);
foreach (c, cookies) { foreach (c, cookies) {
@ -856,7 +887,13 @@ save_cookies(int interactive) {
break; break;
} }
secsave_errno = SS_ERR_OTHER; /* @secure_close doesn't always set it */
if (!secure_close(ssi)) cookies_dirty = 0; if (!secure_close(ssi)) cookies_dirty = 0;
else {
CANNOT_SAVE_COOKIES(MSGBOX_NO_TEXT_INTL,
secsave_strerror(secsave_errno, term));
}
#undef CANNOT_SAVE_COOKIES
} }
static void static void
@ -884,7 +921,7 @@ done_cookies(struct module *module)
free_list(c_domains); free_list(c_domains);
if (!cookies_nosave && get_cookies_save()) if (!cookies_nosave && get_cookies_save())
save_cookies(0); save_cookies(NULL);
free_cookies_list(&cookies); free_cookies_list(&cookies);
free_cookies_list(&cookie_queries); free_cookies_list(&cookie_queries);

View File

@ -8,6 +8,7 @@
#include "util/time.h" #include "util/time.h"
struct listbox_item; struct listbox_item;
struct terminal;
enum cookies_accept { enum cookies_accept {
COOKIES_ACCEPT_NONE, COOKIES_ACCEPT_NONE,
@ -44,7 +45,7 @@ void done_cookie(struct cookie *);
void delete_cookie(struct cookie *); void delete_cookie(struct cookie *);
void set_cookie(struct uri *, unsigned char *); void set_cookie(struct uri *, unsigned char *);
void load_cookies(void); void load_cookies(void);
void save_cookies(int interactive); void save_cookies(struct terminal *);
void set_cookies_dirty(void); void set_cookies_dirty(void);
/* Note that the returned value points to a static structure and thus the /* Note that the returned value points to a static structure and thus the

View File

@ -465,7 +465,7 @@ push_add_server_button(struct dialog_data *dlg_data, struct widget_data *button)
static widget_handler_status_T static widget_handler_status_T
push_save_button(struct dialog_data *dlg_data, struct widget_data *button) push_save_button(struct dialog_data *dlg_data, struct widget_data *button)
{ {
save_cookies(1); save_cookies(dlg_data->win->term);
return EVENT_PROCESSED; return EVENT_PROCESSED;
} }