- simple floppy image dialogbox for win32 added
- references to wx removed from the floppy button handlers (wx doesn't use them)
This commit is contained in:
parent
4e63eca16c
commit
0d60d343b3
@ -1,5 +1,5 @@
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
// $Id: gui.cc,v 1.69 2003-05-27 18:19:12 vruppert Exp $
|
||||
// $Id: gui.cc,v 1.70 2003-07-15 21:02:05 vruppert Exp $
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Copyright (C) 2002 MandrakeSoft S.A.
|
||||
@ -212,48 +212,42 @@ bx_gui_c::update_drive_status_buttons (void) {
|
||||
void
|
||||
bx_gui_c::floppyA_handler(void)
|
||||
{
|
||||
if (!strcmp(bx_options.Osel_config->get_choice(bx_options.Osel_config->get()),
|
||||
"wx")) {
|
||||
// instead of just toggling the status, call wxWindows to bring up
|
||||
#ifdef WIN32
|
||||
// instead of just toggling the status, call win32dialog to bring up
|
||||
// a dialog asking what disk image you want to switch to.
|
||||
int ret = SIM->ask_param (BXP_FLOPPYA_PATH);
|
||||
if (ret < 0) return; // cancelled
|
||||
if (ret > 0) {
|
||||
// eject and then insert the disk. If the new path is invalid,
|
||||
// the status will return 0.
|
||||
unsigned new_status = DEV_floppy_set_media_status(0, 0);
|
||||
printf ("eject disk, new_status is %d\n", new_status);
|
||||
new_status = DEV_floppy_set_media_status(0, 1);
|
||||
printf ("insert disk, new_status is %d\n", new_status);
|
||||
fflush (stdout);
|
||||
BX_GUI_THIS floppyA_status = new_status;
|
||||
} else {
|
||||
}
|
||||
#else
|
||||
BX_GUI_THIS floppyA_status = !BX_GUI_THIS floppyA_status;
|
||||
DEV_floppy_set_media_status(0, BX_GUI_THIS floppyA_status);
|
||||
}
|
||||
#endif
|
||||
BX_GUI_THIS update_drive_status_buttons ();
|
||||
}
|
||||
|
||||
void
|
||||
bx_gui_c::floppyB_handler(void)
|
||||
{
|
||||
if (!strcmp(bx_options.Osel_config->get_choice(bx_options.Osel_config->get()),
|
||||
"wx")) {
|
||||
// instead of just toggling the status, call wxWindows to bring up
|
||||
#ifdef WIN32
|
||||
// instead of just toggling the status, call win32dialog to bring up
|
||||
// a dialog asking what disk image you want to switch to.
|
||||
int ret = SIM->ask_param (BXP_FLOPPYB_PATH);
|
||||
if (ret < 0) return; // cancelled
|
||||
if (ret > 0) {
|
||||
// eject and then insert the disk. If the new path is invalid,
|
||||
// the status will return 0.
|
||||
unsigned new_status = DEV_floppy_set_media_status(1, 0);
|
||||
printf ("eject disk, new_status is %d\n", new_status);
|
||||
new_status = DEV_floppy_set_media_status(1, 1);
|
||||
printf ("insert disk, new_status is %d\n", new_status);
|
||||
fflush (stdout);
|
||||
BX_GUI_THIS floppyB_status = new_status;
|
||||
} else {
|
||||
}
|
||||
#else
|
||||
BX_GUI_THIS floppyB_status = !BX_GUI_THIS floppyB_status;
|
||||
DEV_floppy_set_media_status(1, BX_GUI_THIS floppyB_status);
|
||||
}
|
||||
#endif
|
||||
BX_GUI_THIS update_drive_status_buttons ();
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
// $Id: textconfig.cc,v 1.12 2003-06-07 19:16:53 vruppert Exp $
|
||||
// $Id: textconfig.cc,v 1.13 2003-07-15 21:02:05 vruppert Exp $
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// This is code for a text-mode configuration interfac. Note that this file
|
||||
@ -683,7 +683,11 @@ config_interface_notify_callback (void *unused, BxEvent *event)
|
||||
sparam = (bx_param_string_c *)param;
|
||||
opts = sparam->get_options()->get();
|
||||
if (opts & sparam->IS_FILENAME) {
|
||||
if (param->get_id() == BXP_NULL) {
|
||||
event->retcode = AskFilename((bx_param_filename_c *)sparam);
|
||||
} else {
|
||||
event->retcode = FloppyDialog((bx_param_filename_c *)sparam);
|
||||
}
|
||||
return event;
|
||||
} else {
|
||||
event->retcode = AskString(sparam);
|
||||
|
@ -1,5 +1,5 @@
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
// $Id: win32dialog.cc,v 1.3 2003-05-25 18:34:03 vruppert Exp $
|
||||
// $Id: win32dialog.cc,v 1.4 2003-07-15 21:02:05 vruppert Exp $
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifdef WIN32
|
||||
@ -12,6 +12,7 @@ extern "C" {
|
||||
}
|
||||
#include "win32res.h"
|
||||
#include "siminterface.h"
|
||||
#include "win32dialog.h"
|
||||
|
||||
HWND GetBochsWindow()
|
||||
{
|
||||
@ -91,6 +92,66 @@ static BOOL CALLBACK StringParamProc(HWND hDlg, UINT msg, WPARAM wParam, LPARAM
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static BOOL CALLBACK FloppyDlgProc(HWND hDlg, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||
{
|
||||
static bx_param_filename_c *param;
|
||||
static bx_param_enum_c *status;
|
||||
static char origpath[MAX_PATH];
|
||||
char path[MAX_PATH];
|
||||
|
||||
switch (msg) {
|
||||
case WM_INITDIALOG:
|
||||
param = (bx_param_filename_c *)lParam;
|
||||
if (param->get_id() == BXP_FLOPPYA_PATH) {
|
||||
status = SIM->get_param_enum(BXP_FLOPPYA_STATUS);
|
||||
} else {
|
||||
status = SIM->get_param_enum(BXP_FLOPPYB_STATUS);
|
||||
}
|
||||
if (status->get() == BX_INSERTED) {
|
||||
SendMessage(GetDlgItem(hDlg, IDSTATUS), BM_SETCHECK, BST_CHECKED, 0);
|
||||
}
|
||||
lstrcpy(origpath, param->getptr());
|
||||
SetWindowText(hDlg, param->get_ask_format());
|
||||
if (lstrlen(origpath) && lstrcmp(origpath, "none")) {
|
||||
SetWindowText(GetDlgItem(hDlg, IDPATH), origpath);
|
||||
}
|
||||
return FALSE;
|
||||
case WM_CLOSE:
|
||||
EndDialog(hDlg, -1);
|
||||
break;
|
||||
case WM_COMMAND:
|
||||
switch (LOWORD(wParam)) {
|
||||
case IDBROWSE:
|
||||
if (AskFilename(param) > 0) {
|
||||
SetWindowText(GetDlgItem(hDlg, IDPATH), param->getptr());
|
||||
SendMessage(GetDlgItem(hDlg, IDSTATUS), BM_SETCHECK, BST_CHECKED, 0);
|
||||
}
|
||||
break;
|
||||
case IDOK:
|
||||
if (SendMessage(GetDlgItem(hDlg, IDSTATUS), BM_GETCHECK, 0, 0) == BST_CHECKED) {
|
||||
GetWindowText(GetDlgItem(hDlg, IDPATH), path, MAX_PATH);
|
||||
if (lstrlen(path)) {
|
||||
status->set(BX_INSERTED);
|
||||
} else {
|
||||
status->set(BX_EJECTED);
|
||||
lstrcpy(path, "none");
|
||||
}
|
||||
} else {
|
||||
status->set(BX_EJECTED);
|
||||
lstrcpy(path, "none");
|
||||
}
|
||||
param->set(path);
|
||||
EndDialog(hDlg, 1);
|
||||
break;
|
||||
case IDCANCEL:
|
||||
param->set(origpath);
|
||||
EndDialog(hDlg, -1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
void LogAskDialog(BxEvent *event)
|
||||
{
|
||||
event->retcode = DialogBoxParam(NULL, MAKEINTRESOURCE(ASK_DLG), GetBochsWindow(),
|
||||
@ -99,17 +160,19 @@ void LogAskDialog(BxEvent *event)
|
||||
|
||||
int AskFilename(bx_param_filename_c *param)
|
||||
{
|
||||
const PCHAR Filter = "Text files (*.txt)\0*.txt\0All files (*.*)\0*.*\0";
|
||||
const PCHAR Ext = "txt";
|
||||
OPENFILENAME ofn;
|
||||
int ret;
|
||||
char filename[MAX_PATH];
|
||||
char *title;
|
||||
|
||||
param->get(filename, MAX_PATH);
|
||||
title = param->get_ask_format();
|
||||
if (!title) {
|
||||
title = param->get_description();
|
||||
}
|
||||
ofn.lStructSize = sizeof(OPENFILENAME);
|
||||
ofn.hwndOwner = GetBochsWindow();
|
||||
ofn.hInstance = NULL;
|
||||
ofn.lpstrFilter = Filter;
|
||||
ofn.lpstrCustomFilter = NULL;
|
||||
ofn.nMaxCustFilter = 0;
|
||||
ofn.nFilterIndex = 0;
|
||||
@ -118,18 +181,21 @@ int AskFilename(bx_param_filename_c *param)
|
||||
ofn.lpstrFileTitle = NULL;
|
||||
ofn.nMaxFileTitle = 0;
|
||||
ofn.lpstrInitialDir = NULL;
|
||||
ofn.lpstrTitle = param->get_description();
|
||||
ofn.lpstrTitle = title;
|
||||
ofn.nFileOffset = 0;
|
||||
ofn.nFileExtension = 0;
|
||||
ofn.lpstrDefExt = Ext;
|
||||
ofn.lCustData = 0;
|
||||
ofn.lpfnHook = NULL;
|
||||
ofn.lpTemplateName = NULL;
|
||||
ofn.Flags = OFN_EXPLORER | OFN_HIDEREADONLY;
|
||||
if (param->get_options()->get() & bx_param_filename_c::SAVE_FILE_DIALOG) {
|
||||
ofn.lpstrFilter = "Text files (*.txt)\0*.txt\0All files (*.*)\0*.*\0";
|
||||
ofn.lpstrDefExt = "prg";
|
||||
ofn.Flags |= OFN_OVERWRITEPROMPT;
|
||||
ret = GetSaveFileName(&ofn);
|
||||
} else {
|
||||
ofn.lpstrFilter = "Floppy image files (*.img)\0*.img\0All files (*.*)\0*.*\0";
|
||||
ofn.lpstrDefExt = "img";
|
||||
ofn.Flags |= OFN_FILEMUSTEXIST;
|
||||
ret = GetOpenFileName(&ofn);
|
||||
}
|
||||
@ -144,4 +210,10 @@ int AskString(bx_param_string_c *param)
|
||||
(DLGPROC)StringParamProc, (LPARAM)param);
|
||||
}
|
||||
|
||||
int FloppyDialog(bx_param_filename_c *param)
|
||||
{
|
||||
return DialogBoxParam(NULL, MAKEINTRESOURCE(FLOPPY_DLG), GetBochsWindow(),
|
||||
(DLGPROC)FloppyDlgProc, (LPARAM)param);
|
||||
}
|
||||
|
||||
#endif // WIN32
|
||||
|
@ -1,5 +1,5 @@
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
// $Id: win32dialog.h,v 1.3 2003-05-25 18:34:03 vruppert Exp $
|
||||
// $Id: win32dialog.h,v 1.4 2003-07-15 21:02:05 vruppert Exp $
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifdef WIN32
|
||||
@ -7,5 +7,6 @@
|
||||
void LogAskDialog(BxEvent *event);
|
||||
int AskFilename(bx_param_filename_c *param);
|
||||
int AskString(bx_param_string_c *param);
|
||||
int FloppyDialog(bx_param_filename_c *param);
|
||||
|
||||
#endif
|
||||
|
@ -8,3 +8,7 @@
|
||||
#define IDASKLIST 2050
|
||||
#define STRING_DLG 2100
|
||||
#define IDSTRING 2110
|
||||
#define FLOPPY_DLG 2200
|
||||
#define IDPATH 2210
|
||||
#define IDBROWSE 2220
|
||||
#define IDSTATUS 2230
|
||||
|
@ -1,5 +1,5 @@
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
// $Id: main.cc,v 1.229 2003-07-10 20:26:05 vruppert Exp $
|
||||
// $Id: main.cc,v 1.230 2003-07-15 21:02:05 vruppert Exp $
|
||||
/////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Copyright (C) 2002 MandrakeSoft S.A.
|
||||
@ -360,7 +360,7 @@ void bx_init_options ()
|
||||
"Floppy A image",
|
||||
"Pathname of first floppy image file or device. If you're booting from floppy, this should be a bootable floppy.",
|
||||
"", BX_PATHNAME_LEN);
|
||||
#if BX_WITH_WX
|
||||
#if BX_WITH_WX || defined(WIN32)
|
||||
bx_options.floppya.Opath->set_ask_format ("Filename of first floppy image");
|
||||
#else
|
||||
bx_options.floppya.Opath->set_ask_format ("Enter new filename, or 'none' for no disk: [%s] ");
|
||||
@ -407,7 +407,7 @@ void bx_init_options ()
|
||||
"floppyb:path",
|
||||
"Pathname of second floppy image file or device.",
|
||||
"", BX_PATHNAME_LEN);
|
||||
#if BX_WITH_WX
|
||||
#if BX_WITH_WX || defined(WIN32)
|
||||
bx_options.floppyb.Opath->set_ask_format ("Filename of second floppy image");
|
||||
#else
|
||||
bx_options.floppyb.Opath->set_ask_format ("Enter new filename, or 'none' for no disk: [%s] ");
|
||||
|
@ -26,3 +26,15 @@ BEGIN
|
||||
DEFPUSHBUTTON "OK", IDOK, 10, 40, 50, 14
|
||||
PUSHBUTTON "Cancel", IDCANCEL, 70, 40, 50, 14
|
||||
END
|
||||
|
||||
FLOPPY_DLG DIALOG 30, 30, 190, 80
|
||||
STYLE DS_MODALFRAME | WS_POPUP | WS_VISIBLE | WS_CAPTION | WS_SYSMENU
|
||||
CAPTION "Param"
|
||||
FONT 8, "Helv"
|
||||
BEGIN
|
||||
EDITTEXT IDPATH, 15, 15, 100, 14, ES_AUTOHSCROLL
|
||||
PUSHBUTTON "Browse...", IDBROWSE, 130, 15, 50, 14
|
||||
AUTOCHECKBOX "Inserted", IDSTATUS, 15, 35, 50, 14
|
||||
DEFPUSHBUTTON "OK", IDOK, 40, 55, 50, 14
|
||||
PUSHBUTTON "Cancel", IDCANCEL, 100, 55, 50, 14
|
||||
END
|
||||
|
Loading…
Reference in New Issue
Block a user