Whilst in browse mode pressing Alt-W toggles write protection on a disk image.
This commit is contained in:
parent
5491711446
commit
09cfc4ec86
3 changed files with 26 additions and 0 deletions
|
@ -977,6 +977,24 @@ void FileBrowser::UpdateInputFolders()
|
|||
m_IEC_Commands.CreateD64(newFileName, "42", true);
|
||||
FolderChanged();
|
||||
}
|
||||
else if (inputMappings->BrowseWriteProtect())
|
||||
{
|
||||
FileBrowser::BrowsableList::Entry* current = folder.current;
|
||||
if (current)
|
||||
{
|
||||
if (current->filImage.fattrib & AM_RDO)
|
||||
{
|
||||
current->filImage.fattrib &= ~AM_RDO;
|
||||
f_chmod(current->filImage.fname, 0, AM_RDO);
|
||||
}
|
||||
else
|
||||
{
|
||||
current->filImage.fattrib |= AM_RDO;
|
||||
f_chmod(current->filImage.fname, AM_RDO, AM_RDO);
|
||||
}
|
||||
dirty = true;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
unsigned keySetIndex;
|
||||
|
|
|
@ -191,6 +191,8 @@ bool InputMappings::CheckKeyboardBrowseMode()
|
|||
SetKeyboardFlag(AUTOLOAD_FLAG);
|
||||
else if (keyboard->KeyHeld(KEY_R) && keyboard->KeyEitherAlt() )
|
||||
SetKeyboardFlag(FAKERESET_FLAG);
|
||||
else if (keyboard->KeyHeld(KEY_W) && keyboard->KeyEitherAlt())
|
||||
SetKeyboardFlag(WRITEPROTECT_FLAG);
|
||||
else
|
||||
{
|
||||
unsigned index;
|
||||
|
|
|
@ -40,6 +40,7 @@
|
|||
#define NEWD64_FLAG (1 << 14)
|
||||
#define AUTOLOAD_FLAG (1 << 15)
|
||||
#define FAKERESET_FLAG (1 << 16)
|
||||
#define WRITEPROTECT_FLAG (1 << 17)
|
||||
// dont exceed 32!!
|
||||
|
||||
class InputMappings : public Singleton<InputMappings>
|
||||
|
@ -173,6 +174,11 @@ public:
|
|||
return KeyboardFlag(FAKERESET_FLAG);
|
||||
}
|
||||
|
||||
inline bool BrowseWriteProtect()
|
||||
{
|
||||
return KeyboardFlag(WRITEPROTECT_FLAG);
|
||||
}
|
||||
|
||||
// Used by the 2 cores so need to be volatile
|
||||
//volatile static unsigned directDiskSwapRequest;
|
||||
static unsigned directDiskSwapRequest;
|
||||
|
|
Loading…
Reference in a new issue