Skip to content

Commit

Permalink
DREAMWEB: Add utility function ObjPos::contains
Browse files Browse the repository at this point in the history
  • Loading branch information
wjp committed Nov 27, 2011
1 parent d9e8671 commit 3f30105
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 27 deletions.
3 changes: 3 additions & 0 deletions engines/dreamweb/structs.h
Expand Up @@ -134,6 +134,9 @@ struct ObjPos {
uint8 xMax;
uint8 yMax;
uint8 index;
bool contains(uint8 x, uint8 y) const {
return (x >= xMin) && (x < xMax) && (y >= yMin) && (y < yMax);
}
};

struct Frame {
Expand Down
30 changes: 3 additions & 27 deletions engines/dreamweb/stubs.cpp
Expand Up @@ -1064,15 +1064,7 @@ bool DreamGenContext::checkiffree(uint8 x, uint8 y) {
const ObjPos *freeList = (const ObjPos *)segRef(data.word(kBuffers)).ptr(kFreelist, 80 * sizeof(ObjPos));
for (size_t i = 0; i < 80; ++i) {
const ObjPos *objPos = freeList + 79 - i;
if (objPos->index == 0xff)
continue;
if (x < objPos->xMin)
continue;
if (x >= objPos->xMax)
continue;
if (y < objPos->yMin)
continue;
if (y >= objPos->yMax)
if (objPos->index == 0xff || !objPos->contains(x,y))
continue;
obname(objPos->index, 2);
return true;
Expand All @@ -1088,15 +1080,7 @@ bool DreamGenContext::checkifex(uint8 x, uint8 y) {
const ObjPos *exList = (const ObjPos *)segRef(data.word(kBuffers)).ptr(kExlist, 100 * sizeof(ObjPos));
for (size_t i = 0; i < 100; ++i) {
const ObjPos *objPos = exList + 99 - i;
if (objPos->index == 0xff)
continue;
if (x < objPos->xMin)
continue;
if (x >= objPos->xMax)
continue;
if (y < objPos->yMin)
continue;
if (y >= objPos->yMax)
if (objPos->index == 0xff || !objPos->contains(x,y))
continue;
obname(objPos->index, 4);
return true;
Expand Down Expand Up @@ -1793,15 +1777,7 @@ bool DreamGenContext::checkifset(uint8 x, uint8 y) {
const ObjPos *setList = (const ObjPos *)segRef(data.word(kBuffers)).ptr(kSetlist, sizeof(ObjPos) * 128);
for (size_t i = 0; i < 128; ++i) {
const ObjPos *pos = setList + 127 - i;
if (pos->index == 0xff)
continue;
if (x < pos->xMin)
continue;
if (x >= pos->xMax)
continue;
if (y < pos->yMin)
continue;
if (y >= pos->yMax)
if (pos->index == 0xff || !pos->contains(x,y))
continue;
if (! pixelcheckset(pos, x, y))
continue;
Expand Down

0 comments on commit 3f30105

Please sign in to comment.