Author: dgorbachev
Date: Tue Oct 13 20:43:42 2009
New Revision: 43439
URL: http://svn.reactos.org/svn/reactos?rev=43439&view=rev
Log:
- See if it is a multibyte code page.
- Remove check against zero.
- Fix comments, formatting.
Modified:
trunk/reactos/lib/rtl/unicode.c
Modified: trunk/reactos/lib/rtl/unicode.c
URL: http://svn.reactos.org/svn/reactos/trunk/reactos/lib/rtl/unicode.c?rev=4343…
==============================================================================
--- trunk/reactos/lib/rtl/unicode.c [iso-8859-1] (original)
+++ trunk/reactos/lib/rtl/unicode.c [iso-8859-1] Tue Oct 13 20:43:42 2009
@@ -401,40 +401,52 @@
/*
* @implemented
- *
+ *
* NOTES
- * Check the oem-string to match the uincoded-string.
- *
- * Functions who convert unicode strings to oem strings will set a DefaultChar from
- * the OemCodepage when the character are unknown. So check it against the unicode string
- * and return false when the unicode string not contain an TransDefaultChar.
+ * Check the OEM string to match the Unicode string.
+ *
+ * Functions which convert Unicode strings to OEM strings will set a
+ * DefaultChar from the OEM codepage when the characters are unknown.
+ * So check it against the Unicode string and return false when the
+ * Unicode string does not contain a TransDefaultChar.
*/
BOOLEAN
NTAPI
RtlpDidUnicodeToOemWork(IN PCUNICODE_STRING UnicodeString,
IN POEM_STRING OemString)
{
- ULONG i = 0;
-
- /* Go through all characters of a string */
- while (i < OemString->Length)
- {
- /* Check if it got translated into '?', but source char
- wasn't '?' equivalent */
- if ((OemString->Buffer[i] != 0) &&
- (OemString->Buffer[i] == NlsOemDefaultChar) &&
- (UnicodeString->Buffer[i] != NlsUnicodeDefaultChar))
- {
- /* Yes, it means unmappable characters were found */
- return FALSE;
- }
-
- /* Move to the next char */
- i++;
- }
-
- /* All chars were translated successfuly */
- return TRUE;
+ ULONG i = 0;
+
+ if (NlsMbOemCodePageTag == FALSE)
+ {
+ /* single-byte code page */
+ /* Go through all characters of a string */
+ while (i < OemString->Length)
+ {
+ /* Check if it got translated into a default char,
+ * but source char wasn't a default char equivalent
+ */
+ if ((OemString->Buffer[i] == NlsOemDefaultChar) &&
+ (UnicodeString->Buffer[i] != NlsUnicodeDefaultChar))
+ {
+ /* Yes, it means unmappable characters were found */
+ return FALSE;
+ }
+
+ /* Move to the next char */
+ i++;
+ }
+
+ /* All chars were translated successfuly */
+ return TRUE;
+ }
+ else
+ {
+ /* multibyte code page */
+
+ /* FIXME */
+ return TRUE;
+ }
}
/*
Author: fireball
Date: Tue Oct 13 20:01:55 2009
New Revision: 43438
URL: http://svn.reactos.org/svn/reactos?rev=43438&view=rev
Log:
[rtl]
- Fix an out-of-bounds read in RtlpDidUnicodeToOemWorked.
See issue #4888 for more details.
Modified:
trunk/reactos/lib/rtl/unicode.c
Modified: trunk/reactos/lib/rtl/unicode.c
URL: http://svn.reactos.org/svn/reactos/trunk/reactos/lib/rtl/unicode.c?rev=4343…
==============================================================================
--- trunk/reactos/lib/rtl/unicode.c [iso-8859-1] (original)
+++ trunk/reactos/lib/rtl/unicode.c [iso-8859-1] Tue Oct 13 20:01:55 2009
@@ -417,12 +417,12 @@
ULONG i = 0;
/* Go through all characters of a string */
- while ((OemString->Buffer[i] != 0) &&
- (i < OemString->Length))
+ while (i < OemString->Length)
{
/* Check if it got translated into '?', but source char
wasn't '?' equivalent */
- if ((OemString->Buffer[i] == NlsOemDefaultChar) &&
+ if ((OemString->Buffer[i] != 0) &&
+ (OemString->Buffer[i] == NlsOemDefaultChar) &&
(UnicodeString->Buffer[i] != NlsUnicodeDefaultChar))
{
/* Yes, it means unmappable characters were found */