don't expose M_FONTDATA in public header

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@43547 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Václav Slavík
2006-11-20 16:43:55 +00:00
parent cd4e5a4998
commit d04f9b8e31
3 changed files with 76 additions and 275 deletions

View File

@@ -324,7 +324,7 @@ bool wxFontBase::operator==(const wxFont& font) const
{ {
// either it is the same font, i.e. they share the same common data or they // either it is the same font, i.e. they share the same common data or they
// have different ref datas but still describe the same font // have different ref datas but still describe the same font
return GetFontData() == font.GetFontData() || return m_refData == font.m_refData ||
( (
Ok() == font.Ok() && Ok() == font.Ok() &&
GetPointSize() == font.GetPointSize() && GetPointSize() == font.GetPointSize() &&

View File

@@ -29,85 +29,12 @@
#include "wx/app.h" #include "wx/app.h"
#endif #endif
#include "wx/fontutil.h"
#include "wx/dfb/private.h" #include "wx/dfb/private.h"
#include "wx/private/fontmgr.h"
// ---------------------------------------------------------------------------- typedef wxFontMgrFontRefData wxFontRefData;
// wxFontRefData
// ----------------------------------------------------------------------------
// FIXME: for now, always use single font
static wxIDirectFBFontPtr gs_font = NULL;
static unsigned gs_fontRefCnt = 0;
class wxFontRefData : public wxObjectRefData
{
public:
wxFontRefData(int size = wxDEFAULT,
int family = wxDEFAULT,
int style = wxDEFAULT,
int weight = wxDEFAULT,
bool underlined = false,
const wxString& faceName = wxEmptyString,
wxFontEncoding encoding = wxFONTENCODING_DEFAULT)
{
if ( family == wxDEFAULT )
family = wxSWISS;
if ( style == wxDEFAULT )
style = wxNORMAL;
if ( weight == wxDEFAULT )
weight = wxNORMAL;
if ( size == wxDEFAULT )
size = 12;
m_info.family = (wxFontFamily)family;
m_info.faceName = faceName;
m_info.style = (wxFontStyle)style;
m_info.weight = (wxFontWeight)weight;
m_info.pointSize = size;
m_info.underlined = underlined;
m_info.encoding = encoding;
// FIXME: always use default font for now
if ( !gs_font )
{
DFBFontDescription desc;
desc.flags = (DFBFontDescriptionFlags)0;
wxIDirectFBFontPtr f(wxIDirectFB::Get()->CreateFont(NULL, &desc));
if ( f )
gs_font = f;
}
if ( gs_font ) // the above may fail
{
gs_fontRefCnt++;
m_font = gs_font;
}
}
wxFontRefData(const wxFontRefData& data)
{
m_info = data.m_info;
m_font = data.m_font;
}
~wxFontRefData()
{
if ( m_font )
{
m_font.Reset();
// FIXME
if ( --gs_fontRefCnt == 0 )
gs_font = NULL;
}
}
wxNativeFontInfo m_info;
wxIDirectFBFontPtr m_font;
};
#define M_FONTDATA ((wxFontRefData*)m_refData) #define M_FONTDATA ((wxFontRefData*)m_refData)
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// wxFont // wxFont
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@@ -148,53 +75,55 @@ wxObjectRefData *wxFont::CloneRefData(const wxObjectRefData *data) const
// accessors // accessors
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
wxIDirectFBFontPtr wxFont::GetDirectFBFont() const wxIDirectFBFontPtr wxFont::GetDirectFBFont(bool antialiased) const
{ {
wxCHECK_MSG( Ok(), NULL, wxT("invalid font") ); wxCHECK_MSG( Ok(), NULL, wxT("invalid font") );
return M_FONTDATA->m_font; // we don't support DC scaling yet, so use scale=1
wxFontInstance *i = M_FONTDATA->GetFontInstance(1.0, antialiased);
return i ? i->GetDirectFBFont() : wxIDirectFBFontPtr();
} }
int wxFont::GetPointSize() const int wxFont::GetPointSize() const
{ {
wxCHECK_MSG( Ok(), 0, wxT("invalid font") ); wxCHECK_MSG( Ok(), 0, wxT("invalid font") );
return M_FONTDATA->m_info.pointSize; return M_FONTDATA->GetPointSize();
} }
wxString wxFont::GetFaceName() const wxString wxFont::GetFaceName() const
{ {
wxCHECK_MSG( Ok(), wxEmptyString, wxT("invalid font") ); wxCHECK_MSG( Ok(), wxEmptyString, wxT("invalid font") );
return M_FONTDATA->m_info.faceName; return M_FONTDATA->GetFaceName();
} }
int wxFont::GetFamily() const int wxFont::GetFamily() const
{ {
wxCHECK_MSG( Ok(), 0, wxT("invalid font") ); wxCHECK_MSG( Ok(), 0, wxT("invalid font") );
return M_FONTDATA->m_info.family; return M_FONTDATA->GetFamily();
} }
int wxFont::GetStyle() const int wxFont::GetStyle() const
{ {
wxCHECK_MSG( Ok(), 0, wxT("invalid font") ); wxCHECK_MSG( Ok(), 0, wxT("invalid font") );
return M_FONTDATA->m_info.style; return M_FONTDATA->GetStyle();
} }
int wxFont::GetWeight() const int wxFont::GetWeight() const
{ {
wxCHECK_MSG( Ok(), 0, wxT("invalid font") ); wxCHECK_MSG( Ok(), 0, wxT("invalid font") );
return M_FONTDATA->m_info.weight; return M_FONTDATA->GetWeight();
} }
bool wxFont::GetUnderlined() const bool wxFont::GetUnderlined() const
{ {
wxCHECK_MSG( Ok(), false, wxT("invalid font") ); wxCHECK_MSG( Ok(), false, wxT("invalid font") );
return M_FONTDATA->m_info.underlined; return M_FONTDATA->GetUnderlined();
} }
@@ -202,21 +131,28 @@ wxFontEncoding wxFont::GetEncoding() const
{ {
wxCHECK_MSG( Ok(), wxFONTENCODING_DEFAULT, wxT("invalid font") ); wxCHECK_MSG( Ok(), wxFONTENCODING_DEFAULT, wxT("invalid font") );
return M_FONTDATA->m_info.encoding; return M_FONTDATA->GetEncoding();
} }
bool wxFont::IsFixedWidth() const bool wxFont::IsFixedWidth() const
{ {
wxCHECK_MSG( Ok(), false, wxT("invalid font") ); wxCHECK_MSG( Ok(), false, wxT("invalid font") );
return true; // FIXME_DFB return M_FONTDATA->IsFixedWidth();
} }
const wxNativeFontInfo *wxFont::GetNativeFontInfo() const const wxNativeFontInfo *wxFont::GetNativeFontInfo() const
{ {
wxCHECK_MSG( Ok(), NULL, wxT("invalid font") ); wxCHECK_MSG( Ok(), NULL, wxT("invalid font") );
return &(M_FONTDATA->m_info); return M_FONTDATA->GetNativeFontInfo();
}
bool wxFont::GetNoAntiAliasing() const
{
wxCHECK_MSG( Ok(), false, wxT("invalid font") );
return M_FONTDATA->GetNoAntiAliasing();
} }
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@@ -226,50 +162,48 @@ const wxNativeFontInfo *wxFont::GetNativeFontInfo() const
void wxFont::SetPointSize(int pointSize) void wxFont::SetPointSize(int pointSize)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetPointSize(pointSize);
M_FONTDATA->m_info.pointSize = pointSize;
} }
void wxFont::SetFamily(int family) void wxFont::SetFamily(int family)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetFamily(family);
M_FONTDATA->m_info.family = (wxFontFamily)family;
} }
void wxFont::SetStyle(int style) void wxFont::SetStyle(int style)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetStyle(style);
M_FONTDATA->m_info.style = (wxFontStyle)style;
} }
void wxFont::SetWeight(int weight) void wxFont::SetWeight(int weight)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetWeight(weight);
M_FONTDATA->m_info.weight = (wxFontWeight)weight;
} }
bool wxFont::SetFaceName(const wxString& faceName) bool wxFont::SetFaceName(const wxString& faceName)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetFaceName(faceName);
M_FONTDATA->m_info.faceName = faceName;
return wxFontBase::SetFaceName(faceName); return wxFontBase::SetFaceName(faceName);
} }
void wxFont::SetUnderlined(bool underlined) void wxFont::SetUnderlined(bool underlined)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetUnderlined(underlined);
M_FONTDATA->m_info.underlined = underlined;
} }
void wxFont::SetEncoding(wxFontEncoding encoding) void wxFont::SetEncoding(wxFontEncoding encoding)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetEncoding(encoding);
M_FONTDATA->m_info.encoding = encoding; }
void wxFont::SetNoAntiAliasing(bool no)
{
AllocExclusive();
M_FONTDATA->SetNoAntiAliasing(no);
} }

