mirror of https://github.com/stella-emu/stella.git
Fixed crash when entering the debugger in software mode.
Some cleanup of the various enum's in the UI classes. Fixed issues with ordering when adding dialog boxes; this fixes a bug when adding a dialog from another dialogs ::loadConfig(), in which case the first one is placed below the second and can't be seen (mostly applies to MessageBoxes). Fixed bug in handling OSystem::setBaseDir(); if the directory didn't exist, then the newly created one wouldn't have a slash appended at the end. This causes all further (sub)directories to be created/named incorrectly. Started work on extending BrowerDialog to load files as well as directories, and to allow editing of the items from within the dialog itself. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@2713 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
ab6276a9cc
commit
86b6191570
|
@ -308,8 +308,8 @@ void DebuggerDialog::addRomArea()
|
|||
// Disassembly area
|
||||
|
||||
xpos = r.left + vBorder; ypos += myRam->getHeight() + 5;
|
||||
const int tabWidth = r.width() - vBorder;
|
||||
const int tabHeight = r.height() - ypos;
|
||||
const int tabWidth = r.width() - vBorder - 1;
|
||||
const int tabHeight = r.height() - ypos - 1;
|
||||
int tabID;
|
||||
|
||||
// Since there are two tab widgets in this dialog, we specifically
|
||||
|
|
|
@ -405,7 +405,8 @@ void RomListWidget::handleCommand(CommandSender* sender, int cmd, int data, int
|
|||
case kCheckActionCmd:
|
||||
// We let the parent class handle this
|
||||
// Pass it as a kRLBreakpointChangedCmd command, since that's the intent
|
||||
sendCommand(kRLBreakpointChangedCmd, myCheckList[id]->getState(), _currentPos+id);
|
||||
sendCommand(RomListWidget::kBreakpointChangedCmd,
|
||||
myCheckList[id]->getState(), _currentPos+id);
|
||||
break;
|
||||
|
||||
case kSetPositionCmd:
|
||||
|
@ -597,7 +598,7 @@ void RomListWidget::endEditMode()
|
|||
// Send a message that editing finished with a return/enter key press
|
||||
// The parent then calls getEditString() to get the newly entered data
|
||||
_editMode = false;
|
||||
sendCommand(kRLRomChangedCmd, _selectedItem, _id);
|
||||
sendCommand(RomListWidget::kRomChangedCmd, _selectedItem, _id);
|
||||
|
||||
// Reset to normal data entry
|
||||
EditableWidget::endEditMode();
|
||||
|
|
|
@ -32,17 +32,18 @@ class CheckListWidget;
|
|||
#include "CartDebug.hxx"
|
||||
#include "EditableWidget.hxx"
|
||||
|
||||
// Some special commands for this widget
|
||||
enum {
|
||||
kRLBreakpointChangedCmd = 'RLbp', // click on the checkbox for a breakpoint
|
||||
kRLRomChangedCmd = 'RLpr' // ROM item data changed - 'data' will be item index
|
||||
};
|
||||
|
||||
/** RomListWidget */
|
||||
class RomListWidget : public EditableWidget
|
||||
{
|
||||
friend class RomWidget;
|
||||
|
||||
public:
|
||||
enum {
|
||||
kBreakpointChangedCmd = 'RLbp', // click on the checkbox for a breakpoint
|
||||
kRomChangedCmd = 'RLpr' // ROM item data changed - 'data' will be
|
||||
// item index
|
||||
};
|
||||
|
||||
public:
|
||||
RomListWidget(GuiObject* boss, const GUI::Font& font,
|
||||
int x, int y, int w, int h);
|
||||
|
|
|
@ -139,7 +139,7 @@ void RomWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
|||
{
|
||||
switch(cmd)
|
||||
{
|
||||
case kRLBreakpointChangedCmd:
|
||||
case RomListWidget::kBreakpointChangedCmd:
|
||||
// 'id' is the line in the disassemblylist to be accessed
|
||||
// 'data' is the state of the breakpoint at 'id'
|
||||
setBreak(id, data);
|
||||
|
@ -149,12 +149,12 @@ void RomWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
|||
myRomList->draw();
|
||||
break;
|
||||
|
||||
case kRLRomChangedCmd:
|
||||
case RomListWidget::kRomChangedCmd:
|
||||
// 'data' is the line in the disassemblylist to be accessed
|
||||
patchROM(data, myRomList->getEditString());
|
||||
break;
|
||||
|
||||
case kCMenuItemSelectedCmd:
|
||||
case ContextMenu::kItemSelectedCmd:
|
||||
{
|
||||
const string& rmb = myRomList->myMenu->getSelectedTag();
|
||||
|
||||
|
|
|
@ -87,7 +87,7 @@ void TiaOutputWidget::handleCommand(CommandSender* sender, int cmd, int data, in
|
|||
|
||||
switch(cmd)
|
||||
{
|
||||
case kCMenuItemSelectedCmd:
|
||||
case ContextMenu::kItemSelectedCmd:
|
||||
{
|
||||
const string& rmb = myMenu->getSelectedTag();
|
||||
|
||||
|
|
|
@ -200,7 +200,7 @@ void TiaZoomWidget::handleCommand(CommandSender* sender, int cmd, int data, int
|
|||
{
|
||||
switch(cmd)
|
||||
{
|
||||
case kCMenuItemSelectedCmd:
|
||||
case ContextMenu::kItemSelectedCmd:
|
||||
{
|
||||
int level = (int) atoi(myMenu->getSelectedTag().c_str());
|
||||
if(level > 0)
|
||||
|
|
|
@ -385,9 +385,10 @@ void OSystem::setUIPalette()
|
|||
void OSystem::setBaseDir(const string& basedir)
|
||||
{
|
||||
FilesystemNode node(basedir);
|
||||
myBaseDir = node.getPath();
|
||||
if(!node.isDirectory())
|
||||
node.makeDir();
|
||||
|
||||
myBaseDir = node.getPath();
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -823,6 +824,7 @@ void OSystem::validatePath(string& path, const string& setting,
|
|||
FilesystemNode node(s);
|
||||
if(!node.isDirectory())
|
||||
node.makeDir();
|
||||
|
||||
path = node.getPath();
|
||||
mySettings->setString(setting, node.getShortPath());
|
||||
}
|
||||
|
|
|
@ -47,19 +47,18 @@ BrowserDialog::BrowserDialog(GuiObject* boss, const GUI::Font& font,
|
|||
_fileList(NULL),
|
||||
_currentPath(NULL),
|
||||
_nodeList(NULL),
|
||||
_mode(FilesystemNode::kListDirectoriesOnly)
|
||||
_mode(FilesystemNode::kListAll)
|
||||
{
|
||||
// Set real dimensions
|
||||
_w = max_w;
|
||||
_h = max_h;
|
||||
|
||||
const int lineHeight = font.getLineHeight(),
|
||||
buttonWidth = font.getStringWidth("Defaults") + 20,
|
||||
buttonHeight = font.getLineHeight() + 4;
|
||||
int xpos, ypos;
|
||||
ButtonWidget* b;
|
||||
|
||||
// Set real dimensions
|
||||
// This is one dialog that can take as much space as is available
|
||||
_w = BSPF_min(max_w, 480);
|
||||
_h = BSPF_min(max_h, 380);
|
||||
|
||||
xpos = 10; ypos = 4;
|
||||
_title = new StaticTextWidget(this, font, xpos, ypos,
|
||||
_w - 2 * xpos, lineHeight,
|
||||
|
@ -123,18 +122,6 @@ BrowserDialog::~BrowserDialog()
|
|||
void BrowserDialog::show(const string& title, const string& startpath,
|
||||
FilesystemNode::ListMode mode, int cmd)
|
||||
{
|
||||
// TODO - dialog has to be added before any settings are changed,
|
||||
// since (for example) changing the title triggers a redraw,
|
||||
// and the dialog must be added (so it exists) for that to happen
|
||||
// Fixing this requires changes to the underlying widget classes
|
||||
// (ie, changing a widgets contents should signal its dialog that a
|
||||
// redraw is necessary; it shouldn't be responsible for redraw itself)
|
||||
//
|
||||
// Doing it this way has the unfortunate side effect that a previous
|
||||
// title is temporarily visible when re-using the browser for different
|
||||
// purposes
|
||||
open();
|
||||
|
||||
_title->setLabel(title);
|
||||
_cmd = cmd;
|
||||
_mode = mode;
|
||||
|
@ -151,6 +138,9 @@ void BrowserDialog::show(const string& title, const string& startpath,
|
|||
|
||||
// Alway refresh file list
|
||||
updateListing();
|
||||
|
||||
// Finally, open the dialog after it has been fully updated
|
||||
open();
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -208,7 +198,7 @@ void BrowserDialog::handleCommand(CommandSender* sender, int cmd,
|
|||
case kChooseCmd:
|
||||
// Send a signal to the calling class that a selection has been made
|
||||
// Since we aren't derived from a widget, we don't have a 'data' or 'id'
|
||||
if(_cmd) sendCommand(_cmd, 0, 0);
|
||||
if(_cmd) sendCommand(_cmd, -1, -1);
|
||||
close();
|
||||
break;
|
||||
|
||||
|
|
|
@ -36,6 +36,13 @@ class GameList;
|
|||
|
||||
class BrowserDialog : public Dialog, public CommandSender
|
||||
{
|
||||
public:
|
||||
enum ListMode {
|
||||
kFileLoad, // File selector, no input from user
|
||||
kFileSave, // File selector, filename changable by user
|
||||
kDirectoryOpen // Directories only, no input from user
|
||||
};
|
||||
|
||||
public:
|
||||
BrowserDialog(GuiObject* boss, const GUI::Font& font, int max_w, int max_h);
|
||||
virtual ~BrowserDialog();
|
||||
|
|
|
@ -202,7 +202,7 @@ bool ContextMenu::sendSelectionUp()
|
|||
return false;
|
||||
|
||||
_selectedItem--;
|
||||
sendCommand(_cmd ? _cmd : kCMenuItemSelectedCmd, _selectedItem, -1);
|
||||
sendCommand(_cmd ? _cmd : ContextMenu::kItemSelectedCmd, _selectedItem, -1);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -213,7 +213,7 @@ bool ContextMenu::sendSelectionDown()
|
|||
return false;
|
||||
|
||||
_selectedItem++;
|
||||
sendCommand(_cmd ? _cmd : kCMenuItemSelectedCmd, _selectedItem, -1);
|
||||
sendCommand(_cmd ? _cmd : ContextMenu::kItemSelectedCmd, _selectedItem, -1);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -224,7 +224,7 @@ bool ContextMenu::sendSelectionFirst()
|
|||
return false;
|
||||
|
||||
_selectedItem = 0;
|
||||
sendCommand(_cmd ? _cmd : kCMenuItemSelectedCmd, _selectedItem, -1);
|
||||
sendCommand(_cmd ? _cmd : ContextMenu::kItemSelectedCmd, _selectedItem, -1);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -235,7 +235,7 @@ bool ContextMenu::sendSelectionLast()
|
|||
return false;
|
||||
|
||||
_selectedItem = _entries.size() - 1;
|
||||
sendCommand(_cmd ? _cmd : kCMenuItemSelectedCmd, _selectedItem, -1);
|
||||
sendCommand(_cmd ? _cmd : ContextMenu::kItemSelectedCmd, _selectedItem, -1);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -396,7 +396,7 @@ void ContextMenu::sendSelection()
|
|||
|
||||
// Send any command associated with the selection
|
||||
_selectedItem = item;
|
||||
sendCommand(_cmd ? _cmd : kCMenuItemSelectedCmd, _selectedItem, -1);
|
||||
sendCommand(_cmd ? _cmd : ContextMenu::kItemSelectedCmd, _selectedItem, -1);
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
|
|
@ -27,10 +27,6 @@
|
|||
#include "Command.hxx"
|
||||
#include "Dialog.hxx"
|
||||
|
||||
enum {
|
||||
kCMenuItemSelectedCmd = 'CMsl'
|
||||
};
|
||||
|
||||
/**
|
||||
* Popup context menu which, when clicked, "pop up" a list of items and
|
||||
* lets the user pick on of them.
|
||||
|
@ -43,6 +39,11 @@ enum {
|
|||
*/
|
||||
class ContextMenu : public Dialog, public CommandSender
|
||||
{
|
||||
public:
|
||||
enum {
|
||||
kItemSelectedCmd = 'CMsl'
|
||||
};
|
||||
|
||||
public:
|
||||
ContextMenu(GuiObject* boss, const GUI::Font& font,
|
||||
const StringMap& items, int cmd = 0);
|
||||
|
|
|
@ -80,6 +80,7 @@ void Dialog::open(bool refresh)
|
|||
uInt32 surfaceID = instance().frameBuffer().allocateSurface(_w, _h, _isBase);
|
||||
_surface = instance().frameBuffer().surface(surfaceID);
|
||||
}
|
||||
parent().addDialog(this);
|
||||
|
||||
center();
|
||||
loadConfig();
|
||||
|
@ -90,7 +91,8 @@ void Dialog::open(bool refresh)
|
|||
|
||||
_visible = true;
|
||||
|
||||
parent().addDialog(this, refresh);
|
||||
if(refresh)
|
||||
instance().frameBuffer().refresh();
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -106,7 +108,10 @@ void Dialog::close(bool refresh)
|
|||
|
||||
_visible = false;
|
||||
|
||||
parent().removeDialog(refresh);
|
||||
parent().removeDialog();
|
||||
|
||||
if(refresh)
|
||||
instance().frameBuffer().refresh();
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
|
|
@ -112,27 +112,19 @@ void DialogContainer::draw(bool full)
|
|||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void DialogContainer::addDialog(Dialog* d, bool refresh)
|
||||
void DialogContainer::addDialog(Dialog* d)
|
||||
{
|
||||
const GUI::Rect& screen = myOSystem->frameBuffer().screenRect();
|
||||
assert(d->getWidth() <= screen.width() && d->getHeight() <= screen.height());
|
||||
|
||||
myDialogStack.push(d);
|
||||
|
||||
if(refresh)
|
||||
myOSystem->frameBuffer().refresh();
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void DialogContainer::removeDialog(bool refresh)
|
||||
void DialogContainer::removeDialog()
|
||||
{
|
||||
if(!myDialogStack.empty())
|
||||
{
|
||||
myDialogStack.pop();
|
||||
|
||||
if(refresh)
|
||||
myOSystem->frameBuffer().refresh();
|
||||
}
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
|
|
@ -141,12 +141,12 @@ class DialogContainer
|
|||
/**
|
||||
Add a dialog box to the stack.
|
||||
*/
|
||||
void addDialog(Dialog* d, bool refresh);
|
||||
void addDialog(Dialog* d);
|
||||
|
||||
/**
|
||||
Remove the topmost dialog box from the stack.
|
||||
*/
|
||||
void removeDialog(bool refresh);
|
||||
void removeDialog();
|
||||
|
||||
protected:
|
||||
OSystem* myOSystem;
|
||||
|
|
|
@ -174,7 +174,7 @@ LauncherDialog::LauncherDialog(OSystem* osystem, DialogContainer* parent,
|
|||
mySelectedItem = 0; // Highlight 'Rom Listing'
|
||||
|
||||
// Create an options dialog, similar to the in-game one
|
||||
myOptions = new OptionsDialog(osystem, parent, this, w, h, true); // not in game mode
|
||||
myOptions = new OptionsDialog(osystem, parent, this, w * 0.8, h * 0.8, true);
|
||||
|
||||
// Create a game list, which contains all the information about a ROM that
|
||||
// the launcher needs
|
||||
|
@ -619,7 +619,7 @@ void LauncherDialog::handleCommand(CommandSender* sender, int cmd,
|
|||
updateListing();
|
||||
break;
|
||||
|
||||
case kCMenuItemSelectedCmd:
|
||||
case ContextMenu::kItemSelectedCmd:
|
||||
handleContextMenu();
|
||||
break;
|
||||
|
||||
|
|
|
@ -39,7 +39,7 @@ Menu::Menu(OSystem* osystem)
|
|||
}
|
||||
else
|
||||
{
|
||||
dw = 640; dh = 420;
|
||||
dw = 480; dh = 380;
|
||||
}
|
||||
myBaseDialog = new OptionsDialog(myOSystem, this, 0, dw, dh, false); // in game mode
|
||||
}
|
||||
|
|
|
@ -68,16 +68,13 @@ Widget::~Widget()
|
|||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void Widget::draw()
|
||||
{
|
||||
if(!_dirty)
|
||||
if(!_dirty || !isVisible() || !_boss->isVisible())
|
||||
return;
|
||||
|
||||
_dirty = false;
|
||||
|
||||
FBSurface& s = _boss->dialog().surface();
|
||||
|
||||
if(!isVisible() || !_boss->isVisible())
|
||||
return;
|
||||
|
||||
bool hasBorder = _flags & WIDGET_BORDER;
|
||||
int oldX = _x, oldY = _y, oldW = _w, oldH = _h;
|
||||
|
||||
|
|
|
@ -57,6 +57,10 @@ void FilesystemNodePOSIX::setFlags()
|
|||
{
|
||||
_isDirectory = S_ISDIR(st.st_mode);
|
||||
_isFile = S_ISREG(st.st_mode);
|
||||
|
||||
// Add a trailing slash, if necessary
|
||||
if (_isDirectory && _path.length() > 0 && _path[_path.length()-1] != '/')
|
||||
_path += '/';
|
||||
}
|
||||
else
|
||||
_isDirectory = _isFile = false;
|
||||
|
@ -94,14 +98,8 @@ FilesystemNodePOSIX::FilesystemNodePOSIX(const string& p, bool verify)
|
|||
|
||||
_displayName = lastPathComponent(_path);
|
||||
|
||||
if (verify)
|
||||
{
|
||||
if(verify)
|
||||
setFlags();
|
||||
|
||||
// Add a trailing slash, if necessary
|
||||
if (_isDirectory && _path.length() > 0 && _path[_path.length()-1] != '/')
|
||||
_path += '/';
|
||||
}
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -184,6 +182,9 @@ bool FilesystemNodePOSIX::getChildren(AbstractFSList& myList, ListMode mode,
|
|||
entry._isDirectory = (dp->d_type == DT_DIR);
|
||||
entry._isFile = (dp->d_type == DT_REG);
|
||||
}
|
||||
|
||||
if (entry._isDirectory)
|
||||
entry._path += "/";
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -197,9 +198,6 @@ bool FilesystemNodePOSIX::getChildren(AbstractFSList& myList, ListMode mode,
|
|||
(mode == FilesystemNode::kListDirectoriesOnly && !entry._isDirectory))
|
||||
continue;
|
||||
|
||||
if (entry._isDirectory)
|
||||
entry._path += "/";
|
||||
|
||||
myList.push_back(new FilesystemNodePOSIX(entry));
|
||||
}
|
||||
closedir(dirp);
|
||||
|
|
Loading…
Reference in New Issue