summaryrefslogtreecommitdiff
path: root/gui/DebugMemory.c
diff options
context:
space:
mode:
authorSND\edgbla_cp <SND\edgbla_cp@e17a0e51-4ae3-4d35-97c3-1a29b211df97>2012-12-13 14:26:27 +0000
committerSND\edgbla_cp <SND\edgbla_cp@e17a0e51-4ae3-4d35-97c3-1a29b211df97>2012-12-13 14:26:27 +0000
commitc0cba1977a8cac317af37c3004c53417fbce31bc (patch)
treeecafa13566707a40f1aa26ac8933a4d2a57fcfe6 /gui/DebugMemory.c
parent7e7f6237488dc45f0aa52697cbd30484a5b5661d (diff)
downloadpcsxr-c0cba1977a8cac317af37c3004c53417fbce31bc.tar.gz
Patch 13442, 13443 (ckain);
git-svn-id: https://pcsxr.svn.codeplex.com/svn/pcsxr@81738 e17a0e51-4ae3-4d35-97c3-1a29b211df97
Diffstat (limited to 'gui/DebugMemory.c')
-rwxr-xr-xgui/DebugMemory.c34
1 files changed, 31 insertions, 3 deletions
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);
}