X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/5fe8354960174a56ee21c456ac3ba521a7b9bae5..f427e0d63499522aeeb8360e6a5c748de0a87d92:/src/common/fontmap.cpp diff --git a/src/common/fontmap.cpp b/src/common/fontmap.cpp index 8b159319d4..0ef4622bdf 100644 --- a/src/common/fontmap.cpp +++ b/src/common/fontmap.cpp @@ -133,7 +133,7 @@ static const wxChar* gs_encodingDescs[] = wxTRANSLATE( "Unicode 8 bit (UTF-8)" ), }; -// and the internal names +// and the internal names (these are not translated on purpose!) static const wxChar* gs_encodingNames[] = { wxT( "iso-8859-1" ), @@ -161,8 +161,8 @@ static const wxChar* gs_encodingNames[] = wxT( "windows-1256" ), wxT( "windows-1257" ), wxT( "windows-437" ), - wxT( "utf7" ), - wxT( "utf8" ), + wxT( "utf-7" ), + wxT( "utf-8" ), }; // ---------------------------------------------------------------------------- @@ -385,7 +385,7 @@ wxString wxFontMapper::GetEncodingName(wxFontEncoding encoding) { if ( gs_encodings[i] == encoding ) { - return wxGetTranslation(gs_encodingNames[i]); + return gs_encodingNames[i]; } } @@ -398,6 +398,12 @@ wxString wxFontMapper::GetEncodingName(wxFontEncoding encoding) wxFontEncoding wxFontMapper::CharsetToEncoding(const wxString& charset, bool interactive) { + // a special pseudo encoding which means "don't ask me about this charset + // any more" - we need it to avoid driving the user crazy with asking him + // time after time about the same charset which he [presumably] doesn't + // have the fonts fot + static const int wxFONTENCODING_UNKNOWN = -2; + wxFontEncoding encoding = wxFONTENCODING_SYSTEM; // we're going to modify it, make a copy @@ -414,6 +420,12 @@ wxFontEncoding wxFontMapper::CharsetToEncoding(const wxString& charset, long value = config->Read(charset, -1l); if ( value != -1 ) { + if ( value == wxFONTENCODING_UNKNOWN ) + { + // don't try to find it, in particular don't ask the user + return wxFONTENCODING_SYSTEM; + } + if ( value >= 0 && value <= wxFONTENCODING_MAX ) { encoding = (wxFontEncoding)value; @@ -440,7 +452,7 @@ wxFontEncoding wxFontMapper::CharsetToEncoding(const wxString& charset, RestorePath(pathOld); } -#endif +#endif // wxUSE_CONFIG // if didn't find it there, try to recognize it ourselves if ( encoding == wxFONTENCODING_SYSTEM ) @@ -590,24 +602,25 @@ wxFontEncoding wxFontMapper::CharsetToEncoding(const wxString& charset, if ( n != -1 ) { encoding = gs_encodings[n]; + } #if wxUSE_CONFIG // save the result in the config now - if ( ChangePath(FONTMAPPER_CHARSET_PATH, &pathOld) ) - { - wxConfigBase *config = GetConfig(); - - // remember the alt encoding for this charset - if ( !config->Write(charset, (long)encoding) ) - { - wxLogError(_("Failed to remember the encoding for the charset '%s'."), charset.c_str()); - } + if ( ChangePath(FONTMAPPER_CHARSET_PATH, &pathOld) ) + { + wxConfigBase *config = GetConfig(); - RestorePath(pathOld); + // remember the alt encoding for this charset - or remember that + // we don't know it + long value = n == -1 ? wxFONTENCODING_UNKNOWN : (long)encoding; + if ( !config->Write(charset, value) ) + { + wxLogError(_("Failed to remember the encoding for the charset '%s'."), charset.c_str()); } -#endif // wxUSE_CONFIG + + RestorePath(pathOld); } - //else: cancelled +#endif // wxUSE_CONFIG } #endif // wxUSE_GUI @@ -699,7 +712,8 @@ bool wxFontMapper::GetAltForEncoding(wxFontEncoding encoding, // wxFatalError doesn't return } - wxString configEntry, encName = GetEncodingName(encoding); + wxString configEntry, + encName = GetEncodingName(encoding); if ( !!facename ) { configEntry = facename + _T("_");