mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-22 18:43:02 +01:00
Server will use "stable" implementation of UCNV_FROM_U_CALLBACK_STOP function to provide one behaviour for built-in charset and ICU-charset when source unicode-string contains "ignorable" symbols. It will always produces translation error. This patch restores a behaviour of FB2.1-FB3 for "ignorable" symbols. --- ATTENTION: These changes were not tested in a master tree (only in FB4).
This commit is contained in:
parent
ce2687bb36
commit
02ef0c8d43
@ -427,7 +427,6 @@ private:
|
|||||||
getEntryPoint("u_countChar32", module, u_countChar32);
|
getEntryPoint("u_countChar32", module, u_countChar32);
|
||||||
getEntryPoint("utf8_nextCharSafeBody", module, utf8_nextCharSafeBody);
|
getEntryPoint("utf8_nextCharSafeBody", module, utf8_nextCharSafeBody);
|
||||||
|
|
||||||
getEntryPoint("UCNV_FROM_U_CALLBACK_STOP", module, UCNV_FROM_U_CALLBACK_STOP);
|
|
||||||
getEntryPoint("UCNV_TO_U_CALLBACK_STOP", module, UCNV_TO_U_CALLBACK_STOP);
|
getEntryPoint("UCNV_TO_U_CALLBACK_STOP", module, UCNV_TO_U_CALLBACK_STOP);
|
||||||
getEntryPoint("ucnv_fromUnicode", module, ucnv_fromUnicode);
|
getEntryPoint("ucnv_fromUnicode", module, ucnv_fromUnicode);
|
||||||
getEntryPoint("ucnv_toUnicode", module, ucnv_toUnicode);
|
getEntryPoint("ucnv_toUnicode", module, ucnv_toUnicode);
|
||||||
|
@ -66,14 +66,6 @@ public:
|
|||||||
|
|
||||||
UChar32 (U_EXPORT2* utf8_nextCharSafeBody) (const uint8_t* s, int32_t* pi, int32_t length, UChar32 c, UBool strict);
|
UChar32 (U_EXPORT2* utf8_nextCharSafeBody) (const uint8_t* s, int32_t* pi, int32_t length, UChar32 c, UBool strict);
|
||||||
|
|
||||||
void (U_EXPORT2* UCNV_FROM_U_CALLBACK_STOP) (
|
|
||||||
const void *context,
|
|
||||||
UConverterFromUnicodeArgs *fromUArgs,
|
|
||||||
const UChar* codeUnits,
|
|
||||||
int32_t length,
|
|
||||||
UChar32 codePoint,
|
|
||||||
UConverterCallbackReason reason,
|
|
||||||
UErrorCode * err);
|
|
||||||
void (U_EXPORT2* UCNV_TO_U_CALLBACK_STOP) (
|
void (U_EXPORT2* UCNV_TO_U_CALLBACK_STOP) (
|
||||||
const void *context,
|
const void *context,
|
||||||
UConverterToUnicodeArgs *toUArgs,
|
UConverterToUnicodeArgs *toUArgs,
|
||||||
|
@ -31,6 +31,34 @@
|
|||||||
#include <unicode/ucnv.h>
|
#include <unicode/ucnv.h>
|
||||||
#include "../common/unicode_util.h"
|
#include "../common/unicode_util.h"
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
static void U_EXPORT2 FB_UCNV_FROM_U_CALLBACK_STOP(
|
||||||
|
const void* /*context*/,
|
||||||
|
UConverterFromUnicodeArgs* /*fromUArgs*/,
|
||||||
|
const UChar* /*codeUnits*/,
|
||||||
|
int32_t /*length*/,
|
||||||
|
UChar32 /*codePoint*/,
|
||||||
|
UConverterCallbackReason /*reason*/,
|
||||||
|
UErrorCode* /*err*/)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* A stable implementation of callback function UCNV_FROM_U_CALLBACK_STOP.
|
||||||
|
*
|
||||||
|
* It is equal to a behaviour of old ICU (from FB2.1 and FB3).
|
||||||
|
*
|
||||||
|
* ICU from FB4 (v63.1) translates "ignorable" symbols (..., 0x115F, ...) into an empty string
|
||||||
|
* and this is incompatible with conversion of built-in charsets where
|
||||||
|
* a such case leads to a translation error.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* the caller must have set the error code accordingly */
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
|
||||||
static UConverter* create_converter(csconvert* cv, UErrorCode* status)
|
static UConverter* create_converter(csconvert* cv, UErrorCode* status)
|
||||||
{
|
{
|
||||||
@ -41,7 +69,7 @@ static UConverter* create_converter(csconvert* cv, UErrorCode* status)
|
|||||||
UConverterFromUCallback oldFromAction;
|
UConverterFromUCallback oldFromAction;
|
||||||
cIcu.ucnv_setFromUCallBack(
|
cIcu.ucnv_setFromUCallBack(
|
||||||
conv,
|
conv,
|
||||||
cIcu.UCNV_FROM_U_CALLBACK_STOP,
|
FB_UCNV_FROM_U_CALLBACK_STOP,
|
||||||
NULL,
|
NULL,
|
||||||
&oldFromAction,
|
&oldFromAction,
|
||||||
&oldContext,
|
&oldContext,
|
||||||
|
Loading…
Reference in New Issue
Block a user