diff options
author | John Mark Bell <jmb@netsurf-browser.org> | 2005-03-20 03:35:50 +0000 |
---|---|---|
committer | John Mark Bell <jmb@netsurf-browser.org> | 2005-03-20 03:35:50 +0000 |
commit | 44f1f35436c85ba3d8adf1ba3202db116bb4b914 (patch) | |
tree | 1c524e298e42e2bd46163e338e21c6df723decfa /desktop | |
parent | 4777e75682560d2bab99ef559002d7e6267bbb9c (diff) | |
download | netsurf-44f1f35436c85ba3d8adf1ba3202db116bb4b914.tar.gz netsurf-44f1f35436c85ba3d8adf1ba3202db116bb4b914.tar.bz2 |
[project @ 2005-03-20 03:35:50 by jmb]
Improve handling of fragments on the same page as already loaded.
svn path=/import/netsurf/; revision=1550
Diffstat (limited to 'desktop')
-rw-r--r-- | desktop/browser.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/desktop/browser.c b/desktop/browser.c index 259358acd..47176c8a7 100644 --- a/desktop/browser.c +++ b/desktop/browser.c @@ -192,11 +192,20 @@ void browser_window_go_post(struct browser_window *bw, const char *url, } if (hash) { bw->frag_id = strdup(hash+1); + /* if we're simply moving to another ID on the same page, + * don't bother to fetch, just update the window + */ + if (strncasecmp(bw->current_content->url, + url2, hash - url2) == 0) { + free(url2); + browser_window_update(bw, false); + return; + } } - url_content = url_store_find(url2); - if (url_content) - url_content->visits++; + url_content = url_store_find(url2); + if (url_content) + url_content->visits++; browser_window_set_status(bw, messages_get("Loading")); bw->history_add = history_add; |