1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-12 10:20:32 +00:00

fixed bugs with manual celllisters

This commit is contained in:
Zeno Rogue 2018-06-28 13:35:03 +02:00
parent d11044a80a
commit cf8dffd6b8
8 changed files with 38 additions and 37 deletions

View File

@ -104,7 +104,7 @@ namespace whirlwind {
} }
} }
void moveAt(cell *c, celllister& cl) { void moveAt(cell *c, manual_celllister& cl) {
if(cl.listed(c)) return; if(cl.listed(c)) return;
calcdirs(c); calcdirs(c);
if(qdirs != 1) return; if(qdirs != 1) return;
@ -143,7 +143,7 @@ namespace whirlwind {
} }
void move() { void move() {
celllister cl(manual); manual_celllister cl;
for(int i=0; i<isize(dcal); i++) { for(int i=0; i<isize(dcal); i++) {
cell *c = dcal[i]; cell *c = dcal[i];
moveAt(c, cl); moveAt(c, cl);
@ -349,7 +349,7 @@ namespace elec {
c->wall = waMetal; */ c->wall = waMetal; */
} }
void listChargedCells(cell *c, celllister& cl, eCharge last = ecConductor) { void listChargedCells(cell *c, manual_celllister& cl, eCharge last = ecConductor) {
if(cl.listed(c)) return; if(cl.listed(c)) return;
eCharge here = getCharge(c); eCharge here = getCharge(c);
/* if(c->cpdist <= 2) { /* if(c->cpdist <= 2) {
@ -370,8 +370,10 @@ namespace elec {
void init() { void init() {
chargecells.clear(); chargecells.clear();
if(!haveelec && !afterOrb) return; if(!haveelec && !afterOrb) return;
celllister cl(manual); if(1) {
for(int i=0; i<isize(dcal); i++) listChargedCells(dcal[i], cl); manual_celllister cl;
for(int i=0; i<isize(dcal); i++) listChargedCells(dcal[i], cl);
}
charges.resize(2); charges.resize(2);
charges[0].lowlink = 0; charges[1].lowlink = 1; charges[0].lowlink = 0; charges[1].lowlink = 1;
@ -1011,7 +1013,7 @@ namespace whirlpool {
generate(wto); generate(wto);
} }
void moveAt(cell *c, celllister& cl) { void moveAt(cell *c, manual_celllister& cl) {
if(c->land != laWhirlpool) return; if(c->land != laWhirlpool) return;
if(cl.listed(c)) return; if(cl.listed(c)) return;
if(!(euclid || c->master->alt)) return; if(!(euclid || c->master->alt)) return;
@ -1038,7 +1040,7 @@ namespace whirlpool {
} }
void move() { void move() {
celllister cl(manual); manual_celllister cl;
for(int i=0; i<isize(dcal); i++) { for(int i=0; i<isize(dcal); i++) {
cell *c = dcal[i]; cell *c = dcal[i];
moveAt(c, cl); moveAt(c, cl);
@ -1793,7 +1795,7 @@ namespace heat {
vector<cell*> offscreen2; vector<cell*> offscreen2;
celllister cl(manual); manual_celllister cl;
int gr = gamerange(); int gr = gamerange();
@ -1940,7 +1942,7 @@ namespace heat {
vector<cell*> offscreen2; vector<cell*> offscreen2;
celllister cl(manual); manual_celllister cl;
vector<cell*>& allcells = currentmap->allcells(); vector<cell*>& allcells = currentmap->allcells();
@ -2837,7 +2839,7 @@ namespace prairie {
if(c2) c->mondir = neighborId(c, c2); if(c2) c->mondir = neighborId(c, c2);
} }
void moveAt(cell *c, celllister& cl) { void moveAt(cell *c, manual_celllister& cl) {
if(!cl.add(c)) return; if(!cl.add(c)) return;
vector<cell*> whirlline; vector<cell*> whirlline;
whirlline.push_back(c); whirlline.push_back(c);
@ -2888,7 +2890,7 @@ namespace prairie {
} }
void move() { void move() {
celllister cl(manual); manual_celllister cl;
for(int i=0; i<isize(dcal); i++) { for(int i=0; i<isize(dcal); i++) {
cell *c = dcal[i]; cell *c = dcal[i];
if(isriver(c)) moveAt(c, cl); if(isriver(c)) moveAt(c, cl);

View File

@ -5766,7 +5766,7 @@ void moveNormals(eMonster param) {
} }
} }
void markAmbush(cell *c, celllister& cl) { void markAmbush(cell *c, manual_celllister& cl) {
if(!cl.add(c)) return; if(!cl.add(c)) return;
forCellEx(c2, c) forCellEx(c2, c)
if(c2->cpdist < c->cpdist) if(c2->cpdist < c->cpdist)
@ -5778,7 +5778,7 @@ bool ambushed;
void checkAmbushState() { void checkAmbushState() {
if(havewhat & HF_HUNTER) { if(havewhat & HF_HUNTER) {
celllister cl(manual); manual_celllister cl;
for(cell *c: dcal) { for(cell *c: dcal) {
if(c->monst == moHunterDog) { if(c->monst == moHunterDog) {
if(c->cpdist > ambush_distance) if(c->cpdist > ambush_distance)

29
hyper.h
View File

@ -2543,12 +2543,9 @@ extern vector<hrmap*> allmaps;
// list all cells in distance at most maxdist, or until when maxcount cells are reached // list all cells in distance at most maxdist, or until when maxcount cells are reached
extern struct manual_t {} manual; struct manual_celllister {
struct celllister {
vector<cell*> lst; vector<cell*> lst;
vector<int> tmps; vector<int> tmps;
vector<int> dists;
bool listed(cell *c) { bool listed(cell *c) {
return c->listindex >= 0 && c->listindex < isize(lst) && lst[c->listindex] == c; return c->listindex >= 0 && c->listindex < isize(lst) && lst[c->listindex] == c;
@ -2557,29 +2554,31 @@ struct celllister {
bool add(cell *c) { bool add(cell *c) {
if(listed(c)) return false; if(listed(c)) return false;
tmps.push_back(c->listindex); tmps.push_back(c->listindex);
lst.push_back(c);
c->listindex = isize(lst); c->listindex = isize(lst);
lst.push_back(c);
return true; return true;
} }
void add(cell *c, int d) { ~manual_celllister() {
for(int i=0; i<isize(lst); i++) lst[i]->listindex = tmps[i];
}
};
struct celllister : manual_celllister {
vector<int> dists;
void add_at(cell *c, int d) {
if(add(c)) dists.push_back(d); if(add(c)) dists.push_back(d);
} }
~celllister() {
for(int i=0; i<isize(lst); i++) lst[i]->listindex = tmps[i];
}
celllister(manual_t) {
}
celllister(cell *orig, int maxdist, int maxcount, cell *breakon) { celllister(cell *orig, int maxdist, int maxcount, cell *breakon) {
add(orig, 0); add_at(orig, 0);
cell *last = orig; cell *last = orig;
for(int i=0; i<isize(lst); i++) { for(int i=0; i<isize(lst); i++) {
cell *c = lst[i]; cell *c = lst[i];
if(maxdist) forCellCM(c2, c) { if(maxdist) forCellCM(c2, c) {
add(c2, dists[i]+1); add_at(c2, dists[i]+1);
if(c2 == breakon) return; if(c2 == breakon) return;
} }
if(c == last) { if(c == last) {

View File

@ -60,7 +60,7 @@ bool reptilecheat = false;
#define ONEMPTY if(d == 7 && passable(c, NULL, 0) && !safety) #define ONEMPTY if(d == 7 && passable(c, NULL, 0) && !safety)
bool blizzard_no_escape1(cell *c, celllister &cl) { bool blizzard_no_escape1(cell *c, manual_celllister &cl) {
if(!cl.add(c)) return true; if(!cl.add(c)) return true;
if(c->item == itOrbSafety) if(c->item == itOrbSafety)
return false; return false;
@ -76,7 +76,7 @@ bool blizzard_no_escape1(cell *c, celllister &cl) {
} }
bool blizzard_no_escape(cell *c) { bool blizzard_no_escape(cell *c) {
celllister cl(manual); manual_celllister cl;
return blizzard_no_escape1(c, cl); return blizzard_no_escape1(c, cl);
} }

View File

@ -621,7 +621,7 @@ namespace mapeditor {
vector<pair<cellwalker, cellwalker> > spill_list; vector<pair<cellwalker, cellwalker> > spill_list;
void list_spill(cellwalker tgt, cellwalker src, celllister& cl) { void list_spill(cellwalker tgt, cellwalker src, manual_celllister& cl) {
spill_list.clear(); sval++; spill_list.clear(); sval++;
spill_list.emplace_back(tgt, src); spill_list.emplace_back(tgt, src);
int crad = 0, nextstepat = 0; int crad = 0, nextstepat = 0;
@ -668,7 +668,7 @@ namespace mapeditor {
} }
#endif #endif
void editAt(cellwalker where, celllister& cl) { void editAt(cellwalker where, manual_celllister& cl) {
if(painttype == 4 && radius) { if(painttype == 4 && radius) {
if(where.c->type != copysource.c->type) return; if(where.c->type != copysource.c->type) return;
@ -685,7 +685,7 @@ namespace mapeditor {
void allInPattern(cellwalker where) { void allInPattern(cellwalker where) {
celllister cl(manual); manual_celllister cl;
if(!patterns::whichPattern) { if(!patterns::whichPattern) {
editAt(where, cl); editAt(where, cl);
return; return;

View File

@ -242,7 +242,7 @@ int getSeepcount() {
} }
bool canReachPlayer(cell *cf, eMonster m) { bool canReachPlayer(cell *cf, eMonster m) {
celllister cl(manual); manual_celllister cl;
cl.add(cf); cl.add(cf);
for(int i=0; i<isize(cl.lst) && i < 10000; i++) { for(int i=0; i<isize(cl.lst) && i < 10000; i++) {
cell *c = cl.lst[i]; cell *c = cl.lst[i];

View File

@ -247,7 +247,7 @@ bool distanceBound(cell *c1, cell *c2, int d) {
} }
void checkFreedom(cell *cf) { void checkFreedom(cell *cf) {
celllister cl(manual); manual_celllister cl;
cl.add(cf); cl.add(cf);
for(int i=0; i<isize(cl.lst); i++) { for(int i=0; i<isize(cl.lst); i++) {
cell *c = cl.lst[i]; cell *c = cl.lst[i];

View File

@ -1011,7 +1011,7 @@ namespace peace {
clister.emplace_back(cp, cp); clister.emplace_back(cp, cp);
int id = 0; int id = 0;
celllister cl(manual); manual_celllister cl;
while(id < isize(clister)) { while(id < isize(clister)) {
cell *c = clister[id].first; cell *c = clister[id].first;
cell *fr = clister[id].second; cell *fr = clister[id].second;