From c0cba1977a8cac317af37c3004c53417fbce31bc Mon Sep 17 00:00:00 2001 From: "SND\\edgbla_cp" Date: Thu, 13 Dec 2012 14:26:27 +0000 Subject: Patch 13442, 13443 (ckain); git-svn-id: https://pcsxr.svn.codeplex.com/svn/pcsxr@81738 e17a0e51-4ae3-4d35-97c3-1a29b211df97 --- gui/DebugMemory.c | 34 +++++++++++++++++++++++++++++++--- 1 file changed, 31 insertions(+), 3 deletions(-) (limited to 'gui/DebugMemory.c') diff --git a/gui/DebugMemory.c b/gui/DebugMemory.c index 27dcf8bd..61739978 100755 --- a/gui/DebugMemory.c +++ b/gui/DebugMemory.c @@ -26,6 +26,16 @@ static GtkBuilder *builder; static GtkWidget *MemViewDlg = NULL; static u32 MemViewAddress = 0; +/* Copy value of MemViewAddress as text of entry_address */ +static void sync_update_address_text() { + char buftext[20]; + GtkWidget *widget; + + sprintf(buftext, "%.8X", MemViewAddress | 0x80000000); + widget = gtk_builder_get_object(builder, "entry_address"); + gtk_entry_set_text(GTK_ENTRY(widget), buftext); +} + static void UpdateMemViewDlg() { s32 start, end; int i; @@ -42,9 +52,7 @@ static void UpdateMemViewDlg() { MemViewAddress &= 0x1fffff; - sprintf(buftext, "%.8X", MemViewAddress | 0x80000000); - widget = gtk_builder_get_object(builder, "entry_address"); - gtk_entry_set_text(GTK_ENTRY(widget), buftext); + sync_update_address_text(); start = MemViewAddress & 0x1ffff0; end = start + MEMVIEW_MAX_LINES * 16; @@ -81,6 +89,18 @@ static void UpdateMemViewDlg() { gtk_widget_show(widget); } +static void MemView_Prev() { + MemViewAddress -= MEMVIEW_MAX_LINES; + sync_update_address_text(); + UpdateMemViewDlg(); +} + +static void MemView_Next() { + MemViewAddress += MEMVIEW_MAX_LINES; + sync_update_address_text(); + UpdateMemViewDlg(); +} + static void MemView_Go() { GtkWidget *widget; @@ -311,6 +331,14 @@ void RunDebugMemoryDialog() { g_signal_connect_data(G_OBJECT(widget), "clicked", G_CALLBACK(MemView_Go), builder, NULL, G_CONNECT_AFTER); + widget = gtk_builder_get_object(builder, "btn_prev"); + g_signal_connect_data(G_OBJECT(widget), "clicked", + G_CALLBACK(MemView_Prev), builder, NULL, G_CONNECT_AFTER); + + widget = gtk_builder_get_object(builder, "btn_next"); + g_signal_connect_data(G_OBJECT(widget), "clicked", + G_CALLBACK(MemView_Next), builder, NULL, G_CONNECT_AFTER); + g_signal_connect_data(G_OBJECT(MemViewDlg), "response", G_CALLBACK(MemView_Close), builder, (GClosureNotify)g_object_unref, G_CONNECT_AFTER); } -- cgit v1.2.3