Restructure repository to include all source folders
Move git root from Client/ to src/ to track all source code: - Client: Game client source (moved to Client/Client/) - Server: Game server source - GameTools: Development tools - CryptoSource: Encryption utilities - database: Database scripts - Script: Game scripts - rylCoder_16.02.2008_src: Legacy coder tools - GMFont, Game: Additional resources 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
241
Server/NFAuthTool/NFAuthServer/Nave/NFLogManager.h
Normal file
241
Server/NFAuthTool/NFAuthServer/Nave/NFLogManager.h
Normal file
@@ -0,0 +1,241 @@
|
||||
/**
|
||||
* @file NFLogManager.h
|
||||
* @brief LogManager Ŭ<><C5AC><EFBFBD><EFBFBD>
|
||||
* @remarks
|
||||
* @author <09><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>(edith2580@gmail.com)
|
||||
* @date 2009-04-02
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdarg.h>
|
||||
#include <string>
|
||||
#include <time.h>
|
||||
#include <list>
|
||||
|
||||
#include "NFSync.h"
|
||||
#include "NFThread.h"
|
||||
|
||||
namespace Nave {
|
||||
|
||||
class NFLogManager;
|
||||
|
||||
/**
|
||||
* @class NFLogBuffer
|
||||
* @brief <20>αװ<CEB1> <20><><EFBFBD><EFBFBD><EFBFBD>Ǵ<EFBFBD> <20>α<EFBFBD> <20><><EFBFBD><EFBFBD> <20>̰<EFBFBD> <20><><EFBFBD>Ϸ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ȴ<EFBFBD>.
|
||||
* @remarks
|
||||
*
|
||||
* @par
|
||||
* @author Edith
|
||||
* @date 2009-04-04
|
||||
*/
|
||||
class NFLogBuffer
|
||||
{
|
||||
public:
|
||||
/// Write, Free <20><><EFBFBD>۸<EFBFBD> <20><><EFBFBD><EFBFBD>Ʈ<EFBFBD><C6AE> <20><><EFBFBD><EFBFBD><EFBFBD>ϰ<EFBFBD> <20>Ǵµ<C7B4> typedef<65><66> <20><><EFBFBD>⼭ <20>ߴ<EFBFBD>.
|
||||
typedef std::list<NFLogBuffer*> List;
|
||||
|
||||
enum
|
||||
{
|
||||
MAX_LOG_BUFFER = 65536 /// <20>α<CEB1><D7B9><EFBFBD><EFBFBD><EFBFBD> ũ<><C5A9>
|
||||
};
|
||||
|
||||
/// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
unsigned long m_dwUsage;
|
||||
/// <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
char m_Buffer[MAX_LOG_BUFFER];
|
||||
|
||||
/// NFLogBuffer <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
NFLogBuffer() : m_dwUsage(0)
|
||||
{
|
||||
}
|
||||
|
||||
/// <20>ʱ<EFBFBD>ȭ <20>Լ<EFBFBD>
|
||||
VOID Initialize()
|
||||
{
|
||||
m_dwUsage = 0;
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* @class NFLogThread
|
||||
* @brief <20>α<CEB1> <20><><EFBFBD><EFBFBD><EFBFBD>ϴ<EFBFBD> <20>α<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̴<EFBFBD>. <20>αŴ<D7B8><C5B4><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
||||
* @remarks
|
||||
*
|
||||
* @par
|
||||
* @author Edith
|
||||
* @date 2009-04-04
|
||||
*/
|
||||
class NFLogThread : public NFThread
|
||||
{
|
||||
public:
|
||||
/// NFLogThread <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
NFLogThread();
|
||||
/// NFLogThread <20>Ҹ<EFBFBD><D2B8><EFBFBD>
|
||||
~NFLogThread();
|
||||
|
||||
/**
|
||||
* @brief <09>α<CEB1> <20>ʱ<EFBFBD>ȭ<EFBFBD>Ѵ<EFBFBD>.
|
||||
* @param pLog <09>α<D7B8><DEB4><EFBFBD> <20><>ü
|
||||
* @param bCompress <20><><EFBFBD><EFBFBD><E0BFA9>
|
||||
*/
|
||||
VOID Initialize(NFLogManager* pLog, BOOL bCompress);
|
||||
|
||||
/**
|
||||
* @brief <09>α<EFBFBD><CEB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ũ<>⸦ <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>. <20><>ũ<EFBFBD>Ⱑ <20>Ǹ<EFBFBD> <20>ٸ<EFBFBD> <20><><EFBFBD>Ϸ<EFBFBD> <20>α<CEB1><D7B8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
||||
* @param dwSize <20>α<EFBFBD><CEB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ũ<><C5A9> byte <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 10 * 1024 * 1024 <20><> 10<31>ް<EFBFBD>
|
||||
*/
|
||||
inline VOID SetLogMaxSize(DWORD dwSize = MAX_FILE_SIZE) { m_dwMaxFileSize = dwSize; }
|
||||
|
||||
/// <20>α<CEB1> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
|
||||
BOOL FlushSignal() { return PulseEvent(m_hFlush); }
|
||||
|
||||
/// <20>α<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>带 <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
|
||||
virtual unsigned int Run();
|
||||
/// <20>α<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>带 <20><><EFBFBD><EFBFBD><EFBFBD>մϴ<D5B4>.
|
||||
virtual BOOL End();
|
||||
|
||||
private:
|
||||
enum
|
||||
{
|
||||
MAX_FILE_SIZE = 100 * 1024 * 1024 /// <20>⺻ <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 100<30>ް<EFBFBD>
|
||||
};
|
||||
|
||||
/**
|
||||
* @brief <09>α<EFBFBD><CEB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20≯<EFBFBD><CCB8><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>մϴ<D5B4>.
|
||||
* @return <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
*/
|
||||
BOOL SetLogFileName();
|
||||
/**
|
||||
* @brief <09>α<CEB1><D7B9>ۿ<EFBFBD> <20>α<CEB1> Write <20>մϴ<D5B4>.
|
||||
* @return <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
*/
|
||||
BOOL WriteLog();
|
||||
|
||||
private:
|
||||
/// <20>ش<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>尡 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD>·<EFBFBD><C2B7><EFBFBD>
|
||||
volatile LONG m_bEnd;
|
||||
|
||||
/// <20><><EFBFBD><EFBFBD> <20>ش<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>尡 <20>۵<EFBFBD><DBB5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Ȯ<><C8AE><EFBFBD>ϴ<EFBFBD> <20>̺<EFBFBD>Ʈ
|
||||
HANDLE m_hFlush;
|
||||
/// <20>αװ<CEB1> <20><><EFBFBD><EFBFBD><EFBFBD>Ǵ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ڵ<EFBFBD>
|
||||
HANDLE m_hFile;
|
||||
/// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>ũ<EFBFBD><C5A9>
|
||||
DWORD m_dwTotalWritten;
|
||||
|
||||
/// <20>α<EFBFBD> <20><EFBFBD><DEB4><EFBFBD>
|
||||
NFLogManager* m_pLogHandle;
|
||||
/// <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
BOOL m_bCompress;
|
||||
|
||||
/// <20><><EFBFBD><EFBFBD> <20>α<EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
NFLogBuffer::List m_WriteBufferList;
|
||||
|
||||
/// <20>α<EFBFBD><CEB1><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD≯<EFBFBD>
|
||||
WCHAR m_szLogFileName[MAX_PATH];
|
||||
|
||||
/// <20>α<EFBFBD><CEB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ִ<EFBFBD> ũ<><C5A9>
|
||||
DWORD m_dwMaxFileSize;
|
||||
};
|
||||
|
||||
/**
|
||||
* @class NFLogManager
|
||||
* @brief <20>α<CEB1> <20><><EFBFBD><EFBFBD><EFBFBD>Ҷ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ϴ<EFBFBD> <20>α<EFBFBD> <20>Ŵ<EFBFBD><C5B4><EFBFBD> Ŭ<><C5AC><EFBFBD><EFBFBD>
|
||||
* @remarks <20>α<EFBFBD> <20>Ŵ<EFBFBD><C5B4><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>α<CEB1> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20>ֱ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>̱<EFBFBD><CCB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ʴ´<CAB4>.\r\n
|
||||
* <20><><EFBFBD><EFBFBD><EFBFBD>Ϸα״<CEB1> <20><><EFBFBD>̳ʸ<CCB3><CAB8><EFBFBD><EFBFBD><EFBFBD> <20>ֱ<EFBFBD><D6B1><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ϴ<EFBFBD> <20>α״<CEB1>. \r\n
|
||||
* <20>ȿ<EFBFBD> <20><><EFBFBD><EFBFBD><EEB0A1> <20>α״<CEB1> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20>ش<EFBFBD> <20>α<EFBFBD> <20><><EFBFBD><EFBFBD>ü<EFBFBD><C3BC><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ؾ<EFBFBD><D8BE>Ѵ<EFBFBD>. \r\n
|
||||
* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>α<EFBFBD><CEB1><EFBFBD> <20><><EFBFBD><EFBFBD> <20>ӵ<EFBFBD><D3B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> ó<><C3B3><EFBFBD><EFBFBD> <20><DEB8><F0B8AEBB><EFBFBD> <20><><EFBFBD>۸<EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD>۰<EFBFBD> <20><> á<><C3A1><EFBFBD><EFBFBD> <20>ش<EFBFBD> <20><><EFBFBD>۸<EFBFBD> \r\n
|
||||
* WriteList<73><74> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ش<EFBFBD> <20><><EFBFBD>۸<EFBFBD> ó<><C3B3><EFBFBD>Ѵ<EFBFBD>. \r\n
|
||||
*
|
||||
* @par
|
||||
* @author Edith
|
||||
* @date 2009-04-04
|
||||
*/
|
||||
class NFLogManager
|
||||
{
|
||||
public:
|
||||
/// NFLogManager <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
NFLogManager(void);
|
||||
/// NFLogManager <20>Ҹ<EFBFBD><D2B8><EFBFBD>
|
||||
~NFLogManager(void);
|
||||
|
||||
/**
|
||||
* @brief <09>α<EFBFBD> <20><EFBFBD><DEB4><EFBFBD><EFBFBD><EFBFBD> <20>ʱ<EFBFBD>ȭ <20>մϴ<D5B4>.
|
||||
* @param bCompress <09><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
* @param szLogFilePrefix <09>α<EFBFBD><CEB1><EFBFBD><EFBFBD>ϸ<EFBFBD>
|
||||
* @return <09><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
*/
|
||||
BOOL Initialize(BOOL bCompress, const WCHAR* szLogFilePrefix = 0);
|
||||
/// <20>αŴ<D7B8><C5B4><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>մϴ<D5B4>.
|
||||
BOOL Destroy();
|
||||
|
||||
/// <20>α<CEB1><D7B9><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
|
||||
VOID SetLogMaxSize(DWORD dwSize = 10 * 1024 * 1024);
|
||||
|
||||
|
||||
/**
|
||||
* @brief <09>α<EFBFBD><CEB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20≯<EFBFBD>
|
||||
* @return <09>α<EFBFBD><CEB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD≯<EFBFBD>
|
||||
*/
|
||||
const WCHAR* GetLogFilePrefix() const { return m_szLogFilePrefix; }
|
||||
|
||||
/**
|
||||
* @brief <09>α<CEB1> <20><><EFBFBD><EFBFBD><EFBFBD>մϴ<D5B4>.
|
||||
* @return <09><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
*/
|
||||
BOOL Flush();
|
||||
|
||||
/**
|
||||
* @brief <09><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ǵ<EFBFBD> <20>α<EFBFBD> <20><><EFBFBD>۸<EFBFBD> <20><><EFBFBD>մϴ<D5B4>.
|
||||
* @return <09>α<CEB1><D7B9><EFBFBD>
|
||||
*/
|
||||
NFLogBuffer* GetBuffer();
|
||||
|
||||
/**
|
||||
* @brief <20>α<CEB1><D7B9>۸<EFBFBD> <20>Ҵ<EFBFBD><D2B4>Ѵ<EFBFBD>.
|
||||
* @param usReserve <20>Ҵ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
* @return <09>α<CEB1><D7B9><EFBFBD><EFBFBD><EFBFBD> <20><>ġ<EFBFBD><C4A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
*/
|
||||
char* ReserveBuffer(unsigned short usReserve);
|
||||
|
||||
/**
|
||||
* @brief <09>Ҵ<EFBFBD><D2B4><EFBFBD> <20>α<CEB1><D7B9>۸<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ŵ<EFBFBD>ϴ<EFBFBD>.
|
||||
* @param usRealUse <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
*/
|
||||
VOID Complete(unsigned short usRealUse) { m_lpDetailBuffer->m_dwUsage += usRealUse; }
|
||||
|
||||
/**
|
||||
* @brief <09><><EFBFBD>»<EFBFBD><C2BB>·<EFBFBD> <20>α<CEB1><D7B9>۸<EFBFBD> <20>Ҵ<EFBFBD><D2B4>մϴ<D5B4>.
|
||||
* @param ppDetailBuffer
|
||||
*/
|
||||
VOID PushBuffer(NFLogBuffer** ppDetailBuffer);
|
||||
|
||||
VOID SpliceInWriteBuffer(NFLogBuffer::List& logBufferList);
|
||||
VOID SpliceInFreeBuffer(NFLogBuffer::List& logBufferList);
|
||||
|
||||
private:
|
||||
enum
|
||||
{
|
||||
DEFAULT_FREE_LOG_BUFFER_NUM = 10 /// <20>ִ<EFBFBD> 10<31><30><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>۸<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
|
||||
};
|
||||
|
||||
/// Sync <20><>ü
|
||||
NFSync m_LogSync;
|
||||
|
||||
/// <20>α<EFBFBD> <20><><EFBFBD>ϸ<EFBFBD>
|
||||
WCHAR m_szLogFilePrefix[MAX_PATH];
|
||||
|
||||
/// <20>α<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
NFLogThread m_LogSaveThread;
|
||||
|
||||
/// <20><><EFBFBD><EFBFBD><EFBFBD>ִ<EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
NFLogBuffer::List m_FreeList;
|
||||
/// <20><><EFBFBD>Ͽ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
NFLogBuffer::List m_WriteList;
|
||||
|
||||
/// <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ǵ<EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
NFLogBuffer* m_lpDetailBuffer;
|
||||
};
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user