-
- if (regwin_infos->w == 2) {
- if ((new < 0) || (new > 0xFF)) {
- log_info(" new value: out of range");
- new = old; /* Put back old value... */
- } else {
- log_info(" new value: $%02X", new);
- }
- } else if (regwin_infos->w == 4) {
- if ((new < 0) || (new > 0xFFFF)) {
- log_info(" new value: out of range");
- new = old; /* Put back old value... */
- } else {
- log_info(" new value: $%04X", new);
- }
+ log_info(" new value: $%04X", new);
+
+ /* Store new value in emulator register (if in range). */
+ rc = regwin_write(regwin_infos, new);
+ if (rc == 0) {
+ /* Store new value in gtk model. */
+ int2asciihex(new, str, regwin_infos->w);
+ gtk_list_store_set(GTK_LIST_STORE(model), &iter, COL_VAL, str, -1);
+
+ /*
+ * Make sure to update all windows.
+ * For example, R0-R7 values depends on internal memory values.
+ */
+ emugtk_UpdateDisplay();