-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathDebugCommands.cpp
90 lines (83 loc) · 2.73 KB
/
DebugCommands.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
#include <stdafx.h>
#include "IConVarBase.h"
#include "Util.h"
#include "TF2/Entity/EntityProvider.h"
#include "TF2/Entity/CTFFlag.h"
#include "TF2/Entity/Player.h"
#include "TF2/Entity/EntityDataProvider.h"
#include <metamod/ISmmAPI.h>
#include <hlsdk/public/edict.h>
#include <hlsdk/public/server_class.h>
#include <fstream>
extern IVEngineServer* Engine;
extern IServerGameDLL* Server;
CON_COMMAND(pongbot_debug_dumpoffsets, "Dumps all offsets to addons/pongbot/offsets_dump.txt")
{
std::ofstream file("tf/addons/pongbot/offsets_dump.txt");
ServerClass* serverClass = Server->GetAllServerClasses();
while (serverClass)
{
SendTable* sendTable = serverClass->m_pTable;
for (int i = 0; i < sendTable->GetNumProps(); i++)
{
SendProp* sendProp = sendTable->GetProp(i);
file << serverClass->GetName() << "::" << sendProp->GetName() << " = " << sendProp->GetOffset() << std::endl;
}
serverClass = serverClass->m_pNext;
}
Util::Log("Took a dump successfully!");
file.close();
}
CON_COMMAND(pongbot_debug_getdata, "Outputs specified entity data")
{
const char* data = args.Arg(1);
if (strcmp(data, "") == 0)
{
Util::Log("FLAG_OWNER | FLAG_STATUS | PLAYER_CURRENTWEAPON | PLAYER_HEALTH");
}
else
{
if (strcmp(data, "FLAG_OWNER") == 0)
{
std::vector<Entity> itemFlags = _EntityProvider->SearchEntitiesByClassname("item_teamflag");
for (unsigned int i = 0; i < itemFlags.size(); i++)
{
Util::Log("Flag %d: %d", i, CTFFlag(itemFlags[i]).GetOwner());
}
}
else if (strcmp(data, "FLAG_STATUS") == 0)
{
std::vector<Entity> itemFlags = _EntityProvider->SearchEntitiesByClassname("item_teamflag");
for (unsigned int i = 0; i < itemFlags.size(); i++)
{
Util::Log("Flag %d: %d", i, CTFFlag(itemFlags[i]).GetStatus());
}
}
else if (strcmp(data, "PLAYER_CURRENTWEAPON") == 0)
{
std::vector<Player> players = Util::GetAllPlayers();
for (unsigned int i = 0; i < players.size(); i++)
{
Util::Log("Player %d: %d", i, _EntityDataProvider->GetDataFromEntity<int>(players[i], DATA_PLAYER_CURRENTWEAPON));
}
}
else if (strcmp(data, "PLAYER_HEALTH") == 0)
{
std::vector<Player> players = Util::GetAllPlayers();
for (unsigned int i = 0; i < players.size(); i++)
{
Util::Log("Player %d: %f", i, players[i].GetHealth());
}
}
}
}
CON_COMMAND(pongbot_debug_dumpentitynames, "Dumps names of all currently existing entities on the map to addons/pongbot/entity_names_dump.txt")
{
std::ofstream file("tf/addons/pongbot/entity_names_dump.txt");
for (Entity entity : _EntityProvider->GetEntities())
{
file << entity.GetEdict()->GetClassName() << std::endl;
}
Util::Log("Dumped all entity names!");
file.close();
}