bug 91696, Meta tag does not work, r=shanjian , sr=vidur

This commit is contained in:
loadrunner%betak.net 2001-08-10 02:15:41 +00:00
Родитель 8d64a0247b
Коммит 41bf2e10fe
3 изменённых файлов: 31 добавлений и 14 удалений

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

@ -2520,7 +2520,7 @@ nsParser::DetectMetaTag(const char* aBytes,
if ((offset = tokenizer.GetNextWord(PR_TRUE)) != kNotFound) {
const char* contentStart = attrStart+offset;
CWordTokenizer<char> contentTokenizer(contentStart, 0,
tokenizer.GetLength());
attrEnd-contentStart);
// Read the content type
if (contentTokenizer.GetNextWord() != kNotFound) {

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

@ -179,12 +179,16 @@ NS_IMETHODIMP nsMetaCharsetObserver::Notify(
PRInt32 i;
const PRUnichar *httpEquivValue=nsnull;
const PRUnichar *contentValue=nsnull;
const PRUnichar *charsetValue=nsnull;
for(i=0;i<(numOfAttributes-3);i++)
{
if(0 == nsCRT::strcasecmp((keys->StringAt(i))->get(), "HTTP-EQUIV"))
httpEquivValue=((values->StringAt(i))->get());
else if(0 == nsCRT::strcasecmp((keys->StringAt(i))->get(), "content"))
contentValue=(values->StringAt(i))->get();
else if(0 == nsCRT::strcasecmp((keys->StringAt(i))->get(), "charset"))
charsetValue=(values->StringAt(i))->get();
}
NS_NAMED_LITERAL_STRING(contenttype, "Content-Type");
NS_NAMED_LITERAL_STRING(texthtml, "text/html");
@ -213,18 +217,31 @@ NS_IMETHODIMP nsMetaCharsetObserver::Notify(
))
)
{
nsAutoString contentPart1(contentValue+10); // after "text/html;"
PRInt32 start = contentPart1.RFind("charset=", PR_TRUE ) ;
if(kNotFound != start)
{
start += 8; // 8 = "charset=".length
PRInt32 end = contentPart1.FindCharInSet("\'\";", start );
if(kNotFound == end )
end = contentPart1.Length();
nsAutoString newCharset;
NS_ASSERTION(end>=start, "wrong index");
contentPart1.Mid(newCharset, start, end - start);
nsAutoString newCharset;
if (nsnull == charsetValue)
{
nsAutoString contentPart1(contentValue+10); // after "text/html;"
PRInt32 start = contentPart1.RFind("charset=", PR_TRUE ) ;
if(kNotFound != start)
{
start += 8; // 8 = "charset=".length
PRInt32 end = contentPart1.FindCharInSet("\'\";", start );
if(kNotFound == end )
end = contentPart1.Length();
NS_ASSERTION(end>=start, "wrong index");
contentPart1.Mid(newCharset, start, end - start);
}
}
else
{
newCharset = charsetValue;
}
if (!newCharset.IsEmpty())
{
nsAutoString charsetString(charset);
if(! newCharset.EqualsIgnoreCase(charsetString))
{
@ -248,7 +265,7 @@ NS_IMETHODIMP nsMetaCharsetObserver::Notify(
} // if(NS_SUCCEEDED(res)
}
} // if EqualIgnoreCase
} // if (kNotFound != start)
} // if !newCharset.IsEmpty()
} // if
}
else

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

@ -2520,7 +2520,7 @@ nsParser::DetectMetaTag(const char* aBytes,
if ((offset = tokenizer.GetNextWord(PR_TRUE)) != kNotFound) {
const char* contentStart = attrStart+offset;
CWordTokenizer<char> contentTokenizer(contentStart, 0,
tokenizer.GetLength());
attrEnd-contentStart);
// Read the content type
if (contentTokenizer.GetNextWord() != kNotFound) {