From 91003cbaf39271e8b6611d587eec97301bc6df7e Mon Sep 17 00:00:00 2001 From: Daniel Silverstone Date: Sat, 12 Mar 2011 17:54:02 +0000 Subject: [PATCH] WINDOW REDRAW and WINDOW RELOAD. Also, when quitting, cleanup svn path=/trunk/netsurf/; revision=11978 --- monkey/browser.c | 63 ++++++++++++++++++++++++++++++++++++++++++++++++ monkey/browser.h | 2 +- monkey/main.c | 2 ++ 3 files changed, 66 insertions(+), 1 deletion(-) diff --git a/monkey/browser.c b/monkey/browser.c index 606884451..1c53aae8b 100644 --- a/monkey/browser.c +++ b/monkey/browser.c @@ -76,6 +76,13 @@ monkey_window_process_reformats(void) } RING_ITERATE_END(gw_ring, c_ring); } +void +monkey_kill_browser_windows(void) +{ + while (gw_ring != NULL) { + browser_window_destroy(gw_ring->bw); + } +} struct gui_window * gui_create_browser_window(struct browser_window *bw, @@ -459,6 +466,58 @@ monkey_window_handle_go(int argc, char **argv) } +static void +monkey_window_handle_redraw(int argc, char **argv) +{ + struct gui_window *gw; + struct rect clip; + + if (argc != 3 && argc != 7) { + fprintf(stdout, "ERROR WINDOW REDRAW ARGS BAD"); + return; + } + + gw = monkey_find_window_by_num(atoi(argv[2])); + + if (gw == NULL) { + fprintf(stdout, "ERROR WINDOW NUM BAD\n"); + return; + } + + clip.x0 = 0; + clip.y0 = 0; + clip.x1 = gw->width; + clip.y1 = gw->height; + + if (argc == 7) { + clip.x0 = atoi(argv[3]); + clip.y0 = atoi(argv[4]); + clip.x1 = atoi(argv[5]); + clip.y1 = atoi(argv[6]); + } + + LOG(("Issue redraw")); + browser_window_redraw(gw->bw, gw->scrollx, gw->scrolly, &clip); +} + +static void +monkey_window_handle_reload(int argc, char **argv) +{ + struct gui_window *gw; + if (argc != 3 && argc != 4) { + fprintf(stdout, "ERROR WINDOW RELOAD ARGS BAD"); + } + + gw = monkey_find_window_by_num(atoi(argv[2])); + + if (gw == NULL) { + fprintf(stdout, "ERROR WINDOW NUM BAD\n"); + } else { + browser_window_reload(gw->bw, argc == 4); + } +} + + void monkey_window_handle_command(int argc, char **argv) { @@ -471,6 +530,10 @@ monkey_window_handle_command(int argc, char **argv) monkey_window_handle_destroy(argc, argv); } else if (strcmp(argv[1], "GO") == 0) { monkey_window_handle_go(argc, argv); + } else if (strcmp(argv[1], "REDRAW") == 0) { + monkey_window_handle_redraw(argc, argv); + } else if (strcmp(argv[1], "RELOAD") == 0) { + monkey_window_handle_reload(argc, argv); } } diff --git a/monkey/browser.h b/monkey/browser.h index d0e39e08a..3ccbe7a91 100644 --- a/monkey/browser.h +++ b/monkey/browser.h @@ -41,5 +41,5 @@ struct gui_window *monkey_find_window_by_content(hlcache_handle *content); void monkey_window_process_reformats(void); void monkey_window_handle_command(int argc, char **argv); - +void monkey_kill_browser_windows(void); #endif /* NETSURF_MONKEY_BROWSER_H */ diff --git a/monkey/main.c b/monkey/main.c index 1dab747e2..168419926 100644 --- a/monkey/main.c +++ b/monkey/main.c @@ -131,6 +131,8 @@ main(int argc, char **argv) fprintf(stdout, "GENERIC STARTED\n"); netsurf_main_loop(); fprintf(stdout, "GENERIC CLOSING_DOWN\n"); + monkey_kill_browser_windows(); + netsurf_exit(); fprintf(stdout, "GENERIC FINISHED\n"); return 0;