mirror of
https://github.com/ZDoom/gzdoom-gles.git
synced 2025-01-31 04:20:34 +00:00
- fix the compat_pointonline flag.
This commit is contained in:
parent
7606b22d0b
commit
5da2ecda66
4 changed files with 38 additions and 23 deletions
|
@ -534,28 +534,11 @@ CVAR (Flag, sv_respawnsuper, dmflags2, DF2_RESPAWN_SUPER);
|
|||
|
||||
EXTERN_CVAR(Int, compatmode)
|
||||
|
||||
static int GetCompatibility(FLevelLocals *Level, int mask)
|
||||
{
|
||||
if (Level->info == nullptr) return mask;
|
||||
else return (mask & ~Level->info->compatmask) | (Level->info->compatflags & Level->info->compatmask);
|
||||
}
|
||||
|
||||
static int GetCompatibility2(FLevelLocals *Level, int mask)
|
||||
{
|
||||
return (Level->info == nullptr) ? mask
|
||||
: (mask & ~Level->info->compatmask2) | (Level->info->compatflags2 & Level->info->compatmask2);
|
||||
}
|
||||
|
||||
CUSTOM_CVAR (Int, compatflags, 0, CVAR_ARCHIVE|CVAR_SERVERINFO | CVAR_NOINITCALL)
|
||||
{
|
||||
for (auto Level : AllLevels())
|
||||
{
|
||||
int old = Level->i_compatflags;
|
||||
Level->i_compatflags = GetCompatibility(Level, self) | Level->ii_compatflags;
|
||||
if ((old ^ Level->i_compatflags) & COMPATF_POLYOBJ)
|
||||
{
|
||||
Level->ClearAllSubsectorLinks();
|
||||
}
|
||||
Level->ApplyCompatibility();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -563,7 +546,7 @@ CUSTOM_CVAR (Int, compatflags2, 0, CVAR_ARCHIVE|CVAR_SERVERINFO | CVAR_NOINITCAL
|
|||
{
|
||||
for (auto Level : AllLevels())
|
||||
{
|
||||
Level->i_compatflags2 = GetCompatibility2(Level, self) | Level->ii_compatflags2;
|
||||
Level->ApplyCompatibility2();
|
||||
Level->SetCompatLineOnSide(true);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -2119,8 +2119,35 @@ int FLevelLocals::GetInfighting()
|
|||
void FLevelLocals::SetCompatLineOnSide(bool state)
|
||||
{
|
||||
int on = (state && (i_compatflags2 & COMPATF2_POINTONLINE));
|
||||
if (on) for (auto l : lines) l.flags |= ML_COMPATSIDE;
|
||||
else for (auto l : lines) l.flags &= ML_COMPATSIDE;
|
||||
if (on) for (auto &l : lines) l.flags |= ML_COMPATSIDE;
|
||||
else for (auto &l : lines) l.flags &= ~ML_COMPATSIDE;
|
||||
}
|
||||
|
||||
int FLevelLocals::GetCompatibility(int mask)
|
||||
{
|
||||
if (info == nullptr) return mask;
|
||||
else return (mask & ~info->compatmask) | (info->compatflags & info->compatmask);
|
||||
}
|
||||
|
||||
int FLevelLocals::GetCompatibility2(int mask)
|
||||
{
|
||||
return (info == nullptr) ? mask
|
||||
: (mask & ~info->compatmask2) | (info->compatflags2 & info->compatmask2);
|
||||
}
|
||||
|
||||
void FLevelLocals::ApplyCompatibility()
|
||||
{
|
||||
int old = i_compatflags;
|
||||
i_compatflags = GetCompatibility(compatflags) | ii_compatflags;
|
||||
if ((old ^ i_compatflags) & COMPATF_POLYOBJ)
|
||||
{
|
||||
ClearAllSubsectorLinks();
|
||||
}
|
||||
}
|
||||
|
||||
void FLevelLocals::ApplyCompatibility2()
|
||||
{
|
||||
i_compatflags2 = GetCompatibility2(compatflags2) | ii_compatflags2;
|
||||
}
|
||||
|
||||
//==========================================================================
|
||||
|
|
|
@ -141,6 +141,11 @@ struct FLevelLocals
|
|||
int FindNode (const FStrifeDialogueNode *node);
|
||||
int GetInfighting();
|
||||
void SetCompatLineOnSide(bool state);
|
||||
int GetCompatibility(int mask);
|
||||
int GetCompatibility2(int mask);
|
||||
void ApplyCompatibility();
|
||||
void ApplyCompatibility2();
|
||||
|
||||
void Init();
|
||||
|
||||
private:
|
||||
|
|
|
@ -326,8 +326,8 @@ FName MapLoader::CheckCompatibility(MapData *map)
|
|||
}
|
||||
|
||||
// Reset i_compatflags
|
||||
compatflags.Callback();
|
||||
compatflags2.Callback();
|
||||
Level->ApplyCompatibility();
|
||||
Level->ApplyCompatibility2();
|
||||
// Set floatbob compatibility for all maps with an original Hexen MAPINFO.
|
||||
if (Level->flags2 & LEVEL2_HEXENHACK)
|
||||
{
|
||||
|
|
Loading…
Reference in a new issue