1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-25 02:04:58 +01:00

Turn ed.contents/vmult into arrays

They're always the same size, so there's no need for them to be vectors.

Also made the number of elements in ed.level/kludgewarpdir controllable
by maxwidth/maxheight.

I removed editorclass::saveconvertor() because I didn't want to convert
it to treat ed.contents like an array, because it's unused so I'd have
no way of testing it, plus it's also unused so it doesn't matter. Might
as well get rid of it.
This commit is contained in:
Misa 2020-07-03 02:54:31 -07:00 committed by Ethan Lee
parent 067fbc75f0
commit a80502bdc9
2 changed files with 10 additions and 74 deletions

View file

@ -50,21 +50,12 @@ edlevelclass::edlevelclass()
editorclass::editorclass() editorclass::editorclass()
{ {
maxwidth=20;
maxheight=20;
//We create a blank map //We create a blank map
for (int j = 0; j < 30 * maxwidth; j++) SDL_memset(contents, 0, sizeof(contents));
{
for (int i = 0; i < 40 * maxheight; i++)
{
contents.push_back(0);
}
}
for (int i = 0; i < 30 * maxheight; i++) for (size_t i = 0; i < SDL_arraysize(vmult); i++)
{ {
vmult.push_back(int(i * 40 * maxwidth)); vmult[i] = i * 40 * maxwidth;
} }
reset(); reset();
@ -1544,57 +1535,6 @@ void editorclass::findstartpoint()
} }
} }
void editorclass::saveconvertor()
{
//In the case of resizing breaking a level, this function can fix it
maxwidth=20;
maxheight=20;
int oldwidth=10, oldheight=10;
std::vector <int> tempcontents;
for (int j = 0; j < 30 * oldwidth; j++)
{
for (int i = 0; i < 40 * oldheight; i++)
{
tempcontents.push_back(contents[i+(j*40*oldwidth)]);
}
}
contents.clear();
for (int j = 0; j < 30 * maxheight; j++)
{
for (int i = 0; i < 40 * maxwidth; i++)
{
contents.push_back(0);
}
}
for (int j = 0; j < 30 * oldheight; j++)
{
for (int i = 0; i < 40 * oldwidth; i++)
{
contents[i+(j*40*oldwidth)]=tempcontents[i+(j*40*oldwidth)];
}
}
tempcontents.clear();
for (int i = 0; i < 30 * maxheight; i++)
{
vmult.push_back(int(i * 40 * maxwidth));
}
for (int j = 0; j < maxheight; j++)
{
for (int i = 0; i < maxwidth; i++)
{
level[i+(j*maxwidth)].tilecol=(i+j)%6;
}
}
contents.clear();
}
int editorclass::findtrinket(int t) int editorclass::findtrinket(int t)
{ {
int ttrinket=0; int ttrinket=0;
@ -1884,11 +1824,7 @@ bool editorclass::load(std::string& _path)
if(TextString.length()) if(TextString.length())
{ {
std::vector<std::string> values = split(TextString,','); std::vector<std::string> values = split(TextString,',');
//contents.clear(); SDL_memset(contents, 0, sizeof(contents));
for(size_t i = 0; i < contents.size(); i++)
{
contents[i] =0;
}
int x =0; int x =0;
int y =0; int y =0;
for(size_t i = 0; i < values.size(); i++) for(size_t i = 0; i < values.size(); i++)

View file

@ -128,7 +128,6 @@ class editorclass{
void getDirectoryData(); void getDirectoryData();
bool getLevelMetaData(std::string& filename, LevelMetaData& _data ); bool getLevelMetaData(std::string& filename, LevelMetaData& _data );
void saveconvertor();
void reset(); void reset();
void getlin(const enum textmode mode, const std::string& prompt, std::string* ptr); void getlin(const enum textmode mode, const std::string& prompt, std::string* ptr);
const int* loadlevel(int rxi, int ryi); const int* loadlevel(int rxi, int ryi);
@ -189,12 +188,14 @@ class editorclass{
int getwarpbackground(int rx, int ry); int getwarpbackground(int rx, int ry);
std::vector<std::string> getLevelDirFileNames( ); std::vector<std::string> getLevelDirFileNames( );
std::vector <int> contents; static const int maxwidth = 20, maxheight = 20; //Special; the physical max the engine allows
std::vector <int> vmult; static const int numrooms = maxwidth * maxheight;
int contents[40 * 30 * numrooms];
int vmult[30 * maxheight];
int numtrinkets(); int numtrinkets();
int numcrewmates(); int numcrewmates();
edlevelclass level[400]; //Maxwidth*maxheight edlevelclass level[numrooms]; //Maxwidth*maxheight
int kludgewarpdir[400]; //Also maxwidth*maxheight int kludgewarpdir[numrooms]; //Also maxwidth*maxheight
int notedelay; int notedelay;
int oldnotedelay; int oldnotedelay;
@ -236,7 +237,6 @@ class editorclass{
int levmusic; int levmusic;
int mapwidth, mapheight; //Actual width and height of stage int mapwidth, mapheight; //Actual width and height of stage
int maxwidth, maxheight; //Special; the physical max the engine allows
int version; int version;