Skip to content

Commit

Permalink
HLTV: Some fixes director part and small refactoring.
Browse files Browse the repository at this point in the history
  • Loading branch information
s1lentq committed May 13, 2017
1 parent 92b6fd6 commit ebfdd70
Show file tree
Hide file tree
Showing 13 changed files with 292 additions and 53 deletions.
43 changes: 24 additions & 19 deletions rehlds/HLTV/Core/src/BSPModel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -410,35 +410,40 @@ bool BSPModel::InPVS(vec_t *point)
return false;
}

void BSPModel::Free(void *ptr)
{
if (ptr) {
Mem_Free(ptr);
}
}

void BSPModel::Clear()
{
#define FREE_FIELD(field) if (field) { Mem_Free(field); }
FREE_FIELD(m_model.leafs);
FREE_FIELD(m_model.nodes);
FREE_FIELD(m_model.planes);
FREE_FIELD(m_model.visdata);
FREE_FIELD(m_model.vertexes);
FREE_FIELD(m_model.entities);
FREE_FIELD(m_model.edges);
FREE_FIELD(m_model.lightdata);
FREE_FIELD(m_model.surfedges);
FREE_FIELD(m_model.surfaces);
FREE_FIELD(m_model.marksurfaces);
FREE_FIELD(m_model.clipnodes);
FREE_FIELD(m_model.hulls[0].clipnodes);
FREE_FIELD(m_model.texinfo);
Free(m_model.leafs);
Free(m_model.nodes);
Free(m_model.planes);
Free(m_model.visdata);
Free(m_model.vertexes);
Free(m_model.entities);
Free(m_model.edges);
Free(m_model.lightdata);
Free(m_model.surfedges);
Free(m_model.surfaces);
Free(m_model.marksurfaces);
Free(m_model.clipnodes);
Free(m_model.hulls[0].clipnodes);
Free(m_model.texinfo);

if (m_model.textures)
{
for (int i = 0; i < m_model.numtextures; ++i) {
FREE_FIELD(m_model.textures[i]);
Free(m_model.textures[i]);
}

FREE_FIELD(m_model.textures);
Free(m_model.textures);
}

FREE_FIELD(m_wadpath);
#undef FREE_FIELD
Free(m_wadpath);

memset(&m_model, 0, sizeof(m_model));

Expand Down
1 change: 1 addition & 0 deletions rehlds/HLTV/Core/src/BSPModel.h
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,7 @@ class BSPModel: public IBSPModel {
void DecompressPVS(unsigned char *in, unsigned char *decompressed, int byteCount);
unsigned char *DecompressVis(unsigned char *in);
void SetParent(mnode_t *node, mnode_t *parent);
void Free(void *ptr);

protected:
model_t m_model;
Expand Down
2 changes: 1 addition & 1 deletion rehlds/HLTV/Core/src/World.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1393,7 +1393,7 @@ char *World::GetStatusLine()
m_LevelName,
COM_FormatTime(m_WorldTime),
GetNumPlayers(),
(float)m_CacheHits / (float)(m_CacheHits + m_CacheFaults),
m_CacheHits / float(m_CacheHits + m_CacheFaults),
GetBufferedGameTime());
}
else
Expand Down
18 changes: 10 additions & 8 deletions rehlds/HLTV/Director/src/Director.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -161,7 +161,7 @@ void Director::NewGame(IWorld *world, IProxy *proxy)
m_World = world;
m_Proxy = proxy;

world->RegisterListener(this);
m_World->RegisterListener(this);
m_WorldModel = m_World->GetWorldModel();

memset(m_history, 0, sizeof(*m_history) * m_historyLength);
Expand Down Expand Up @@ -203,7 +203,7 @@ void Director::AnalyseFrame(frame_t *frame)
return;
}

if (m_currentTime)
if (!m_currentTime)
{
m_nextCutTime = frame->time;
m_nextCutSeqnr = seqnr;
Expand All @@ -224,7 +224,7 @@ void Director::AnalyseFrame(frame_t *frame)
continue;
}

playerData_t *player = &now->players[i];
playerData_t *player = &now->players[index];
player->active = (ent->solid != SOLID_NOT);
if (player->active)
{
Expand Down Expand Up @@ -477,7 +477,7 @@ float Director::AddBestMODCut()

cmd = new DirectorCmd;
cmd->SetTimeScaleData(1.0);
cmd->SetTime(timepoint->time + 1.5f);
cmd->SetTime(timepoint->time + trailTime);
m_Commands.Add(cmd, cmd->GetTime());
}

