mirror of https://github.com/stella-emu/stella.git
added PlusROM info to debugger (resolves #844)
added PlusROM user info to System log
This commit is contained in:
parent
2ff5fffe37
commit
645c2fc5bb
|
@ -31,6 +31,8 @@
|
||||||
|
|
||||||
* Added another oddball TIA glitch option for score mode color.
|
* Added another oddball TIA glitch option for score mode color.
|
||||||
|
|
||||||
|
* Debugger: added PlusROM information.
|
||||||
|
|
||||||
-Have fun!
|
-Have fun!
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2856,7 +2856,7 @@
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td><pre>-autopause <1|0></pre></td>
|
<td><pre>-autopause <1|0></pre></td>
|
||||||
<td>Enable or disable automatic pause/continue of emulation, when
|
<td>Enable or disable automatic pause/continue of emulation when
|
||||||
Stella loses/gains focus.</td>
|
Stella loses/gains focus.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -3972,7 +3972,7 @@
|
||||||
<tr><td>Fast SuperCharger load</td><td>Skip progress loading bars for SuperCharger ROMs</td><td>-fastscbios</td></tr>
|
<tr><td>Fast SuperCharger load</td><td>Skip progress loading bars for SuperCharger ROMs</td><td>-fastscbios</td></tr>
|
||||||
<tr><td>Show UI messages</td><td>Overlay UI messages onscreen</td><td>-uimessages</td></tr>
|
<tr><td>Show UI messages</td><td>Overlay UI messages onscreen</td><td>-uimessages</td></tr>
|
||||||
<tr><td>
|
<tr><td>
|
||||||
Automatic pause</td><td>Enable or disable automatic pause/continue of emulation,
|
Automatic pause</td><td>Enable or disable automatic pause/continue of emulation
|
||||||
when Stella loses/gains focus.</td><td>-autopause
|
when Stella loses/gains focus.</td><td>-autopause
|
||||||
</td></tr>
|
</td></tr>
|
||||||
<tr><td>Confirm exiting...</td><td>Display a popup when emulation is exited</td><td>-confirmexit</td></tr>
|
<tr><td>Confirm exiting...</td><td>Display a popup when emulation is exited</td><td>-confirmexit</td></tr>
|
||||||
|
|
|
@ -1315,7 +1315,7 @@ string TIADebug::toString()
|
||||||
<< "AUDF0: "
|
<< "AUDF0: "
|
||||||
<< hexWithLabel("", int(audF0()),
|
<< hexWithLabel("", int(audF0()),
|
||||||
state.aud[0] != oldState.aud[0]) << "/"
|
state.aud[0] != oldState.aud[0]) << "/"
|
||||||
<< std::setw(11) << std::right << stringOnly(audFreq0(),
|
<< std::setw(9) << std::right << stringOnly(audFreq0(),
|
||||||
state.aud[0] != oldState.aud[0]) << " "
|
state.aud[0] != oldState.aud[0]) << " "
|
||||||
<< "AUDC0: "
|
<< "AUDC0: "
|
||||||
<< hexWithLabel("", int(audC0()),
|
<< hexWithLabel("", int(audC0()),
|
||||||
|
@ -1327,7 +1327,7 @@ string TIADebug::toString()
|
||||||
<< "AUDF1: "
|
<< "AUDF1: "
|
||||||
<< hexWithLabel("", int(audF1()),
|
<< hexWithLabel("", int(audF1()),
|
||||||
state.aud[1] != oldState.aud[1]) << "/"
|
state.aud[1] != oldState.aud[1]) << "/"
|
||||||
<< std::setw(11) << std::right << stringOnly(audFreq1(),
|
<< std::setw(9) << std::right << stringOnly(audFreq1(),
|
||||||
state.aud[1] != oldState.aud[1]) << " "
|
state.aud[1] != oldState.aud[1]) << " "
|
||||||
<< "AUDC1: "
|
<< "AUDC1: "
|
||||||
<< hexWithLabel("", int(audC1()),
|
<< hexWithLabel("", int(audC1()),
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
|
#include "EditTextWidget.hxx"
|
||||||
#include "PopUpWidget.hxx"
|
#include "PopUpWidget.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "Debugger.hxx"
|
#include "Debugger.hxx"
|
||||||
|
@ -35,8 +36,10 @@ CartridgeEnhancedWidget::CartridgeEnhancedWidget(GuiObject* boss, const GUI::Fon
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
int CartridgeEnhancedWidget::initialize()
|
int CartridgeEnhancedWidget::initialize()
|
||||||
{
|
{
|
||||||
int ypos = addBaseInformation(size(), manufacturer(), description(), descriptionLines())
|
int ypos = addBaseInformation(size(), manufacturer(), description(), descriptionLines());
|
||||||
+ myLineHeight;
|
|
||||||
|
plusROMInfo(ypos);
|
||||||
|
ypos += myLineHeight;
|
||||||
|
|
||||||
bankSelect(ypos);
|
bankSelect(ypos);
|
||||||
|
|
||||||
|
@ -137,6 +140,41 @@ string CartridgeEnhancedWidget::romDescription()
|
||||||
return info.str();
|
return info.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void CartridgeEnhancedWidget::plusROMInfo(int& ypos)
|
||||||
|
{
|
||||||
|
if(myCart.isPlusROM())
|
||||||
|
{
|
||||||
|
const int xpos = 2,
|
||||||
|
lwidth = _font.getStringWidth("Manufacturer "),
|
||||||
|
fwidth = _w - lwidth - 12;
|
||||||
|
|
||||||
|
new StaticTextWidget(_boss, _font, xpos, ypos + 1, "PlusROM:");
|
||||||
|
ypos += myLineHeight + 4;
|
||||||
|
|
||||||
|
new StaticTextWidget(_boss, _font, xpos + _fontWidth * 2, ypos + 1, "Host");
|
||||||
|
myPlusROMHostWidget = new EditTextWidget(_boss, _font, xpos + lwidth, ypos - 1, fwidth, myLineHeight);
|
||||||
|
myPlusROMHostWidget->setEditable(false);
|
||||||
|
ypos += myLineHeight + 4;
|
||||||
|
|
||||||
|
new StaticTextWidget(_boss, _font, xpos + _fontWidth * 2, ypos + 1, "Path");
|
||||||
|
myPlusROMPathWidget = new EditTextWidget(_boss, _font, xpos + lwidth, ypos - 1, fwidth, myLineHeight);
|
||||||
|
myPlusROMPathWidget->setEditable(false);
|
||||||
|
ypos += myLineHeight + 4;
|
||||||
|
|
||||||
|
new StaticTextWidget(_boss, _font, xpos + _fontWidth * 2, ypos + 1, "Send");
|
||||||
|
myPlusROMSendWidget = new EditTextWidget(_boss, _nfont, xpos + lwidth, ypos - 1, fwidth, myLineHeight);
|
||||||
|
myPlusROMSendWidget->setEditable(false);
|
||||||
|
ypos += myLineHeight + 4;
|
||||||
|
|
||||||
|
new StaticTextWidget(_boss, _font, xpos + _fontWidth * 2, ypos + 1, "Receive");
|
||||||
|
myPlusROMReceiveWidget = new EditTextWidget(_boss, _nfont, xpos + lwidth, ypos - 1, fwidth, myLineHeight);
|
||||||
|
myPlusROMReceiveWidget->setEditable(false);
|
||||||
|
ypos += myLineHeight + 4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void CartridgeEnhancedWidget::bankList(uInt16 bankCount, int seg, VariantList& items, int& width)
|
void CartridgeEnhancedWidget::bankList(uInt16 bankCount, int seg, VariantList& items, int& width)
|
||||||
{
|
{
|
||||||
|
@ -278,9 +316,28 @@ void CartridgeEnhancedWidget::saveOldState()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void CartridgeEnhancedWidget::loadConfig()
|
void CartridgeEnhancedWidget::loadConfig()
|
||||||
{
|
{
|
||||||
|
if(myCart.isPlusROM())
|
||||||
|
{
|
||||||
|
myPlusROMHostWidget->setText(myCart.myPlusROM->getHost());
|
||||||
|
myPlusROMPathWidget->setText(myCart.myPlusROM->getPath());
|
||||||
|
|
||||||
|
ostringstream buf;
|
||||||
|
ByteArray arr = myCart.myPlusROM->getSend();
|
||||||
|
|
||||||
|
for(int i = 0; i < arr.size(); ++i)
|
||||||
|
buf << Common::Base::HEX2 << int(arr[i]) << " ";
|
||||||
|
myPlusROMSendWidget->setText(buf.str());
|
||||||
|
|
||||||
|
buf.str("");
|
||||||
|
arr = myCart.myPlusROM->getReceive();
|
||||||
|
|
||||||
|
for(int i = 0; i < arr.size(); ++i)
|
||||||
|
buf << Common::Base::HEX2 << int(arr[i]) << " ";
|
||||||
|
myPlusROMReceiveWidget->setText(buf.str());
|
||||||
|
}
|
||||||
if(myBankWidgets != nullptr)
|
if(myBankWidgets != nullptr)
|
||||||
{
|
{
|
||||||
if (bankSegs() > 1)
|
if(bankSegs() > 1)
|
||||||
for(int seg = 0; seg < bankSegs(); ++seg)
|
for(int seg = 0; seg < bankSegs(); ++seg)
|
||||||
myBankWidgets[seg]->setSelectedIndex(myCart.getSegmentBank(seg),
|
myBankWidgets[seg]->setSelectedIndex(myCart.getSegmentBank(seg),
|
||||||
myCart.getSegmentBank(seg) != myOldState.banks[seg]);
|
myCart.getSegmentBank(seg) != myOldState.banks[seg]);
|
||||||
|
|
|
@ -19,6 +19,8 @@
|
||||||
#define CART_ENHANCED_WIDGET_HXX
|
#define CART_ENHANCED_WIDGET_HXX
|
||||||
|
|
||||||
class CartridgeEnhanced;
|
class CartridgeEnhanced;
|
||||||
|
class EditTextWidget;
|
||||||
|
class StringListWidget;
|
||||||
class PopUpWidget;
|
class PopUpWidget;
|
||||||
|
|
||||||
namespace GUI {
|
namespace GUI {
|
||||||
|
@ -52,6 +54,8 @@ class CartridgeEnhancedWidget : public CartDebugWidget
|
||||||
|
|
||||||
virtual string romDescription();
|
virtual string romDescription();
|
||||||
|
|
||||||
|
virtual void plusROMInfo(int& ypos);
|
||||||
|
|
||||||
virtual void bankList(uInt16 bankCount, int seg, VariantList& items, int& width);
|
virtual void bankList(uInt16 bankCount, int seg, VariantList& items, int& width);
|
||||||
|
|
||||||
virtual void bankSelect(int& ypos);
|
virtual void bankSelect(int& ypos);
|
||||||
|
@ -92,6 +96,11 @@ class CartridgeEnhancedWidget : public CartDebugWidget
|
||||||
// Distance between two hotspots
|
// Distance between two hotspots
|
||||||
int myHotspotDelta{1};
|
int myHotspotDelta{1};
|
||||||
|
|
||||||
|
EditTextWidget* myPlusROMHostWidget{nullptr};
|
||||||
|
EditTextWidget* myPlusROMPathWidget{nullptr};
|
||||||
|
EditTextWidget* myPlusROMSendWidget{nullptr};
|
||||||
|
EditTextWidget* myPlusROMReceiveWidget{nullptr};
|
||||||
|
|
||||||
std::unique_ptr<PopUpWidget* []> myBankWidgets{nullptr};
|
std::unique_ptr<PopUpWidget* []> myBankWidgets{nullptr};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,6 @@
|
||||||
#ifndef CARTRIDGE_HXX
|
#ifndef CARTRIDGE_HXX
|
||||||
#define CARTRIDGE_HXX
|
#define CARTRIDGE_HXX
|
||||||
|
|
||||||
class Cartridge;
|
|
||||||
class Properties;
|
class Properties;
|
||||||
class FilesystemNode;
|
class FilesystemNode;
|
||||||
class CartDebugWidget;
|
class CartDebugWidget;
|
||||||
|
|
|
@ -517,21 +517,30 @@ string OSystem::createConsole(const FilesystemNode& rom, const string& md5sum,
|
||||||
myFrameBuffer->showTextMessage(msg.str());
|
myFrameBuffer->showTextMessage(msg.str());
|
||||||
}
|
}
|
||||||
// Check for first PlusROM start
|
// Check for first PlusROM start
|
||||||
if(myConsole->cartridge().isPlusROM() &&
|
if(myConsole->cartridge().isPlusROM())
|
||||||
settings().getString("plusroms.fixedid") == EmptyString)
|
|
||||||
{
|
{
|
||||||
// Make sure there always is an id
|
if(settings().getString("plusroms.fixedid") == EmptyString)
|
||||||
constexpr int ID_LEN = 32;
|
{
|
||||||
const char* HEX_DIGITS = "0123456789ABCDEF";
|
// Make sure there always is an id
|
||||||
char id_chr[ID_LEN] = {0};
|
constexpr int ID_LEN = 32;
|
||||||
Random rnd;
|
const char* HEX_DIGITS = "0123456789ABCDEF";
|
||||||
|
char id_chr[ID_LEN] = { 0 };
|
||||||
|
Random rnd;
|
||||||
|
|
||||||
for(char& c: id_chr)
|
for(char& c : id_chr)
|
||||||
c = HEX_DIGITS[rnd.next() % 16];
|
c = HEX_DIGITS[rnd.next() % 16];
|
||||||
|
|
||||||
settings().setValue("plusroms.fixedid", string(id_chr, ID_LEN));
|
settings().setValue("plusroms.fixedid", string(id_chr, ID_LEN));
|
||||||
|
|
||||||
myEventHandler->changeStateByEvent(Event::PlusRomsSetupMode);
|
myEventHandler->changeStateByEvent(Event::PlusRomsSetupMode);
|
||||||
|
}
|
||||||
|
|
||||||
|
string id = settings().getString("plusroms.id");
|
||||||
|
|
||||||
|
if(id == EmptyString)
|
||||||
|
id = settings().getString("plusroms.fixedid");
|
||||||
|
|
||||||
|
Logger::info("PlusROM Nick: " + settings().getString("plusroms.nick") + ", ID: " + id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -156,6 +156,16 @@ class PlusROMRequest {
|
||||||
return myState;
|
return myState;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const Destination& getDestination() const
|
||||||
|
{
|
||||||
|
return myDestination;
|
||||||
|
}
|
||||||
|
|
||||||
|
const PlusStoreId& getPlusStoreId() const
|
||||||
|
{
|
||||||
|
return myId;
|
||||||
|
}
|
||||||
|
|
||||||
std::pair<size_t, const uInt8*> getResponse() {
|
std::pair<size_t, const uInt8*> getResponse() {
|
||||||
if (myState != State::done) throw runtime_error("invalid access to response");
|
if (myState != State::done) throw runtime_error("invalid access to response");
|
||||||
|
|
||||||
|
@ -221,7 +231,7 @@ bool PlusROM::initialize(const ByteBuffer& image, size_t size)
|
||||||
return myIsPlusROM = false; // Invalid host
|
return myIsPlusROM = false; // Invalid host
|
||||||
|
|
||||||
myHost = host;
|
myHost = host;
|
||||||
myPath = "/" + path;
|
myPath = path;
|
||||||
|
|
||||||
reset();
|
reset();
|
||||||
|
|
||||||
|
@ -398,7 +408,7 @@ void PlusROM::send()
|
||||||
{
|
{
|
||||||
const string nick = mySettings.getString("plusroms.nick");
|
const string nick = mySettings.getString("plusroms.nick");
|
||||||
auto request = make_shared<PlusROMRequest>(
|
auto request = make_shared<PlusROMRequest>(
|
||||||
PlusROMRequest::Destination(myHost, myPath),
|
PlusROMRequest::Destination(myHost, "/" + myPath),
|
||||||
PlusROMRequest::PlusStoreId(nick, id),
|
PlusROMRequest::PlusStoreId(nick, id),
|
||||||
myTxBuffer.data(),
|
myTxBuffer.data(),
|
||||||
myTxPos
|
myTxPos
|
||||||
|
@ -440,8 +450,8 @@ void PlusROM::receive()
|
||||||
#if defined(HTTP_LIB_SUPPORT)
|
#if defined(HTTP_LIB_SUPPORT)
|
||||||
auto iter = myPendingRequests.begin();
|
auto iter = myPendingRequests.begin();
|
||||||
|
|
||||||
while (iter != myPendingRequests.end()) {
|
while(iter != myPendingRequests.end()) {
|
||||||
switch ((*iter)->getState()) {
|
switch((*iter)->getState()) {
|
||||||
case PlusROMRequest::State::failed:
|
case PlusROMRequest::State::failed:
|
||||||
myMsgCallback("PlusROM data receiving failed!");
|
myMsgCallback("PlusROM data receiving failed!");
|
||||||
// Request has failed? -> remove it and start over
|
// Request has failed? -> remove it and start over
|
||||||
|
@ -456,7 +466,7 @@ void PlusROM::receive()
|
||||||
// and start over
|
// and start over
|
||||||
auto [responseSize, response] = (*iter)->getResponse();
|
auto [responseSize, response] = (*iter)->getResponse();
|
||||||
|
|
||||||
for (uInt8 i = 0; i < responseSize; i++)
|
for(uInt8 i = 0; i < responseSize; i++)
|
||||||
myRxBuffer[myRxWritePos++] = response[i];
|
myRxBuffer[myRxWritePos++] = response[i];
|
||||||
|
|
||||||
myPendingRequests.erase(iter);
|
myPendingRequests.erase(iter);
|
||||||
|
@ -470,3 +480,25 @@ void PlusROM::receive()
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
ByteArray PlusROM::getSend() const
|
||||||
|
{
|
||||||
|
ByteArray arr;
|
||||||
|
|
||||||
|
for(int i = 0; i < myTxPos; ++i)
|
||||||
|
arr.push_back(myTxBuffer[i]);
|
||||||
|
|
||||||
|
return arr;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
ByteArray PlusROM::getReceive() const
|
||||||
|
{
|
||||||
|
ByteArray arr;
|
||||||
|
|
||||||
|
for(uInt8 i = myRxReadPos; i != myRxWritePos; ++i)
|
||||||
|
arr.push_back(myRxBuffer[i]);
|
||||||
|
|
||||||
|
return arr;
|
||||||
|
}
|
||||||
|
|
|
@ -121,6 +121,33 @@ class PlusROM : public Serializable
|
||||||
*/
|
*/
|
||||||
void reset();
|
void reset();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Retrieve host.
|
||||||
|
|
||||||
|
@return The host string
|
||||||
|
*/
|
||||||
|
const string& getHost() const { return myHost; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
Retrieve path.
|
||||||
|
|
||||||
|
@return The path string
|
||||||
|
*/
|
||||||
|
const string& getPath() const { return myPath; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
Retrieve send data.
|
||||||
|
|
||||||
|
@return The send data
|
||||||
|
*/
|
||||||
|
ByteArray getSend() const;
|
||||||
|
/**
|
||||||
|
Retrieve receive data.
|
||||||
|
|
||||||
|
@return The receive data
|
||||||
|
*/
|
||||||
|
ByteArray getReceive() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Set the callback for displaying messages
|
Set the callback for displaying messages
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in New Issue