/* Document (meta) refresh. */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #include #include "elinks.h" #include "config/options.h" #include "document/document.h" #include "document/refresh.h" #include "document/view.h" #include "main/timer.h" #include "protocol/uri.h" #include "session/download.h" #include "session/session.h" #include "session/task.h" #include "util/error.h" #include "util/memory.h" #include "util/string.h" struct document_refresh * init_document_refresh(unsigned char *url, unsigned long seconds) { struct document_refresh *refresh; refresh = mem_alloc(sizeof(*refresh)); if (!refresh) return NULL; refresh->uri = get_uri(url, 0); if (!refresh->uri) { mem_free(refresh); return NULL; } refresh->seconds = seconds; refresh->timer = TIMER_ID_UNDEF; refresh->restart = 1; return refresh; } void kill_document_refresh(struct document_refresh *refresh) { kill_timer(&refresh->timer); } void done_document_refresh(struct document_refresh *refresh) { kill_document_refresh(refresh); done_uri(refresh->uri); mem_free(refresh); } static void do_document_refresh(void *data) { struct session *ses = data; struct document_refresh *refresh = ses->doc_view->document->refresh; struct type_query *type_query; assert(refresh); refresh->timer = TIMER_ID_UNDEF; /* When refreshing documents that will trigger a download (like * sourceforge's download pages) make sure that we do not endlessly * trigger the download (bug 289). */ foreach (type_query, ses->type_queries) if (compare_uri(refresh->uri, type_query->uri, URI_BASE)) return; if (compare_uri(refresh->uri, ses->doc_view->document->uri, 0)) { /* If the refreshing is for the current URI, force a reload. */ reload(ses, CACHE_MODE_FORCE_RELOAD); } else { /* This makes sure that we send referer. */ goto_uri_frame(ses, refresh->uri, NULL, CACHE_MODE_NORMAL); /* XXX: A possible very wrong work-around for refreshing used when * downloading files. */ refresh->restart = 0; } } void start_document_refresh(struct document_refresh *refresh, struct session *ses) { milliseconds_T minimum = (milliseconds_T) get_opt_int("document.browse.minimum_refresh_time"); milliseconds_T refresh_delay = sec_to_ms(refresh->seconds); milliseconds_T time = ms_max(refresh_delay, minimum); struct type_query *type_query; /* FIXME: This is just a work-around for stopping more than one timer * from being started at anytime. The refresh timer should maybe belong * to the session? The multiple refresh timers is triggered by * http://ttforums.owenrudge.net/login.php when pressing 'Log in' and * waiting for it to refresh. --jonas */ if (!refresh->restart || refresh->timer != TIMER_ID_UNDEF) return; /* Like bug 289 another sourceforge download thingy this time with * number 434. It should take care when refreshing to the same URI or * what ever the cause is. */ foreach (type_query, ses->type_queries) if (compare_uri(refresh->uri, type_query->uri, URI_BASE)) return; install_timer(&refresh->timer, time, do_document_refresh, ses); }