From 7b2dd0d7c1c64f0eb087b960aee3902cb0bc1bb7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jos=C3=A9=20Sim=C3=B5es?= Date: Wed, 13 Jun 2018 10:24:35 +0100 Subject: [PATCH] Fix issue with CLR_RT_UnicodeHelper::ConvertFromUTF8 (#742) --- src/CLR/Core/CLR_RT_UnicodeHelper.cpp | 24 ++++++++++++++---------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/src/CLR/Core/CLR_RT_UnicodeHelper.cpp b/src/CLR/Core/CLR_RT_UnicodeHelper.cpp index 87304db235..82d5b8029e 100644 --- a/src/CLR/Core/CLR_RT_UnicodeHelper.cpp +++ b/src/CLR/Core/CLR_RT_UnicodeHelper.cpp @@ -122,6 +122,13 @@ int CLR_RT_UnicodeHelper::CountNumberOfBytes( int max ) //--// +// dev note: need the pragma bellow because there are a couple of 'smart' hacks in +// the switch cases to improve the algorithm +#ifdef __GNUC__ +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wimplicit-fallthrough" +#endif + bool CLR_RT_UnicodeHelper::ConvertFromUTF8( int iMaxChars, bool fJustMove, int iMaxBytes ) { NATIVE_PROFILE_CLR_CORE(); @@ -143,14 +150,7 @@ bool CLR_RT_UnicodeHelper::ConvertFromUTF8( int iMaxChars, bool fJustMove, int i switch(ch & 0xF0) { - case 0x00: - if(ch == 0) - { - inputUTF8--; - goto ExitFalse; - } - break; - + case 0x00: if(ch == 0) { inputUTF8--; goto ExitFalse; } case 0x10: case 0x20: case 0x30: @@ -310,10 +310,10 @@ bool CLR_RT_UnicodeHelper::ConvertFromUTF8( int iMaxChars, bool fJustMove, int i res = true; goto Exit; -ExitFalse: + ExitFalse: res = false; -Exit: + Exit: m_inputUTF8 = inputUTF8; m_outputUTF16 = outputUTF16; m_outputUTF16_size = outputUTF16_size; @@ -321,6 +321,10 @@ bool CLR_RT_UnicodeHelper::ConvertFromUTF8( int iMaxChars, bool fJustMove, int i return res; } +#ifdef __GNUC__ +#pragma GCC diagnostic pop +#endif + bool CLR_RT_UnicodeHelper::ConvertToUTF8( int iMaxChars, bool fJustMove ) { NATIVE_PROFILE_CLR_CORE();