Revert some changes to MovieRecord class. savestate vector is de-pointered & public again as well.

This commit is contained in:
adelikat 2010-05-15 04:08:16 +00:00
parent 2cd959fd84
commit 1415fb402c
3 changed files with 19 additions and 35 deletions

View File

@ -105,11 +105,11 @@ static LONG CustomDraw(NMLVCUSTOMDRAW* msg)
SelectObject(msg->nmcd.hdc,debugSystem->hFixedFont); SelectObject(msg->nmcd.hdc,debugSystem->hFixedFont);
if((msg->iSubItem-2)/8==0) if((msg->iSubItem-2)/8==0)
if((int)msg->nmcd.dwItemSpec < currMovieData.greenZoneCount && if((int)msg->nmcd.dwItemSpec < currMovieData.greenZoneCount &&
!currMovieData.records[msg->nmcd.dwItemSpec].GetSavestate().empty()) !currMovieData.records[msg->nmcd.dwItemSpec].savestate.empty())
msg->clrTextBk = RGB(192,255,192); msg->clrTextBk = RGB(192,255,192);
else {} else {}
else if((int)msg->nmcd.dwItemSpec < currMovieData.greenZoneCount && else if((int)msg->nmcd.dwItemSpec < currMovieData.greenZoneCount &&
!currMovieData.records[msg->nmcd.dwItemSpec].GetSavestate().empty()) !currMovieData.records[msg->nmcd.dwItemSpec].savestate.empty())
msg->clrTextBk = RGB(144,192,144); msg->clrTextBk = RGB(144,192,144);
else msg->clrTextBk = RGB(192,192,192); else msg->clrTextBk = RGB(192,192,192);
return CDRF_DODEFAULT; return CDRF_DODEFAULT;
@ -233,7 +233,7 @@ void LockGreenZone(int newstart)
{ {
for (int i=1; i<newstart; ++i) for (int i=1; i<newstart; ++i)
{ {
currMovieData.records[i].GetSavestate().clear(); currMovieData.records[i].savestate.clear();
} }
} }
@ -268,9 +268,8 @@ bool JumpToFrame(int index)
} }
if (static_cast<unsigned int>(index)<currMovieData.records.size() && if (static_cast<unsigned int>(index)<currMovieData.records.size() &&
!currMovieData.records[index].GetSavestate().empty() && !currMovieData.records[index].savestate.empty() &&
MovieData::loadSavestateFrom(&currMovieData.records[index].GetSavestate())) MovieData::loadSavestateFrom(&currMovieData.records[index].savestate))
//MovieData::loadSavestateFrom(&currMovieData.records[index].savestate))
{ {
currFrameCounter = index; currFrameCounter = index;
return true; return true;
@ -288,8 +287,8 @@ bool JumpToFrame(int index)
/* Search for an earlier frame, and try warping to the current. */ /* Search for an earlier frame, and try warping to the current. */
for (; i>0; --i) for (; i>0; --i)
{ {
if (!currMovieData.records[i].GetSavestate().empty() && if (!currMovieData.records[i].savestate.empty() &&
MovieData::loadSavestateFrom(&currMovieData.records[i].GetSavestate())) MovieData::loadSavestateFrom(&currMovieData.records[i].savestate))
{ {
currFrameCounter=i; currFrameCounter=i;
turbo=i+60<index; // turbo unless close turbo=i+60<index; // turbo unless close
@ -300,7 +299,7 @@ bool JumpToFrame(int index)
poweron(true); poweron(true);
currFrameCounter=0; currFrameCounter=0;
MovieData::dumpSavestateTo(&currMovieData.records[0].GetSavestate(),0); MovieData::dumpSavestateTo(&currMovieData.records[0].savestate,0);
turbo = index>60; turbo = index>60;
pauseframe=index+1; pauseframe=index+1;
} }
@ -310,7 +309,7 @@ bool JumpToFrame(int index)
{ {
poweron(false); poweron(false);
currFrameCounter=0; currFrameCounter=0;
MovieData::dumpSavestateTo(&currMovieData.records[0].GetSavestate(),0); MovieData::dumpSavestateTo(&currMovieData.records[0].savestate,0);
return true; return true;
} }

View File

@ -131,7 +131,7 @@ void MovieData::TryDumpIncremental()
{ {
if (turbo && pauseframe-256>currFrameCounter && ((currFrameCounter-pauseframe)&0xff)) if (turbo && pauseframe-256>currFrameCounter && ((currFrameCounter-pauseframe)&0xff))
return; return;
MovieData::dumpSavestateTo(&currMovieData.records[currFrameCounter].GetSavestate(),Z_DEFAULT_COMPRESSION); MovieData::dumpSavestateTo(&currMovieData.records[currFrameCounter].savestate,Z_DEFAULT_COMPRESSION);
} }
if(currFrameCounter == currMovieData.greenZoneCount) if(currFrameCounter == currMovieData.greenZoneCount)
{ {
@ -140,15 +140,15 @@ void MovieData::TryDumpIncremental()
currMovieData.insertEmpty(-1,1); currMovieData.insertEmpty(-1,1);
} }
MovieData::dumpSavestateTo(&currMovieData.records[currFrameCounter].GetSavestate(),Z_DEFAULT_COMPRESSION); MovieData::dumpSavestateTo(&currMovieData.records[currFrameCounter].savestate,Z_DEFAULT_COMPRESSION);
currMovieData.greenZoneCount++; currMovieData.greenZoneCount++;
} else if (currFrameCounter < currMovieData.greenZoneCount || !movie_readonly) } else if (currFrameCounter < currMovieData.greenZoneCount || !movie_readonly)
{ {
MovieData::dumpSavestateTo(&currMovieData.records[currFrameCounter].GetSavestate(),Z_DEFAULT_COMPRESSION); MovieData::dumpSavestateTo(&currMovieData.records[currFrameCounter].savestate,Z_DEFAULT_COMPRESSION);
} else if (currFrameCounter > currMovieData.greenZoneCount && static_cast<unsigned int>(currMovieData.greenZoneCount)<currMovieData.records.size()) } else if (currFrameCounter > currMovieData.greenZoneCount && static_cast<unsigned int>(currMovieData.greenZoneCount)<currMovieData.records.size())
{ {
/* May be required in some malformed TAS projects. */ /* May be required in some malformed TAS projects. */
MovieData::dumpSavestateTo(&currMovieData.records[currFrameCounter].GetSavestate(),Z_DEFAULT_COMPRESSION); MovieData::dumpSavestateTo(&currMovieData.records[currFrameCounter].savestate,Z_DEFAULT_COMPRESSION);
currMovieData.greenZoneCount= currFrameCounter+1; currMovieData.greenZoneCount= currFrameCounter+1;
} }
} }
@ -174,14 +174,6 @@ MovieRecord::MovieRecord()
zappers[1].x = 0; zappers[1].x = 0;
zappers[1].y = 0; zappers[1].y = 0;
zappers[1].zaphit = 0; zappers[1].zaphit = 0;
savestate = NULL;
}
MovieRecord::~MovieRecord()
{
if (savestate != NULL)
delete savestate;
} }
void MovieRecord::clear() void MovieRecord::clear()
@ -529,14 +521,14 @@ int MovieData::dumpGreenzone(std::ostream *os, bool binary)
int frame, size; int frame, size;
for (int i=0; i<(int)records.size(); ++i) for (int i=0; i<(int)records.size(); ++i)
{ {
if (records[i].GetSavestate().empty()) if (records[i].savestate.empty())
continue; continue;
frame=i; frame=i;
size=records[i].GetSavestate().size(); size=records[i].savestate.size();
write32le(frame, os); write32le(frame, os);
write32le(size, os); write32le(size, os);
os->write(&records[i].GetSavestate()[0], size); os->write(&records[i].savestate[0], size);
} }
frame=-1; frame=-1;
size=currMovieData.greenZoneCount; size=currMovieData.greenZoneCount;

View File

@ -97,7 +97,6 @@ class MovieRecord
public: public:
MovieRecord(); MovieRecord();
~MovieRecord();
ValueArray<uint8,4> joysticks; ValueArray<uint8,4> joysticks;
struct { struct {
@ -143,6 +142,9 @@ public:
bool Compare(MovieRecord& compareRec); bool Compare(MovieRecord& compareRec);
void clear(); void clear();
//a waste of memory in lots of cases.. maybe make it a pointer later?
std::vector<char> savestate;
void parse(MovieData* md, std::istream* is); void parse(MovieData* md, std::istream* is);
bool parseBinary(MovieData* md, std::istream* is); bool parseBinary(MovieData* md, std::istream* is);
void dump(MovieData* md, std::ostream* os, int index); void dump(MovieData* md, std::ostream* os, int index);
@ -152,16 +154,7 @@ public:
static const char mnemonics[8]; static const char mnemonics[8];
std::vector<char>& GetSavestate()
{
if (savestate == NULL)
savestate = new std::vector<char>;
return *savestate;
}
private: private:
//a waste of memory in lots of cases.. maybe make it a pointer later?
std::vector<char> *savestate;
int mask(int bit) { return 1<<bit; } int mask(int bit) { return 1<<bit; }
}; };