2020-04-26 00:12:11 +02:00
|
|
|
#define UNICODE
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
#include <Windows.h>
|
|
|
|
|
#include <86box/86box.h>
|
|
|
|
|
#include <86box/cdrom.h>
|
|
|
|
|
#include <86box/device.h>
|
|
|
|
|
#include <86box/timer.h>
|
|
|
|
|
#include <86box/fdd.h>
|
|
|
|
|
#include <86box/hdc.h>
|
|
|
|
|
#include <86box/language.h>
|
|
|
|
|
#include <86box/machine.h>
|
|
|
|
|
#include <86box/scsi_device.h>
|
|
|
|
|
#include <86box/mo.h>
|
|
|
|
|
#include <86box/scsi.h>
|
|
|
|
|
#include <86box/zip.h>
|
|
|
|
|
#include <86box/win.h>
|
|
|
|
|
|
|
|
|
|
#define MACHINE_HAS_IDE ((machines[machine].flags & MACHINE_HDC) || !memcmp(hdc_get_internal_name(hdc_current), "ide", 3))
|
|
|
|
|
|
|
|
|
|
#define FDD_FIRST 0
|
|
|
|
|
#define CDROM_FIRST FDD_FIRST + FDD_NUM
|
|
|
|
|
#define ZIP_FIRST CDROM_FIRST + CDROM_NUM
|
|
|
|
|
#define MO_FIRST ZIP_FIRST + ZIP_NUM
|
|
|
|
|
|
|
|
|
|
static HMENU media_menu, stbar_menu;
|
|
|
|
|
static HMENU menus[FDD_NUM + CDROM_NUM + ZIP_NUM + MO_NUM];
|
|
|
|
|
static char index_map[255];
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
media_menu_set_ids(HMENU hMenu, int id)
|
|
|
|
|
{
|
|
|
|
|
int c = GetMenuItemCount(hMenu);
|
|
|
|
|
|
|
|
|
|
MENUITEMINFO mii;
|
|
|
|
|
mii.fMask = MIIM_ID;
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < c; i++)
|
|
|
|
|
{
|
|
|
|
|
GetMenuItemInfo(hMenu, i, TRUE, &mii);
|
|
|
|
|
mii.wID |= id;
|
|
|
|
|
SetMenuItemInfo(hMenu, i, TRUE, &mii);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Loads the submenu from resource by name */
|
|
|
|
|
static HMENU
|
|
|
|
|
media_menu_load_resource(wchar_t *lpName)
|
|
|
|
|
{
|
|
|
|
|
HMENU loaded = LoadMenu(NULL, lpName);
|
|
|
|
|
|
|
|
|
|
/* The actual submenu is in a dummy popup menu item */
|
|
|
|
|
HMENU actual = GetSubMenu(loaded, 0);
|
|
|
|
|
|
|
|
|
|
/* Now that we have our submenu, we can destroy the parent menu */
|
|
|
|
|
RemoveMenu(loaded, (UINT_PTR)actual, MF_BYCOMMAND);
|
|
|
|
|
DestroyMenu(loaded);
|
|
|
|
|
|
|
|
|
|
return actual;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
media_menu_update_floppy(int id)
|
|
|
|
|
{
|
|
|
|
|
int i = FDD_FIRST + id;
|
|
|
|
|
|
|
|
|
|
if (floppyfns[id][0] == 0x0000) {
|
|
|
|
|
EnableMenuItem(menus[i], IDM_FLOPPY_EJECT | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
EnableMenuItem(menus[i], IDM_FLOPPY_EXPORT_TO_86F | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
media_menu_update_cdrom(int id)
|
|
|
|
|
{
|
|
|
|
|
int i = CDROM_FIRST + id;
|
|
|
|
|
|
|
|
|
|
if (! cdrom[id].sound_on)
|
|
|
|
|
CheckMenuItem(menus[i], IDM_CDROM_MUTE | id, MF_CHECKED);
|
|
|
|
|
|
|
|
|
|
if (cdrom[id].host_drive == 200)
|
|
|
|
|
CheckMenuItem(menus[i], IDM_CDROM_IMAGE | id, MF_CHECKED);
|
|
|
|
|
else {
|
|
|
|
|
cdrom[id].host_drive = 0;
|
|
|
|
|
CheckMenuItem(menus[i], IDM_CDROM_EMPTY | id, MF_CHECKED);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
media_menu_update_zip(int id)
|
|
|
|
|
{
|
|
|
|
|
int i = ZIP_FIRST + id;
|
|
|
|
|
|
|
|
|
|
if (zip_drives[id].image_path[0] == 0x0000) {
|
|
|
|
|
EnableMenuItem(menus[i], IDM_ZIP_EJECT | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
EnableMenuItem(menus[i], IDM_ZIP_RELOAD | id, MF_BYCOMMAND | MF_ENABLED);
|
|
|
|
|
} else {
|
|
|
|
|
EnableMenuItem(menus[i], IDM_ZIP_EJECT | id, MF_BYCOMMAND | MF_ENABLED);
|
|
|
|
|
EnableMenuItem(menus[i], IDM_ZIP_RELOAD | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
media_menu_update_mo(int id)
|
|
|
|
|
{
|
|
|
|
|
int i = MO_FIRST + id;
|
|
|
|
|
|
|
|
|
|
if (mo_drives[id].image_path[0] == 0x0000) {
|
|
|
|
|
EnableMenuItem(menus[i], IDM_MO_EJECT | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
EnableMenuItem(menus[i], IDM_MO_RELOAD | id, MF_BYCOMMAND | MF_ENABLED);
|
|
|
|
|
} else {
|
|
|
|
|
EnableMenuItem(menus[i], IDM_MO_EJECT | id, MF_BYCOMMAND | MF_ENABLED);
|
|
|
|
|
EnableMenuItem(menus[i], IDM_MO_RELOAD | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
media_menu_load_submenus()
|
|
|
|
|
{
|
|
|
|
|
memset(index_map, -1, sizeof(index_map));
|
|
|
|
|
|
|
|
|
|
int curr = 0;
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < FDD_NUM; i++) {
|
|
|
|
|
menus[curr] = media_menu_load_resource(FLOPPY_SUBMENU_NAME);
|
|
|
|
|
media_menu_set_ids(menus[curr++], i);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < CDROM_NUM; i++) {
|
|
|
|
|
menus[curr] = media_menu_load_resource(CDROM_SUBMENU_NAME);
|
|
|
|
|
media_menu_set_ids(menus[curr++], i);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < ZIP_NUM; i++) {
|
|
|
|
|
menus[curr] = media_menu_load_resource(ZIP_SUBMENU_NAME);
|
|
|
|
|
media_menu_set_ids(menus[curr++], i);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < MO_NUM; i++) {
|
|
|
|
|
menus[curr] = media_menu_load_resource(MO_SUBMENU_NAME);
|
|
|
|
|
media_menu_set_ids(menus[curr++], i);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
|
is_valid_fdd(int i)
|
|
|
|
|
{
|
|
|
|
|
return fdd_get_type(i) != 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
|
is_valid_cdrom(int i)
|
|
|
|
|
{
|
|
|
|
|
if ((cdrom[i].bus_type == CDROM_BUS_ATAPI) && !MACHINE_HAS_IDE)
|
|
|
|
|
return 0;
|
|
|
|
|
if ((cdrom[i].bus_type == CDROM_BUS_SCSI) && (scsi_card_current == 0))
|
|
|
|
|
return 0;
|
|
|
|
|
return cdrom[i].bus_type != 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
|
is_valid_zip(int i)
|
|
|
|
|
{
|
|
|
|
|
if ((zip_drives[i].bus_type == ZIP_BUS_ATAPI) && !MACHINE_HAS_IDE)
|
|
|
|
|
return 0;
|
|
|
|
|
if ((zip_drives[i].bus_type == ZIP_BUS_SCSI) && (scsi_card_current == 0))
|
|
|
|
|
return 0;
|
|
|
|
|
return zip_drives[i].bus_type != 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
|
is_valid_mo(int i)
|
|
|
|
|
{
|
|
|
|
|
if ((mo_drives[i].bus_type == MO_BUS_ATAPI) && !MACHINE_HAS_IDE)
|
|
|
|
|
return 0;
|
|
|
|
|
if ((mo_drives[i].bus_type == MO_BUS_SCSI) && (scsi_card_current == 0))
|
|
|
|
|
return 0;
|
|
|
|
|
return mo_drives[i].bus_type != 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
media_menu_reset()
|
|
|
|
|
{
|
|
|
|
|
/* Remove existing entries. */
|
|
|
|
|
int c = GetMenuItemCount(media_menu);
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < c; i++)
|
|
|
|
|
RemoveMenu(media_menu, i, TRUE);
|
|
|
|
|
|
|
|
|
|
/* Add new ones. */
|
|
|
|
|
int curr = 0;
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < FDD_NUM; i++) {
|
|
|
|
|
if(is_valid_fdd(i)) {
|
|
|
|
|
AppendMenu(media_menu, MF_POPUP | MF_STRING, (UINT_PTR)menus[curr], L"Test");
|
|
|
|
|
media_menu_update_floppy(i);
|
|
|
|
|
}
|
|
|
|
|
curr++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < CDROM_NUM; i++) {
|
|
|
|
|
if(is_valid_cdrom(i)) {
|
|
|
|
|
AppendMenu(media_menu, MF_POPUP | MF_STRING, (UINT_PTR)menus[curr], L"Test");
|
|
|
|
|
media_menu_update_cdrom(i);
|
|
|
|
|
}
|
|
|
|
|
curr++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < ZIP_NUM; i++) {
|
|
|
|
|
if(is_valid_zip(i)) {
|
|
|
|
|
AppendMenu(media_menu, MF_POPUP | MF_STRING, (UINT_PTR)menus[curr], L"Test");
|
|
|
|
|
media_menu_update_zip(i);
|
|
|
|
|
}
|
|
|
|
|
curr++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for(int i = 0; i < MO_NUM; i++) {
|
|
|
|
|
if(is_valid_mo(i)) {
|
|
|
|
|
AppendMenu(media_menu, MF_POPUP | MF_STRING, (UINT_PTR)menus[curr], L"Test");
|
|
|
|
|
media_menu_update_mo(i);
|
|
|
|
|
}
|
|
|
|
|
curr++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Initializes the Media menu in the main menu bar. */
|
|
|
|
|
static void
|
|
|
|
|
media_menu_main_init()
|
|
|
|
|
{
|
|
|
|
|
HMENU hMenu;
|
|
|
|
|
LPWSTR lpMenuName;
|
|
|
|
|
|
|
|
|
|
hMenu = GetMenu(hwndMain);
|
|
|
|
|
media_menu = CreatePopupMenu();
|
|
|
|
|
|
|
|
|
|
/* Get the menu name */
|
|
|
|
|
int len = GetMenuString(hMenu, IDM_MEDIA, NULL, 0, MF_BYCOMMAND);
|
|
|
|
|
lpMenuName = malloc((len + 1) * sizeof(WCHAR));
|
|
|
|
|
GetMenuString(hMenu, IDM_MEDIA, lpMenuName, len + 1, MF_BYCOMMAND);
|
|
|
|
|
|
|
|
|
|
/* Replace the placeholder menu item */
|
|
|
|
|
ModifyMenu(hMenu, IDM_MEDIA, MF_BYCOMMAND | MF_STRING | MF_POPUP, (UINT_PTR)media_menu, lpMenuName);
|
|
|
|
|
|
|
|
|
|
/* Clean up */
|
|
|
|
|
DrawMenuBar(hwndMain);
|
|
|
|
|
free(lpMenuName);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
media_menu_init()
|
|
|
|
|
{
|
|
|
|
|
/* Initialize the main menu bar menu */
|
|
|
|
|
media_menu_main_init();
|
|
|
|
|
|
|
|
|
|
/* Initialize the dummy status bar menu. */
|
|
|
|
|
stbar_menu = CreateMenu();
|
|
|
|
|
AppendMenu(stbar_menu, MF_POPUP, (UINT_PTR)media_menu, NULL);
|
|
|
|
|
|
|
|
|
|
/* Load the submenus for each drive type. */
|
|
|
|
|
media_menu_load_submenus();
|
|
|
|
|
|
|
|
|
|
/* Populate the Media and status bar menus. */
|
|
|
|
|
media_menu_reset();
|
2020-04-26 14:19:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
fdd_mount(uint8_t id, wchar_t *fn, uint8_t wp)
|
|
|
|
|
{
|
|
|
|
|
fdd_close(id);
|
|
|
|
|
ui_writeprot[id] = wp;
|
|
|
|
|
fdd_load(id, fn);
|
|
|
|
|
|
|
|
|
|
config_save();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
cdrom_mount(uint8_t id, wchar_t *fn)
|
|
|
|
|
{
|
|
|
|
|
cdrom[id].prev_host_drive = cdrom[id].host_drive;
|
|
|
|
|
wcscpy(cdrom[id].prev_image_path, cdrom[id].image_path);
|
|
|
|
|
if (cdrom[id].ops && cdrom[id].ops->exit)
|
|
|
|
|
cdrom[id].ops->exit(&(cdrom[id]));
|
|
|
|
|
cdrom[id].ops = NULL;
|
|
|
|
|
memset(cdrom[id].image_path, 0, sizeof(cdrom[id].image_path));
|
|
|
|
|
cdrom_image_open(&(cdrom[id]), fn);
|
|
|
|
|
/* Signal media change to the emulated machine. */
|
|
|
|
|
if (cdrom[id].insert)
|
|
|
|
|
cdrom[id].insert(cdrom[id].priv);
|
|
|
|
|
cdrom[id].host_drive = (wcslen(cdrom[id].image_path) == 0) ? 0 : 200;
|
|
|
|
|
|
|
|
|
|
config_save();
|
2020-04-26 00:12:11 +02:00
|
|
|
}
|