Merge branch 'momo5502:main' into main

This commit is contained in:
Liam 2023-02-17 07:18:26 +00:00 committed by GitHub
commit fa7b99f687
3 changed files with 103 additions and 9 deletions

View File

@ -3,8 +3,9 @@
#include "command.hpp" #include "command.hpp"
#include <utils/nt.hpp>
#include <utils/hook.hpp> #include <utils/hook.hpp>
#include <utils/io.hpp>
#include <utils/string.hpp>
#include <game/game.hpp> #include <game/game.hpp>
@ -12,15 +13,61 @@ namespace bots
{ {
namespace namespace
{ {
const std::vector<std::string>& get_bot_names() constexpr auto* bot_format_string = "connect \"\\invited\\1\\cg_predictItems\\1\\cl_anonymous\\0\\color\\4\\head\\default\\model\\multi\\snaps\\20\\rate\\"
"5000\\name\\%s\\clanAbbrev\\%s\\xuid\\%s\\xnaddr\\%s\\natType\\2\\protocol\\%d\\netfieldchk\\%d\\sessionmode\\%s\\qport\\%d\"";
using bot_name = std::pair<std::string, std::string>;
std::vector<bot_name> load_bots_names()
{
std::vector<bot_name> bot_names =
{
{"momo5502", "IW5x"},
{"Maurice", "IW5x" },
{"Jasmin", "<3"},
};
std::string buffer;
if (!utils::io::read_file("boiii_cfg/bots.txt", &buffer) || buffer.empty())
{
return bot_names;
}
auto data = utils::string::split(buffer, '\n');
for (auto& entry : data)
{
utils::string::replace(entry, "\r", "");
utils::string::trim(entry);
if (entry.empty())
{
continue;
}
std::string clan_abbrev;
// Check if there is a clan tag
if (const auto pos = entry.find(','); pos != std::string::npos)
{
// Only start copying over from non-null characters (otherwise it can be "<=")
if ((pos + 1) < entry.size())
{
clan_abbrev = entry.substr(pos + 1);
}
entry = entry.substr(0, pos);
}
bot_names.emplace_back(std::make_pair(entry, clan_abbrev));
}
return bot_names;
}
const std::vector<bot_name>& get_bot_names()
{ {
static const auto bot_names = [] static const auto bot_names = []
{ {
std::vector<std::string> names{ auto names = load_bots_names();
"momo5502",
"Maurice",
"Jasmin",
};
std::random_device rd; std::random_device rd;
std::mt19937 gen(rd()); std::mt19937 gen(rd());
@ -37,7 +84,26 @@ namespace bots
const auto& names = get_bot_names(); const auto& names = get_bot_names();
current = (current + 1) % names.size(); current = (current + 1) % names.size();
return names.at(current).data(); return names.at(current).first.data();
}
int format_bot_string(char* buffer, [[maybe_unused]] const char* format, const char* name, const char* xuid,
const char* xnaddr, int protocol, int netfieldchk, const char* session_mode, int qport)
{
const auto find_name = [](const std::string& needle) -> const char*
{
for (const auto& entry : get_bot_names())
{
if (entry.first == needle)
{
return entry.second.data();
}
}
return "3arc";
};
return sprintf_s(buffer, 1024, bot_format_string, name, find_name(name), xuid, xnaddr, protocol, netfieldchk, session_mode, qport);
} }
} }
@ -46,10 +112,11 @@ namespace bots
void post_unpack() override void post_unpack() override
{ {
utils::hook::jump(game::select(0x141653B70, 0x1402732E0), get_bot_name); utils::hook::jump(game::select(0x141653B70, 0x1402732E0), get_bot_name);
utils::hook::call(game::select(0x142249AF7, 0x14052E53A), format_bot_string);
if (!game::is_server()) if (!game::is_server())
{ {
utils::hook::jump(0x141654280_g, get_bot_name); utils::hook::jump(0x141654280_g, get_bot_name); // SV_ZombieNameRandom
} }
command::add("spawnBot", [](const command::params& params) command::add("spawnBot", [](const command::params& params)

View File

@ -175,6 +175,31 @@ namespace utils::string
return str; return str;
} }
std::string& ltrim(std::string& str)
{
str.erase(str.begin(), std::find_if(str.begin(), str.end(), [](const unsigned char input)
{
return !std::isspace(input);
}));
return str;
}
std::string& rtrim(std::string& str)
{
str.erase(std::find_if(str.rbegin(), str.rend(), [](const unsigned char input)
{
return !std::isspace(input);
}).base(), str.end());
return str;
}
void trim(std::string& str)
{
ltrim(rtrim(str));
}
void copy(char* dest, const size_t max_size, const char* src) void copy(char* dest, const size_t max_size, const char* src)
{ {
if (!max_size) if (!max_size)

View File

@ -95,6 +95,8 @@ namespace utils::string
std::string replace(std::string str, const std::string& from, const std::string& to); std::string replace(std::string str, const std::string& from, const std::string& to);
void trim(std::string& str);
void copy(char* dest, size_t max_size, const char* src); void copy(char* dest, size_t max_size, const char* src);
template <size_t Size> template <size_t Size>