Files
Client/CryptoSource/ScriptConvert-GSF File/Utility/DelimitedFile.cpp
LGram16 dd97ddec92 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>
2025-11-29 20:17:20 +09:00

514 lines
10 KiB
C++

#include "stdafx.h"
#include "DelimitedFile.h"
CDelimitedFile::CDelimitedFile(const char* pszDelimiter)
: m_fpFile(0), m_dwColumn(0), m_dwColumnCount(0)
{
m_ColumnNames.reserve(DEFAULT_COLUMN_NUM);
strncpy(m_szDelimiter, pszDelimiter, MAX_DELIMITER_NUM);
}
CDelimitedFile::~CDelimitedFile()
{
Close();
}
CDelimitedFile::SectionInfo::SectionInfo(std::string& szSectionName, unsigned long dwLine)
: m_szSectionName(szSectionName), m_dwLine(dwLine)
{
}
bool CDelimitedFile::Open( LPCSTR szFilename, int nHeadLine, UINT nOpenFlags )
{
m_fpFile = ::fopen( szFilename, (nOpenFlags & modeCreate) ? "wt" : "rt" );
if (NULL == m_fpFile)
{
#ifdef ERRLOG2
unsigned long dwError = ::GetLastError();
ERRLOG2(g_Log, "파일 %s를 열 수 없습니다. Error Code : %d", szFilename, dwError);
#endif
return false;
}
if (nHeadLine > -1)
{
for (int i = 0; i < nHeadLine; )
{
if (true == ReadLine())
{
++i;
}
}
for (m_dwColumnCount = 0; true; ++m_dwColumnCount)
{
char* szColumnName = new char[MAX_COLUMN_LENGHT];
if (0 == szColumnName)
{
return false;
}
if (false == ReadString(szColumnName, MAX_COLUMN_LENGHT - 1))
{
delete szColumnName;
break;
}
size_t nLength = strlen(szColumnName);
while (nLength-- > 0)
{
if (szColumnName[nLength] == '\r' || szColumnName[nLength] == '\n')
{
szColumnName[nLength] = 0;
}
}
szColumnName[MAX_COLUMN_LENGHT - 1] = 0;
m_ColumnNames.push_back(szColumnName);
}
}
return true;
}
void CDelimitedFile::Close( void )
{
if ( m_fpFile )
{
::fclose( m_fpFile );
m_fpFile = 0;
}
ColumnArray::size_type nTotalSize = m_ColumnNames.size();
for (ColumnArray::size_type nCount = 0; nCount < nTotalSize; ++nCount)
{
delete [] m_ColumnNames[nCount];
}
m_ColumnNames.clear();
}
unsigned long CDelimitedFile::GetSection(std::string& szSectionName)
{
for (SectionArray::iterator it = m_SectionInfo.begin(); it != m_SectionInfo.end(); ++it)
{
if (szSectionName == it->m_szSectionName)
{
return it->m_dwLine;
}
}
return 0;
}
bool CDelimitedFile::ReadSection(void)
{
char szBuffer[MAX_LINE_LENGTH];
unsigned long dwLine = 1;
m_SectionInfo.clear();
while (NULL != fgets(szBuffer, MAX_LINE_LENGTH, m_fpFile))
{
std::string strSectionIn = std::string(szBuffer);
if (';' == *(strSectionIn.begin()) || 0 == strcmp("\n", strSectionIn.c_str()))
{
continue;
}
if ('[' == *(strSectionIn.begin()))
{
std::string::iterator end = std::find(strSectionIn.begin(), strSectionIn.end(), ']');
if (end != strSectionIn.end())
{
std::string strSectionOut;
strSectionOut.assign(strSectionIn.begin() + 1, end);
m_SectionInfo.push_back(SectionInfo(strSectionOut, dwLine));
}
}
++dwLine;
}
if (true == m_SectionInfo.empty())
{
return false;
}
rewind(m_fpFile);
return true;
}
bool CDelimitedFile::ReadLine(void)
{
while (NULL != ::fgets(m_szLine, MAX_LINE_LENGTH, m_fpFile))
{
if (0 == strcmp("\n", m_szLine))
{
break;
}
if (';' != m_szLine[0])
{
m_dwColumn = 0;
memcpy(m_szBackupLine, m_szLine, MAX_LINE_LENGTH);
return true;
}
}
return false;
}
// 빈줄 및 C++ 스타일 주석 지원
bool CDelimitedFile::ReadLine2nd(void)
{
while (NULL != ::fgets(m_szLine, MAX_LINE_LENGTH, m_fpFile))
{
// 문자열 처음부분에 있는 Tab 없애주기
int iEnd = 0;
while (true)
{
if ('\t' == m_szLine[iEnd])
{
++iEnd;
}
else
{
if (0 != iEnd)
{
strcpy(m_szLine, m_szLine + iEnd);
}
break;
}
}
if (0 == strcmp("\n", m_szLine))
{
continue;
}
if ('/' != m_szLine[0] && '/' != m_szLine[1])
{
m_dwColumn = 0;
memcpy(m_szBackupLine, m_szLine, MAX_LINE_LENGTH);
return true;
}
}
return false;
}
bool CDelimitedFile::ReadData( bool &bNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
bNumber = false;
if (atoi(pszData) == 1)
bNumber = true;
char szString[2];
strncpy(szString, pszData, 1);
if (NULL == ::strcmp(szString, "O"))
bNumber = true;
return true;
}
bool CDelimitedFile::ReadData( double &dNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
dNumber = atof( pszData );
return true;
}
bool CDelimitedFile::ReadData( float &fNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
fNumber = (float) atof( pszData );
return true;
}
bool CDelimitedFile::ReadData( long &lNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
lNumber = (long) atol( pszData );
return true;
}
bool CDelimitedFile::ReadData( unsigned long &fNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
fNumber = (unsigned long) atol( pszData );
return true;
}
bool CDelimitedFile::ReadData( int &iNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
iNumber = atoi( pszData );
return true;
}
bool CDelimitedFile::ReadData( unsigned short &iNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
iNumber = (unsigned short)atoi( pszData );
return true;
}
bool CDelimitedFile::ReadData( short &iNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
iNumber = (short)atoi( pszData );
return true;
}
bool CDelimitedFile::ReadData( unsigned char &iNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
iNumber = (unsigned char)atoi( pszData );
return true;
}
bool CDelimitedFile::ReadData( char &iNumber )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
iNumber = (char)atoi( pszData );
return true;
}
bool CDelimitedFile::ReadData( __int64 &i64Number )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
i64Number = _atoi64( pszData );
return true;
}
bool CDelimitedFile::ReadData( DWORD64 &i64Number )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
i64Number = (unsigned long)_atoi64( pszData );
return true;
}
bool CDelimitedFile::ReadString( char *szString, unsigned long dwSize )
{
CHAR *pszData = ::strtok( (m_dwColumn++) ? NULL : m_szLine, m_szDelimiter );
if ( !pszData || !(*pszData) )
return false;
strncpy(szString, pszData, dwSize);
return true;
}
bool CDelimitedFile::ReadData(const char *szField, double &dNumber )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( dNumber );
}
bool CDelimitedFile::ReadData(const char *szField, float &fNumber )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( fNumber );
}
bool CDelimitedFile::ReadData(const char *szField, long &lNumber )
{
int nSearch;
if( ((nSearch = FindColumn( szField )) == -1) )
return FALSE;
GotoColumn( nSearch );
return ReadData( lNumber );
}
bool CDelimitedFile::ReadData(const char *szField, unsigned long &fNumber )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( fNumber );
}
bool CDelimitedFile::ReadData(const char *szField, int &iNumber )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( iNumber );
}
bool CDelimitedFile::ReadData(const char *szField, unsigned short &iNumber )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( iNumber );
}
bool CDelimitedFile::ReadData(const char *szField, short &iNumber )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( iNumber );
}
bool CDelimitedFile::ReadData(const char *szField, unsigned char &iNumber )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( iNumber );
}
bool CDelimitedFile::ReadData(const char *szField, char &iNumber )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( iNumber );
}
bool CDelimitedFile::ReadData(const char *szField, __int64 &i64Number )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( i64Number );
}
bool CDelimitedFile::ReadData(const char *szField, DWORD64 &i64Number )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadData( i64Number );
}
bool CDelimitedFile::ReadString(const char *szField, char *szString, unsigned long dwSize )
{
int nSearch;
if ( ((nSearch = FindColumn( szField )) == -1) )
return false;
GotoColumn( nSearch );
return ReadString( szString, dwSize );
}
bool CDelimitedFile::GotoColumn( int nColumn )
{
CHAR* pszPos = 0;
if (nColumn < 0 || (unsigned long)nColumn > m_dwColumnCount) {
return false;
}
if ((m_dwColumn == (unsigned long) nColumn)) {
return true;
}
if ( nColumn == 0 ) {
m_dwColumn = 0;
strtok(m_szLine, m_szDelimiter);
}
else {
for (;m_dwColumn < m_dwColumnCount && nColumn != m_dwColumn; ++m_dwColumn )
pszPos = strtok(0, m_szDelimiter);
if (m_dwColumn == m_dwColumnCount) {
memcpy(m_szLine, m_szBackupLine, MAX_LINE_LENGTH);
pszPos = strtok(m_szLine, m_szDelimiter);
for (m_dwColumn = 1; m_dwColumn < (unsigned long)nColumn && nColumn != m_dwColumn; ++m_dwColumn ) {
pszPos = strtok(NULL, m_szDelimiter );
}
}
}
return true;
}
int CDelimitedFile::FindColumn(const char *szField)
{
for (ColumnArray::size_type nCount = 0; nCount < m_ColumnNames.size(); ++nCount)
{
const char* szColumnName = m_ColumnNames[nCount];
if (0 == strcmp(szField, szColumnName))
{
return static_cast<int>(nCount);
}
}
return -1;
}