зеркало из https://github.com/mozilla/pjs.git
Bug 7427. Need to convert enumerated font names from system code page to
Unicode, and then convert Unicode font names back to system code page when loading font.
This commit is contained in:
Родитель
7ca1293268
Коммит
96f002fcd8
|
@ -532,9 +532,19 @@ nsFontMetricsWin::LoadFont(HDC aDC, nsString* aName)
|
||||||
LOGFONT logFont;
|
LOGFONT logFont;
|
||||||
FillLogFont(&logFont);
|
FillLogFont(&logFont);
|
||||||
|
|
||||||
// XXX need to preserve Unicode chars in face name (use LOGFONTW) -- erik
|
/*
|
||||||
aName->ToCString(logFont.lfFaceName, LF_FACESIZE);
|
* XXX we are losing info by converting from Unicode to system code page
|
||||||
|
* but we don't really have a choice since CreateFontIndirectW is
|
||||||
|
* not supported on Windows 9X (see below) -- erik
|
||||||
|
*/
|
||||||
|
logFont.lfFaceName[0] = 0;
|
||||||
|
WideCharToMultiByte(CP_ACP, 0, aName->GetUnicode(), aName->Length() + 1,
|
||||||
|
logFont.lfFaceName, sizeof(logFont.lfFaceName), nsnull, nsnull);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* According to http://msdn.microsoft.com/library/
|
||||||
|
* CreateFontIndirectW is only supported on NT/2000
|
||||||
|
*/
|
||||||
HFONT hfont = ::CreateFontIndirect(&logFont);
|
HFONT hfont = ::CreateFontIndirect(&logFont);
|
||||||
|
|
||||||
if (hfont) {
|
if (hfont) {
|
||||||
|
@ -600,8 +610,11 @@ static int CALLBACK enumProc(const LOGFONT* logFont, const TEXTMETRIC* metrics,
|
||||||
nsGlobalFont* font =
|
nsGlobalFont* font =
|
||||||
&nsFontMetricsWin::gGlobalFonts[nsFontMetricsWin::gGlobalFontsCount++];
|
&nsFontMetricsWin::gGlobalFonts[nsFontMetricsWin::gGlobalFontsCount++];
|
||||||
|
|
||||||
// XXX do correct character encoding conversion here
|
PRUnichar name[LF_FACESIZE];
|
||||||
font->name = new nsString(logFont->lfFaceName);
|
name[0] = 0;
|
||||||
|
MultiByteToWideChar(CP_ACP, 0, logFont->lfFaceName,
|
||||||
|
strlen(logFont->lfFaceName) + 1, name, sizeof(name)/sizeof(name[0]));
|
||||||
|
font->name = new nsString(name);
|
||||||
if (!font->name) {
|
if (!font->name) {
|
||||||
nsFontMetricsWin::gGlobalFontsCount--;
|
nsFontMetricsWin::gGlobalFontsCount--;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче