]> git.mxchange.org Git - quix0rs-blobwars.git/blob - src/CSpawnPoint.cpp
Prevent a segmentation fault when using the -map option without specifying a map.
[quix0rs-blobwars.git] / src / CSpawnPoint.cpp
1 /*
2 Copyright (C) 2004-2011 Parallel Realities
3 Copyright (C) 2011-2015 Perpendicular Dimensions
4
5 This program is free software; you can redistribute it and/or
6 modify it under the terms of the GNU General Public License
7 as published by the Free Software Foundation; either version 2
8 of the License, or (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13
14 See the GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19
20 */
21
22 #include "headers.h"
23
24 SpawnPoint::SpawnPoint()
25 {
26         name[0] = 0;
27         active = false;
28         x = y = 0;
29
30         spawnType = spawnSubType = 0;
31
32         currentInterval = minInterval = maxInterval = 0;
33
34         next = NULL;
35 }
36
37 void SpawnPoint::reset()
38 {
39         currentInterval = 0;
40
41         requiredInterval = Math::rrand(minInterval, maxInterval);
42 }
43
44 void SpawnPoint::create(const char *name, int x, int y, int spawnType, int spawnSubType, int minInterval, int maxInterval, bool active)
45 {
46         strlcpy(this->name, name, sizeof this->name);
47         this->x = x;
48         this->y = y;
49         this->spawnType = spawnType;
50         this->spawnSubType = spawnSubType;
51         this->minInterval = minInterval * 60;
52         this->maxInterval = maxInterval * 60;
53         this->active = active;
54
55         reset();
56 }
57
58 void SpawnPoint::think()
59 {
60         if (active)
61                 Math::limitInt(&(++currentInterval), 0, maxInterval);
62 }
63
64 bool SpawnPoint::readyToSpawn()
65 {
66         if (currentInterval >= requiredInterval)
67                 return true;
68
69         return false;
70 }