Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
88034969
Commit
88034969
authored
Nov 03, 2006
by
bar@bar.intranet.mysql.r18.ru
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/usr/home/bar/mysql-5.0-rpl
into mysql.com:/usr/home/bar/mysql-5.1-rpl
parents
8748cde9
c378d3a1
Changes
13
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
270 additions
and
35 deletions
+270
-35
BitKeeper/etc/collapsed
BitKeeper/etc/collapsed
+1
-0
include/m_ctype.h
include/m_ctype.h
+6
-6
mysql-test/r/lowercase_table.result
mysql-test/r/lowercase_table.result
+24
-0
mysql-test/r/rpl_ignore_table.result
mysql-test/r/rpl_ignore_table.result
+16
-0
mysql-test/t/lowercase_table.test
mysql-test/t/lowercase_table.test
+20
-0
mysql-test/t/rpl_ignore_table-slave.opt
mysql-test/t/rpl_ignore_table-slave.opt
+1
-1
mysql-test/t/rpl_ignore_table.test
mysql-test/t/rpl_ignore_table.test
+22
-0
sql/sql_parse.cc
sql/sql_parse.cc
+18
-2
strings/ctype-bin.c
strings/ctype-bin.c
+2
-1
strings/ctype-mb.c
strings/ctype-mb.c
+14
-10
strings/ctype-simple.c
strings/ctype-simple.c
+12
-6
strings/ctype-ucs2.c
strings/ctype-ucs2.c
+5
-3
strings/ctype-utf8.c
strings/ctype-utf8.c
+129
-6
No files found.
BitKeeper/etc/collapsed
View file @
88034969
...
@@ -8,3 +8,4 @@
...
@@ -8,3 +8,4 @@
4519a6c5BVUxEHTf5iJnjZkixMBs8g
4519a6c5BVUxEHTf5iJnjZkixMBs8g
451ab499rgdjXyOnUDqHu-wBDoS-OQ
451ab499rgdjXyOnUDqHu-wBDoS-OQ
452c6c6dAjuNghfc1ObZ_UQ5SCl85g
452c6c6dAjuNghfc1ObZ_UQ5SCl85g
4538a7b0EbDHHkWPbIwxO6ZIDdg6Dg
include/m_ctype.h
View file @
88034969
...
@@ -190,8 +190,8 @@ typedef struct my_charset_handler_st
...
@@ -190,8 +190,8 @@ typedef struct my_charset_handler_st
const
unsigned
char
*
s
,
const
unsigned
char
*
e
);
const
unsigned
char
*
s
,
const
unsigned
char
*
e
);
/* Functions for case and sort conversion */
/* Functions for case and sort conversion */
void
(
*
caseup_str
)(
struct
charset_info_st
*
,
char
*
);
uint
(
*
caseup_str
)(
struct
charset_info_st
*
,
char
*
);
void
(
*
casedn_str
)(
struct
charset_info_st
*
,
char
*
);
uint
(
*
casedn_str
)(
struct
charset_info_st
*
,
char
*
);
uint
(
*
caseup
)(
struct
charset_info_st
*
,
char
*
src
,
uint
srclen
,
uint
(
*
caseup
)(
struct
charset_info_st
*
,
char
*
src
,
uint
srclen
,
char
*
dst
,
uint
dstlen
);
char
*
dst
,
uint
dstlen
);
uint
(
*
casedn
)(
struct
charset_info_st
*
,
char
*
src
,
uint
srclen
,
uint
(
*
casedn
)(
struct
charset_info_st
*
,
char
*
src
,
uint
srclen
,
...
@@ -324,8 +324,8 @@ extern uint my_instr_simple(struct charset_info_st *,
...
@@ -324,8 +324,8 @@ extern uint my_instr_simple(struct charset_info_st *,
/* Functions for 8bit */
/* Functions for 8bit */
extern
void
my_caseup_str_8bit
(
CHARSET_INFO
*
,
char
*
);
extern
uint
my_caseup_str_8bit
(
CHARSET_INFO
*
,
char
*
);
extern
void
my_casedn_str_8bit
(
CHARSET_INFO
*
,
char
*
);
extern
uint
my_casedn_str_8bit
(
CHARSET_INFO
*
,
char
*
);
extern
uint
my_caseup_8bit
(
CHARSET_INFO
*
,
char
*
src
,
uint
srclen
,
extern
uint
my_caseup_8bit
(
CHARSET_INFO
*
,
char
*
src
,
uint
srclen
,
char
*
dst
,
uint
dstlen
);
char
*
dst
,
uint
dstlen
);
extern
uint
my_casedn_8bit
(
CHARSET_INFO
*
,
char
*
src
,
uint
srclen
,
extern
uint
my_casedn_8bit
(
CHARSET_INFO
*
,
char
*
src
,
uint
srclen
,
...
@@ -415,8 +415,8 @@ int my_mbcharlen_8bit(CHARSET_INFO *, uint c);
...
@@ -415,8 +415,8 @@ int my_mbcharlen_8bit(CHARSET_INFO *, uint c);
/* Functions for multibyte charsets */
/* Functions for multibyte charsets */
extern
void
my_caseup_str_mb
(
CHARSET_INFO
*
,
char
*
);
extern
uint
my_caseup_str_mb
(
CHARSET_INFO
*
,
char
*
);
extern
void
my_casedn_str_mb
(
CHARSET_INFO
*
,
char
*
);
extern
uint
my_casedn_str_mb
(
CHARSET_INFO
*
,
char
*
);
extern
uint
my_caseup_mb
(
CHARSET_INFO
*
,
char
*
src
,
uint
srclen
,
extern
uint
my_caseup_mb
(
CHARSET_INFO
*
,
char
*
src
,
uint
srclen
,
char
*
dst
,
uint
dstlen
);
char
*
dst
,
uint
dstlen
);
extern
uint
my_casedn_mb
(
CHARSET_INFO
*
,
char
*
src
,
uint
srclen
,
extern
uint
my_casedn_mb
(
CHARSET_INFO
*
,
char
*
src
,
uint
srclen
,
...
...
mysql-test/r/lowercase_table.result
View file @
88034969
...
@@ -84,3 +84,27 @@ create table t2 like T1;
...
@@ -84,3 +84,27 @@ create table t2 like T1;
drop table t1, t2;
drop table t1, t2;
show tables;
show tables;
Tables_in_test
Tables_in_test
set names utf8;
drop table if exists İ,İİ;
create table İ (s1 int);
show create table İ;
Table Create Table
İ CREATE TABLE `i` (
`s1` int(11) default NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
show tables;
Tables_in_test
i
drop table İ;
create table İİ (s1 int);
show create table İİ;
Table Create Table
İİ CREATE TABLE `ii` (
`s1` int(11) default NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
show tables;
Tables_in_test
ii
drop table İİ;
set names latin1;
End of 5.0 tests
mysql-test/r/rpl_ignore_table.result
View file @
88034969
...
@@ -14,3 +14,19 @@ SELECT * FROM t4;
...
@@ -14,3 +14,19 @@ SELECT * FROM t4;
a
a
DROP TABLE t1;
DROP TABLE t1;
DROP TABLE t4;
DROP TABLE t4;
DROP TABLE IF EXISTS t5;
CREATE TABLE t5 (
word varchar(50) collate utf8_unicode_ci NOT NULL default ''
) DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
SET @@session.character_set_client=33,@@session.collation_connection=192;
CREATE TEMPORARY TABLE tmptbl504451f4258$1 (id INT NOT NULL) ENGINE=MEMORY;
INSERT INTO t5 (word) VALUES ('TEST’');
SELECT HEX(word) FROM t5;
HEX(word)
54455354E28099
SELECT HEX(word) FROM t5;
HEX(word)
54455354E28099
SELECT * FROM tmptbl504451f4258$1;
ERROR 42S02: Table 'test.tmptbl504451f4258$1' doesn't exist
DROP TABLE t5;
mysql-test/t/lowercase_table.test
View file @
88034969
...
@@ -85,3 +85,23 @@ drop table t1, t2;
...
@@ -85,3 +85,23 @@ drop table t1, t2;
show
tables
;
show
tables
;
# End of 4.1 tests
# End of 4.1 tests
#
# Bug#20404: SHOW CREATE TABLE fails with Turkish I
#
set
names
utf8
;
--
disable_warnings
drop
table
if
exists
İ
,
İİ
;
--
enable_warnings
create
table
İ
(
s1
int
);
show
create
table
İ
;
show
tables
;
drop
table
İ
;
create
table
İİ
(
s1
int
);
show
create
table
İİ
;
show
tables
;
drop
table
İİ
;
set
names
latin1
;
--
echo
End
of
5.0
tests
mysql-test/t/rpl_ignore_table-slave.opt
View file @
88034969
--replicate-ignore-table=test.t1 --replicate-ignore-table=test.t2 --replicate-ignore-table=test.t3
--replicate-ignore-table=test.t1 --replicate-ignore-table=test.t2 --replicate-ignore-table=test.t3
--replicate-wild-ignore-table=%.tmptbl%
mysql-test/t/rpl_ignore_table.test
View file @
88034969
...
@@ -28,3 +28,25 @@ connection master;
...
@@ -28,3 +28,25 @@ connection master;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
DROP
TABLE
t4
;
DROP
TABLE
t4
;
sync_slave_with_master
;
sync_slave_with_master
;
#
# bug#22877 replication character sets get out of sync
# using replicate-wild-ignore-table
#
--
disable_warnings
DROP
TABLE
IF
EXISTS
t5
;
--
enable_warnings
CREATE
TABLE
t5
(
word
varchar
(
50
)
collate
utf8_unicode_ci
NOT
NULL
default
''
)
DEFAULT
CHARSET
=
utf8
COLLATE
=
utf8_unicode_ci
;
SET
@@
session
.
character_set_client
=
33
,
@@
session
.
collation_connection
=
192
;
CREATE
TEMPORARY
TABLE
tmptbl504451f4258
$
1
(
id
INT
NOT
NULL
)
ENGINE
=
MEMORY
;
INSERT
INTO
t5
(
word
)
VALUES
(
'TEST’'
);
SELECT
HEX
(
word
)
FROM
t5
;
sync_slave_with_master
;
connection
slave
;
SELECT
HEX
(
word
)
FROM
t5
;
--
error
1146
SELECT
*
FROM
tmptbl504451f4258
$
1
;
connection
master
;
DROP
TABLE
t5
;
sql/sql_parse.cc
View file @
88034969
...
@@ -2543,7 +2543,23 @@ mysql_execute_command(THD *thd)
...
@@ -2543,7 +2543,23 @@ mysql_execute_command(THD *thd)
{
{
/* we warn the slave SQL thread */
/* we warn the slave SQL thread */
my_message
(
ER_SLAVE_IGNORED_TABLE
,
ER
(
ER_SLAVE_IGNORED_TABLE
),
MYF
(
0
));
my_message
(
ER_SLAVE_IGNORED_TABLE
,
ER
(
ER_SLAVE_IGNORED_TABLE
),
MYF
(
0
));
if
(
thd
->
one_shot_set
)
{
/*
It's ok to check thd->one_shot_set here:
The charsets in a MySQL 5.0 slave can change by both a binlogged
SET ONE_SHOT statement and the event-internal charset setting,
and these two ways to change charsets do not seems to work
together.
At least there seems to be problems in the rli cache for
charsets if we are using ONE_SHOT. Note that this is normally no
problem because either the >= 5.0 slave reads a 4.1 binlog (with
ONE_SHOT) *or* or 5.0 binlog (without ONE_SHOT) but never both."
*/
reset_one_shot_variables
(
thd
);
reset_one_shot_variables
(
thd
);
}
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
}
}
...
@@ -6358,7 +6374,7 @@ TABLE_LIST *st_select_lex::add_table_to_list(THD *thd,
...
@@ -6358,7 +6374,7 @@ TABLE_LIST *st_select_lex::add_table_to_list(THD *thd,
ptr
->
alias
=
alias_str
;
ptr
->
alias
=
alias_str
;
if
(
lower_case_table_names
&&
table
->
table
.
length
)
if
(
lower_case_table_names
&&
table
->
table
.
length
)
my_casedn_str
(
files_charset_info
,
table
->
table
.
str
);
table
->
table
.
length
=
my_casedn_str
(
files_charset_info
,
table
->
table
.
str
);
ptr
->
table_name
=
table
->
table
.
str
;
ptr
->
table_name
=
table
->
table
.
str
;
ptr
->
table_name_length
=
table
->
table
.
length
;
ptr
->
table_name_length
=
table
->
table
.
length
;
ptr
->
lock_type
=
lock_type
;
ptr
->
lock_type
=
lock_type
;
...
...
strings/ctype-bin.c
View file @
88034969
...
@@ -211,9 +211,10 @@ static int my_strnncollsp_8bit_bin(CHARSET_INFO * cs __attribute__((unused)),
...
@@ -211,9 +211,10 @@ static int my_strnncollsp_8bit_bin(CHARSET_INFO * cs __attribute__((unused)),
/* This function is used for all conversion functions */
/* This function is used for all conversion functions */
static
void
my_case_str_bin
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
static
uint
my_case_str_bin
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
char
*
str
__attribute__
((
unused
)))
char
*
str
__attribute__
((
unused
)))
{
{
return
0
;
}
}
static
uint
my_case_bin
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
static
uint
my_case_bin
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
...
...
strings/ctype-mb.c
View file @
88034969
...
@@ -21,40 +21,44 @@
...
@@ -21,40 +21,44 @@
#ifdef USE_MB
#ifdef USE_MB
void
my_caseup_str_mb
(
CHARSET_INFO
*
cs
,
char
*
str
)
uint
my_caseup_str_mb
(
CHARSET_INFO
*
cs
,
char
*
str
)
{
{
register
uint32
l
;
register
uint32
l
;
register
uchar
*
map
=
cs
->
to_upper
;
register
uchar
*
map
=
cs
->
to_upper
;
char
*
str_orig
=
str
;
while
(
*
str
)
while
(
*
str
)
{
{
/* Pointing after the '\0' is safe here. */
/* Pointing after the '\0' is safe here. */
if
((
l
=
my_ismbchar
(
cs
,
str
,
str
+
cs
->
mbmaxlen
)))
if
((
l
=
my_ismbchar
(
cs
,
str
,
str
+
cs
->
mbmaxlen
)))
str
+=
l
;
str
+=
l
;
else
else
{
{
*
str
=
(
char
)
map
[(
uchar
)
*
str
];
*
str
=
(
char
)
map
[(
uchar
)
*
str
];
str
++
;
str
++
;
}
}
}
}
return
str
-
str_orig
;
}
}
void
my_casedn_str_mb
(
CHARSET_INFO
*
cs
,
char
*
str
)
uint
my_casedn_str_mb
(
CHARSET_INFO
*
cs
,
char
*
str
)
{
{
register
uint32
l
;
register
uint32
l
;
register
uchar
*
map
=
cs
->
to_lower
;
register
uchar
*
map
=
cs
->
to_lower
;
char
*
str_orig
=
str
;
while
(
*
str
)
while
(
*
str
)
{
{
/* Pointing after the '\0' is safe here. */
/* Pointing after the '\0' is safe here. */
if
((
l
=
my_ismbchar
(
cs
,
str
,
str
+
cs
->
mbmaxlen
)))
if
((
l
=
my_ismbchar
(
cs
,
str
,
str
+
cs
->
mbmaxlen
)))
str
+=
l
;
str
+=
l
;
else
else
{
{
*
str
=
(
char
)
map
[(
uchar
)
*
str
];
*
str
=
(
char
)
map
[(
uchar
)
*
str
];
str
++
;
str
++
;
}
}
}
}
return
str
-
str_orig
;
}
}
uint
my_caseup_mb
(
CHARSET_INFO
*
cs
,
char
*
src
,
uint
srclen
,
uint
my_caseup_mb
(
CHARSET_INFO
*
cs
,
char
*
src
,
uint
srclen
,
...
...
strings/ctype-simple.c
View file @
88034969
...
@@ -188,20 +188,26 @@ int my_strnncollsp_simple(CHARSET_INFO * cs, const uchar *a, uint a_length,
...
@@ -188,20 +188,26 @@ int my_strnncollsp_simple(CHARSET_INFO * cs, const uchar *a, uint a_length,
}
}
void
my_caseup_str_8bit
(
CHARSET_INFO
*
cs
,
char
*
str
)
uint
my_caseup_str_8bit
(
CHARSET_INFO
*
cs
,
char
*
str
)
{
{
register
uchar
*
map
=
cs
->
to_upper
;
register
uchar
*
map
=
cs
->
to_upper
;
while
((
*
str
=
(
char
)
map
[(
uchar
)
*
str
])
!=
0
)
char
*
str_orig
=
str
;
while
((
*
str
=
(
char
)
map
[(
uchar
)
*
str
])
!=
0
)
str
++
;
str
++
;
return
str
-
str_orig
;
}
}
void
my_casedn_str_8bit
(
CHARSET_INFO
*
cs
,
char
*
str
)
uint
my_casedn_str_8bit
(
CHARSET_INFO
*
cs
,
char
*
str
)
{
{
register
uchar
*
map
=
cs
->
to_lower
;
register
uchar
*
map
=
cs
->
to_lower
;
while
((
*
str
=
(
char
)
map
[(
uchar
)
*
str
])
!=
0
)
char
*
str_orig
=
str
;
while
((
*
str
=
(
char
)
map
[(
uchar
)
*
str
])
!=
0
)
str
++
;
str
++
;
return
str
-
str_orig
;
}
}
uint
my_caseup_8bit
(
CHARSET_INFO
*
cs
,
char
*
src
,
uint
srclen
,
uint
my_caseup_8bit
(
CHARSET_INFO
*
cs
,
char
*
src
,
uint
srclen
,
char
*
dst
__attribute__
((
unused
)),
char
*
dst
__attribute__
((
unused
)),
uint
dstlen
__attribute__
((
unused
)))
uint
dstlen
__attribute__
((
unused
)))
...
...
strings/ctype-ucs2.c
View file @
88034969
...
@@ -159,13 +159,13 @@ static void my_hash_sort_ucs2(CHARSET_INFO *cs, const uchar *s, uint slen,
...
@@ -159,13 +159,13 @@ static void my_hash_sort_ucs2(CHARSET_INFO *cs, const uchar *s, uint slen,
}
}
static
void
my_caseup_str_ucs2
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
static
uint
my_caseup_str_ucs2
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
char
*
s
__attribute__
((
unused
)))
char
*
s
__attribute__
((
unused
)))
{
{
return
0
;
}
}
static
uint
my_casedn_ucs2
(
CHARSET_INFO
*
cs
,
char
*
src
,
uint
srclen
,
static
uint
my_casedn_ucs2
(
CHARSET_INFO
*
cs
,
char
*
src
,
uint
srclen
,
char
*
dst
__attribute__
((
unused
)),
char
*
dst
__attribute__
((
unused
)),
uint
dstlen
__attribute__
((
unused
)))
uint
dstlen
__attribute__
((
unused
)))
...
@@ -188,9 +188,11 @@ static uint my_casedn_ucs2(CHARSET_INFO *cs, char *src, uint srclen,
...
@@ -188,9 +188,11 @@ static uint my_casedn_ucs2(CHARSET_INFO *cs, char *src, uint srclen,
return
srclen
;
return
srclen
;
}
}
static
void
my_casedn_str_ucs2
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
static
uint
my_casedn_str_ucs2
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
char
*
s
__attribute__
((
unused
)))
char
*
s
__attribute__
((
unused
)))
{
{
return
0
;
}
}
...
...
strings/ctype-utf8.c
View file @
88034969
...
@@ -2047,6 +2047,52 @@ static int my_utf8_uni(CHARSET_INFO *cs __attribute__((unused)),
...
@@ -2047,6 +2047,52 @@ static int my_utf8_uni(CHARSET_INFO *cs __attribute__((unused)),
return
MY_CS_ILSEQ
;
return
MY_CS_ILSEQ
;
}
}
/*
The same as above, but without range check
for example, for a null-terminated string
*/
static
int
my_utf8_uni_no_range
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
my_wc_t
*
pwc
,
const
uchar
*
s
)
{
unsigned
char
c
;
c
=
s
[
0
];
if
(
c
<
0x80
)
{
*
pwc
=
c
;
return
1
;
}
if
(
c
<
0xc2
)
return
MY_CS_ILSEQ
;
if
(
c
<
0xe0
)
{
if
(
!
((
s
[
1
]
^
0x80
)
<
0x40
))
return
MY_CS_ILSEQ
;
*
pwc
=
((
my_wc_t
)
(
c
&
0x1f
)
<<
6
)
|
(
my_wc_t
)
(
s
[
1
]
^
0x80
);
return
2
;
}
if
(
c
<
0xf0
)
{
if
(
!
((
s
[
1
]
^
0x80
)
<
0x40
&&
(
s
[
2
]
^
0x80
)
<
0x40
&&
(
c
>=
0xe1
||
s
[
1
]
>=
0xa0
)))
return
MY_CS_ILSEQ
;
*
pwc
=
((
my_wc_t
)
(
c
&
0x0f
)
<<
12
)
|
((
my_wc_t
)
(
s
[
1
]
^
0x80
)
<<
6
)
|
(
my_wc_t
)
(
s
[
2
]
^
0x80
);
return
3
;
}
return
MY_CS_ILSEQ
;
}
static
int
my_uni_utf8
(
CHARSET_INFO
*
cs
__attribute__
((
unused
))
,
static
int
my_uni_utf8
(
CHARSET_INFO
*
cs
__attribute__
((
unused
))
,
my_wc_t
wc
,
uchar
*
r
,
uchar
*
e
)
my_wc_t
wc
,
uchar
*
r
,
uchar
*
e
)
{
{
...
@@ -2093,6 +2139,34 @@ static int my_uni_utf8 (CHARSET_INFO *cs __attribute__((unused)) ,
...
@@ -2093,6 +2139,34 @@ static int my_uni_utf8 (CHARSET_INFO *cs __attribute__((unused)) ,
}
}
/*
The same as above, but without range check.
*/
static
int
my_uni_utf8_no_range
(
CHARSET_INFO
*
cs
__attribute__
((
unused
)),
my_wc_t
wc
,
uchar
*
r
)
{
int
count
;
if
(
wc
<
0x80
)
count
=
1
;
else
if
(
wc
<
0x800
)
count
=
2
;
else
if
(
wc
<
0x10000
)
count
=
3
;
else
return
MY_CS_ILUNI
;
switch
(
count
)
{
/* Fall through all cases!!! */
case
3
:
r
[
2
]
=
(
uchar
)
(
0x80
|
(
wc
&
0x3f
));
wc
=
wc
>>
6
;
wc
|=
0x800
;
case
2
:
r
[
1
]
=
(
uchar
)
(
0x80
|
(
wc
&
0x3f
));
wc
=
wc
>>
6
;
wc
|=
0xc0
;
case
1
:
r
[
0
]
=
(
uchar
)
wc
;
}
return
count
;
}
static
uint
my_caseup_utf8
(
CHARSET_INFO
*
cs
,
char
*
src
,
uint
srclen
,
static
uint
my_caseup_utf8
(
CHARSET_INFO
*
cs
,
char
*
src
,
uint
srclen
,
char
*
dst
,
uint
dstlen
)
char
*
dst
,
uint
dstlen
)
{
{
...
@@ -2143,10 +2217,26 @@ static void my_hash_sort_utf8(CHARSET_INFO *cs, const uchar *s, uint slen,
...
@@ -2143,10 +2217,26 @@ static void my_hash_sort_utf8(CHARSET_INFO *cs, const uchar *s, uint slen,
}
}
static
void
my_caseup_str_utf8
(
CHARSET_INFO
*
cs
,
char
*
s
)
static
uint
my_caseup_str_utf8
(
CHARSET_INFO
*
cs
,
char
*
src
)
{
{
uint
len
=
(
uint
)
strlen
(
s
);
my_wc_t
wc
;
my_caseup_utf8
(
cs
,
s
,
len
,
s
,
len
);
int
srcres
,
dstres
;
char
*
dst
=
src
,
*
dst0
=
src
;
MY_UNICASE_INFO
**
uni_plane
=
cs
->
caseinfo
;
DBUG_ASSERT
(
cs
->
caseup_multiply
==
1
);
while
(
*
src
&&
(
srcres
=
my_utf8_uni_no_range
(
cs
,
&
wc
,
(
uchar
*
)
src
))
>
0
)
{
int
plane
=
(
wc
>>
8
)
&
0xFF
;
wc
=
uni_plane
[
plane
]
?
uni_plane
[
plane
][
wc
&
0xFF
].
toupper
:
wc
;
if
((
dstres
=
my_uni_utf8_no_range
(
cs
,
wc
,
(
uchar
*
)
dst
))
<=
0
)
break
;
src
+=
srcres
;
dst
+=
dstres
;
}
*
dst
=
'\0'
;
return
(
uint
)
(
dst
-
dst0
);
}
}
...
@@ -2172,10 +2262,43 @@ static uint my_casedn_utf8(CHARSET_INFO *cs, char *src, uint srclen,
...
@@ -2172,10 +2262,43 @@ static uint my_casedn_utf8(CHARSET_INFO *cs, char *src, uint srclen,
return
(
uint
)
(
dst
-
dst0
);
return
(
uint
)
(
dst
-
dst0
);
}
}
static
void
my_casedn_str_utf8
(
CHARSET_INFO
*
cs
,
char
*
s
)
static
uint
my_casedn_str_utf8
(
CHARSET_INFO
*
cs
,
char
*
src
)
{
{
uint
len
=
(
uint
)
strlen
(
s
);
my_wc_t
wc
;
my_casedn_utf8
(
cs
,
s
,
len
,
s
,
len
);
int
srcres
,
dstres
;
char
*
dst
=
src
,
*
dst0
=
src
;
MY_UNICASE_INFO
**
uni_plane
=
cs
->
caseinfo
;
DBUG_ASSERT
(
cs
->
casedn_multiply
==
1
);
while
(
*
src
&&
(
srcres
=
my_utf8_uni_no_range
(
cs
,
&
wc
,
(
uchar
*
)
src
))
>
0
)
{
int
plane
=
(
wc
>>
8
)
&
0xFF
;
wc
=
uni_plane
[
plane
]
?
uni_plane
[
plane
][
wc
&
0xFF
].
tolower
:
wc
;
if
((
dstres
=
my_uni_utf8_no_range
(
cs
,
wc
,
(
uchar
*
)
dst
))
<=
0
)
break
;
src
+=
srcres
;
dst
+=
dstres
;
}
/*
In rare cases lower string can be shorter than
the original string, for example:
"U+0130 LATIN CAPITAL LETTER I WITH DOT ABOVE"
(which is 0xC4B0 in utf8, i.e. two bytes)
is converted into
"U+0069 LATIN SMALL LETTER I"
(which is 0x69 in utf8, i.e. one byte)
So, we need to put '\0' terminator after converting.
*/
*
dst
=
'\0'
;
return
(
uint
)
(
dst
-
dst0
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment