Commit e014ef73 authored by Erwan Tulou's avatar Erwan Tulou

skins2: fix font path processing

parent 2d32bb48
...@@ -277,41 +277,36 @@ void Builder::addBitmapFont( const BuilderData::BitmapFont &rData ) ...@@ -277,41 +277,36 @@ void Builder::addBitmapFont( const BuilderData::BitmapFont &rData )
void Builder::addFont( const BuilderData::Font &rData ) void Builder::addFont( const BuilderData::Font &rData )
{ {
string full_path = getFilePath( rData.m_fontFile );
if( !full_path.size() )
return;
// Try to load the font from the theme directory // Try to load the font from the theme directory
GenericFont *pFont = new FT2Font( getIntf(), full_path, rData.m_size ); string full_path = getFilePath( rData.m_fontFile );
if( pFont->init() ) if( full_path.size() )
{
m_pTheme->m_fonts[rData.m_id] = GenericFontPtr( pFont );
}
else
{ {
GenericFont *pFont = new FT2Font( getIntf(), full_path, rData.m_size );
if( pFont->init() )
{
m_pTheme->m_fonts[rData.m_id] = GenericFontPtr( pFont );
return;
}
delete pFont; delete pFont;
}
// Font not found; try in the resource path // Font not found; try in the resource path
OSFactory *pOSFactory = OSFactory::instance( getIntf() ); OSFactory *pOSFactory = OSFactory::instance( getIntf() );
const list<string> &resPath = pOSFactory->getResourcePath(); const list<string> &resPath = pOSFactory->getResourcePath();
const string &sep = pOSFactory->getDirSeparator(); const string &sep = pOSFactory->getDirSeparator();
list<string>::const_iterator it; list<string>::const_iterator it;
for( it = resPath.begin(); it != resPath.end(); it++ ) for( it = resPath.begin(); it != resPath.end(); ++it )
{
string path = (*it) + sep + "fonts" + sep + rData.m_fontFile;
GenericFont *pFont = new FT2Font( getIntf(), path, rData.m_size );
if( pFont->init() )
{ {
string path = (*it) + sep + "fonts" + sep + rData.m_fontFile; // Font loaded successfully
pFont = new FT2Font( getIntf(), path, rData.m_size ); m_pTheme->m_fonts[rData.m_id] = GenericFontPtr( pFont );
if( pFont->init() ) return;
{
// Font loaded successfully
m_pTheme->m_fonts[rData.m_id] = GenericFontPtr( pFont );
break;
}
else
{
delete pFont;
}
} }
delete pFont;
} }
} }
......
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