1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-08 18:09:45 +01:00

Move roomchange off of Game

The purpose of this variable was to keep track of if gamelogic() called
map.gotoroom() at any point during its execution. So map.gotoroom()
always unconditionally set it to true, and then gamelogic() would check
it later.

Well, there's no need to put that in a global variable and do it like
that! It makes it less clear when you do that.

So what I've done instead is made a temporary macro wrapper around
map.gotoroom() that also sets roomchange to true. I've also made it so
any attempt to use map.gotoroom() directly results in failure (and since
then using map.gotoroom() in the wrapper macro would also fail, I've had
to make a gotoroom wrapper function around map.gotoroom() so the wrapper
macro itself doesn't fail).
This commit is contained in:
Misa 2021-04-16 23:34:54 -07:00 committed by Misa Elizabeth Kai
parent 75ed9f9631
commit 7a598f5811
5 changed files with 31 additions and 26 deletions

View file

@ -124,7 +124,6 @@ void Game::init(void)
teleport = false;
edteleportent = 0; //Added in the port!
companion = 0;
roomchange = false;
quickrestartkludge = false;

View file

@ -384,7 +384,6 @@ public:
float inertia;
int companion;
bool roomchange;
SDL_Rect teleblock;
bool activetele;
int readytotele;

View file

@ -120,9 +120,19 @@ void gamecompletelogic2(void)
}
}
static void gotoroom_wrapper(const int rx, const int ry)
{
map.gotoroom(rx, ry);
}
void gamelogic(void)
{
bool roomchange = false;
#define GOTOROOM(rx, ry) \
gotoroom_wrapper(rx, ry); \
roomchange = true
#define gotoroom Do not use map.gotoroom directly.
/* Update old lerp positions of entities */
{size_t i; for (i = 0; i < obj.entities.size(); ++i)
{
@ -1129,13 +1139,13 @@ void gamelogic(void)
if (INBOUNDS_VEC(player, obj.entities) && game.door_down > -2 && obj.entities[player].yp >= 238)
{
obj.entities[player].yp -= 240;
map.gotoroom(game.roomx, game.roomy + 1);
GOTOROOM(game.roomx, game.roomy + 1);
screen_transition = true;
}
if (INBOUNDS_VEC(player, obj.entities) && game.door_up > -2 && obj.entities[player].yp < -2)
{
obj.entities[player].yp += 240;
map.gotoroom(game.roomx, game.roomy - 1);
GOTOROOM(game.roomx, game.roomy - 1);
screen_transition = true;
}
}
@ -1147,13 +1157,13 @@ void gamelogic(void)
if (INBOUNDS_VEC(player, obj.entities) && game.door_left > -2 && obj.entities[player].xp < -14)
{
obj.entities[player].xp += 320;
map.gotoroom(game.roomx - 1, game.roomy);
GOTOROOM(game.roomx - 1, game.roomy);
screen_transition = true;
}
if (INBOUNDS_VEC(player, obj.entities) && game.door_right > -2 && obj.entities[player].xp >= 308)
{
obj.entities[player].xp -= 320;
map.gotoroom(game.roomx + 1, game.roomy);
GOTOROOM(game.roomx + 1, game.roomy);
screen_transition = true;
}
}
@ -1168,13 +1178,13 @@ void gamelogic(void)
if (INBOUNDS_VEC(player, obj.entities) && game.door_left > -2 && obj.entities[player].xp < -14)
{
obj.entities[player].xp += 320;
map.gotoroom(48, 52);
GOTOROOM(48, 52);
}
if (INBOUNDS_VEC(player, obj.entities) && game.door_right > -2 && obj.entities[player].xp >= 308)
{
obj.entities[player].xp -= 320;
obj.entities[player].yp -= (71*8);
map.gotoroom(game.roomx + 1, game.roomy+1);
GOTOROOM(game.roomx + 1, game.roomy+1);
}
}
else
@ -1187,18 +1197,18 @@ void gamelogic(void)
{
obj.entities[player].xp += 320;
obj.entities[player].yp -= (71 * 8);
map.gotoroom(50, 54);
GOTOROOM(50, 54);
}
else
{
obj.entities[player].xp += 320;
map.gotoroom(50, 53);
GOTOROOM(50, 53);
}
}
if (INBOUNDS_VEC(player, obj.entities) && game.door_right > -2 && obj.entities[player].xp >= 308)
{
obj.entities[player].xp -= 320;
map.gotoroom(52, 53);
GOTOROOM(52, 53);
}
}
}
@ -1229,12 +1239,12 @@ void gamelogic(void)
{
obj.entities[player].xp += 320;
obj.entities[player].yp -= (671 * 8);
map.gotoroom(108, 109);
GOTOROOM(108, 109);
}
if (INBOUNDS_VEC(player, obj.entities) && game.door_right > -2 && obj.entities[player].xp >= 308)
{
obj.entities[player].xp -= 320;
map.gotoroom(110, 104);
GOTOROOM(110, 104);
}
}
}
@ -1268,7 +1278,7 @@ void gamelogic(void)
{
obj.entities[i].yp = 225;
}
map.gotoroom(119, 100);
GOTOROOM(119, 100);
game.teleport = false;
}
else if (game.roomx == 119 && game.roomy == 100)
@ -1278,7 +1288,7 @@ void gamelogic(void)
{
obj.entities[i].yp = 225;
}
map.gotoroom(119, 103);
GOTOROOM(119, 103);
game.teleport = false;
}
else if (game.roomx == 119 && game.roomy == 103)
@ -1288,7 +1298,7 @@ void gamelogic(void)
{
obj.entities[i].xp = 0;
}
map.gotoroom(116, 103);
GOTOROOM(116, 103);
game.teleport = false;
}
else if (game.roomx == 116 && game.roomy == 103)
@ -1298,7 +1308,7 @@ void gamelogic(void)
{
obj.entities[i].yp = 225;
}
map.gotoroom(116, 100);
GOTOROOM(116, 100);
game.teleport = false;
}
else if (game.roomx == 116 && game.roomy == 100)
@ -1308,7 +1318,7 @@ void gamelogic(void)
{
obj.entities[i].xp = 0;
}
map.gotoroom(114, 102);
GOTOROOM(114, 102);
game.teleport = false;
}
else if (game.roomx == 114 && game.roomy == 102)
@ -1318,7 +1328,7 @@ void gamelogic(void)
{
obj.entities[i].yp = 225;
}
map.gotoroom(113, 100);
GOTOROOM(113, 100);
game.teleport = false;
}
else if (game.roomx == 116 && game.roomy == 104)
@ -1401,10 +1411,9 @@ void gamelogic(void)
}
}
if (game.roomchange)
if (roomchange)
{
//We've changed room? Let's bring our companion along!
game.roomchange = false;
int i = obj.getplayer();
if (game.companion > 0 && INBOUNDS_VEC(i, obj.entities))
{
@ -1644,4 +1653,7 @@ void gamelogic(void)
if (game.teleport_to_new_area)
script.teleport();
#undef gotoroom
#undef GOTOROOM
}

View file

@ -967,7 +967,6 @@ void mapclass::gotoroom(int rx, int ry)
//Ok, what way are we moving?
game.roomx = rx;
game.roomy = ry;
game.roomchange = true;
if (game.roomy < 10)
{
@ -994,7 +993,6 @@ void mapclass::gotoroom(int rx, int ry)
{
game.roomx = rx;
game.roomy = ry;
game.roomchange = true;
if (game.roomx < 100) game.roomx = 100 + ed.mapwidth-1;
if (game.roomy < 100) game.roomy = 100 + ed.mapheight-1;
if (game.roomx > 100 + ed.mapwidth-1) game.roomx = 100;
@ -1005,7 +1003,6 @@ void mapclass::gotoroom(int rx, int ry)
{
game.roomx = rx;
game.roomy = ry;
game.roomchange = true;
if (game.roomx < 100) game.roomx = 119;
if (game.roomy < 100) game.roomy = 119;
if (game.roomx > 119) game.roomx = 100;

View file

@ -1572,7 +1572,6 @@ void scriptclass::run(void)
game.gravitycontrol = 0;
game.teleport = false;
game.companion = 0;
game.roomchange = false;
game.teleport_to_new_area = false;
game.teleport_to_x = 0;
game.teleport_to_y = 0;
@ -3386,7 +3385,6 @@ void scriptclass::hardreset(void)
game.gravitycontrol = 0;
game.teleport = false;
game.companion = 0;
game.roomchange = false;
if (!version2_2)
{
// Ironically, resetting more variables makes the janky fadeout system in glitchrunnermode even more glitchy