Bug 85813 - PDT+ crash when selecting an I18N text

initializes mRTLKeyboard or mLTRKeyboard
r=mkaply, yokoyama sr=sfraser.
This commit is contained in:
yokoyama%netscape.com 2001-07-05 23:36:33 +00:00
parent 027e1300fd
commit 3648da66ec

View File

@ -30,6 +30,9 @@ nsBidiKeyboard::nsBidiKeyboard() : nsIBidiKeyboard()
NS_INIT_REFCNT(); NS_INIT_REFCNT();
#ifdef IBMBIDI #ifdef IBMBIDI
mDefaultsSet = PR_FALSE; mDefaultsSet = PR_FALSE;
mLTRKeyboard[0] = '\0';
mRTLKeyboard[0] = '\0';
mCurrentLocaleName[0] = '\0';
#endif #endif
} }
@ -50,7 +53,12 @@ NS_IMETHODIMP nsBidiKeyboard::SetLangFromBidiLevel(PRUint8 aLevel)
// call LoadKeyboardLayout() only if the target keyboard layout is different from the current // call LoadKeyboardLayout() only if the target keyboard layout is different from the current
char currentLocaleName[KL_NAMELENGTH]; char currentLocaleName[KL_NAMELENGTH];
strcpy(currentLocaleName, (aLevel & 1) ? mRTLKeyboard : mLTRKeyboard); strncpy(currentLocaleName, (aLevel & 1) ? mRTLKeyboard : mLTRKeyboard, KL_NAMELENGTH);
currentLocaleName[KL_NAMELENGTH-1] = '\0'; // null terminate
NS_ASSERTION((strlen(currentLocaleName) > 0),
"currentLocaleName has string length == 0");
if (strcmp(mCurrentLocaleName, currentLocaleName)) { if (strcmp(mCurrentLocaleName, currentLocaleName)) {
if (!::LoadKeyboardLayout(currentLocaleName, KLF_ACTIVATE | KLF_SUBSTITUTE_OK)) { if (!::LoadKeyboardLayout(currentLocaleName, KLF_ACTIVATE | KLF_SUBSTITUTE_OK)) {
return NS_ERROR_FAILURE; return NS_ERROR_FAILURE;
@ -72,11 +80,24 @@ NS_IMETHODIMP nsBidiKeyboard::IsLangRTL(PRBool *aIsRTL)
if (!::GetKeyboardLayoutName(mCurrentLocaleName)) if (!::GetKeyboardLayoutName(mCurrentLocaleName))
return NS_ERROR_FAILURE; return NS_ERROR_FAILURE;
NS_ASSERTION((strlen(mCurrentLocaleName) > 0),
"GetKeyboardLayoutName return string length == 0");
NS_ASSERTION((strlen(mCurrentLocaleName) < KL_NAMELENGTH),
"GetKeyboardLayoutName return string length >= KL_NAMELENGTH");
// The language set by the user overrides the default language for that direction // The language set by the user overrides the default language for that direction
if (*aIsRTL) if (*aIsRTL) {
strcpy(mRTLKeyboard, mCurrentLocaleName); strncpy(mRTLKeyboard, mCurrentLocaleName, KL_NAMELENGTH);
else mRTLKeyboard[KL_NAMELENGTH-1] = '\0'; // null terminate
strcpy(mLTRKeyboard, mCurrentLocaleName); } else {
strncpy(mLTRKeyboard, mCurrentLocaleName, KL_NAMELENGTH);
mLTRKeyboard[KL_NAMELENGTH-1] = '\0'; // null terminate
}
NS_ASSERTION((strlen(mRTLKeyboard) < KL_NAMELENGTH),
"mLTRKeyboard has string length >= KL_NAMELENGTH");
NS_ASSERTION((strlen(mLTRKeyboard) < KL_NAMELENGTH),
"mRTLKeyboard has string length >= KL_NAMELENGTH");
#endif #endif
return NS_OK; return NS_OK;
} }
@ -92,6 +113,8 @@ nsresult nsBidiKeyboard::EnumerateKeyboards()
HKL far* buf; HKL far* buf;
HKL locale; HKL locale;
char localeName[KL_NAMELENGTH]; char localeName[KL_NAMELENGTH];
PRBool isLTRKeyboardSet = PR_FALSE;
PRBool isRTLKeyboardSet = PR_FALSE;
// GetKeyboardLayoutList with 0 as first parameter returns the number of keyboard layouts available // GetKeyboardLayoutList with 0 as first parameter returns the number of keyboard layouts available
keyboards = ::GetKeyboardLayoutList(0, nsnull); keyboards = ::GetKeyboardLayoutList(0, nsnull);
@ -112,10 +135,14 @@ nsresult nsBidiKeyboard::EnumerateKeyboards()
// Go through the list and pick a default LTR and RTL keyboard layout // Go through the list and pick a default LTR and RTL keyboard layout
while (keyboards--) { while (keyboards--) {
locale = buf[keyboards]; locale = buf[keyboards];
if (IsRTLLanguage(locale)) if (IsRTLLanguage(locale)) {
sprintf(mRTLKeyboard, "%.*x", KL_NAMELENGTH - 1, LANGIDFROMLCID(locale)); sprintf(mRTLKeyboard, "%.*x", KL_NAMELENGTH - 1, LANGIDFROMLCID(locale));
else isRTLKeyboardSet = PR_TRUE;
}
else {
sprintf(mLTRKeyboard, "%.*x", KL_NAMELENGTH - 1, LANGIDFROMLCID(locale)); sprintf(mLTRKeyboard, "%.*x", KL_NAMELENGTH - 1, LANGIDFROMLCID(locale));
isLTRKeyboardSet = PR_TRUE;
}
} }
PR_Free(buf); PR_Free(buf);
@ -123,16 +150,39 @@ nsresult nsBidiKeyboard::EnumerateKeyboards()
// mLTRKeyboard as appropriate. If the user has many keyboard layouts // mLTRKeyboard as appropriate. If the user has many keyboard layouts
// installed this prevents us from arbitrarily resetting the current // installed this prevents us from arbitrarily resetting the current
// layout (bug 80274) // layout (bug 80274)
// If one or other keyboard is still not initialized, copy the
// initialized keyboard to the uninitialized (bug 85813)
locale = ::GetKeyboardLayout(0); locale = ::GetKeyboardLayout(0);
if (!::GetKeyboardLayoutName(localeName)) if (!::GetKeyboardLayoutName(localeName))
return NS_ERROR_FAILURE; return NS_ERROR_FAILURE;
NS_ASSERTION((strlen(localeName) > 0),
"GetKeyboardLayoutName return string length == 0");
NS_ASSERTION((strlen(localeName) < KL_NAMELENGTH),
"GetKeyboardLayout return string length >= KL_NAMELENGTH");
if (IsRTLLanguage(locale)) { if (IsRTLLanguage(locale)) {
strcpy(mRTLKeyboard, localeName); strncpy(mRTLKeyboard, localeName, KL_NAMELENGTH);
mRTLKeyboard[KL_NAMELENGTH-1] = '\0'; // null terminate
if (! isLTRKeyboardSet) {
strncpy(mLTRKeyboard, localeName, KL_NAMELENGTH);
mLTRKeyboard[KL_NAMELENGTH-1] = '\0'; // null terminate
}
} }
else { else {
strcpy(mLTRKeyboard, localeName); strncpy(mLTRKeyboard, localeName, KL_NAMELENGTH);
mLTRKeyboard[KL_NAMELENGTH-1] = '\0'; // null terminate
if (! isRTLKeyboardSet) {
strncpy(mRTLKeyboard, localeName, KL_NAMELENGTH);
mRTLKeyboard[KL_NAMELENGTH-1] = '\0'; // null terminate
} }
}
NS_ASSERTION((strlen(mRTLKeyboard) > 0),
"mLTRKeyboard has string length == 0");
NS_ASSERTION((strlen(mLTRKeyboard) > 0),
"mLTRKeyboard has string length == 0");
return NS_OK; return NS_OK;
} }