1 |
39 |
zeus |
/////////////////////////////////////////////////////////////////////////
|
2 |
52 |
zeus |
// $Id: gui.cc,v 1.105 2008/05/04 09:29:45 vruppert Exp $
|
3 |
39 |
zeus |
/////////////////////////////////////////////////////////////////////////
|
4 |
|
|
//
|
5 |
|
|
// Copyright (C) 2002 MandrakeSoft S.A.
|
6 |
|
|
//
|
7 |
|
|
// MandrakeSoft S.A.
|
8 |
|
|
// 43, rue d'Aboukir
|
9 |
|
|
// 75002 Paris - France
|
10 |
|
|
// http://www.linux-mandrake.com/
|
11 |
|
|
// http://www.mandrakesoft.com/
|
12 |
|
|
//
|
13 |
|
|
// This library is free software; you can redistribute it and/or
|
14 |
|
|
// modify it under the terms of the GNU Lesser General Public
|
15 |
|
|
// License as published by the Free Software Foundation; either
|
16 |
|
|
// version 2 of the License, or (at your option) any later version.
|
17 |
|
|
//
|
18 |
|
|
// This library is distributed in the hope that it will be useful,
|
19 |
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
20 |
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
21 |
|
|
// Lesser General Public License for more details.
|
22 |
|
|
//
|
23 |
|
|
// You should have received a copy of the GNU Lesser General Public
|
24 |
|
|
// License along with this library; if not, write to the Free Software
|
25 |
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
26 |
|
|
|
27 |
|
|
|
28 |
|
|
#include <signal.h>
|
29 |
|
|
#include "bochs.h"
|
30 |
|
|
#include "iodev.h"
|
31 |
|
|
#include "gui/bitmaps/floppya.h"
|
32 |
|
|
#include "gui/bitmaps/floppyb.h"
|
33 |
|
|
#include "gui/bitmaps/mouse.h"
|
34 |
|
|
#include "gui/bitmaps/reset.h"
|
35 |
|
|
#include "gui/bitmaps/power.h"
|
36 |
|
|
#include "gui/bitmaps/snapshot.h"
|
37 |
|
|
#include "gui/bitmaps/copy.h"
|
38 |
|
|
#include "gui/bitmaps/paste.h"
|
39 |
|
|
#include "gui/bitmaps/configbutton.h"
|
40 |
|
|
#include "gui/bitmaps/cdromd.h"
|
41 |
|
|
#include "gui/bitmaps/userbutton.h"
|
42 |
|
|
#include "gui/bitmaps/saverestore.h"
|
43 |
|
|
|
44 |
|
|
#if BX_WITH_MACOS
|
45 |
|
|
# include <Disks.h>
|
46 |
|
|
#endif
|
47 |
|
|
|
48 |
|
|
bx_gui_c *bx_gui = NULL;
|
49 |
|
|
|
50 |
|
|
#define BX_GUI_THIS bx_gui->
|
51 |
|
|
#define LOG_THIS BX_GUI_THIS
|
52 |
|
|
|
53 |
|
|
#define BX_KEY_UNKNOWN 0x7fffffff
|
54 |
|
|
#define N_USER_KEYS 37
|
55 |
|
|
|
56 |
|
|
typedef struct {
|
57 |
|
|
const char *key;
|
58 |
|
|
Bit32u symbol;
|
59 |
|
|
} user_key_t;
|
60 |
|
|
|
61 |
|
|
static user_key_t user_keys[N_USER_KEYS] =
|
62 |
|
|
{
|
63 |
|
|
{ "f1", BX_KEY_F1 },
|
64 |
|
|
{ "f2", BX_KEY_F2 },
|
65 |
|
|
{ "f3", BX_KEY_F3 },
|
66 |
|
|
{ "f4", BX_KEY_F4 },
|
67 |
|
|
{ "f5", BX_KEY_F5 },
|
68 |
|
|
{ "f6", BX_KEY_F6 },
|
69 |
|
|
{ "f7", BX_KEY_F7 },
|
70 |
|
|
{ "f8", BX_KEY_F8 },
|
71 |
|
|
{ "f9", BX_KEY_F9 },
|
72 |
|
|
{ "f10", BX_KEY_F10 },
|
73 |
|
|
{ "f11", BX_KEY_F11 },
|
74 |
|
|
{ "f12", BX_KEY_F12 },
|
75 |
|
|
{ "alt", BX_KEY_ALT_L },
|
76 |
|
|
{ "bksl", BX_KEY_BACKSLASH },
|
77 |
|
|
{ "bksp", BX_KEY_BACKSPACE },
|
78 |
|
|
{ "ctrl", BX_KEY_CTRL_L },
|
79 |
|
|
{ "del", BX_KEY_DELETE },
|
80 |
|
|
{ "down", BX_KEY_DOWN },
|
81 |
|
|
{ "end", BX_KEY_END },
|
82 |
|
|
{ "enter", BX_KEY_ENTER },
|
83 |
|
|
{ "esc", BX_KEY_ESC },
|
84 |
|
|
{ "home", BX_KEY_HOME },
|
85 |
|
|
{ "ins", BX_KEY_INSERT },
|
86 |
|
|
{ "left", BX_KEY_LEFT },
|
87 |
|
|
{ "menu", BX_KEY_MENU },
|
88 |
|
|
{ "minus", BX_KEY_MINUS },
|
89 |
|
|
{ "pgdwn", BX_KEY_PAGE_DOWN },
|
90 |
|
|
{ "pgup", BX_KEY_PAGE_UP },
|
91 |
|
|
{ "plus", BX_KEY_KP_ADD },
|
92 |
|
|
{ "right", BX_KEY_RIGHT },
|
93 |
|
|
{ "shift", BX_KEY_SHIFT_L },
|
94 |
|
|
{ "space", BX_KEY_SPACE },
|
95 |
|
|
{ "tab", BX_KEY_TAB },
|
96 |
|
|
{ "up", BX_KEY_UP },
|
97 |
|
|
{ "win", BX_KEY_WIN_L },
|
98 |
|
|
{ "print", BX_KEY_PRINT },
|
99 |
|
|
{ "power", BX_KEY_POWER_POWER }
|
100 |
|
|
};
|
101 |
|
|
|
102 |
|
|
bx_gui_c::bx_gui_c(void)
|
103 |
|
|
{
|
104 |
|
|
put("GUI"); // Init in specific_init
|
105 |
|
|
settype(GUILOG);
|
106 |
|
|
statusitem_count = 0;
|
107 |
|
|
framebuffer = NULL;
|
108 |
|
|
}
|
109 |
|
|
|
110 |
|
|
bx_gui_c::~bx_gui_c()
|
111 |
|
|
{
|
112 |
|
|
if (framebuffer != NULL) {
|
113 |
|
|
delete [] framebuffer;
|
114 |
|
|
}
|
115 |
|
|
}
|
116 |
|
|
|
117 |
|
|
void bx_gui_c::init(int argc, char **argv, unsigned tilewidth, unsigned tileheight)
|
118 |
|
|
{
|
119 |
|
|
BX_GUI_THIS new_gfx_api = 0;
|
120 |
|
|
BX_GUI_THIS host_xres = 640;
|
121 |
|
|
BX_GUI_THIS host_yres = 480;
|
122 |
|
|
BX_GUI_THIS host_bpp = 8;
|
123 |
|
|
BX_GUI_THIS dialog_caps = BX_GUI_DLG_RUNTIME | BX_GUI_DLG_SAVE_RESTORE;
|
124 |
|
|
|
125 |
|
|
specific_init(argc, argv, tilewidth, tileheight, BX_HEADER_BAR_Y);
|
126 |
|
|
|
127 |
|
|
// Define some bitmaps to use in the headerbar
|
128 |
|
|
BX_GUI_THIS floppyA_bmap_id = create_bitmap(bx_floppya_bmap,
|
129 |
|
|
BX_FLOPPYA_BMAP_X, BX_FLOPPYA_BMAP_Y);
|
130 |
|
|
BX_GUI_THIS floppyA_eject_bmap_id = create_bitmap(bx_floppya_eject_bmap,
|
131 |
|
|
BX_FLOPPYA_BMAP_X, BX_FLOPPYA_BMAP_Y);
|
132 |
|
|
BX_GUI_THIS floppyB_bmap_id = create_bitmap(bx_floppyb_bmap,
|
133 |
|
|
BX_FLOPPYB_BMAP_X, BX_FLOPPYB_BMAP_Y);
|
134 |
|
|
BX_GUI_THIS floppyB_eject_bmap_id = create_bitmap(bx_floppyb_eject_bmap,
|
135 |
|
|
BX_FLOPPYB_BMAP_X, BX_FLOPPYB_BMAP_Y);
|
136 |
|
|
BX_GUI_THIS cdromD_bmap_id = create_bitmap(bx_cdromd_bmap,
|
137 |
|
|
BX_CDROMD_BMAP_X, BX_CDROMD_BMAP_Y);
|
138 |
|
|
BX_GUI_THIS cdromD_eject_bmap_id = create_bitmap(bx_cdromd_eject_bmap,
|
139 |
|
|
BX_CDROMD_BMAP_X, BX_CDROMD_BMAP_Y);
|
140 |
|
|
BX_GUI_THIS mouse_bmap_id = create_bitmap(bx_mouse_bmap,
|
141 |
|
|
BX_MOUSE_BMAP_X, BX_MOUSE_BMAP_Y);
|
142 |
|
|
BX_GUI_THIS nomouse_bmap_id = create_bitmap(bx_nomouse_bmap,
|
143 |
|
|
BX_MOUSE_BMAP_X, BX_MOUSE_BMAP_Y);
|
144 |
|
|
|
145 |
|
|
BX_GUI_THIS power_bmap_id = create_bitmap(bx_power_bmap, BX_POWER_BMAP_X, BX_POWER_BMAP_Y);
|
146 |
|
|
BX_GUI_THIS reset_bmap_id = create_bitmap(bx_reset_bmap, BX_RESET_BMAP_X, BX_RESET_BMAP_Y);
|
147 |
|
|
BX_GUI_THIS snapshot_bmap_id = create_bitmap(bx_snapshot_bmap, BX_SNAPSHOT_BMAP_X, BX_SNAPSHOT_BMAP_Y);
|
148 |
|
|
BX_GUI_THIS copy_bmap_id = create_bitmap(bx_copy_bmap, BX_COPY_BMAP_X, BX_COPY_BMAP_Y);
|
149 |
|
|
BX_GUI_THIS paste_bmap_id = create_bitmap(bx_paste_bmap, BX_PASTE_BMAP_X, BX_PASTE_BMAP_Y);
|
150 |
|
|
BX_GUI_THIS config_bmap_id = create_bitmap(bx_config_bmap, BX_CONFIG_BMAP_X, BX_CONFIG_BMAP_Y);
|
151 |
|
|
BX_GUI_THIS user_bmap_id = create_bitmap(bx_user_bmap, BX_USER_BMAP_X, BX_USER_BMAP_Y);
|
152 |
|
|
BX_GUI_THIS save_restore_bmap_id = create_bitmap(bx_save_restore_bmap,
|
153 |
|
|
BX_SAVE_RESTORE_BMAP_X, BX_SAVE_RESTORE_BMAP_Y);
|
154 |
|
|
|
155 |
|
|
// Add the initial bitmaps to the headerbar, and enable callback routine, for use
|
156 |
|
|
// when that bitmap is clicked on
|
157 |
|
|
|
158 |
|
|
// Floppy A:
|
159 |
|
|
// BX_GUI_THIS floppyA_status = DEV_floppy_get_media_status(0);
|
160 |
|
|
BX_GUI_THIS floppyA_status = true;
|
161 |
|
|
if (BX_GUI_THIS floppyA_status)
|
162 |
|
|
BX_GUI_THIS floppyA_hbar_id = headerbar_bitmap(BX_GUI_THIS floppyA_bmap_id,
|
163 |
|
|
BX_GRAVITY_LEFT, floppyA_handler);
|
164 |
|
|
else
|
165 |
|
|
BX_GUI_THIS floppyA_hbar_id = headerbar_bitmap(BX_GUI_THIS floppyA_eject_bmap_id,
|
166 |
|
|
BX_GRAVITY_LEFT, floppyA_handler);
|
167 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS floppyA_hbar_id, "Change floppy A: media");
|
168 |
|
|
|
169 |
|
|
// Floppy B:
|
170 |
|
|
// BX_GUI_THIS floppyB_status = DEV_floppy_get_media_status(1);
|
171 |
|
|
BX_GUI_THIS floppyB_status = false;
|
172 |
|
|
if (BX_GUI_THIS floppyB_status)
|
173 |
|
|
BX_GUI_THIS floppyB_hbar_id = headerbar_bitmap(BX_GUI_THIS floppyB_bmap_id,
|
174 |
|
|
BX_GRAVITY_LEFT, floppyB_handler);
|
175 |
|
|
else
|
176 |
|
|
BX_GUI_THIS floppyB_hbar_id = headerbar_bitmap(BX_GUI_THIS floppyB_eject_bmap_id,
|
177 |
|
|
BX_GRAVITY_LEFT, floppyB_handler);
|
178 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS floppyB_hbar_id, "Change floppy B: media");
|
179 |
|
|
|
180 |
|
|
// CDROM,
|
181 |
|
|
// the harddrive object is not initialised yet,
|
182 |
|
|
// so we just set the bitmap to ejected for now
|
183 |
|
|
BX_GUI_THIS cdromD_hbar_id = headerbar_bitmap(BX_GUI_THIS cdromD_eject_bmap_id,
|
184 |
|
|
BX_GRAVITY_LEFT, cdromD_handler);
|
185 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS cdromD_hbar_id, "Change first CDROM media");
|
186 |
|
|
|
187 |
|
|
// Mouse button
|
188 |
|
|
if (SIM->get_param_bool(BXPN_MOUSE_ENABLED)->get())
|
189 |
|
|
BX_GUI_THIS mouse_hbar_id = headerbar_bitmap(BX_GUI_THIS mouse_bmap_id,
|
190 |
|
|
BX_GRAVITY_LEFT, toggle_mouse_enable);
|
191 |
|
|
else
|
192 |
|
|
BX_GUI_THIS mouse_hbar_id = headerbar_bitmap(BX_GUI_THIS nomouse_bmap_id,
|
193 |
|
|
BX_GRAVITY_LEFT, toggle_mouse_enable);
|
194 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS mouse_hbar_id, "Enable mouse capture");
|
195 |
|
|
|
196 |
|
|
// These are the buttons on the right side. They are created in order
|
197 |
|
|
// of right to left.
|
198 |
|
|
|
199 |
|
|
// Power button
|
200 |
|
|
BX_GUI_THIS power_hbar_id = headerbar_bitmap(BX_GUI_THIS power_bmap_id,
|
201 |
|
|
BX_GRAVITY_RIGHT, power_handler);
|
202 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS power_hbar_id, "Turn power off");
|
203 |
|
|
// Save/Restore Button
|
204 |
|
|
BX_GUI_THIS save_restore_hbar_id = headerbar_bitmap(BX_GUI_THIS save_restore_bmap_id,
|
205 |
|
|
BX_GRAVITY_RIGHT, save_restore_handler);
|
206 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS save_restore_hbar_id, "Save simulation state");
|
207 |
|
|
// Reset button
|
208 |
|
|
BX_GUI_THIS reset_hbar_id = headerbar_bitmap(BX_GUI_THIS reset_bmap_id,
|
209 |
|
|
BX_GRAVITY_RIGHT, reset_handler);
|
210 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS reset_hbar_id, "Reset the system");
|
211 |
|
|
// Configure button
|
212 |
|
|
BX_GUI_THIS config_hbar_id = headerbar_bitmap(BX_GUI_THIS config_bmap_id,
|
213 |
|
|
BX_GRAVITY_RIGHT, config_handler);
|
214 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS config_hbar_id, "Runtime config dialog");
|
215 |
|
|
// Snapshot button
|
216 |
|
|
BX_GUI_THIS snapshot_hbar_id = headerbar_bitmap(BX_GUI_THIS snapshot_bmap_id,
|
217 |
|
|
BX_GRAVITY_RIGHT, snapshot_handler);
|
218 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS snapshot_hbar_id, "Save snapshot of the text mode screen");
|
219 |
|
|
// Paste button
|
220 |
|
|
BX_GUI_THIS paste_hbar_id = headerbar_bitmap(BX_GUI_THIS paste_bmap_id,
|
221 |
|
|
BX_GRAVITY_RIGHT, paste_handler);
|
222 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS paste_hbar_id, "Paste clipboard text as emulated keystrokes");
|
223 |
|
|
// Copy button
|
224 |
|
|
BX_GUI_THIS copy_hbar_id = headerbar_bitmap(BX_GUI_THIS copy_bmap_id,
|
225 |
|
|
BX_GRAVITY_RIGHT, copy_handler);
|
226 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS copy_hbar_id, "Copy text mode screen to the clipboard");
|
227 |
|
|
// User button
|
228 |
|
|
BX_GUI_THIS user_hbar_id = headerbar_bitmap(BX_GUI_THIS user_bmap_id,
|
229 |
|
|
BX_GRAVITY_RIGHT, userbutton_handler);
|
230 |
|
|
BX_GUI_THIS set_tooltip(BX_GUI_THIS user_hbar_id, "Send keyboard shortcut");
|
231 |
|
|
|
232 |
|
|
if (SIM->get_param_bool(BXPN_TEXT_SNAPSHOT_CHECK)->get()) {
|
233 |
|
|
bx_pc_system.register_timer(this, bx_gui_c::snapshot_checker, (unsigned) 1000000, 1, 1, "snap_chk");
|
234 |
|
|
}
|
235 |
|
|
|
236 |
|
|
BX_GUI_THIS charmap_updated = 0;
|
237 |
|
|
|
238 |
|
|
if (!BX_GUI_THIS new_gfx_api && (BX_GUI_THIS framebuffer == NULL)) {
|
239 |
|
|
BX_GUI_THIS framebuffer = new Bit8u[BX_MAX_XRES * BX_MAX_YRES * 4];
|
240 |
|
|
}
|
241 |
|
|
show_headerbar();
|
242 |
|
|
}
|
243 |
|
|
|
244 |
|
|
void bx_gui_c::cleanup(void)
|
245 |
|
|
{
|
246 |
|
|
statusitem_count = 0;
|
247 |
|
|
}
|
248 |
|
|
|
249 |
|
|
void bx_gui_c::update_drive_status_buttons(void)
|
250 |
|
|
{
|
251 |
|
|
BX_GUI_THIS floppyA_status = /* DEV_floppy_get_media_status(0)
|
252 |
|
|
&& */ (SIM->get_param_enum(BXPN_FLOPPYA_STATUS)->get() == BX_INSERTED);
|
253 |
|
|
BX_GUI_THIS floppyB_status = false /*DEV_floppy_get_media_status(1)
|
254 |
|
|
&& (SIM->get_param_enum(BXPN_FLOPPYB_STATUS)->get() == BX_INSERTED) */;
|
255 |
|
|
//Bit32u handle = DEV_hd_get_first_cd_handle();
|
256 |
|
|
//BX_GUI_THIS cdromD_status = DEV_hd_get_cd_media_status(handle);
|
257 |
|
|
BX_GUI_THIS cdromD_status = false;
|
258 |
|
|
if (BX_GUI_THIS floppyA_status)
|
259 |
|
|
replace_bitmap(BX_GUI_THIS floppyA_hbar_id, BX_GUI_THIS floppyA_bmap_id);
|
260 |
|
|
else {
|
261 |
|
|
#if BX_WITH_MACOS
|
262 |
|
|
// If we are using the Mac floppy driver, eject the disk
|
263 |
|
|
// from the floppy drive. This doesn't work in MacOS X.
|
264 |
|
|
if (!strcmp(SIM->get_param_string(BXPN_FLOPPYA_PATH)->getptr(), SuperDrive))
|
265 |
|
|
DiskEject(1);
|
266 |
|
|
#endif
|
267 |
|
|
replace_bitmap(BX_GUI_THIS floppyA_hbar_id, BX_GUI_THIS floppyA_eject_bmap_id);
|
268 |
|
|
}
|
269 |
|
|
if (BX_GUI_THIS floppyB_status)
|
270 |
|
|
replace_bitmap(BX_GUI_THIS floppyB_hbar_id, BX_GUI_THIS floppyB_bmap_id);
|
271 |
|
|
else {
|
272 |
|
|
#if BX_WITH_MACOS
|
273 |
|
|
// If we are using the Mac floppy driver, eject the disk
|
274 |
|
|
// from the floppy drive. This doesn't work in MacOS X.
|
275 |
|
|
if (!strcmp(SIM->get_param_string(BXPN_FLOPPYB_PATH)->getptr(), SuperDrive))
|
276 |
|
|
DiskEject(1);
|
277 |
|
|
#endif
|
278 |
|
|
replace_bitmap(BX_GUI_THIS floppyB_hbar_id, BX_GUI_THIS floppyB_eject_bmap_id);
|
279 |
|
|
}
|
280 |
|
|
if (BX_GUI_THIS cdromD_status)
|
281 |
|
|
replace_bitmap(BX_GUI_THIS cdromD_hbar_id, BX_GUI_THIS cdromD_bmap_id);
|
282 |
|
|
else {
|
283 |
|
|
replace_bitmap(BX_GUI_THIS cdromD_hbar_id, BX_GUI_THIS cdromD_eject_bmap_id);
|
284 |
|
|
}
|
285 |
|
|
}
|
286 |
|
|
|
287 |
|
|
void bx_gui_c::floppyA_handler(void)
|
288 |
|
|
{
|
289 |
|
|
if (SIM->get_param_enum(BXPN_FLOPPYA_DEVTYPE)->get() == BX_FLOPPY_NONE)
|
290 |
|
|
return; // no primary floppy device present
|
291 |
|
|
if (BX_GUI_THIS dialog_caps & BX_GUI_DLG_FLOPPY) {
|
292 |
|
|
// instead of just toggling the status, call win32dialog to bring up
|
293 |
|
|
// a dialog asking what disk image you want to switch to.
|
294 |
|
|
int ret = SIM->ask_param(BXPN_FLOPPYA_PATH);
|
295 |
|
|
if (ret > 0) {
|
296 |
|
|
BX_GUI_THIS update_drive_status_buttons();
|
297 |
|
|
}
|
298 |
|
|
return;
|
299 |
|
|
}
|
300 |
|
|
BX_GUI_THIS floppyA_status = !BX_GUI_THIS floppyA_status;
|
301 |
|
|
DEV_floppy_set_media_status(0, BX_GUI_THIS floppyA_status);
|
302 |
|
|
BX_GUI_THIS update_drive_status_buttons();
|
303 |
|
|
}
|
304 |
|
|
|
305 |
|
|
void bx_gui_c::floppyB_handler(void)
|
306 |
|
|
{
|
307 |
|
|
if (SIM->get_param_enum(BXPN_FLOPPYB_DEVTYPE)->get() == BX_FLOPPY_NONE)
|
308 |
|
|
return; // no secondary floppy device present
|
309 |
|
|
if (BX_GUI_THIS dialog_caps & BX_GUI_DLG_FLOPPY) {
|
310 |
|
|
// instead of just toggling the status, call win32dialog to bring up
|
311 |
|
|
// a dialog asking what disk image you want to switch to.
|
312 |
|
|
int ret = SIM->ask_param(BXPN_FLOPPYB_PATH);
|
313 |
|
|
if (ret > 0) {
|
314 |
|
|
BX_GUI_THIS update_drive_status_buttons();
|
315 |
|
|
}
|
316 |
|
|
return;
|
317 |
|
|
}
|
318 |
|
|
BX_GUI_THIS floppyB_status = !BX_GUI_THIS floppyB_status;
|
319 |
|
|
DEV_floppy_set_media_status(1, BX_GUI_THIS floppyB_status);
|
320 |
|
|
BX_GUI_THIS update_drive_status_buttons();
|
321 |
|
|
}
|
322 |
|
|
|
323 |
|
|
void bx_gui_c::cdromD_handler(void)
|
324 |
|
|
{
|
325 |
|
|
Bit32u handle = DEV_hd_get_first_cd_handle();
|
326 |
|
|
if (BX_GUI_THIS dialog_caps & BX_GUI_DLG_CDROM) {
|
327 |
|
|
// instead of just toggling the status, call win32dialog to bring up
|
328 |
|
|
// a dialog asking what disk image you want to switch to.
|
329 |
|
|
// This code handles the first cdrom only. The cdrom drives #2, #3 and
|
330 |
|
|
// #4 are handled in the win32 runtime dialog.
|
331 |
|
|
bx_param_c *cdrom = SIM->get_first_cdrom();
|
332 |
|
|
if (cdrom == NULL)
|
333 |
|
|
return; // no cdrom found
|
334 |
|
|
int ret = SIM->ask_param(cdrom);
|
335 |
|
|
if (ret > 0) {
|
336 |
|
|
BX_GUI_THIS update_drive_status_buttons();
|
337 |
|
|
}
|
338 |
|
|
return;
|
339 |
|
|
}
|
340 |
|
|
BX_GUI_THIS cdromD_status =
|
341 |
|
|
DEV_hd_set_cd_media_status(handle, !BX_GUI_THIS cdromD_status);
|
342 |
|
|
BX_GUI_THIS update_drive_status_buttons();
|
343 |
|
|
}
|
344 |
|
|
|
345 |
|
|
void bx_gui_c::reset_handler(void)
|
346 |
|
|
{
|
347 |
|
|
BX_INFO(("system RESET callback"));
|
348 |
|
|
bx_pc_system.Reset(BX_RESET_HARDWARE);
|
349 |
|
|
}
|
350 |
|
|
|
351 |
|
|
void bx_gui_c::power_handler(void)
|
352 |
|
|
{
|
353 |
|
|
// test case for yes/no dialog: confirm power off
|
354 |
|
|
//if (!SIM->ask_yes_no("Quit Bochs", "Are you sure ?", 0))
|
355 |
|
|
// return;
|
356 |
|
|
// the user pressed power button, so there's no doubt they want bochs
|
357 |
|
|
// to quit. Change panics to fatal for the GUI and then do a panic.
|
358 |
|
|
bx_user_quit = 1;
|
359 |
|
|
LOG_THIS setonoff(LOGLEV_PANIC, ACT_FATAL);
|
360 |
|
|
BX_PANIC (("POWER button turned off."));
|
361 |
|
|
// shouldn't reach this point, but if you do, QUIT!!!
|
362 |
|
|
fprintf (stderr, "Bochs is exiting because you pressed the power button.\n");
|
363 |
|
|
BX_EXIT (1);
|
364 |
|
|
}
|
365 |
|
|
|
366 |
|
|
Bit32s bx_gui_c::make_text_snapshot(char **snapshot, Bit32u *length)
|
367 |
|
|
{
|
368 |
|
|
Bit8u* raw_snap = NULL;
|
369 |
|
|
char *clean_snap;
|
370 |
|
|
unsigned line_addr, txt_addr, txHeight, txWidth;
|
371 |
|
|
|
372 |
|
|
DEV_vga_get_text_snapshot(&raw_snap, &txHeight, &txWidth);
|
373 |
|
|
if (txHeight <= 0) return -1;
|
374 |
|
|
clean_snap = (char*) malloc(txHeight*(txWidth+2)+1);
|
375 |
|
|
txt_addr = 0;
|
376 |
|
|
for (unsigned i=0; i<txHeight; i++) {
|
377 |
|
|
line_addr = i * txWidth * 2;
|
378 |
|
|
for (unsigned j=0; j<(txWidth*2); j+=2) {
|
379 |
|
|
clean_snap[txt_addr++] = raw_snap[line_addr+j];
|
380 |
|
|
}
|
381 |
|
|
while ((txt_addr > 0) && (clean_snap[txt_addr-1] == ' ')) txt_addr--;
|
382 |
|
|
#ifdef WIN32
|
383 |
|
|
if(!(SIM->get_param_bool(BXPN_TEXT_SNAPSHOT_CHECK)->get())) {
|
384 |
|
|
clean_snap[txt_addr++] = 13;
|
385 |
|
|
}
|
386 |
|
|
#endif
|
387 |
|
|
clean_snap[txt_addr++] = 10;
|
388 |
|
|
}
|
389 |
|
|
clean_snap[txt_addr] = 0;
|
390 |
|
|
*snapshot = clean_snap;
|
391 |
|
|
*length = txt_addr;
|
392 |
|
|
return 0;
|
393 |
|
|
}
|
394 |
|
|
|
395 |
|
|
// create a text snapshot and copy to the system clipboard. On guis that
|
396 |
|
|
// we haven't figured out how to support yet, dump to a file instead.
|
397 |
|
|
void bx_gui_c::copy_handler(void)
|
398 |
|
|
{
|
399 |
|
|
Bit32u len;
|
400 |
|
|
char *text_snapshot;
|
401 |
|
|
if (make_text_snapshot (&text_snapshot, &len) < 0) {
|
402 |
|
|
BX_INFO(("copy button failed, mode not implemented"));
|
403 |
|
|
return;
|
404 |
|
|
}
|
405 |
|
|
if (!BX_GUI_THIS set_clipboard_text(text_snapshot, len)) {
|
406 |
|
|
// platform specific code failed, use portable code instead
|
407 |
|
|
FILE *fp = fopen("copy.txt", "w");
|
408 |
|
|
fwrite(text_snapshot, 1, len, fp);
|
409 |
|
|
fclose(fp);
|
410 |
|
|
}
|
411 |
|
|
free(text_snapshot);
|
412 |
|
|
}
|
413 |
|
|
|
414 |
|
|
// Check the current text snapshot against file snapchk.txt.
|
415 |
|
|
void bx_gui_c::snapshot_checker(void *this_ptr)
|
416 |
|
|
{
|
417 |
|
|
char filename[BX_PATHNAME_LEN];
|
418 |
|
|
strcpy(filename,"snapchk.txt");
|
419 |
|
|
FILE *fp = fopen(filename, "rb");
|
420 |
|
|
if(fp) {
|
421 |
|
|
char *text_snapshot;
|
422 |
|
|
Bit32u len;
|
423 |
|
|
if (make_text_snapshot (&text_snapshot, &len) < 0) {
|
424 |
|
|
return;
|
425 |
|
|
}
|
426 |
|
|
char *compare_snapshot = (char *) malloc((len+1) * sizeof(char));
|
427 |
|
|
fread(compare_snapshot, 1, len, fp);
|
428 |
|
|
fclose(fp);
|
429 |
|
|
strcpy(filename,"snapmask.txt");
|
430 |
|
|
fp=fopen(filename, "rb");
|
431 |
|
|
if(fp) {
|
432 |
|
|
char *mask_snapshot = (char *) malloc((len+1) * sizeof(char));
|
433 |
|
|
unsigned i;
|
434 |
|
|
bx_bool flag = 1;
|
435 |
|
|
fread(mask_snapshot, 1, len, fp);
|
436 |
|
|
fclose(fp);
|
437 |
|
|
for(i=0;i<len;i++) {
|
438 |
|
|
if((text_snapshot[i] != compare_snapshot[i]) &&
|
439 |
|
|
(compare_snapshot[i] == mask_snapshot[i])) {
|
440 |
|
|
flag = 0;
|
441 |
|
|
break;
|
442 |
|
|
}
|
443 |
|
|
}
|
444 |
|
|
if(flag) {
|
445 |
|
|
if(!memcmp(text_snapshot,compare_snapshot,len)) {
|
446 |
|
|
BX_PASS(("Test Passed."));
|
447 |
|
|
} else {
|
448 |
|
|
BX_PASS(("Test Passed with Mask."));
|
449 |
|
|
}
|
450 |
|
|
}
|
451 |
|
|
} else {
|
452 |
|
|
if(!memcmp(text_snapshot,compare_snapshot,len)) {
|
453 |
|
|
BX_PASS(("Test Passed."));
|
454 |
|
|
}
|
455 |
|
|
}
|
456 |
|
|
free(compare_snapshot);
|
457 |
|
|
free(text_snapshot);
|
458 |
|
|
}
|
459 |
|
|
}
|
460 |
|
|
|
461 |
|
|
// create a text snapshot and dump it to a file
|
462 |
|
|
void bx_gui_c::snapshot_handler(void)
|
463 |
|
|
{
|
464 |
|
|
char *text_snapshot;
|
465 |
|
|
Bit32u len;
|
466 |
|
|
if (make_text_snapshot (&text_snapshot, &len) < 0) {
|
467 |
|
|
BX_ERROR(("snapshot button failed, mode not implemented"));
|
468 |
|
|
return;
|
469 |
|
|
}
|
470 |
|
|
//FIXME
|
471 |
|
|
char filename[BX_PATHNAME_LEN];
|
472 |
|
|
if (BX_GUI_THIS dialog_caps & BX_GUI_DLG_SNAPSHOT) {
|
473 |
|
|
int ret = SIM->ask_filename (filename, sizeof(filename),
|
474 |
|
|
"Save snapshot as...", "snapshot.txt",
|
475 |
|
|
bx_param_string_c::SAVE_FILE_DIALOG);
|
476 |
|
|
if (ret < 0) { // cancelled
|
477 |
|
|
free(text_snapshot);
|
478 |
|
|
return;
|
479 |
|
|
}
|
480 |
|
|
} else {
|
481 |
|
|
strcpy (filename, "snapshot.txt");
|
482 |
|
|
}
|
483 |
|
|
FILE *fp = fopen(filename, "wb");
|
484 |
|
|
fwrite(text_snapshot, 1, len, fp);
|
485 |
|
|
fclose(fp);
|
486 |
|
|
free(text_snapshot);
|
487 |
|
|
}
|
488 |
|
|
|
489 |
|
|
// Read ASCII chars from the system clipboard and paste them into bochs.
|
490 |
|
|
// Note that paste cannot work with the key mapping tables loaded.
|
491 |
|
|
void bx_gui_c::paste_handler(void)
|
492 |
|
|
{
|
493 |
|
|
Bit32s nbytes;
|
494 |
|
|
Bit8u *bytes;
|
495 |
|
|
if (!bx_keymap.isKeymapLoaded ()) {
|
496 |
|
|
BX_ERROR (("keyboard_mapping disabled, so paste cannot work"));
|
497 |
|
|
return;
|
498 |
|
|
}
|
499 |
|
|
if (!BX_GUI_THIS get_clipboard_text(&bytes, &nbytes)) {
|
500 |
|
|
BX_ERROR (("paste not implemented on this platform"));
|
501 |
|
|
return;
|
502 |
|
|
}
|
503 |
|
|
BX_INFO (("pasting %d bytes", nbytes));
|
504 |
|
|
DEV_kbd_paste_bytes (bytes, nbytes);
|
505 |
|
|
}
|
506 |
|
|
|
507 |
|
|
void bx_gui_c::config_handler(void)
|
508 |
|
|
{
|
509 |
|
|
if (BX_GUI_THIS dialog_caps & BX_GUI_DLG_RUNTIME) {
|
510 |
|
|
SIM->configuration_interface(NULL, CI_RUNTIME_CONFIG);
|
511 |
|
|
}
|
512 |
|
|
}
|
513 |
|
|
|
514 |
|
|
void bx_gui_c::toggle_mouse_enable(void)
|
515 |
|
|
{
|
516 |
|
|
int old = SIM->get_param_bool(BXPN_MOUSE_ENABLED)->get();
|
517 |
|
|
BX_DEBUG (("toggle mouse_enabled, now %d", !old));
|
518 |
|
|
SIM->get_param_bool(BXPN_MOUSE_ENABLED)->set(!old);
|
519 |
|
|
}
|
520 |
|
|
|
521 |
|
|
Bit32u get_user_key(char *key)
|
522 |
|
|
{
|
523 |
|
|
int i = 0;
|
524 |
|
|
|
525 |
|
|
while (i < N_USER_KEYS) {
|
526 |
|
|
if (!strcmp(key, user_keys[i].key))
|
527 |
|
|
return user_keys[i].symbol;
|
528 |
|
|
i++;
|
529 |
|
|
}
|
530 |
|
|
return BX_KEY_UNKNOWN;
|
531 |
|
|
}
|
532 |
|
|
|
533 |
|
|
void bx_gui_c::userbutton_handler(void)
|
534 |
|
|
{
|
535 |
|
|
Bit32u shortcut[4];
|
536 |
|
|
Bit32u symbol;
|
537 |
|
|
char user_shortcut[512];
|
538 |
|
|
char *ptr;
|
539 |
|
|
int i, len = 0, ret = 1;
|
540 |
|
|
|
541 |
|
|
if (BX_GUI_THIS dialog_caps & BX_GUI_DLG_USER) {
|
542 |
|
|
ret = SIM->ask_param(BXPN_USER_SHORTCUT);
|
543 |
|
|
}
|
544 |
|
|
strcpy(user_shortcut, SIM->get_param_string(BXPN_USER_SHORTCUT)->getptr());
|
545 |
|
|
if ((ret > 0) && user_shortcut[0] && (strcmp(user_shortcut, "none"))) {
|
546 |
|
|
ptr = strtok(user_shortcut, "-");
|
547 |
|
|
if ((strcmp(ptr, SIM->get_param_string(BXPN_USER_SHORTCUT)->getptr())) ||
|
548 |
|
|
(strlen(SIM->get_param_string(BXPN_USER_SHORTCUT)->getptr()) < 6)) {
|
549 |
|
|
while (ptr) {
|
550 |
|
|
symbol = get_user_key(ptr);
|
551 |
|
|
if (symbol == BX_KEY_UNKNOWN) {
|
552 |
|
|
BX_ERROR(("Unknown shortcut %s ignored", ptr));
|
553 |
|
|
return;
|
554 |
|
|
}
|
555 |
|
|
shortcut[len++] = symbol;
|
556 |
|
|
ptr = strtok(NULL, "-");
|
557 |
|
|
}
|
558 |
|
|
} else {
|
559 |
|
|
BX_ERROR(("Unknown shortcut %s ignored", user_shortcut));
|
560 |
|
|
return;
|
561 |
|
|
}
|
562 |
|
|
i = 0;
|
563 |
|
|
while (i < len) {
|
564 |
|
|
DEV_kbd_gen_scancode(shortcut[i++]);
|
565 |
|
|
}
|
566 |
|
|
i--;
|
567 |
|
|
while (i >= 0) {
|
568 |
|
|
DEV_kbd_gen_scancode(shortcut[i--] | BX_KEY_RELEASED);
|
569 |
|
|
}
|
570 |
|
|
}
|
571 |
|
|
}
|
572 |
|
|
|
573 |
|
|
void bx_gui_c::save_restore_handler(void)
|
574 |
|
|
{
|
575 |
|
|
int ret;
|
576 |
|
|
char sr_path[BX_PATHNAME_LEN];
|
577 |
|
|
|
578 |
|
|
if (BX_GUI_THIS dialog_caps & BX_GUI_DLG_SAVE_RESTORE) {
|
579 |
|
|
sr_path[0] = 0;
|
580 |
|
|
ret = SIM->ask_filename(sr_path, sizeof(sr_path),
|
581 |
|
|
"Save Bochs state to folder...", "none",
|
582 |
|
|
bx_param_string_c::SELECT_FOLDER_DLG);
|
583 |
|
|
if ((ret >= 0) && (strcmp(sr_path, "none"))) {
|
584 |
|
|
if (SIM->save_state(sr_path)) {
|
585 |
|
|
if (!SIM->ask_yes_no("WARNING",
|
586 |
|
|
"The save function currently doesn't handle the state of hard drive images,\n"
|
587 |
|
|
"so we don't recommend to continue, unless you are running a read-only\n"
|
588 |
|
|
"guest system (e.g. Live-CD).\n\n"
|
589 |
|
|
"Do you want to continue?", 0)) {
|
590 |
|
|
power_handler();
|
591 |
|
|
}
|
592 |
|
|
}
|
593 |
|
|
}
|
594 |
|
|
}
|
595 |
|
|
}
|
596 |
|
|
|
597 |
|
|
void bx_gui_c::mouse_enabled_changed(bx_bool val)
|
598 |
|
|
{
|
599 |
|
|
// This is only called when SIM->get_init_done is 1. Note that VAL
|
600 |
|
|
// is the new value of mouse_enabled, which may not match the old
|
601 |
|
|
// value which is still in SIM->get_param_bool(BXPN_MOUSE_ENABLED)->get().
|
602 |
|
|
BX_DEBUG (("replacing the mouse bitmaps"));
|
603 |
|
|
if (val)
|
604 |
|
|
BX_GUI_THIS replace_bitmap(BX_GUI_THIS mouse_hbar_id, BX_GUI_THIS mouse_bmap_id);
|
605 |
|
|
else
|
606 |
|
|
BX_GUI_THIS replace_bitmap(BX_GUI_THIS mouse_hbar_id, BX_GUI_THIS nomouse_bmap_id);
|
607 |
|
|
// give the GUI a chance to respond to the event. Most guis will hide
|
608 |
|
|
// the native mouse cursor and do something to trap the mouse inside the
|
609 |
|
|
// bochs VGA display window.
|
610 |
|
|
BX_GUI_THIS mouse_enabled_changed_specific (val);
|
611 |
|
|
}
|
612 |
|
|
|
613 |
|
|
void bx_gui_c::init_signal_handlers()
|
614 |
|
|
{
|
615 |
|
|
#if BX_GUI_SIGHANDLER
|
616 |
|
|
if (bx_gui_sighandler)
|
617 |
|
|
{
|
618 |
|
|
Bit32u mask = bx_gui->get_sighandler_mask ();
|
619 |
|
|
for (Bit32u sig=0; sig<32; sig++)
|
620 |
|
|
{
|
621 |
|
|
if (mask & (1<<sig))
|
622 |
|
|
signal (sig, bx_signal_handler);
|
623 |
|
|
}
|
624 |
|
|
}
|
625 |
|
|
#endif
|
626 |
|
|
}
|
627 |
|
|
|
628 |
|
|
void bx_gui_c::set_text_charmap(Bit8u *fbuffer)
|
629 |
|
|
{
|
630 |
|
|
memcpy(& BX_GUI_THIS vga_charmap, fbuffer, 0x2000);
|
631 |
|
|
for (unsigned i=0; i<256; i++) BX_GUI_THIS char_changed[i] = 1;
|
632 |
|
|
BX_GUI_THIS charmap_updated = 1;
|
633 |
|
|
}
|
634 |
|
|
|
635 |
|
|
void bx_gui_c::set_text_charbyte(Bit16u address, Bit8u data)
|
636 |
|
|
{
|
637 |
|
|
BX_GUI_THIS vga_charmap[address] = data;
|
638 |
|
|
BX_GUI_THIS char_changed[address >> 5] = 1;
|
639 |
|
|
BX_GUI_THIS charmap_updated = 1;
|
640 |
|
|
}
|
641 |
|
|
|
642 |
|
|
void bx_gui_c::beep_on(float frequency)
|
643 |
|
|
{
|
644 |
|
|
BX_INFO(("GUI Beep ON (frequency=%.2f)", frequency));
|
645 |
|
|
}
|
646 |
|
|
|
647 |
|
|
void bx_gui_c::beep_off()
|
648 |
|
|
{
|
649 |
|
|
BX_INFO(("GUI Beep OFF"));
|
650 |
|
|
}
|
651 |
|
|
|
652 |
|
|
int bx_gui_c::register_statusitem(const char *text)
|
653 |
|
|
{
|
654 |
|
|
if (statusitem_count < BX_MAX_STATUSITEMS) {
|
655 |
|
|
strncpy(statusitem_text[statusitem_count], text, 8);
|
656 |
|
|
statusitem_text[statusitem_count][7] = 0;
|
657 |
|
|
return statusitem_count++;
|
658 |
|
|
} else {
|
659 |
|
|
return -1;
|
660 |
|
|
}
|
661 |
|
|
}
|
662 |
|
|
|
663 |
|
|
void bx_gui_c::get_capabilities(Bit16u *xres, Bit16u *yres, Bit16u *bpp)
|
664 |
|
|
{
|
665 |
|
|
*xres = 1024;
|
666 |
|
|
*yres = 768;
|
667 |
|
|
*bpp = 32;
|
668 |
|
|
}
|
669 |
|
|
|
670 |
|
|
bx_svga_tileinfo_t *bx_gui_c::graphics_tile_info(bx_svga_tileinfo_t *info)
|
671 |
|
|
{
|
672 |
|
|
if (!info) {
|
673 |
|
|
info = (bx_svga_tileinfo_t *)malloc(sizeof(bx_svga_tileinfo_t));
|
674 |
|
|
if (!info) {
|
675 |
|
|
return NULL;
|
676 |
|
|
}
|
677 |
|
|
}
|
678 |
|
|
|
679 |
|
|
BX_GUI_THIS host_pitch = BX_GUI_THIS host_xres * ((BX_GUI_THIS host_bpp + 1) >> 3);
|
680 |
|
|
|
681 |
|
|
info->bpp = BX_GUI_THIS host_bpp;
|
682 |
|
|
info->pitch = BX_GUI_THIS host_pitch;
|
683 |
|
|
switch (info->bpp) {
|
684 |
|
|
case 15:
|
685 |
|
|
info->red_shift = 15;
|
686 |
|
|
info->green_shift = 10;
|
687 |
|
|
info->blue_shift = 5;
|
688 |
|
|
info->red_mask = 0x7c00;
|
689 |
|
|
info->green_mask = 0x03e0;
|
690 |
|
|
info->blue_mask = 0x001f;
|
691 |
|
|
break;
|
692 |
|
|
case 16:
|
693 |
|
|
info->red_shift = 16;
|
694 |
|
|
info->green_shift = 11;
|
695 |
|
|
info->blue_shift = 5;
|
696 |
|
|
info->red_mask = 0xf800;
|
697 |
|
|
info->green_mask = 0x07e0;
|
698 |
|
|
info->blue_mask = 0x001f;
|
699 |
|
|
break;
|
700 |
|
|
case 24:
|
701 |
|
|
case 32:
|
702 |
|
|
info->red_shift = 24;
|
703 |
|
|
info->green_shift = 16;
|
704 |
|
|
info->blue_shift = 8;
|
705 |
|
|
info->red_mask = 0xff0000;
|
706 |
|
|
info->green_mask = 0x00ff00;
|
707 |
|
|
info->blue_mask = 0x0000ff;
|
708 |
|
|
break;
|
709 |
|
|
}
|
710 |
|
|
info->is_indexed = (BX_GUI_THIS host_bpp == 8);
|
711 |
|
|
#ifdef BX_LITTLE_ENDIAN
|
712 |
|
|
info->is_little_endian = 1;
|
713 |
|
|
#else
|
714 |
|
|
info->is_little_endian = 0;
|
715 |
|
|
#endif
|
716 |
|
|
|
717 |
|
|
return info;
|
718 |
|
|
}
|
719 |
|
|
|
720 |
|
|
Bit8u *bx_gui_c::graphics_tile_get(unsigned x0, unsigned y0,
|
721 |
|
|
unsigned *w, unsigned *h)
|
722 |
|
|
{
|
723 |
|
|
if (x0+X_TILESIZE > BX_GUI_THIS host_xres) {
|
724 |
|
|
*w = BX_GUI_THIS host_xres - x0;
|
725 |
|
|
}
|
726 |
|
|
else {
|
727 |
|
|
*w = X_TILESIZE;
|
728 |
|
|
}
|
729 |
|
|
|
730 |
|
|
if (y0+Y_TILESIZE > BX_GUI_THIS host_yres) {
|
731 |
|
|
*h = BX_GUI_THIS host_yres - y0;
|
732 |
|
|
}
|
733 |
|
|
else {
|
734 |
|
|
*h = Y_TILESIZE;
|
735 |
|
|
}
|
736 |
|
|
|
737 |
|
|
return (Bit8u *)framebuffer + y0 * BX_GUI_THIS host_pitch +
|
738 |
|
|
x0 * ((BX_GUI_THIS host_bpp + 1) >> 3);
|
739 |
|
|
}
|
740 |
|
|
|
741 |
|
|
void bx_gui_c::graphics_tile_update_in_place(unsigned x0, unsigned y0,
|
742 |
|
|
unsigned w, unsigned h)
|
743 |
|
|
{
|
744 |
|
|
Bit8u tile[X_TILESIZE * Y_TILESIZE * 4];
|
745 |
|
|
Bit8u *tile_ptr, *fb_ptr;
|
746 |
|
|
Bit16u xc, yc, fb_pitch, tile_pitch;
|
747 |
|
|
Bit8u r, diffx, diffy;
|
748 |
|
|
|
749 |
|
|
diffx = (x0 % X_TILESIZE);
|
750 |
|
|
diffy = (y0 % Y_TILESIZE);
|
751 |
|
|
if (diffx > 0) {
|
752 |
|
|
x0 -= diffx;
|
753 |
|
|
w += diffx;
|
754 |
|
|
}
|
755 |
|
|
if (diffy > 0) {
|
756 |
|
|
y0 -= diffy;
|
757 |
|
|
h += diffy;
|
758 |
|
|
}
|
759 |
|
|
fb_pitch = BX_GUI_THIS host_pitch;
|
760 |
|
|
tile_pitch = X_TILESIZE * ((BX_GUI_THIS host_bpp + 1) >> 3);
|
761 |
|
|
for (yc=y0; yc<(y0+h); yc+=Y_TILESIZE) {
|
762 |
|
|
for (xc=x0; xc<(x0+w); xc+=X_TILESIZE) {
|
763 |
|
|
fb_ptr = BX_GUI_THIS framebuffer + (yc * fb_pitch + xc * ((BX_GUI_THIS host_bpp + 1) >> 3));
|
764 |
|
|
tile_ptr = &tile[0];
|
765 |
|
|
for (r=0; r<h; r++) {
|
766 |
|
|
memcpy(tile_ptr, fb_ptr, tile_pitch);
|
767 |
|
|
fb_ptr += fb_pitch;
|
768 |
|
|
tile_ptr += tile_pitch;
|
769 |
|
|
}
|
770 |
|
|
BX_GUI_THIS graphics_tile_update(tile, xc, yc);
|
771 |
|
|
}
|
772 |
|
|
}
|
773 |
|
|
}
|
774 |
|
|
|
775 |
|
|
void bx_gui_c::show_ips(Bit32u ips_count)
|
776 |
|
|
{
|
777 |
|
|
#if BX_SHOW_IPS
|
778 |
|
|
BX_INFO(("ips = %u", ips_count));
|
779 |
|
|
#endif
|
780 |
|
|
}
|
781 |
|
|
|
782 |
|
|
Bit8u bx_gui_c::get_mouse_headerbar_id()
|
783 |
|
|
{
|
784 |
|
|
return BX_GUI_THIS mouse_hbar_id;
|
785 |
|
|
}
|