mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-04 10:14:29 +03:00
split out status bar text cache into separate struct
This commit is contained in:
parent
028c4e2860
commit
855721282c
@ -87,7 +87,6 @@
|
||||
* \param x Updated to x-coord of top left of scrollbar widget
|
||||
* \param y Updated to y-coord of top left of scrollbar widget
|
||||
*/
|
||||
|
||||
static inline void browser_window_get_scrollbar_pos(struct browser_window *bw,
|
||||
bool horizontal, int *x, int *y)
|
||||
{
|
||||
@ -129,6 +128,7 @@ browser_window_get_name(struct browser_window *bw, const char **out_name)
|
||||
return NSERROR_OK;
|
||||
}
|
||||
|
||||
|
||||
/* exported interface, documented in browser.h */
|
||||
nserror
|
||||
browser_window_set_name(struct browser_window *bw, const char *name)
|
||||
@ -153,6 +153,7 @@ browser_window_set_name(struct browser_window *bw, const char *name)
|
||||
return NSERROR_OK;
|
||||
}
|
||||
|
||||
|
||||
/* exported interface, documented in browser.h */
|
||||
bool
|
||||
browser_window_redraw(struct browser_window *bw,
|
||||
@ -330,6 +331,7 @@ browser_window_redraw(struct browser_window *bw,
|
||||
return plot_ok;
|
||||
}
|
||||
|
||||
|
||||
/* exported interface, documented in browser.h */
|
||||
bool browser_window_redraw_ready(struct browser_window *bw)
|
||||
{
|
||||
@ -344,6 +346,7 @@ bool browser_window_redraw_ready(struct browser_window *bw)
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
/* exported interface, documented in browser_private.h */
|
||||
void browser_window_update_extent(struct browser_window *bw)
|
||||
{
|
||||
@ -355,9 +358,13 @@ void browser_window_update_extent(struct browser_window *bw)
|
||||
browser_window_handle_scrollbars(bw);
|
||||
}
|
||||
|
||||
|
||||
/* exported interface, documented in browser.h */
|
||||
void browser_window_get_position(struct browser_window *bw, bool root,
|
||||
int *pos_x, int *pos_y)
|
||||
void
|
||||
browser_window_get_position(struct browser_window *bw,
|
||||
bool root,
|
||||
int *pos_x,
|
||||
int *pos_y)
|
||||
{
|
||||
*pos_x = 0;
|
||||
*pos_y = 0;
|
||||
@ -397,6 +404,7 @@ void browser_window_get_position(struct browser_window *bw, bool root,
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/* exported interface, documented in browser.h */
|
||||
void browser_window_set_position(struct browser_window *bw, int x, int y)
|
||||
{
|
||||
@ -939,10 +947,10 @@ nserror browser_window_initialise_common(enum browser_window_create_flags flags,
|
||||
bw->focus = NULL;
|
||||
|
||||
/* initialise status text cache */
|
||||
bw->status_text = NULL;
|
||||
bw->status_text_len = 0;
|
||||
bw->status_match = 0;
|
||||
bw->status_miss = 0;
|
||||
bw->status.text = NULL;
|
||||
bw->status.text_len = 0;
|
||||
bw->status.match = 0;
|
||||
bw->status.miss = 0;
|
||||
|
||||
return NSERROR_OK;
|
||||
}
|
||||
@ -1318,8 +1326,10 @@ static void browser_window_convert_to_download(struct browser_window *bw,
|
||||
/**
|
||||
* Browser window content event callback handler.
|
||||
*/
|
||||
static nserror browser_window_callback(hlcache_handle *c,
|
||||
const hlcache_event *event, void *pw)
|
||||
static nserror
|
||||
browser_window_callback(hlcache_handle *c,
|
||||
const hlcache_event *event,
|
||||
void *pw)
|
||||
{
|
||||
struct browser_window *bw = pw;
|
||||
nserror res = NSERROR_OK;
|
||||
@ -1857,9 +1867,9 @@ static void browser_window_destroy_internal(struct browser_window *bw)
|
||||
browser_window_history_destroy(bw);
|
||||
|
||||
free(bw->name);
|
||||
free(bw->status_text);
|
||||
bw->status_text = NULL;
|
||||
LOG("Status text cache match:miss %d:%d", bw->status_match, bw->status_miss);
|
||||
free(bw->status.text);
|
||||
bw->status.text = NULL;
|
||||
LOG("Status text cache match:miss %d:%d", bw->status.match, bw->status.miss);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1931,7 +1941,8 @@ nserror browser_window_refresh_url_bar(struct browser_window *bw)
|
||||
|
||||
|
||||
/* exported interface documented in netsurf/browser_window.h */
|
||||
nserror browser_window_navigate(struct browser_window *bw,
|
||||
nserror
|
||||
browser_window_navigate(struct browser_window *bw,
|
||||
nsurl *url,
|
||||
nsurl *referrer,
|
||||
enum browser_window_nav_flags flags,
|
||||
@ -2289,14 +2300,16 @@ void browser_window_update(struct browser_window *bw, bool scroll_to_top)
|
||||
|
||||
browser_window_update_extent(bw);
|
||||
|
||||
if (scroll_to_top)
|
||||
browser_window_set_scroll(bw, 0, 0);
|
||||
|
||||
/* if frag_id exists, then try to scroll to it */
|
||||
/** @todo don't do this if the user has scrolled */
|
||||
if (bw->frag_id && html_get_id_offset(bw->current_content,
|
||||
bw->frag_id, &x, &y)) {
|
||||
if (bw->frag_id &&
|
||||
html_get_id_offset(bw->current_content,
|
||||
bw->frag_id, &x, &y)) {
|
||||
browser_window_set_scroll(bw, x, y);
|
||||
} else {
|
||||
if (scroll_to_top) {
|
||||
browser_window_set_scroll(bw, 0, 0);
|
||||
}
|
||||
}
|
||||
|
||||
guit->window->redraw(bw->window);
|
||||
@ -2476,10 +2489,10 @@ void browser_window_set_status(struct browser_window *bw, const char *text)
|
||||
while (bw->parent)
|
||||
bw = bw->parent;
|
||||
|
||||
if ((bw->status_text != NULL) &&
|
||||
(strcmp(text, bw->status_text) == 0)) {
|
||||
if ((bw->status.text != NULL) &&
|
||||
(strcmp(text, bw->status.text) == 0)) {
|
||||
/* status text is unchanged */
|
||||
bw->status_match++;
|
||||
bw->status.match++;
|
||||
return;
|
||||
}
|
||||
|
||||
@ -2487,18 +2500,18 @@ void browser_window_set_status(struct browser_window *bw, const char *text)
|
||||
|
||||
text_len = strlen(text);
|
||||
|
||||
if ((bw->status_text == NULL) || (bw->status_text_len < text_len)) {
|
||||
if ((bw->status.text == NULL) || (bw->status.text_len < text_len)) {
|
||||
/* no current string allocation or it is not long enough */
|
||||
free(bw->status_text);
|
||||
bw->status_text = strdup(text);
|
||||
bw->status_text_len = text_len;
|
||||
free(bw->status.text);
|
||||
bw->status.text = strdup(text);
|
||||
bw->status.text_len = text_len;
|
||||
} else {
|
||||
/* current allocation has enough space */
|
||||
memcpy(bw->status_text, text, text_len + 1);
|
||||
memcpy(bw->status.text, text, text_len + 1);
|
||||
}
|
||||
|
||||
bw->status_miss++;
|
||||
guit->window->set_status(bw->window, bw->status_text);
|
||||
bw->status.miss++;
|
||||
guit->window->set_status(bw->window, bw->status.text);
|
||||
}
|
||||
|
||||
|
||||
|
@ -37,24 +37,34 @@ struct gui_window;
|
||||
struct history;
|
||||
struct selection;
|
||||
|
||||
/** Browser window data. */
|
||||
/**
|
||||
* Browser window data.
|
||||
*/
|
||||
struct browser_window {
|
||||
/** Page currently displayed, or 0. Must have status READY or DONE. */
|
||||
/**
|
||||
* Content handle of page currently displayed which must have
|
||||
* READY or DONE status or NULL for no content.
|
||||
*/
|
||||
struct hlcache_handle *current_content;
|
||||
/** Page being loaded, or 0. */
|
||||
/** Page being loaded, or NULL. */
|
||||
struct hlcache_handle *loading_content;
|
||||
|
||||
/** Page Favicon */
|
||||
struct hlcache_handle *current_favicon;
|
||||
/** handle for favicon which we started loading early */
|
||||
struct hlcache_handle *loading_favicon;
|
||||
/** favicon fetch already failed - prevents infinite error looping */
|
||||
/**
|
||||
* flag to indicate favicon fetch already failed which
|
||||
* prevents infinite error looping.
|
||||
*/
|
||||
bool failed_favicon;
|
||||
|
||||
/** Window history structure. */
|
||||
/** local history handle. */
|
||||
struct history *history;
|
||||
|
||||
/** Platform specific window data. */
|
||||
/**
|
||||
* Platform specific window data only valid at top level.
|
||||
*/
|
||||
struct gui_window *window;
|
||||
|
||||
/** Busy indicator is active. */
|
||||
@ -156,14 +166,15 @@ struct browser_window {
|
||||
struct jscontext *jsctx;
|
||||
|
||||
/** cache of the currently displayed status text. */
|
||||
char *status_text; /**< Current status bar text. */
|
||||
int status_text_len; /**< Length of the browser_window::status_text buffer. */
|
||||
int status_match; /**< Number of times an idempotent status-set operation was performed. */
|
||||
int status_miss; /**< Number of times status was really updated. */
|
||||
struct {
|
||||
char *text; /**< Current status bar text. */
|
||||
int text_len; /**< Length of the status::text buffer. */
|
||||
int match; /**< Number of times an idempotent status-set operation was performed. */
|
||||
int miss; /**< Number of times status was really updated. */
|
||||
} status;
|
||||
};
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Initialise common parts of a browser window
|
||||
*
|
||||
@ -174,6 +185,7 @@ struct browser_window {
|
||||
nserror browser_window_initialise_common(enum browser_window_create_flags flags,
|
||||
struct browser_window *bw, struct browser_window *existing);
|
||||
|
||||
|
||||
/**
|
||||
* Get the dimensions of the area a browser window occupies
|
||||
*
|
||||
@ -185,6 +197,7 @@ nserror browser_window_initialise_common(enum browser_window_create_flags flags,
|
||||
void browser_window_get_dimensions(struct browser_window *bw,
|
||||
int *width, int *height, bool scaled);
|
||||
|
||||
|
||||
/**
|
||||
* Update the extent of the inside of a browser window to that of the current
|
||||
* content
|
||||
@ -193,6 +206,7 @@ void browser_window_get_dimensions(struct browser_window *bw,
|
||||
*/
|
||||
void browser_window_update_extent(struct browser_window *bw);
|
||||
|
||||
|
||||
/**
|
||||
* Change the status bar of a browser window.
|
||||
*
|
||||
@ -201,6 +215,7 @@ void browser_window_update_extent(struct browser_window *bw);
|
||||
*/
|
||||
void browser_window_set_status(struct browser_window *bw, const char *text);
|
||||
|
||||
|
||||
/**
|
||||
* Get the root level browser window
|
||||
*
|
||||
|
Loading…
Reference in New Issue
Block a user