mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-17 22:30:59 +00:00
Mapster32: for copy-pasting map portions without TROR, fix wrongly resetting xpanning.
This is really an artifact of overloading the sector fields for different uses. For copy-pasting TROR'd portions, the bug still persists. git-svn-id: https://svn.eduke32.com/eduke32@2963 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
4724f5d18c
commit
acdb7c139c
1 changed files with 32 additions and 10 deletions
|
@ -1559,9 +1559,9 @@ static int32_t backup_highlighted_map(mapinfofull_t *mapinfo)
|
||||||
{
|
{
|
||||||
// only back up complete bunches
|
// only back up complete bunches
|
||||||
if (numsectsofbunch[i] == yax_numsectsinbunch(i, 0)+yax_numsectsinbunch(i, 1))
|
if (numsectsofbunch[i] == yax_numsectsinbunch(i, 0)+yax_numsectsinbunch(i, 1))
|
||||||
otonbunch[i] = j++;
|
otonbunch[i] = j++; // kept bunch
|
||||||
else
|
else
|
||||||
otonbunch[i] = -1;
|
otonbunch[i] = -1; // discarded bunch
|
||||||
}
|
}
|
||||||
mapinfo->numyaxbunches = j;
|
mapinfo->numyaxbunches = j;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1623,13 +1623,30 @@ static int32_t backup_highlighted_map(mapinfofull_t *mapinfo)
|
||||||
mapinfo->sector[i].wallptr = tmpnumwalls;
|
mapinfo->sector[i].wallptr = tmpnumwalls;
|
||||||
|
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
if (mapinfo->numyaxbunches > 0)
|
if (mapinfo->numyaxbunches > 0 || numyaxbunches > 0)
|
||||||
{
|
{
|
||||||
int16_t bn[2];
|
int16_t bn[2];
|
||||||
|
|
||||||
yax_getbunches(k, &bn[0], &bn[1]);
|
yax_getbunches(k, &bn[0], &bn[1]);
|
||||||
for (j=0; j<2; j++)
|
for (j=0; j<2; j++)
|
||||||
mapinfo->bunchnum[2*i + j] = (bn[j]>=0) ? otonbunch[bn[j]] : -1;
|
{
|
||||||
|
// old bunchnum, new bunchnum
|
||||||
|
int32_t obn=bn[j], nbn=(obn>=0) ? otonbunch[obn] : -1;
|
||||||
|
|
||||||
|
if (mapinfo->numyaxbunches > 0)
|
||||||
|
mapinfo->bunchnum[2*i + j] = nbn;
|
||||||
|
|
||||||
|
if (obn >= 0 && nbn < 0)
|
||||||
|
{
|
||||||
|
// if a bunch was discarded
|
||||||
|
sectortype *const sec = &mapinfo->sector[i];
|
||||||
|
int16_t *const cs = j==YAX_CEILING ? &sec->ceilingstat : &sec->floorstat;
|
||||||
|
uint8_t *const xp = j==YAX_CEILING ? &sec->ceilingxpanning : &sec->floorxpanning;
|
||||||
|
|
||||||
|
*cs &= ~YAX_BIT;
|
||||||
|
*xp = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1707,7 +1724,7 @@ static void mapinfofull_free(mapinfofull_t *mapinfo)
|
||||||
// forreal: if 0, only test if we have enough space (same return values)
|
// forreal: if 0, only test if we have enough space (same return values)
|
||||||
static int32_t restore_highlighted_map(mapinfofull_t *mapinfo, int32_t forreal)
|
static int32_t restore_highlighted_map(mapinfofull_t *mapinfo, int32_t forreal)
|
||||||
{
|
{
|
||||||
int32_t i, j, sect, onumsectors=numsectors, newnumsectors, newnumwalls;
|
int32_t i, j, onumsectors=numsectors, newnumsectors, newnumwalls;
|
||||||
|
|
||||||
if (numsectors+mapinfo->numsectors>MAXSECTORS || numwalls+mapinfo->numwalls>MAXWALLS
|
if (numsectors+mapinfo->numsectors>MAXSECTORS || numwalls+mapinfo->numwalls>MAXWALLS
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
|
@ -1764,19 +1781,24 @@ static int32_t restore_highlighted_map(mapinfofull_t *mapinfo, int32_t forreal)
|
||||||
|
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
for (j=0; j<2; j++)
|
for (j=0; j<2; j++)
|
||||||
|
{
|
||||||
if (mapinfo->numyaxbunches > 0)
|
if (mapinfo->numyaxbunches > 0)
|
||||||
yax_setbunch(i, j, mapinfo->bunchnum[2*(i-onumsectors)+j] >= 0 ?
|
{
|
||||||
numyaxbunches + mapinfo->bunchnum[2*(i-onumsectors)+j] : -2);
|
int32_t bn = mapinfo->bunchnum[2*(i-onumsectors)+j];
|
||||||
|
yax_setbunch(i, j, bn>=0 ? numyaxbunches+bn : -2);
|
||||||
|
// -2 clears forward yax-nextwall links.
|
||||||
|
// XXX: still may wrongly reset xpanning.
|
||||||
|
}
|
||||||
else
|
else
|
||||||
yax_setbunch(i, j, -2);
|
Bassert(yax_getbunch(i, j) < 0);
|
||||||
// -2 clears forward yax-nextwall links
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// insert sprites
|
// insert sprites
|
||||||
for (i=0; i<mapinfo->numsprites; i++)
|
for (i=0; i<mapinfo->numsprites; i++)
|
||||||
{
|
{
|
||||||
sect = onumsectors+mapinfo->sprite[i].sectnum;
|
int32_t sect = onumsectors+mapinfo->sprite[i].sectnum;
|
||||||
j = insertsprite(sect, mapinfo->sprite[i].statnum);
|
j = insertsprite(sect, mapinfo->sprite[i].statnum);
|
||||||
Bmemcpy(&sprite[j], &mapinfo->sprite[i], sizeof(spritetype));
|
Bmemcpy(&sprite[j], &mapinfo->sprite[i], sizeof(spritetype));
|
||||||
sprite[j].sectnum = sect;
|
sprite[j].sectnum = sect;
|
||||||
|
|
Loading…
Reference in a new issue