X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/5ea50c92a5d5a3f261c2aa849849a21a6898ed11..345fec0d578c3033b82d799fbfd0c647b2229e30:/src/dfb/fontmgr.cpp diff --git a/src/dfb/fontmgr.cpp b/src/dfb/fontmgr.cpp index 76b09cf1b3..7abfabaacf 100644 --- a/src/dfb/fontmgr.cpp +++ b/src/dfb/fontmgr.cpp @@ -16,6 +16,11 @@ #pragma hdrstop #endif +#ifndef WX_PRECOMP + #include "wx/utils.h" + #include "wx/log.h" +#endif + #include "wx/fileconf.h" #include "wx/filename.h" #include "wx/tokenzr.h" @@ -32,6 +37,11 @@ // wxFontInstance // ---------------------------------------------------------------------------- +// This is a fake "filename" for DirectFB's builtin font (which isn't loaded +// from a file); we can't use empty string, because that's already used for +// "this face is not available" by wxFontsManagerBase +#define BUILTIN_DFB_FONT_FILENAME "/dev/null" + wxFontInstance::wxFontInstance(float ptSize, bool aa, const wxString& filename) : wxFontInstanceBase(ptSize, aa) @@ -50,7 +60,11 @@ wxFontInstance::wxFontInstance(float ptSize, bool aa, DFDESC_ATTRIBUTES | DFDESC_FRACT_HEIGHT); desc.attributes = aa ? DFFA_NONE : DFFA_MONOCHROME; desc.fract_height = pixSize; - m_font = wxIDirectFB::Get()->CreateFont(filename.fn_str(), &desc); + + if ( filename == BUILTIN_DFB_FONT_FILENAME ) + m_font = wxIDirectFB::Get()->CreateFont(NULL, &desc); + else + m_font = wxIDirectFB::Get()->CreateFont(filename.fn_str(), &desc); wxASSERT_MSG( m_font, _T("cannot create font instance") ); } @@ -139,6 +153,12 @@ void wxFontsManager::AddAllFonts() { wxString dir = tkn.GetNextToken(); + if ( !wxDir::Exists(dir) ) + { + wxLogDebug(_T("font directory %s doesn't exist"), dir); + continue; + } + wxArrayString indexFiles; if ( !wxDir::GetAllFiles(dir, &indexFiles, _T("FontsIndex")) ) continue; @@ -152,8 +172,23 @@ void wxFontsManager::AddAllFonts() if ( GetBundles().empty() ) { - // wxDFB is unusable without fonts, so terminate the app - wxLogFatalError(_("No fonts found in %s."), path.c_str()); + // We can fall back to the builtin default font if no other fonts are + // defined: + wxLogTrace(_T("font"), + _("no fonts found in %s, using builtin font"), path); + + AddBundle + ( + new wxFontBundle + ( + _("Default font"), + BUILTIN_DFB_FONT_FILENAME, + wxEmptyString, + wxEmptyString, + wxEmptyString, + false // IsFixed + ) + ); } }