Expand Down Expand Up @@ -642,7 +642,7 @@ void Director::ExecuteDirectorCommands()

if (timescale < 1.0)
{
vec3_t pos = { 0.02f, 0.85f, 0.f };
vec3_t pos = { 0.02f, 0.75f, 0.f };

DirectorCmd slowmo;
slowmo.SetMessageData(0, COM_PackRGBA(255, 160, 0, 255), pos, 0.3f, 0.1f, 2, 0, "Slow Motion");
Expand Down Expand Up @@ -685,12 +685,14 @@ void Director::CMD_SlowMotion(char *cmdLine)

Director::worldHistory_t *Director::FindBestEvent()
{
const int MAX_BEST_EVENT = 4;

int i;
int nseqMod = m_nextCutSeqnr % m_historyLength;
int bestEvent[] = { 0, 0, 0, 0 };
int bestEventPrio[] = { 0, 0, 0, 0 };
int bestEvent[MAX_BEST_EVENT] = { 0, 0, 0, 0 };
int bestEventPrio[MAX_BEST_EVENT] = { 0, 0, 0, 0 };

for (i = 0; i < 4; i++)
for (i = 0; i < MAX_BEST_EVENT; i++)
{
bestEventPrio[i] = 0;
bestEvent[i] = 0;
Expand Down
4 changes: 2 additions & 2 deletions rehlds/HLTV/Director/src/Director.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,9 +49,9 @@ class Director: public IDirector, public BaseSystemModule {
virtual void ShutDown();

virtual void NewGame(IWorld *world, IProxy *proxy);
virtual int AddCommand(DirectorCmd *cmd);
virtual void WriteCommands(BitBuffer *stream, float startTime, float endTime);
virtual char *GetModName();
virtual void WriteCommands(BitBuffer *stream, float startTime, float endTime);
virtual int AddCommand(DirectorCmd *cmd);
virtual bool RemoveCommand(int index);
virtual DirectorCmd *GetLastCommand();
virtual IObjectContainer *GetCommands();
Expand Down
1 change: 1 addition & 0 deletions rehlds/HLTV/Proxy/msvc/Proxy.vcxproj
Original file line number Diff line number Diff line change
Expand Up @@ -231,6 +231,7 @@
<ClInclude Include="..\..\common\NetAddress.h" />
<ClInclude Include="..\..\common\net_internal.h" />
<ClInclude Include="..\..\common\random.h" />
<ClInclude Include="..\..\Director\src\Director.h" />
<ClInclude Include="..\src\DemoClient.h" />
<ClInclude Include="..\src\FakeClient.h" />
<ClInclude Include="..\src\Master.h" />
Expand Down
3 changes: 3 additions & 0 deletions rehlds/HLTV/Proxy/msvc/Proxy.vcxproj.filters
Original file line number Diff line number Diff line change
Expand Up @@ -191,5 +191,8 @@
<ClInclude Include="..\..\..\engine\mem.h">
<Filter>engine</Filter>
</ClInclude>
<ClInclude Include="..\..\Director\src\Director.h">
<Filter>src</Filter>
</ClInclude>
</ItemGroup>
</Project>
9 changes: 5 additions & 4 deletions rehlds/HLTV/Proxy/src/DemoClient.h
Original file line number Diff line number Diff line change
Expand Up @@ -40,18 +40,19 @@ class DemoClient: public IClient, public BaseSystemModule {
char *GetStatusLine();
char *GetType();
void ShutDown();

bool Connect(INetSocket *socket = nullptr, NetAddress *adr = nullptr, char *userinfo = "");
void Send(unsigned char *data, int length, bool isReliable);
void Disconnect(const char *reason);
void Reconnect();
void SetWorld(IWorld *world);
bool IsHearingVoices();
bool HasChatEnabled();
NetAddress *GetAddress();
int GetClientType();
char *GetClientName();
InfoString *GetUserInfo();
NetAddress *GetAddress();
bool IsActive();
void Send(unsigned char *data, int length, bool isReliable);
bool IsHearingVoices();
bool HasChatEnabled();

void SetProxy(IProxy *proxy);
void SetFileName(char *fileName);
Expand Down
10 changes: 5 additions & 5 deletions rehlds/HLTV/Proxy/src/Proxy.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -470,7 +470,7 @@ void Proxy::ReplyConnect(NetAddress *to, int protocol, int challenge, char *prot
if (type == TYPE_CLIENT && m_DispatchMode != DISPATCH_OFF)
{
float ratio = m_Status.GetBestRelayProxy(&relayProxy);
float myRatio = (float)(m_Clients.CountElements() / m_MaxClients) * 1.25f;
float myRatio = float(m_Clients.CountElements()) / float(m_MaxClients) * 1.25f;
if (myRatio > 1) {
myRatio = 1;
}
Expand Down Expand Up @@ -740,7 +740,7 @@ bool Proxy::WriteSignonData(int type, BitBuffer *stream)
stream->WriteString(COM_VarArgs("%s\n", m_SignonCommands));
}

float ex_interp = (float)(1 / GetMaxUpdateRate()) + 0.05f;
float ex_interp = (1.0f / GetMaxUpdateRate()) + 0.05f;
stream->WriteByte(svc_stufftext);
stream->WriteString(COM_VarArgs("ex_interp %.2f\n", ex_interp));

Expand Down Expand Up @@ -1811,7 +1811,7 @@ bool Proxy::CheckDirectorModule()
m_Director = dynamic_cast<IDirector *>(m_System->GetModule(DIRECTOR_INTERFACE_VERSION, szAbsoluteLibFilename, "director"));
if (m_Director)
{
m_System->Printf("Using extern director module (%s).\n", szAbsoluteLibFilename);
m_System->DPrintf("Using extern director module (%s).\n", szAbsoluteLibFilename);
return true;
}

Expand Down Expand Up @@ -2363,7 +2363,7 @@ double Proxy::GetProxyTime()
void Proxy::IncreaseCheering(int votes)
{
m_CheeringPlayers += votes;
float fraction = (float)(m_CheeringPlayers / m_Clients.CountElements());
float fraction = float(m_CheeringPlayers) / float(m_Clients.CountElements());
if (fraction > 1) {
fraction = 1;
}
Expand Down Expand Up @@ -2496,7 +2496,7 @@ void Proxy::SetClientTime(double time, bool relative)
void Proxy::SetClientTimeScale(float scale)
{
BitBuffer buf(32);
m_ClientTimeScale = clamp(scale, 4.0f, 0.5f);
m_ClientTimeScale = clamp(scale, 0.5f, 4.0f);

buf.WriteByte(svc_timescale);
buf.WriteFloat(m_ClientTimeScale);
Expand Down
2 changes: 1 addition & 1 deletion rehlds/HLTV/Proxy/src/ProxyClient.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ class IBaseSystem;

class ProxyClient: public BaseClient {
public:
ProxyClient(IProxy *proxy);
ProxyClient(IProxy *proxy = nullptr);
virtual ~ProxyClient() {}

bool Init(IBaseSystem *system, int serial, char *name);
Expand Down
8 changes: 6 additions & 2 deletions rehlds/HLTV/Proxy/src/Status.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -254,7 +254,11 @@ void Status::ParseStatusReport(NetAddress *from, BitBuffer *stream)
proxy->time = float(m_SystemTime);
proxy->isPrivate = isPrivate;

float ratio = (slots > 0 && !isPrivate) ? float(spectators / slots) : 1;
float ratio = 1;
if (slots > 0 && !isPrivate) {
ratio = float(spectators) / float(slots);
}

m_Proxies.ChangeKey(proxy, ratio);
}

Expand Down Expand Up @@ -313,7 +317,7 @@ float Status::GetBestRelayProxy(NetAddress *addr)
{
if (proxy->slots > 0 && proxy->slots >= proxy->spectators && !proxy->isPrivate)
{
float ratio = float(++proxy->spectators / proxy->slots);
float ratio = float(++proxy->spectators) / float(proxy->slots);

m_Proxies.ChangeKey(proxy, ratio);
addr->FromNetAddress(&proxy->address);
Expand Down
2 changes: 1 addition & 1 deletion rehlds/HLTV/Proxy/src/Status.h
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,8 @@ class Status: public BaseSystemModule {
virtual ~Status() {}

bool Init(IBaseSystem *system, int serial, char *name);
void ExecuteCommand(int commandID, char *commandLine);
void RunFrame(double time);
void ExecuteCommand(int commandID, char *commandLine);
char *GetStatusLine();
char *GetType();
void ShutDown();
Expand Down
Loading

0 comments on commit ebfdd70

Please sign in to comment.