emu48-mirror/sources/Emu48/SETTINGS.C

205 lines
6 KiB
C
Raw Normal View History

2024-03-19 22:25:45 +01:00
/*
* settings.c
*
* This file is part of Emu48
*
2024-03-19 22:37:03 +01:00
* Copyright (C) 2000 Christoph Gie<EFBFBD>elink
2024-03-19 22:25:45 +01:00
*
*/
#include "pch.h"
#include "Emu48.h"
2024-03-19 22:36:03 +01:00
#include "i28f160.h"
2024-03-19 22:25:45 +01:00
2024-03-19 22:37:03 +01:00
// #define REGISTRY // use registry instead of *.ini file
//################
//#
//# Low level subroutines
//#
//################
2024-03-19 22:38:33 +01:00
#if !defined REGISTRY
2024-03-19 22:37:03 +01:00
2024-03-19 22:38:33 +01:00
// INI-file handling
#if !defined EMU48_INI
#define EMU48_INI "Emu48.ini"
#endif
2024-03-19 22:25:45 +01:00
2024-03-19 22:37:03 +01:00
#define ReadString(sec,key,dv,v,sv) GetPrivateProfileString(sec,key,dv,v,sv,_T(EMU48_INI))
#define ReadInt(sec,key,dv) GetPrivateProfileInt(sec,key,dv,_T(EMU48_INI));
#define WriteString(sec,key,v) WritePrivateProfileString(sec,key,v,_T(EMU48_INI))
#define WriteInt(sec,key,v) WritePrivateProfileInt(sec,key,v,_T(EMU48_INI))
2024-03-19 22:25:45 +01:00
static BOOL WritePrivateProfileInt(LPCTSTR lpszSection, LPCTSTR lpszEntry, int nValue, LPCTSTR lpszFilename)
{
2024-03-19 22:37:03 +01:00
TCHAR s[16];
wsprintf(s,_T("%i"),nValue);
2024-03-19 22:25:45 +01:00
return WritePrivateProfileString(lpszSection, lpszEntry, s, lpszFilename);
}
2024-03-19 22:37:03 +01:00
#else
2024-03-19 22:38:33 +01:00
// registry handling
#if !defined REGISTRYKEY
#define REGISTRYKEY "Software\\Emu48"
#endif
2024-03-19 22:37:03 +01:00
#define ReadString(sec,key,dv,v,sv) GetRegistryString(sec,key,dv,v,sv)
#define ReadInt(sec,key,dv) GetRegistryInt(sec,key,dv)
#define WriteString(sec,key,v) WriteReg(sec,key,REG_SZ,(BYTE *) v,(lstrlen(v)+1) * sizeof(*v))
#define WriteInt(sec,key,v) WriteReg(sec,key,REG_DWORD,(BYTE *) &v,sizeof(int))
static VOID ReadReg(LPCTSTR lpSubKey, LPCTSTR lpValueName, LPBYTE lpData, DWORD *pdwSize)
{
2024-03-19 22:38:33 +01:00
TCHAR lpKey[256] = _T(REGISTRYKEY) _T("\\");
2024-03-19 22:37:03 +01:00
DWORD retCode,dwType;
HKEY hKey;
lstrcat(lpKey, lpSubKey); // full registry key
retCode = RegOpenKeyEx(HKEY_CURRENT_USER,
lpKey,
0,
KEY_QUERY_VALUE,
&hKey);
if (retCode == ERROR_SUCCESS)
{
retCode = RegQueryValueEx(hKey,lpValueName,NULL,&dwType,lpData,pdwSize);
RegCloseKey(hKey);
}
if (retCode != ERROR_SUCCESS) // registry entry not found
*pdwSize = 0; // return zero size
return;
}
static VOID WriteReg(LPCTSTR lpSubKey, LPCTSTR lpValueName, DWORD dwType, CONST BYTE *lpData, DWORD cbData)
{
2024-03-19 22:38:33 +01:00
TCHAR lpKey[256] = _T(REGISTRYKEY) _T("\\");
2024-03-19 22:37:03 +01:00
DWORD retCode;
HKEY hKey;
DWORD dwDisposition;
lstrcat(lpKey, lpSubKey); // full registry key
retCode = RegCreateKeyEx(HKEY_CURRENT_USER,
lpKey,
0,_T(""),
REG_OPTION_NON_VOLATILE,
KEY_WRITE,
NULL,
&hKey,
&dwDisposition);
_ASSERT(retCode == ERROR_SUCCESS);
RegSetValueEx(hKey,lpValueName,0,dwType,lpData,cbData);
RegCloseKey(hKey);
return;
}
static DWORD GetRegistryString(LPCTSTR lpszSection, LPCTSTR lpszEntry, LPCTSTR lpDefault, LPTSTR lpData, DWORD dwSize)
{
dwSize *= sizeof(*lpData); // buffer size in bytes
ReadReg(lpszSection,lpszEntry,(LPBYTE) lpData,&dwSize);
if (dwSize == 0)
{
lstrcpy(lpData,lpDefault);
dwSize = lstrlen(lpData);
}
else
{
dwSize = (dwSize / sizeof(*lpData)) - 1;
}
return dwSize;
}
static INT GetRegistryInt(LPCTSTR lpszSection, LPCTSTR lpszEntry, INT nDefault)
{
UINT nValue;
DWORD dwSize = sizeof(nValue);
ReadReg(lpszSection,lpszEntry,(LPBYTE) &nValue,&dwSize);
return dwSize ? nValue : nDefault;
}
#endif
//################
//#
//# Public functions
//#
//################
2024-03-19 22:25:45 +01:00
VOID ReadSettings(VOID)
{
// Files
2024-03-19 22:38:33 +01:00
ReadString(_T("Files"),_T("Emu48Directory"),szCurrentDirectory,szEmuDirectory,ARRAYSIZEOF(szEmuDirectory));
bAutoSave = ReadInt(_T("Files"),_T("AutoSave"),bAutoSave);
bAutoSaveOnExit = ReadInt(_T("Files"),_T("AutoSaveOnExit"),bAutoSaveOnExit);
bLoadObjectWarning = ReadInt(_T("Files"),_T("LoadObjectWarning"),bLoadObjectWarning);
2024-03-19 22:25:45 +01:00
// Port2
2024-03-19 22:37:03 +01:00
bPort2IsShared = ReadInt(_T("Port2"),_T("IsShared"),bPort2IsShared);
ReadString(_T("Port2"),_T("Filename"),_T("SHARED.BIN"),szPort2Filename,ARRAYSIZEOF(szPort2Filename));
2024-03-19 22:25:45 +01:00
// KML
2024-03-19 22:37:03 +01:00
bAlwaysDisplayLog = ReadInt(_T("KML"),_T("AlwaysDisplayLog"),bAlwaysDisplayLog);
2024-03-19 22:38:33 +01:00
bClassicCursor = ReadInt(_T("KML"),_T("ClassicCursor"),bClassicCursor);
// Disassembler
2024-03-19 22:37:03 +01:00
disassembler_mode = ReadInt(_T("Disassembler"),_T("Mnemonics"),disassembler_mode);
2024-03-19 22:25:45 +01:00
// Emulator
2024-03-19 22:37:03 +01:00
bRealSpeed = ReadInt(_T("Emulator"),_T("RealSpeed"),bRealSpeed);
dwSXCycles = ReadInt(_T("Emulator"),_T("SXCycles"),dwSXCycles);
dwGXCycles = ReadInt(_T("Emulator"),_T("GXCycles"),dwGXCycles);
2024-03-19 22:25:45 +01:00
SetSpeed(bRealSpeed); // set speed
// Serial
2024-03-19 22:37:03 +01:00
ReadString(_T("Serial"),_T("Wire"),_T(NO_SERIAL),szSerialWire,ARRAYSIZEOF(szSerialWire));
ReadString(_T("Serial"),_T("Ir"),_T(NO_SERIAL),szSerialIr,ARRAYSIZEOF(szSerialIr));
2024-03-19 22:36:03 +01:00
// ROM
2024-03-19 22:37:03 +01:00
bRomWriteable = ReadInt(_T("ROM"),_T("Writeable"),bRomWriteable);
bWP = ReadInt(_T("ROM"),_T("WP#"),bWP);
2024-03-19 22:25:45 +01:00
return;
}
VOID WriteSettings(VOID)
{
// Files
2024-03-19 22:38:33 +01:00
WriteString(_T("Files"),_T("Emu48Directory"),szEmuDirectory);
2024-03-19 22:37:03 +01:00
WriteInt(_T("Files"),_T("AutoSave"),bAutoSave);
WriteInt(_T("Files"),_T("AutoSaveOnExit"),bAutoSaveOnExit);
2024-03-19 22:38:33 +01:00
WriteInt(_T("Files"),_T("LoadObjectWarning"),bLoadObjectWarning);
2024-03-19 22:25:45 +01:00
// Port2
2024-03-19 22:37:03 +01:00
WriteInt(_T("Port2"),_T("IsShared"),bPort2IsShared);
WriteString(_T("Port2"),_T("Filename"),szPort2Filename);
2024-03-19 22:25:45 +01:00
// KML
2024-03-19 22:37:03 +01:00
WriteInt(_T("KML"),_T("AlwaysDisplayLog"),bAlwaysDisplayLog);
2024-03-19 22:38:33 +01:00
WriteInt(_T("KML"),_T("ClassicCursor"),bClassicCursor);
// Disassembler
2024-03-19 22:37:03 +01:00
WriteInt(_T("Disassembler"),_T("Mnemonics"),disassembler_mode);
2024-03-19 22:25:45 +01:00
// Emulator
2024-03-19 22:37:03 +01:00
WriteInt(_T("Emulator"),_T("RealSpeed"),bRealSpeed);
WriteInt(_T("Emulator"),_T("SXCycles"),dwSXCycles);
WriteInt(_T("Emulator"),_T("GXCycles"),dwGXCycles);
2024-03-19 22:25:45 +01:00
// Serial
2024-03-19 22:37:03 +01:00
WriteString(_T("Serial"),_T("Wire"),szSerialWire);
WriteString(_T("Serial"),_T("Ir"),szSerialIr);
2024-03-19 22:36:03 +01:00
// ROM
2024-03-19 22:37:03 +01:00
WriteInt(_T("ROM"),_T("Writeable"),bRomWriteable);
2024-03-19 22:25:45 +01:00
return;
}
VOID ReadLastDocument(LPTSTR szFilename, DWORD nSize)
{
2024-03-19 22:37:03 +01:00
ReadString(_T("Files"),_T("LastDocument"),_T(""),szFilename,nSize);
2024-03-19 22:25:45 +01:00
return;
}
VOID WriteLastDocument(LPCTSTR szFilename)
{
2024-03-19 22:37:03 +01:00
WriteString(_T("Files"),_T("LastDocument"),szFilename);
2024-03-19 22:25:45 +01:00
return;
}