View File

@@ -23,136 +23,14 @@
#include "wx/font.h" #include "wx/font.h"
#ifndef WX_PRECOMP #include "wx/private/fontmgr.h"
#include "wx/log.h"
#include "wx/utils.h"
#include "wx/settings.h"
#include "wx/cmndata.h"
#include "wx/gdicmn.h"
#endif
#include "wx/fontutil.h"
#include "wx/tokenzr.h"
#include "wx/mgl/private.h"
// ----------------------------------------------------------------------------
// wxFontRefData
// ----------------------------------------------------------------------------
class wxFontRefData : public wxObjectRefData
{
public:
wxFontRefData(int size = wxDEFAULT,
int family = wxDEFAULT,
int style = wxDEFAULT,
int weight = wxDEFAULT,
bool underlined = false,
const wxString& faceName = wxEmptyString,
wxFontEncoding encoding = wxFONTENCODING_DEFAULT);
wxFontRefData(const wxFontRefData& data);
virtual ~wxFontRefData();
protected:
// common part of all ctors
void Init(int pointSize,
int family,
int style,
int weight,
bool underlined,
const wxString& faceName,
wxFontEncoding encoding);
private:
int m_pointSize;
int m_family,
m_style,
m_weight;
bool m_underlined;
wxString m_faceName;
wxFontEncoding m_encoding;
wxMGLFontLibrary *m_library;
bool m_valid;
wxNativeFontInfo m_info;
friend class wxFont;
};
#define M_FONTDATA ((wxFontRefData*)m_refData)
// ============================================================================ // ============================================================================
// implementation // implementation
// ============================================================================ // ============================================================================
// ---------------------------------------------------------------------------- typedef wxFontMgrFontRefData wxFontRefData;
// wxFontRefData #define M_FONTDATA ((wxFontRefData*)m_refData)
// ----------------------------------------------------------------------------
void wxFontRefData::Init(int pointSize,
int family,
int style,
int weight,
bool underlined,
const wxString& faceName,
wxFontEncoding encoding)
{
if ( family == wxDEFAULT )
m_family = wxSWISS;
else
m_family = family;
m_faceName = faceName;
if ( style == wxDEFAULT )
m_style = wxNORMAL;
else
m_style = style;
if ( weight == wxDEFAULT )
m_weight = wxNORMAL;
else
m_weight = weight;
if ( pointSize == wxDEFAULT )
m_pointSize = 12;
else
m_pointSize = pointSize;
m_underlined = underlined;
m_encoding = encoding;
m_library = NULL;
m_valid = false;
}
wxFontRefData::wxFontRefData(const wxFontRefData& data)
{
Init(data.m_pointSize, data.m_family, data.m_style, data.m_weight,
data.m_underlined, data.m_faceName, data.m_encoding);
m_library = data.m_library;
m_valid = data.m_valid;
if ( m_library )
m_library->IncRef();
wxLogTrace("mgl_font", "created fntrefdata %p, library is %p", this, m_library);
}
wxFontRefData::wxFontRefData(int size, int family, int style,
int weight, bool underlined,
const wxString& faceName,
wxFontEncoding encoding)
{
Init(size, family, style, weight, underlined, faceName, encoding);
wxLogTrace("mgl_font", "created fntrefdata %p, library is %p", this, m_library);
}
wxFontRefData::~wxFontRefData()
{
wxLogTrace("mgl_font", "destructing fntrefdata %p, library is %p", this, m_library);
if ( m_library )
m_library->DecRef();
}
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// wxFont // wxFont
@@ -179,23 +57,6 @@ bool wxFont::Create(int pointSize,
return true; return true;
} }
struct font_t *wxFont::GetMGLfont_t(float scale, bool antialiased)
{
if ( !M_FONTDATA->m_valid )
{
wxMGLFontLibrary *old = M_FONTDATA->m_library;
M_FONTDATA->m_library = wxTheFontsManager->GetFontLibrary(this);
M_FONTDATA->m_library->IncRef();
if ( old )
old->DecRef();
}
wxMGLFontInstance *instance =
M_FONTDATA->m_library->GetFontInstance(this, scale, antialiased);
return instance->GetMGLfont_t();
}
wxObjectRefData *wxFont::CreateRefData() const wxObjectRefData *wxFont::CreateRefData() const
{ {
return new wxFontRefData; return new wxFontRefData;
@@ -211,46 +72,55 @@ wxObjectRefData *wxFont::CloneRefData(const wxObjectRefData *data) const
// accessors // accessors
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
struct font_t *wxFont::GetMGLfont_t(float scale, bool antialiased)
{
wxCHECK_MSG( Ok(), NULL, wxT("invalid font") );
// we don't support DC scaling yet, so use scale=1
wxFontInstance *i = M_FONTDATA->GetFontInstance(1.0, antialiased);
return i ? i->GetMGLfont_t() : NULL;
}
int wxFont::GetPointSize() const int wxFont::GetPointSize() const
{ {
wxCHECK_MSG( Ok(), 0, wxT("invalid font") ); wxCHECK_MSG( Ok(), 0, wxT("invalid font") );
return M_FONTDATA->m_pointSize; return M_FONTDATA->GetPointSize();
} }
wxString wxFont::GetFaceName() const wxString wxFont::GetFaceName() const
{ {
wxCHECK_MSG( Ok(), wxEmptyString, wxT("invalid font") ); wxCHECK_MSG( Ok(), wxEmptyString, wxT("invalid font") );
return M_FONTDATA->m_faceName; return M_FONTDATA->GetFaceName();
} }
int wxFont::GetFamily() const int wxFont::GetFamily() const
{ {
wxCHECK_MSG( Ok(), 0, wxT("invalid font") ); wxCHECK_MSG( Ok(), 0, wxT("invalid font") );
return M_FONTDATA->m_family; return M_FONTDATA->GetFamily();
} }
int wxFont::GetStyle() const int wxFont::GetStyle() const
{ {
wxCHECK_MSG( Ok(), 0, wxT("invalid font") ); wxCHECK_MSG( Ok(), 0, wxT("invalid font") );
return M_FONTDATA->m_style; return M_FONTDATA->GetStyle();
} }
int wxFont::GetWeight() const int wxFont::GetWeight() const
{ {
wxCHECK_MSG( Ok(), 0, wxT("invalid font") ); wxCHECK_MSG( Ok(), 0, wxT("invalid font") );
return M_FONTDATA->m_weight; return M_FONTDATA->GetWeight();
} }
bool wxFont::GetUnderlined() const bool wxFont::GetUnderlined() const
{ {
wxCHECK_MSG( Ok(), false, wxT("invalid font") ); wxCHECK_MSG( Ok(), false, wxT("invalid font") );
return M_FONTDATA->m_underlined; return M_FONTDATA->GetUnderlined();
} }
@@ -258,23 +128,28 @@ wxFontEncoding wxFont::GetEncoding() const
{ {
wxCHECK_MSG( Ok(), wxFONTENCODING_DEFAULT, wxT("invalid font") ); wxCHECK_MSG( Ok(), wxFONTENCODING_DEFAULT, wxT("invalid font") );
return M_FONTDATA->m_encoding; return M_FONTDATA->GetEncoding();
} }
bool wxFont::IsFixedWidth() const bool wxFont::IsFixedWidth() const
{ {
wxCHECK_MSG( Ok(), false, wxT("invalid font") ); wxCHECK_MSG( Ok(), false, wxT("invalid font") );
return (bool)(M_FONTDATA->m_library->GetFamily()->GetInfo()->isFixed); return M_FONTDATA->IsFixedWidth();
} }
const wxNativeFontInfo *wxFont::GetNativeFontInfo() const const wxNativeFontInfo *wxFont::GetNativeFontInfo() const
{ {
wxCHECK_MSG( Ok(), NULL, wxT("invalid font") ); wxCHECK_MSG( Ok(), NULL, wxT("invalid font") );
M_FONTDATA->m_info.InitFromFont(*this); return M_FONTDATA->GetNativeFontInfo();
}
return &(M_FONTDATA->m_info); bool wxFont::GetNoAntiAliasing() const
{
wxCHECK_MSG( Ok(), false, wxT("invalid font") );
return M_FONTDATA->GetNoAntiAliasing();
} }
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@@ -284,56 +159,48 @@ const wxNativeFontInfo *wxFont::GetNativeFontInfo() const
void wxFont::SetPointSize(int pointSize) void wxFont::SetPointSize(int pointSize)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetPointSize(pointSize);
M_FONTDATA->m_pointSize = pointSize;
M_FONTDATA->m_valid = false;
} }
void wxFont::SetFamily(int family) void wxFont::SetFamily(int family)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetFamily(family);
M_FONTDATA->m_family = family;
M_FONTDATA->m_valid = false;
} }
void wxFont::SetStyle(int style) void wxFont::SetStyle(int style)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetStyle(style);
M_FONTDATA->m_style = style;
M_FONTDATA->m_valid = false;
} }
void wxFont::SetWeight(int weight) void wxFont::SetWeight(int weight)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetWeight(weight);
M_FONTDATA->m_weight = weight;
M_FONTDATA->m_valid = false;
} }
bool wxFont::SetFaceName(const wxString& faceName) bool wxFont::SetFaceName(const wxString& faceName)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetFaceName(faceName);
M_FONTDATA->m_faceName = faceName;
M_FONTDATA->m_valid = false;
return wxFontBase::SetFaceName(faceName); return wxFontBase::SetFaceName(faceName);
} }
void wxFont::SetUnderlined(bool underlined) void wxFont::SetUnderlined(bool underlined)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetUnderlined(underlined);
M_FONTDATA->m_underlined = underlined;
} }
void wxFont::SetEncoding(wxFontEncoding encoding) void wxFont::SetEncoding(wxFontEncoding encoding)
{ {
AllocExclusive(); AllocExclusive();
M_FONTDATA->SetEncoding(encoding);
M_FONTDATA->m_encoding = encoding; }
M_FONTDATA->m_valid = false;
void wxFont::SetNoAntiAliasing(bool no)
{
AllocExclusive();
M_FONTDATA->SetNoAntiAliasing(no);
} }