mirror of
https://github.com/ddnet/ddnet.git
synced 2024-11-13 11:38:19 +00:00
fa4bcd5ec0
This makes the "black console window" less important on Windows (or anywhere else, for that matter), lets you see logs from other threads in the f1 console, and removes the distinction between `IConsole::Print` and `dbg_msg`.
125 lines
3.4 KiB
C++
125 lines
3.4 KiB
C++
/* (c) Magnus Auvinen. See licence.txt in the root of the distribution for more information. */
|
|
/* If you are missing that file, acquire a complete release at teeworlds.com. */
|
|
|
|
#include <base/logger.h>
|
|
#include <base/system.h>
|
|
|
|
#include <engine/console.h>
|
|
#include <engine/engine.h>
|
|
#include <engine/shared/config.h>
|
|
#include <engine/shared/network.h>
|
|
#include <engine/storage.h>
|
|
|
|
#include <engine/shared/assertion_logger.h>
|
|
|
|
CHostLookup::CHostLookup() = default;
|
|
|
|
CHostLookup::CHostLookup(const char *pHostname, int Nettype)
|
|
{
|
|
str_copy(m_aHostname, pHostname, sizeof(m_aHostname));
|
|
m_Nettype = Nettype;
|
|
}
|
|
|
|
void CHostLookup::Run()
|
|
{
|
|
m_Result = net_host_lookup(m_aHostname, &m_Addr, m_Nettype);
|
|
}
|
|
|
|
class CEngine : public IEngine
|
|
{
|
|
public:
|
|
IConsole *m_pConsole;
|
|
IStorage *m_pStorage;
|
|
bool m_Logging;
|
|
|
|
std::shared_ptr<CFutureLogger> m_pFutureLogger;
|
|
|
|
char m_aAppName[256];
|
|
|
|
static void Con_DbgLognetwork(IConsole::IResult *pResult, void *pUserData)
|
|
{
|
|
CEngine *pEngine = static_cast<CEngine *>(pUserData);
|
|
|
|
if(pEngine->m_Logging)
|
|
{
|
|
CNetBase::CloseLog();
|
|
pEngine->m_Logging = false;
|
|
}
|
|
else
|
|
{
|
|
char aBuf[32];
|
|
str_timestamp(aBuf, sizeof(aBuf));
|
|
char aFilenameSent[IO_MAX_PATH_LENGTH], aFilenameRecv[IO_MAX_PATH_LENGTH];
|
|
str_format(aFilenameSent, sizeof(aFilenameSent), "dumps/network_sent_%s.txt", aBuf);
|
|
str_format(aFilenameRecv, sizeof(aFilenameRecv), "dumps/network_recv_%s.txt", aBuf);
|
|
CNetBase::OpenLog(pEngine->m_pStorage->OpenFile(aFilenameSent, IOFLAG_WRITE, IStorage::TYPE_SAVE),
|
|
pEngine->m_pStorage->OpenFile(aFilenameRecv, IOFLAG_WRITE, IStorage::TYPE_SAVE));
|
|
pEngine->m_Logging = true;
|
|
}
|
|
}
|
|
|
|
CEngine(bool Test, const char *pAppname, std::shared_ptr<CFutureLogger> pFutureLogger, int Jobs) :
|
|
m_pFutureLogger(std::move(pFutureLogger))
|
|
{
|
|
str_copy(m_aAppName, pAppname, std::size(m_aAppName));
|
|
if(!Test)
|
|
{
|
|
//
|
|
dbg_msg("engine", "running on %s-%s-%s", CONF_FAMILY_STRING, CONF_PLATFORM_STRING, CONF_ARCH_STRING);
|
|
#ifdef CONF_ARCH_ENDIAN_LITTLE
|
|
dbg_msg("engine", "arch is little endian");
|
|
#elif defined(CONF_ARCH_ENDIAN_BIG)
|
|
dbg_msg("engine", "arch is big endian");
|
|
#else
|
|
dbg_msg("engine", "unknown endian");
|
|
#endif
|
|
|
|
// init the network
|
|
net_init();
|
|
CNetBase::Init();
|
|
}
|
|
|
|
m_JobPool.Init(Jobs);
|
|
|
|
m_Logging = false;
|
|
}
|
|
|
|
~CEngine() override
|
|
{
|
|
m_JobPool.Destroy();
|
|
}
|
|
|
|
void Init() override
|
|
{
|
|
m_pConsole = Kernel()->RequestInterface<IConsole>();
|
|
m_pStorage = Kernel()->RequestInterface<IStorage>();
|
|
|
|
if(!m_pConsole || !m_pStorage)
|
|
return;
|
|
|
|
char aFullPath[IO_MAX_PATH_LENGTH];
|
|
m_pStorage->GetCompletePath(IStorage::TYPE_SAVE, "dumps/", aFullPath, sizeof(aFullPath));
|
|
m_pConsole->Register("dbg_lognetwork", "", CFGFLAG_SERVER | CFGFLAG_CLIENT, Con_DbgLognetwork, this, "Log the network");
|
|
}
|
|
|
|
void AddJob(std::shared_ptr<IJob> pJob) override
|
|
{
|
|
if(g_Config.m_Debug)
|
|
dbg_msg("engine", "job added");
|
|
m_JobPool.Add(std::move(pJob));
|
|
}
|
|
|
|
void SetAdditionalLogger(std::unique_ptr<ILogger> &&pLogger) override
|
|
{
|
|
m_pFutureLogger->Set(std::move(pLogger));
|
|
}
|
|
};
|
|
|
|
void IEngine::RunJobBlocking(IJob *pJob)
|
|
{
|
|
CJobPool::RunBlocking(pJob);
|
|
}
|
|
|
|
IEngine *CreateEngine(const char *pAppname, std::shared_ptr<CFutureLogger> pFutureLogger, int Jobs) { return new CEngine(false, pAppname, std::move(pFutureLogger), Jobs); }
|
|
IEngine *CreateTestEngine(const char *pAppname, int Jobs) { return new CEngine(true, pAppname, nullptr, Jobs); }
|