8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-22 15:23:03 +01:00

CORE-2929 - 'Invalid ESCAPE sequence' when connecting to the database

This commit is contained in:
asfernandes 2010-05-17 15:30:38 +00:00
parent bb0ca45669
commit 7a110f4be0
2 changed files with 4 additions and 10 deletions

View File

@ -31,16 +31,6 @@ may automatically convert the filename and insert the DPB. Clients older than v2
so the received filenames are going to be considered as on the server codepage. We again guarantee so the received filenames are going to be considered as on the server codepage. We again guarantee
backward compatibility when client and server codepage are the same. backward compatibility when client and server codepage are the same.
The OS codepage and UTF-8 may not be the better choice for filenames. For example, if you had a
ISQL (or some other tool) script and that script uses another connection charset. You could not
correctly edit a script (or any file) using multiple character sets (codepages). So you may now
encode any Unicode character as ASCII characters on the connection string filename. That's
accomplished using the symbol #. It is a prefix for an Unicode code point number (in hexadecimal
format, like U+XXXX notation). You should write it in this way: #XXXX with X being 0-9, a-f, A-F.
If you want to use the literal #, you could use ## or #0023 (the code point number for it).
That character is interpreted with this new semantics at the server even if the client is older
than v2.5.
The OS codepage used for conversions is: The OS codepage used for conversions is:
- Windows: The Windows ANSI code page - Windows: The Windows ANSI code page
- Others: UTF-8 - Others: UTF-8

View File

@ -1696,12 +1696,14 @@ void ISC_utf8ToSystem(Firebird::AbstractString& str)
// Escape Unicode characters from a string // Escape Unicode characters from a string
void ISC_escape(AbstractString& str) void ISC_escape(AbstractString& str)
{ {
#if 0 // CORE-2929
size_t pos = 0; size_t pos = 0;
while ((pos = str.find_first_of("#", pos)) != npos) while ((pos = str.find_first_of("#", pos)) != npos)
{ {
str.insert(pos, "#"); str.insert(pos, "#");
pos += 2; pos += 2;
} }
#endif
} }
@ -1736,6 +1738,7 @@ static inline void FB_U8_APPEND_UNSAFE(char* s, int& i, const int c)
// Unescape Unicode characters from a string // Unescape Unicode characters from a string
void ISC_unescape(AbstractString& str) void ISC_unescape(AbstractString& str)
{ {
#if 0 // CORE-2929
size_t pos = 0; size_t pos = 0;
while ((pos = str.find_first_of("#", pos)) != npos) while ((pos = str.find_first_of("#", pos)) != npos)
{ {
@ -1764,4 +1767,5 @@ void ISC_unescape(AbstractString& str)
else else
status_exception::raise(Arg::Gds(isc_bad_conn_str) << Arg::Gds(isc_escape_invalid)); status_exception::raise(Arg::Gds(isc_bad_conn_str) << Arg::Gds(isc_escape_invalid));
} }
#endif
} }