mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
When X- or Y-flipping a selection of highlighted sectors, also handle setting
the nextwall pointers correctly; Add some 'asksave=1' and 'make old-nextwalls invalid'. git-svn-id: https://svn.eduke32.com/eduke32@2048 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
2603acd340
commit
64ead0a130
2 changed files with 43 additions and 6 deletions
|
@ -2989,6 +2989,9 @@ void overheadeditor(void)
|
||||||
|
|
||||||
for (j=startwall; j<=endwall; j++)
|
for (j=startwall; j<=endwall; j++)
|
||||||
{
|
{
|
||||||
|
// NEXTWALL tweak: keep nextsector!
|
||||||
|
wall[j].nextwall = -1;
|
||||||
|
|
||||||
//fix position of walls
|
//fix position of walls
|
||||||
if (about_x)
|
if (about_x)
|
||||||
{
|
{
|
||||||
|
@ -3062,6 +3065,16 @@ void overheadeditor(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mkonwinvalid();
|
||||||
|
|
||||||
|
// NEXTWALL tweak: finally, construct the nextwalls for the new arrangement!
|
||||||
|
for (i=0; i<highlightsectorcnt; i++)
|
||||||
|
{
|
||||||
|
for (WALLS_OF_SECTOR(i, j))
|
||||||
|
if (wall[j].nextsector >= 0)
|
||||||
|
checksectorpointer(j, i);
|
||||||
|
}
|
||||||
|
|
||||||
printmessage16("Selected sector(s) flipped");
|
printmessage16("Selected sector(s) flipped");
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
}
|
}
|
||||||
|
@ -4027,6 +4040,8 @@ end_yax: ;
|
||||||
refextcf>=0 ? "-extended " : "", refsect);
|
refextcf>=0 ? "-extended " : "", refsect);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
asksave = 1;
|
||||||
|
|
||||||
if (refextcf >= 0)
|
if (refextcf >= 0)
|
||||||
{
|
{
|
||||||
yax_update(0);
|
yax_update(0);
|
||||||
|
@ -5809,6 +5824,7 @@ check_next_sector: ;
|
||||||
#endif
|
#endif
|
||||||
printmessage16("Added inner loop to sector %d", k);
|
printmessage16("Added inner loop to sector %d", k);
|
||||||
mkonwinvalid();
|
mkonwinvalid();
|
||||||
|
asksave = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // if connected to at least one other sector
|
else // if connected to at least one other sector
|
||||||
|
|
|
@ -1644,6 +1644,7 @@ const int16_t *chsecptr_onextwall = NULL;
|
||||||
|
|
||||||
int32_t checksectorpointer(int16_t i, int16_t sectnum)
|
int32_t checksectorpointer(int16_t i, int16_t sectnum)
|
||||||
{
|
{
|
||||||
|
int32_t startsec, endsec;
|
||||||
int32_t j, k, startwall, endwall, x1, y1, x2, y2, numnewwalls=0;
|
int32_t j, k, startwall, endwall, x1, y1, x2, y2, numnewwalls=0;
|
||||||
int32_t bestnextwall=-1, bestnextsec=-1, bestwallscore=INT32_MIN;
|
int32_t bestnextwall=-1, bestnextsec=-1, bestwallscore=INT32_MIN;
|
||||||
int32_t cz[4], fz[4], tmp[2], tmpscore=0;
|
int32_t cz[4], fz[4], tmp[2], tmpscore=0;
|
||||||
|
@ -1676,6 +1677,19 @@ int32_t checksectorpointer(int16_t i, int16_t sectnum)
|
||||||
wall[k].nextwall = wall[k].nextsector = -1;
|
wall[k].nextwall = wall[k].nextsector = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((unsigned)wall[i].nextsector < (unsigned)numsectors && wall[i].nextwall < 0)
|
||||||
|
{
|
||||||
|
// if we have a nextsector but no nextwall, take this as a hint
|
||||||
|
// to search only the walls of that sector
|
||||||
|
startsec = wall[i].nextsector;
|
||||||
|
endsec = startsec+1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
startsec = 0;
|
||||||
|
endsec = numsectors;
|
||||||
|
}
|
||||||
|
|
||||||
wall[i].nextsector = wall[i].nextwall = -1;
|
wall[i].nextsector = wall[i].nextwall = -1;
|
||||||
|
|
||||||
if (chsecptr_onextwall && (k=chsecptr_onextwall[i])>=0 && wall[k].nextwall<0)
|
if (chsecptr_onextwall && (k=chsecptr_onextwall[i])>=0 && wall[k].nextwall<0)
|
||||||
|
@ -1694,7 +1708,7 @@ int32_t checksectorpointer(int16_t i, int16_t sectnum)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (j=0; j<numsectors; j++)
|
for (j=startsec; j<endsec; j++)
|
||||||
{
|
{
|
||||||
if (j == sectnum)
|
if (j == sectnum)
|
||||||
continue;
|
continue;
|
||||||
|
@ -1751,8 +1765,9 @@ int32_t checksectorpointer(int16_t i, int16_t sectnum)
|
||||||
// sectnum -2 means dry run
|
// sectnum -2 means dry run
|
||||||
if (bestnextwall >= 0 && sectnum!=-2)
|
if (bestnextwall >= 0 && sectnum!=-2)
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
// be conservative in case if score <=0 (meaning that no wall area is mutually
|
// for walls with TROR neighbors, be conservative in case if score <=0
|
||||||
// visible) -- it could be that another sector is a better candidate later on
|
// (meaning that no wall area is mutually visible) -- it could be that
|
||||||
|
// another sector is a better candidate later on
|
||||||
if ((yax_getnextwall(i, 0)<0 && yax_getnextwall(i, 1)<0) || bestwallscore>0)
|
if ((yax_getnextwall(i, 0)<0 && yax_getnextwall(i, 1)<0) || bestwallscore>0)
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
|
@ -13776,7 +13791,9 @@ void setfirstwall(int16_t sectnum, int16_t newfirstwall)
|
||||||
if (dagoalloop > 0)
|
if (dagoalloop > 0)
|
||||||
{
|
{
|
||||||
j = 0;
|
j = 0;
|
||||||
while (loopnumofsector(sectnum,j+startwall) != dagoalloop) j++;
|
while (loopnumofsector(sectnum,j+startwall) != dagoalloop)
|
||||||
|
j++;
|
||||||
|
|
||||||
for (i=0; i<danumwalls; i++)
|
for (i=0; i<danumwalls; i++)
|
||||||
{
|
{
|
||||||
k = i+j; if (k >= danumwalls) k -= danumwalls;
|
k = i+j; if (k >= danumwalls) k -= danumwalls;
|
||||||
|
@ -13787,8 +13804,10 @@ void setfirstwall(int16_t sectnum, int16_t newfirstwall)
|
||||||
wall[startwall+i].point2 -= danumwalls;
|
wall[startwall+i].point2 -= danumwalls;
|
||||||
wall[startwall+i].point2 += startwall;
|
wall[startwall+i].point2 += startwall;
|
||||||
}
|
}
|
||||||
|
|
||||||
newfirstwall += danumwalls-j;
|
newfirstwall += danumwalls-j;
|
||||||
if (newfirstwall >= startwall+danumwalls) newfirstwall -= danumwalls;
|
if (newfirstwall >= startwall+danumwalls)
|
||||||
|
newfirstwall -= danumwalls;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=0; i<numwallsofloop; i++)
|
for (i=0; i<numwallsofloop; i++)
|
||||||
|
@ -13806,7 +13825,9 @@ void setfirstwall(int16_t sectnum, int16_t newfirstwall)
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=startwall; i<endwall; i++)
|
for (i=startwall; i<endwall; i++)
|
||||||
if (wall[i].nextwall >= 0) wall[wall[i].nextwall].nextwall = i;
|
if (wall[i].nextwall >= 0)
|
||||||
|
wall[wall[i].nextwall].nextwall = i;
|
||||||
|
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
{
|
{
|
||||||
int16_t cb, fb;
|
int16_t cb, fb;
|
||||||
|
|
Loading…
Reference in a new issue