From c215dc75d34d3373d9f40cf6185fc62dc5ef7c59 Mon Sep 17 00:00:00 2001 From: Steve Date: Sun, 17 Apr 2016 11:52:48 +0100 Subject: [PATCH] Jumpgate state fix. --- .../missions/india/02 - india defence #2.json | 4 +- src/battle/jumpgate.c | 37 +++++++++++-------- 2 files changed, 24 insertions(+), 17 deletions(-) diff --git a/data/missions/india/02 - india defence #2.json b/data/missions/india/02 - india defence #2.json index 711a68d..7531eaf 100644 --- a/data/missions/india/02 - india defence #2.json +++ b/data/missions/india/02 - india defence #2.json @@ -66,7 +66,7 @@ "type" : "ET_JUMPGATE", "x" : 48, "y" : 48, - "active" : 0 + "flags" : "+EF_DISABLED" } ], "spawners" : [ @@ -93,7 +93,7 @@ { "function" : "ENEMIES_KILLED 80", "lines" : [ - "MSG_BOX UNF Hopper;We're picking up a lot of chatter on the mercenaries' channels. They're not happy how things are going.", + "MSG_BOX UNF Hopper;We're picking up a lot of chatter on the mercenaries' channels. They're not happy with how things are going.", "MSG_BOX Wing Commander;Then let's concentrate on making them even more unhappy." ] }, diff --git a/src/battle/jumpgate.c b/src/battle/jumpgate.c index adc41b4..e972dff 100644 --- a/src/battle/jumpgate.c +++ b/src/battle/jumpgate.c @@ -32,8 +32,15 @@ static float portalAngle; Entity *spawnJumpgate(int side, long flags) { - Entity *jumpgate = spawnEntity(); - + Entity *jumpgate; + + if (battle.jumpgate) + { + printf("ERROR: Only one jumpgate is allowed\n"); + exit(1); + } + + jumpgate = spawnEntity(); jumpgate->type = ET_JUMPGATE; jumpgate->health = jumpgate->maxHealth = 1; jumpgate->texture = getTexture("gfx/entities/jumpgate.png"); @@ -41,6 +48,10 @@ Entity *spawnJumpgate(int side, long flags) jumpgate->draw = draw; jumpgate->side = side; jumpgate->flags = EF_NO_MT_BOX+EF_IMMORTAL+EF_AI_IGNORE; + if (flags & EF_DISABLED) + { + jumpgate->flags |= EF_DISABLED; + } addNodes(jumpgate, flags); @@ -48,6 +59,8 @@ Entity *spawnJumpgate(int side, long flags) portalAngle = 0; SDL_QueryTexture(jumpgate->texture, NULL, NULL, &jumpgate->w, &jumpgate->h); + + battle.jumpgate = jumpgate; return jumpgate; } @@ -129,28 +142,22 @@ static void think(void) self->thinkTime = 4; self->angle += 0.1; + if (self->angle >= 360) { self->angle -= 360; } - + if (jumpgateEnabled()) { handleFleeingEntities(); } - - if (!battle.jumpgate) + + portalAngle += 2; + + if (portalAngle >= 360) { - battle.jumpgate = self; - } - - if (battle.jumpgate == self) - { - portalAngle += 2; - if (portalAngle >= 360) - { - portalAngle -= 360; - } + portalAngle -= 360; } }