#include "wx/utils.h"
#include "wx/log.h"
#include "wx/gdicmn.h"
+#include "wx/tokenzr.h"
#include <strings.h>
#include "gdk/gdk.h"
if (wxTheFontList) wxTheFontList->Append( this );
}
-wxFont::wxFont( char *xFontName )
+wxFont::wxFont( GdkFont *font, char *xFontName )
{
if (!xFontName) return;
m_refData = new wxFontRefData();
- M_FONTDATA->m_byXFontName = TRUE;
- M_FONTDATA->m_font = gdk_font_load( xFontName );
+// M_FONTDATA->m_byXFontName = TRUE;
+ M_FONTDATA->m_font = font;
+
+ wxString tmp;
+
+ wxString fontname( xFontName );
+ wxStringTokenizer tn( fontname, _T("-") );
+
+ tn.GetNextToken(); // foundry
+
+ M_FONTDATA->m_faceName = tn.GetNextToken(); // courier
+
+ tmp = tn.GetNextToken().MakeUpper();
+ if (tmp == _T("BOLD")) M_FONTDATA->m_weight = wxBOLD;
+
+ tmp = tn.GetNextToken().MakeUpper();
+ if (tmp == _T("I")) M_FONTDATA->m_style = wxITALIC;
+ if (tmp == _T("O")) M_FONTDATA->m_style = wxITALIC;
+
+ tn.GetNextToken(); // set width
+ tn.GetNextToken(); // ?
+ tn.GetNextToken(); // pixel size
+
+ tmp = tn.GetNextToken(); // pointsize
+ int num = wxStrtol (tmp.c_str(), (wxChar **) NULL, 10);
+ M_FONTDATA->m_pointSize = num / 10;
+
+ tn.GetNextToken(); // x-res
+ tn.GetNextToken(); // y-res
+
+ tmp = tn.GetNextToken().MakeUpper();
+ if (tmp == _T("M")) M_FONTDATA->m_family = wxMODERN;
+ else if (M_FONTDATA->m_faceName == _T("TIMES")) M_FONTDATA->m_family = wxROMAN;
+ else if (M_FONTDATA->m_faceName == _T("HELVETICA")) M_FONTDATA->m_family = wxSWISS;
+ else if (M_FONTDATA->m_faceName == _T("LUCIDATYPEWRITER")) M_FONTDATA->m_family = wxTELETYPE;
+ else if (M_FONTDATA->m_faceName == _T("LUCIDA")) M_FONTDATA->m_family = wxDECORATIVE;
+ else if (M_FONTDATA->m_faceName == _T("UTOPIA")) M_FONTDATA->m_family = wxSCRIPT;
}
wxFont::wxFont( int pointSize, int family, int style, int weight, bool underlined, const wxString& face )
{
m_refData = new wxFontRefData();
- if (family == wxDEFAULT)
+ if (family == wxDEFAULT)
M_FONTDATA->m_family = wxSWISS;
else
M_FONTDATA->m_family = family;
-
+
if (!face.IsEmpty()) M_FONTDATA->m_faceName = face;
- if (style == wxDEFAULT)
+ if (style == wxDEFAULT)
M_FONTDATA->m_style = wxNORMAL;
else
M_FONTDATA->m_style = style;
-
- if (weight == wxDEFAULT)
+
+ if (weight == wxDEFAULT)
M_FONTDATA->m_weight = wxNORMAL;
else
M_FONTDATA->m_weight = weight;
-
- if (pointSize == wxDEFAULT)
+
+ if (pointSize == wxDEFAULT)
M_FONTDATA->m_pointSize = 12;
else
M_FONTDATA->m_pointSize = pointSize;
-
+
M_FONTDATA->m_underlined = underlined;
if (wxTheFontList) wxTheFontList->Append( this );
-
+
}
wxFont::wxFont( const wxFont& font )
{
if (!m_refData)
{
- m_refData = new wxFontRefData();
+ m_refData = new wxFontRefData();
}
else
{
- wxFontRefData* ref = new wxFontRefData(*(wxFontRefData*)m_refData);
- UnRef();
- m_refData = ref;
+ wxFontRefData* ref = new wxFontRefData(*(wxFontRefData*)m_refData);
+ UnRef();
+ m_refData = ref;
}
}
// get internal representation of font
//-----------------------------------------------------------------------------
-static GdkFont *wxLoadQueryNearestFont( int point_size, int family, int style, int weight,
+static GdkFont *wxLoadQueryNearestFont( int point_size, int family, int style, int weight,
bool underlined, const wxString &facename );
GdkFont *wxFont::GetInternalFont( float scale ) const
}
M_FONTDATA->m_scaled_xfonts.Append( int_scale, (wxObject*)font );
}
-
+
if (!font)
{
wxLogError(_T("could not load any font"));
}
-
+
return font;
}
// local utilities to find a X font
//-----------------------------------------------------------------------------
-static GdkFont*wxLoadQueryFont( int pointSize, int family, int style, int weight,
- bool underlined, const wxString &facename )
+static GdkFont*wxLoadQueryFont( int pointSize, int family, int style, int weight,
+ bool WXUNUSED(underlined), const wxString &facename )
{
wxChar *xfamily = (wxChar*) NULL;
wxChar *xstyle = (wxChar*) NULL;
wxChar *xweight = (wxChar*) NULL;
-
+
switch (family)
{
case wxDECORATIVE: xfamily = _T("lucida"); break;
case wxROMAN: xfamily = _T("times"); break;
case wxMODERN: xfamily = _T("courier"); break;
case wxSWISS: xfamily = _T("helvetica"); break;
- case wxTELETYPE: xfamily = _T("lucidatypewriter"); break;
- case wxSCRIPT: xfamily = _T("utopia"); break;
+ case wxTELETYPE: xfamily = _T("lucidatypewriter"); break;
+ case wxSCRIPT: xfamily = _T("utopia"); break;
default: xfamily = _T("*");
}
-
+
if (!facename.IsEmpty())
{
wxSprintf( wxBuffer, _T("-*-%s-*-*-normal-*-*-*-*-*-*-*-*-*"), facename.c_str() );
GdkFont *test = gdk_font_load( wxConvCurrent->cWX2MB(wxBuffer) );
if (test)
- {
- gdk_font_unref( test );
- xfamily = WXSTRINGCAST facename;
- }
+ {
+ gdk_font_unref( test );
+ xfamily = WXSTRINGCAST facename;
+ }
}
-
+
switch (style)
{
case wxITALIC: xstyle = _T("i"); break;
case wxNORMAL: xweight = _T("medium"); break;
default: xweight = _T("*"); break;
}
-
+
wxSprintf( wxBuffer, _T("-*-%s-%s-%s-normal-*-*-%d-*-*-*-*-*-*"),
xfamily, xweight, xstyle, pointSize);
-
+
return gdk_font_load( wxConvCurrent->cWX2MB(wxBuffer) );
}
-static GdkFont *wxLoadQueryNearestFont( int point_size, int family, int style, int weight,
- bool underlined, const wxString &facename )
+static GdkFont *wxLoadQueryNearestFont( int point_size, int family, int style, int weight,
+ bool underlined, const wxString &facename )
{
GdkFont *font = wxLoadQueryFont( point_size, family, style, weight, underlined, facename );
- if (!font)
+ if (!font)
{
/* search up and down by stepsize 10 */
int max_size = point_size + 20 * (1 + (point_size/180));
if (!font)
font = wxLoadQueryFont(120, wxDEFAULT, wxNORMAL, wxNORMAL, underlined, facename );
}
-
+
return font;
}
"ScreenSlant", "o",
"ScreenDefaultBase", "*-times",
-
+
"ScreenRomanBase", "*-times",
"ScreenDecorativeBase", "*-helvetica",
"ScreenModernBase", "*-courier",
static int WCoordinate(int w)
{
- switch (w)
+ switch (w)
{
case wxBOLD: return wxWEIGHT_BOLD;
case wxLIGHT: return wxWEIGHT_LIGHT;
static int SCoordinate(int s)
{
- switch (s)
+ switch (s)
{
case wxITALIC: return wxSTYLE_ITALIC;
case wxSLANT: return wxSTYLE_SLANT;
// wxSuffixMap
//-----------------------------------------------------------------------------
-class wxSuffixMap
+class wxSuffixMap
{
public:
~wxSuffixMap();
*v = (char *) NULL;
internal = (char *) NULL;
- for (i = 0; i < k; i++)
+ for (i = 0; i < k; i++)
{
strcpy(resource, prefix);
- for (j = 0; j < count; j++)
- {
- // upon failure to find a matching fontname
- // in the default fonts above, we substitute more
- // and more values by _ so that at last ScreenMyFontBoldNormal
- // would turn into Screen___ and this will then get
- // converted to -${ScreenDefaultBase}${ScreenStdSuffix}
-
+ for (j = 0; j < count; j++)
+ {
+ // upon failure to find a matching fontname
+ // in the default fonts above, we substitute more
+ // and more values by _ so that at last ScreenMyFontBoldNormal
+ // would turn into Screen___ and this will then get
+ // converted to -${ScreenDefaultBase}${ScreenStdSuffix}
+
if (!(i & (1 << j)))
strcat(resource, names[j]);
else
strcat(resource, "_");
}
-
- // we previously search the Xt-resources here
- if (!internal)
- {
+ // we previously search the Xt-resources here
+
+ if (!internal)
+ {
defaults = font_defaults;
- while (*defaults)
- {
- if (!strcmp(*defaults, resource))
- {
+ while (*defaults)
+ {
+ if (!strcmp(*defaults, resource))
+ {
internal = defaults[1];
break;
}
}
}
}
-
+
if (internal)
{
if ((strcmp(internal,"-${ScreenDefaultBase}${ScreenStdSuffix}") == 0) &&
- (strcmp(names[0], "Default") != 0))
- {
- // we did not find any font name in the standard list.
- // this can (hopefully does) mean that someone supplied
- // the facename in the wxFont constructor so we insert
- // it here
-
- strcpy( resource,"-*-" ); // any producer
- strcat( resource, names[0] ); // facename
- strcat( resource, "${ScreenStdSuffix}" ); // add size params later on
- *v = copystring(resource);
- }
- else
- {
+ (strcmp(names[0], "Default") != 0))
+ {
+ // we did not find any font name in the standard list.
+ // this can (hopefully does) mean that someone supplied
+ // the facename in the wxFont constructor so we insert
+ // it here
+
+ strcpy( resource,"-*-" ); // any producer
+ strcat( resource, names[0] ); // facename
+ strcat( resource, "${ScreenStdSuffix}" ); // add size params later on
+ *v = copystring(resource);
+ }
+ else
+ {
*v = copystring(internal);
- }
+ }
}
}
for (k = 0; k < wxNUM_WEIGHTS; ++k)
for (j = 0; j < wxNUM_STYLES; ++j)
- if (map[k][j])
- {
+ if (map[k][j])
+ {
delete[] map[k][j];
map[k][j] = (char *) NULL;
}
int i, j, k;
const char *names[3];
- for (k = 0; k < wxNUM_WEIGHTS; k++)
+ for (k = 0; k < wxNUM_WEIGHTS; k++)
{
- switch (k)
- {
+ switch (k)
+ {
case wxWEIGHT_NORMAL: weight = "Medium"; break;
case wxWEIGHT_LIGHT: weight = "Light"; break;
case wxWEIGHT_BOLD:
default: weight = "Bold";
}
- for (j = 0; j < wxNUM_STYLES; j++)
- {
- switch (j)
- {
+ for (j = 0; j < wxNUM_STYLES; j++)
+ {
+ switch (j)
+ {
case wxSTYLE_NORMAL: style = "Straight"; break;
case wxSTYLE_ITALIC: style = "Italic"; break;
case wxSTYLE_SLANT:
names[2] = style;
SearchResource(devresname, names, 3, &v);
-
- // Expand macros in the found string:
+
+ // Expand macros in the found string:
found:
int len, closer = 0, startpos = 0;
len = (v ? strlen(v) : 0);
- for (i = 0; i < len; i++)
- {
- if (v[i] == '$' && ((v[i+1] == '[') || (v[i+1] == '{')))
- {
+ for (i = 0; i < len; i++)
+ {
+ if (v[i] == '$' && ((v[i+1] == '[') || (v[i+1] == '{')))
+ {
startpos = i;
closer = (v[i+1] == '[') ? ']' : '}';
++i;
- }
- else if (v[i] == closer)
- {
+ }
+ else if (v[i] == closer)
+ {
int newstrlen;
const char *r = (char *) NULL; bool delete_r = FALSE;
char *name;
name = v + startpos + 2;
v[i] = 0;
- if (closer == '}')
- {
+ if (closer == '}')
+ {
int i, count, len;
char **names;
names = new char*[count];
names[0] = name;
for (i = 0, count = 1; i < len; i++)
- if (name[i] == ',')
- {
+ if (name[i] == ',')
+ {
names[count++] = name + i + 1;
name[i] = 0;
}
delete_r = (r != 0);
delete[] names;
- if (!r)
- {
+ if (!r)
+ {
for (i = 0; i < len; i++)
if (!name[i])
name[i] = ',';
goto found;
}
}
- // We have a final value:
+ // We have a final value:
map[k][j] = v;
}
}
// wxFontNameItem
//-----------------------------------------------------------------------------
-class wxFontNameItem : public wxObject
+class wxFontNameItem : public wxObject
{
DECLARE_DYNAMIC_CLASS(wxFontNameItem)
public:
// Cleanup wxFontNameItems allocated
table->BeginFind();
wxNode *node = table->Next();
- while (node)
+ while (node)
{
wxFontNameItem *item = (wxFontNameItem*)node->Data();
delete item;
sprintf(resource, "Family%s", resname);
SearchResource((const char *)resource, (const char **) NULL, 0, (char **)&fam);
-
- if (fam)
+
+ if (fam)
{
if (!strcmp(fam, "Default")) family = wxDEFAULT;
else if (!strcmp(fam, "Roman")) family = wxROMAN;
int wxFontNameDirectory::FindOrCreateFontId(const char *name, int family)
{
int id;
-
+
// font exists -> return id
if ( (id = GetFontId(name)) ) return id;
-
+
// create new font
Initialize(id=GetNewFontId(), family, name);
return id;
wxFontNameItem *item = (wxFontNameItem*)table->Get(fontid); // find font
if (item)
return item->GetScreenName(weight, style);
-
+
// font does not exist
return (char *) NULL;
}
wxFontNameItem *item = (wxFontNameItem*)table->Get(fontid); // find font
if (item)
return item->GetPostScriptName(weight, style);
-
+
// font does not exist
return (char *) NULL;
}
wxFontNameItem *item = (wxFontNameItem *)table->Get(fontid); // find font
if (item)
return item->GetName();
-
+
// font does not exist
return (char *) NULL;
}
table->BeginFind();
- while ( (node = table->Next()) )
+ while ( (node = table->Next()) )
{
wxFontNameItem *item = (wxFontNameItem*)node->Data();
if (!strcmp(name, item->name))
return item->id;
}
-
+
// font does not exist
return 0;
}
if (item)
return item->family;
-
+
// font does not exist
return wxDEFAULT;
}