Bug 548545 - don't try to get an atom for a NULL string. r=roc

This commit is contained in:
Jonathan Kew 2010-02-25 15:02:31 -08:00
Родитель 046387bdf5
Коммит b45694ede3
3 изменённых файлов: 16 добавлений и 5 удалений

Просмотреть файл

@ -74,7 +74,14 @@ nsThebesFontEnumerator::EnumerateFonts(const char *aLangGroup,
else
generic.SetIsVoid(PR_TRUE);
nsCOMPtr<nsIAtom> langGroupAtom = do_GetAtom(aLangGroup);
nsCOMPtr<nsIAtom> langGroupAtom;
if (aLangGroup) {
nsCAutoString lowered;
lowered.Assign(aLangGroup);
ToLowerCase(lowered);
langGroupAtom = do_GetAtom(lowered);
}
nsresult rv = gfxPlatform::GetPlatform()->GetFontList(langGroupAtom, generic, fontList);
if (NS_FAILED(rv)) {

Просмотреть файл

@ -282,8 +282,10 @@ gfxFontconfigUtils::GetFontList(nsIAtom *aLangGroup,
aListOfFonts.Clear();
nsTArray<nsCString> fonts;
nsCString langGroupStr;
aLangGroup->ToUTF8String(langGroupStr);
nsCAutoString langGroupStr;
if (aLangGroup) {
aLangGroup->ToUTF8String(langGroupStr);
}
nsresult rv = GetFontListInternal(fonts, langGroupStr);
if (NS_FAILED(rv))
return rv;

Просмотреть файл

@ -115,8 +115,10 @@ gfxOS2Platform::GetFontList(nsIAtom *aLangGroup,
nsTArray<nsString>& aListOfFonts)
{
#ifdef DEBUG_thebes
const char *langgroup;
aLangGroup->GetUTF8String(&langgroup);
const char *langgroup = "(null)";
if (aLangGroup) {
aLangGroup->GetUTF8String(&langgroup);
}
char *family = ToNewCString(aGenericFamily);
printf("gfxOS2Platform::GetFontList(%s, %s, ..)\n",
langgroup, family);