Commit 4f0d244c authored by Oleg.Korshul's avatar Oleg.Korshul Committed by Alexander Trofimov
parent bd096199
#ifndef _FONT_FILE_BASE_H
#define _FONT_FILE_BASE_H
#ifndef _ASC_FONTCONVERTER_FONT_FILE_BASE_H
#define _ASC_FONTCONVERTER_FONT_FILE_BASE_H
#include <stdio.h>
#include "MemoryUtils.h"
#include "../../common/File.h"
//------------------------------------------------------------------------
namespace NSFontConverter
{
//------------------------------------------------------------------------
typedef void (*FontFileOutputFunc)(void *pStream, char *sData, int nLen);
typedef void (*FontFileOutputFunc)(void *pStream, char *sData, int nLen);
//------------------------------------------------------------------------
// CFontFileBase
//------------------------------------------------------------------------
//------------------------------------------------------------------------
// CFontFileBase
//------------------------------------------------------------------------
class CFontFileBase
{
public:
class CFontFileBase
{
public:
virtual ~CFontFileBase()
{
......@@ -22,9 +25,9 @@ public:
MemUtilsFree( m_sFileData );
}
protected:
protected:
CFontFileBase(char *sFile, int nLen, BOOL bFreeFileData)
CFontFileBase(char *sFile, int nLen, bool bFreeFileData)
{
m_sFileData = m_sFile = (unsigned char *)sFile;
m_nLen = nLen;
......@@ -38,23 +41,21 @@ protected:
}
static char *ReadFile(wchar_t *wsFileName, int *pnFileLen)
{
FILE *pFile;
if ( !( pFile = _wfopen( wsFileName, _T("rb") ) ) )
NSFile::CFileBinary oFile;
if ( !oFile.OpenFile(wsFileName) )
return NULL;
fseek( pFile, 0, SEEK_END );
int nLen = (int)ftell( pFile );
fseek( pFile, 0, SEEK_SET );
int nLen = (int)oFile.GetFileSize();
char *sBuffer = (char *)MemUtilsMalloc( nLen );
if ( (int)fread( sBuffer, 1, nLen, pFile) != nLen )
DWORD dwRead = 0;
oFile.ReadFile((BYTE*)sBuffer, (DWORD)nLen, dwRead);
if ((int)dwRead != nLen)
{
MemUtilsFree( sBuffer );
fclose( pFile );
return NULL;
}
fclose( pFile );
*pnFileLen = nLen;
return sBuffer;
}
......@@ -62,13 +63,13 @@ protected:
// S = signed / U = unsigned
// 8/16/32/Var = word length, in bytes
// BE = big endian
int GetS8 (int nPos, BOOL *pbSuccess)
int GetS8 (int nPos, bool *pbSuccess)
{
*pbSuccess = TRUE;
*pbSuccess = true;
if ( nPos < 0 || nPos >= m_nLen )
{
*pbSuccess = FALSE;
*pbSuccess = false;
return 0;
}
int nRes = m_sFile[ nPos ];
......@@ -77,24 +78,24 @@ protected:
return nRes;
}
int GetU8 (int nPos, BOOL *pbSuccess)
int GetU8 (int nPos, bool *pbSuccess)
{
*pbSuccess = TRUE;
*pbSuccess = true;
if ( nPos < 0 || nPos >= m_nLen )
{
*pbSuccess = FALSE;
*pbSuccess = false;
return 0;
}
return m_sFile[ nPos ];
}
int GetS16BE (int nPos, BOOL *pbSuccess)
int GetS16BE (int nPos, bool *pbSuccess)
{
*pbSuccess = TRUE;
*pbSuccess = true;
if ( nPos < 0 || nPos + 1 >= m_nLen )
{
*pbSuccess = FALSE;
*pbSuccess = false;
return 0;
}
int nRes = m_sFile[nPos];
......@@ -104,13 +105,13 @@ protected:
return nRes;
}
int GetU16BE (int nPos, BOOL *pbSuccess)
int GetU16BE (int nPos, bool *pbSuccess)
{
*pbSuccess = TRUE;
*pbSuccess = true;
if ( nPos < 0 || nPos + 1 >= m_nLen)
{
*pbSuccess = FALSE;
*pbSuccess = false;
return 0;
}
int nRes = m_sFile[ nPos ];
......@@ -118,13 +119,13 @@ protected:
return nRes;
}
int GetS32BE (int nPos, BOOL *pbSuccess)
int GetS32BE (int nPos, bool *pbSuccess)
{
*pbSuccess = TRUE;
*pbSuccess = true;
if ( nPos < 0 || nPos + 3 >= m_nLen )
{
*pbSuccess = FALSE;
*pbSuccess = false;
return 0;
}
int nRes = m_sFile[ nPos ];
......@@ -137,13 +138,13 @@ protected:
return nRes;
}
unsigned int GetU32BE (int nPos, BOOL *pbSuccess)
unsigned int GetU32BE (int nPos, bool *pbSuccess)
{
*pbSuccess = TRUE;
*pbSuccess = true;
if ( nPos < 0 || nPos + 3 >= m_nLen )
{
*pbSuccess = FALSE;
*pbSuccess = false;
return 0;
}
unsigned int nRes = m_sFile[nPos];
......@@ -152,13 +153,13 @@ protected:
nRes = (nRes << 8) + m_sFile[nPos + 3];
return nRes;
}
unsigned int GetU32LE (int nPos, BOOL *pbSuccess)
unsigned int GetU32LE (int nPos, bool *pbSuccess)
{
*pbSuccess = TRUE;
*pbSuccess = true;
if ( nPos < 0 || nPos + 3 >= m_nLen )
{
*pbSuccess = FALSE;
*pbSuccess = false;
return 0;
}
unsigned int nRes = m_sFile[nPos + 3];
......@@ -167,13 +168,13 @@ protected:
nRes = (nRes << 8) + m_sFile[nPos + 0];
return nRes;
}
unsigned int GetUVarBE(int nPos, int nSize, BOOL *pbSuccess)
unsigned int GetUVarBE(int nPos, int nSize, bool *pbSuccess)
{
*pbSuccess = TRUE;
*pbSuccess = true;
if ( nPos < 0 || nPos + nSize > m_nLen )
{
*pbSuccess = FALSE;
*pbSuccess = false;
return 0;
}
unsigned int nRes = 0;
......@@ -183,25 +184,25 @@ protected:
return nRes;
}
BOOL CheckRegion(int nPos, int nSize)
bool CheckRegion(int nPos, int nSize)
{
return (nPos >= 0 && nPos + nSize >= nPos && nPos + nSize <= m_nLen);
}
int ReadS8 (BOOL *pbSuccess)
int ReadS8 (bool *pbSuccess)
{
return GetS8( m_nPos++, pbSuccess );
}
int ReadU8 (BOOL *pbSuccess)
int ReadU8 (bool *pbSuccess)
{
return GetU8( m_nPos++, pbSuccess );
}
unsigned int ReadU32BE(BOOL *pbSuccess)
unsigned int ReadU32BE(bool *pbSuccess)
{
unsigned int unResult = GetU32BE( m_nPos, pbSuccess );
m_nPos += 4;
return unResult;
}
unsigned int ReadU32LE(BOOL *pbSuccess)
unsigned int ReadU32LE(bool *pbSuccess)
{
unsigned int unResult = GetU32LE( m_nPos, pbSuccess );
m_nPos += 4;
......@@ -218,14 +219,15 @@ protected:
return nSize;
}
protected:
protected:
unsigned char *m_sFileData;
unsigned char *m_sFile;
int m_nLen;
BOOL m_bFreeFileData;
bool m_bFreeFileData;
int m_nPos;
};
};
}
#endif /* _FONT_FILE_BASE_H */
#endif /* _ASC_FONTCONVERTER_FONT_FILE_BASE_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment