Initialize wxCSConv immediately instead of deferring it.
Deferred initialization code was not MT-safe and just wasn't that useful anyhow because it is rare to create a wxCSConv object and not use it afterwards. Remove the deferred initialization logic and create the real conversion used by wxCSConv immediately in its ctor. Also improve the comments by clearly explaining the possible values of wxCSConv::m_name and m_encoding. Closes #12630. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@66119 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
93fdbfb70d
commit
6c4d607e60
@ -522,31 +522,36 @@ private:
|
|||||||
// common part of all ctors
|
// common part of all ctors
|
||||||
void Init();
|
void Init();
|
||||||
|
|
||||||
// creates m_convReal if necessary
|
// Creates the conversion to use, called from all ctors to initialize
|
||||||
void CreateConvIfNeeded() const;
|
// m_convReal.
|
||||||
|
|
||||||
// do create m_convReal (unconditionally)
|
|
||||||
wxMBConv *DoCreate() const;
|
wxMBConv *DoCreate() const;
|
||||||
|
|
||||||
// set the name (may be only called when m_name == NULL), makes copy of
|
// Set the name (may be only called when m_name == NULL), makes copy of
|
||||||
// the charset string
|
// the charset string.
|
||||||
void SetName(const char *charset);
|
void SetName(const char *charset);
|
||||||
|
|
||||||
|
// Set m_encoding field respecting the rules below, i.e. making sure it has
|
||||||
// m_name may be NULL in which case m_encoding should be used
|
// a valid value if m_name == NULL (thus this should be always called after
|
||||||
|
// SetName()).
|
||||||
//
|
//
|
||||||
// note that we can't use wxString here because of compilation
|
// Input encoding may be valid or not.
|
||||||
// dependencies: we're included from wx/string.h
|
void SetEncoding(wxFontEncoding encoding);
|
||||||
|
|
||||||
|
|
||||||
|
// The encoding we use is specified by the two fields below:
|
||||||
|
//
|
||||||
|
// 1. If m_name != NULL, m_encoding corresponds to it if it's one of
|
||||||
|
// encodings we know about (i.e. member of wxFontEncoding) or is
|
||||||
|
// wxFONTENCODING_SYSTEM otherwise.
|
||||||
|
//
|
||||||
|
// 2. If m_name == NULL, m_encoding is always valid, i.e. not one of
|
||||||
|
// wxFONTENCODING_{SYSTEM,DEFAULT,MAX}.
|
||||||
char *m_name;
|
char *m_name;
|
||||||
|
|
||||||
// may be wxFONTENCODING_SYSTEM in which case m_name is used
|
|
||||||
//
|
|
||||||
// if m_name is NULL, then we should use the default system encoding
|
|
||||||
wxFontEncoding m_encoding;
|
wxFontEncoding m_encoding;
|
||||||
|
|
||||||
// use CreateConvIfNeeded() before accessing m_convReal!
|
// The conversion object for our encoding or NULL if we failed to create it
|
||||||
|
// in which case we fall back to hard-coded ISO8859-1 conversion.
|
||||||
wxMBConv *m_convReal;
|
wxMBConv *m_convReal;
|
||||||
bool m_deferred;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -2945,7 +2945,41 @@ void wxCSConv::Init()
|
|||||||
{
|
{
|
||||||
m_name = NULL;
|
m_name = NULL;
|
||||||
m_convReal = NULL;
|
m_convReal = NULL;
|
||||||
m_deferred = true;
|
}
|
||||||
|
|
||||||
|
void wxCSConv::SetEncoding(wxFontEncoding encoding)
|
||||||
|
{
|
||||||
|
switch ( encoding )
|
||||||
|
{
|
||||||
|
case wxFONTENCODING_MAX:
|
||||||
|
case wxFONTENCODING_SYSTEM:
|
||||||
|
if ( m_name )
|
||||||
|
{
|
||||||
|
// It's ok to not have encoding value if we have a name for it.
|
||||||
|
m_encoding = wxFONTENCODING_SYSTEM;
|
||||||
|
}
|
||||||
|
else // No name neither.
|
||||||
|
{
|
||||||
|
// Fall back to the system default encoding in this case (not
|
||||||
|
// sure how much sense does this make but this is how the old
|
||||||
|
// code used to behave).
|
||||||
|
#if wxUSE_INTL
|
||||||
|
m_encoding = wxLocale::GetSystemEncoding();
|
||||||
|
if ( m_encoding == wxFONTENCODING_SYSTEM )
|
||||||
|
#endif // wxUSE_INTL
|
||||||
|
m_encoding = wxFONTENCODING_ISO8859_1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxFONTENCODING_DEFAULT:
|
||||||
|
// wxFONTENCODING_DEFAULT is same as US-ASCII in this context
|
||||||
|
m_encoding = wxFONTENCODING_ISO8859_1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
// Just use the provided encoding.
|
||||||
|
m_encoding = encoding;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
wxCSConv::wxCSConv(const wxString& charset)
|
wxCSConv::wxCSConv(const wxString& charset)
|
||||||
@ -2958,20 +2992,12 @@ wxCSConv::wxCSConv(const wxString& charset)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if wxUSE_FONTMAP
|
#if wxUSE_FONTMAP
|
||||||
m_encoding = wxFontMapperBase::GetEncodingFromName(charset);
|
SetEncoding(wxFontMapperBase::GetEncodingFromName(charset));
|
||||||
if ( m_encoding == wxFONTENCODING_MAX )
|
|
||||||
{
|
|
||||||
// set to unknown/invalid value
|
|
||||||
m_encoding = wxFONTENCODING_SYSTEM;
|
|
||||||
}
|
|
||||||
else if ( m_encoding == wxFONTENCODING_DEFAULT )
|
|
||||||
{
|
|
||||||
// wxFONTENCODING_DEFAULT is same as US-ASCII in this context
|
|
||||||
m_encoding = wxFONTENCODING_ISO8859_1;
|
|
||||||
}
|
|
||||||
#else
|
#else
|
||||||
m_encoding = wxFONTENCODING_SYSTEM;
|
SetEncoding(wxFONTENCODING_SYSTEM);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
m_convReal = DoCreate();
|
||||||
}
|
}
|
||||||
|
|
||||||
wxCSConv::wxCSConv(wxFontEncoding encoding)
|
wxCSConv::wxCSConv(wxFontEncoding encoding)
|
||||||
@ -2985,7 +3011,9 @@ wxCSConv::wxCSConv(wxFontEncoding encoding)
|
|||||||
|
|
||||||
Init();
|
Init();
|
||||||
|
|
||||||
m_encoding = encoding;
|
SetEncoding(encoding);
|
||||||
|
|
||||||
|
m_convReal = DoCreate();
|
||||||
}
|
}
|
||||||
|
|
||||||
wxCSConv::~wxCSConv()
|
wxCSConv::~wxCSConv()
|
||||||
@ -2999,7 +3027,9 @@ wxCSConv::wxCSConv(const wxCSConv& conv)
|
|||||||
Init();
|
Init();
|
||||||
|
|
||||||
SetName(conv.m_name);
|
SetName(conv.m_name);
|
||||||
m_encoding = conv.m_encoding;
|
SetEncoding(conv.m_encoding);
|
||||||
|
|
||||||
|
m_convReal = DoCreate();
|
||||||
}
|
}
|
||||||
|
|
||||||
wxCSConv& wxCSConv::operator=(const wxCSConv& conv)
|
wxCSConv& wxCSConv::operator=(const wxCSConv& conv)
|
||||||
@ -3007,7 +3037,9 @@ wxCSConv& wxCSConv::operator=(const wxCSConv& conv)
|
|||||||
Clear();
|
Clear();
|
||||||
|
|
||||||
SetName(conv.m_name);
|
SetName(conv.m_name);
|
||||||
m_encoding = conv.m_encoding;
|
SetEncoding(conv.m_encoding);
|
||||||
|
|
||||||
|
m_convReal = DoCreate();
|
||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
@ -3015,18 +3047,15 @@ wxCSConv& wxCSConv::operator=(const wxCSConv& conv)
|
|||||||
void wxCSConv::Clear()
|
void wxCSConv::Clear()
|
||||||
{
|
{
|
||||||
free(m_name);
|
free(m_name);
|
||||||
wxDELETE(m_convReal);
|
|
||||||
|
|
||||||
m_name = NULL;
|
m_name = NULL;
|
||||||
|
|
||||||
|
wxDELETE(m_convReal);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxCSConv::SetName(const char *charset)
|
void wxCSConv::SetName(const char *charset)
|
||||||
{
|
{
|
||||||
if (charset)
|
if ( charset )
|
||||||
{
|
|
||||||
m_name = wxStrdup(charset);
|
m_name = wxStrdup(charset);
|
||||||
m_deferred = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#if wxUSE_FONTMAP
|
#if wxUSE_FONTMAP
|
||||||
@ -3049,8 +3078,7 @@ wxMBConv *wxCSConv::DoCreate() const
|
|||||||
// check for the special case of ASCII or ISO8859-1 charset: as we have
|
// check for the special case of ASCII or ISO8859-1 charset: as we have
|
||||||
// special knowledge of it anyhow, we don't need to create a special
|
// special knowledge of it anyhow, we don't need to create a special
|
||||||
// conversion object
|
// conversion object
|
||||||
if ( m_encoding == wxFONTENCODING_ISO8859_1 ||
|
if ( m_encoding == wxFONTENCODING_ISO8859_1 )
|
||||||
m_encoding == wxFONTENCODING_DEFAULT )
|
|
||||||
{
|
{
|
||||||
// don't convert at all
|
// don't convert at all
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -3225,33 +3253,8 @@ wxMBConv *wxCSConv::DoCreate() const
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxCSConv::CreateConvIfNeeded() const
|
|
||||||
{
|
|
||||||
if ( m_deferred )
|
|
||||||
{
|
|
||||||
wxCSConv *self = const_cast<wxCSConv *>(this);
|
|
||||||
|
|
||||||
// if we don't have neither the name nor the encoding, use the default
|
|
||||||
// encoding for this system
|
|
||||||
if ( !m_name && m_encoding == wxFONTENCODING_SYSTEM )
|
|
||||||
{
|
|
||||||
#if wxUSE_INTL
|
|
||||||
self->m_encoding = wxLocale::GetSystemEncoding();
|
|
||||||
#else
|
|
||||||
// fallback to some reasonable default:
|
|
||||||
self->m_encoding = wxFONTENCODING_ISO8859_1;
|
|
||||||
#endif // wxUSE_INTL
|
|
||||||
}
|
|
||||||
|
|
||||||
self->m_convReal = DoCreate();
|
|
||||||
self->m_deferred = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool wxCSConv::IsOk() const
|
bool wxCSConv::IsOk() const
|
||||||
{
|
{
|
||||||
CreateConvIfNeeded();
|
|
||||||
|
|
||||||
// special case: no convReal created for wxFONTENCODING_ISO8859_1
|
// special case: no convReal created for wxFONTENCODING_ISO8859_1
|
||||||
if ( m_encoding == wxFONTENCODING_ISO8859_1 )
|
if ( m_encoding == wxFONTENCODING_ISO8859_1 )
|
||||||
return true; // always ok as we do it ourselves
|
return true; // always ok as we do it ourselves
|
||||||
@ -3264,8 +3267,6 @@ bool wxCSConv::IsOk() const
|
|||||||
size_t wxCSConv::ToWChar(wchar_t *dst, size_t dstLen,
|
size_t wxCSConv::ToWChar(wchar_t *dst, size_t dstLen,
|
||||||
const char *src, size_t srcLen) const
|
const char *src, size_t srcLen) const
|
||||||
{
|
{
|
||||||
CreateConvIfNeeded();
|
|
||||||
|
|
||||||
if (m_convReal)
|
if (m_convReal)
|
||||||
return m_convReal->ToWChar(dst, dstLen, src, srcLen);
|
return m_convReal->ToWChar(dst, dstLen, src, srcLen);
|
||||||
|
|
||||||
@ -3288,8 +3289,6 @@ size_t wxCSConv::ToWChar(wchar_t *dst, size_t dstLen,
|
|||||||
size_t wxCSConv::FromWChar(char *dst, size_t dstLen,
|
size_t wxCSConv::FromWChar(char *dst, size_t dstLen,
|
||||||
const wchar_t *src, size_t srcLen) const
|
const wchar_t *src, size_t srcLen) const
|
||||||
{
|
{
|
||||||
CreateConvIfNeeded();
|
|
||||||
|
|
||||||
if (m_convReal)
|
if (m_convReal)
|
||||||
return m_convReal->FromWChar(dst, dstLen, src, srcLen);
|
return m_convReal->FromWChar(dst, dstLen, src, srcLen);
|
||||||
|
|
||||||
@ -3325,12 +3324,8 @@ size_t wxCSConv::FromWChar(char *dst, size_t dstLen,
|
|||||||
|
|
||||||
size_t wxCSConv::GetMBNulLen() const
|
size_t wxCSConv::GetMBNulLen() const
|
||||||
{
|
{
|
||||||
CreateConvIfNeeded();
|
|
||||||
|
|
||||||
if ( m_convReal )
|
if ( m_convReal )
|
||||||
{
|
|
||||||
return m_convReal->GetMBNulLen();
|
return m_convReal->GetMBNulLen();
|
||||||
}
|
|
||||||
|
|
||||||
// otherwise, we are ISO-8859-1
|
// otherwise, we are ISO-8859-1
|
||||||
return 1;
|
return 1;
|
||||||
@ -3339,12 +3334,8 @@ size_t wxCSConv::GetMBNulLen() const
|
|||||||
#if wxUSE_UNICODE_UTF8
|
#if wxUSE_UNICODE_UTF8
|
||||||
bool wxCSConv::IsUTF8() const
|
bool wxCSConv::IsUTF8() const
|
||||||
{
|
{
|
||||||
CreateConvIfNeeded();
|
|
||||||
|
|
||||||
if ( m_convReal )
|
if ( m_convReal )
|
||||||
{
|
|
||||||
return m_convReal->IsUTF8();
|
return m_convReal->IsUTF8();
|
||||||
}
|
|
||||||
|
|
||||||
// otherwise, we are ISO-8859-1
|
// otherwise, we are ISO-8859-1
|
||||||
return false;
|
return false;
|
||||||
|
Loading…
Reference in New Issue
Block a user