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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
ebbc1dc1
Commit
ebbc1dc1
authored
Sep 25, 2003
by
bar@bar.mysql.r18.ru
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
LPAD() and RPAD() are now multibyte-compatible
parent
9b4b9f91
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
61 additions
and
56 deletions
+61
-56
mysql-test/r/func_str.result
mysql-test/r/func_str.result
+1
-1
sql/item_strfunc.cc
sql/item_strfunc.cc
+60
-55
No files found.
mysql-test/r/func_str.result
View file @
ebbc1dc1
...
...
@@ -410,7 +410,7 @@ collation(concat(_latin2'a',_latin2'b')) coercibility(concat(_latin2'a',_latin2'
latin2_general_ci 3
select collation(lpad(_latin2'a',4,_latin2'b')), coercibility(lpad(_latin2'a',4,_latin2'b'));
collation(lpad(_latin2'a',4,_latin2'b')) coercibility(lpad(_latin2'a',4,_latin2'b'))
binary
3
latin2_general_ci
3
select collation(rpad(_latin2'a',4,_latin2'b')), coercibility(rpad(_latin2'a',4,_latin2'b'));
collation(rpad(_latin2'a',4,_latin2'b')) coercibility(rpad(_latin2'a',4,_latin2'b'))
latin2_general_ci 3
...
...
sql/item_strfunc.cc
View file @
ebbc1dc1
...
...
@@ -1885,7 +1885,7 @@ void Item_func_rpad::fix_length_and_dec()
if
(
args
[
1
]
->
const_item
())
{
uint32
length
=
(
uint32
)
args
[
1
]
->
val_int
();
uint32
length
=
(
uint32
)
args
[
1
]
->
val_int
()
*
collation
.
collation
->
mbmaxlen
;
max_length
=
max
(
args
[
0
]
->
max_length
,
length
);
if
(
max_length
>=
MAX_BLOB_WIDTH
)
{
...
...
@@ -1903,36 +1903,46 @@ void Item_func_rpad::fix_length_and_dec()
String
*
Item_func_rpad
::
val_str
(
String
*
str
)
{
uint32
res_
length
,
length_pad
;
uint32
res_
byte_length
,
res_char_length
,
pad_char_length
,
pad_byte_length
;
char
*
to
;
const
char
*
ptr_pad
;
int32
count
=
(
int32
)
args
[
1
]
->
val_int
();
int32
byte_count
=
count
*
collation
.
collation
->
mbmaxlen
;
String
*
res
=
args
[
0
]
->
val_str
(
str
);
String
*
rpad
=
args
[
2
]
->
val_str
(
str
);
if
(
!
res
||
args
[
1
]
->
null_value
||
!
rpad
||
count
<
0
)
goto
err
;
null_value
=
0
;
if
(
count
<=
(
int32
)
(
res_
length
=
res
->
length
()))
if
(
count
<=
(
int32
)
(
res_
char_length
=
res
->
numchars
()))
{
// String to pad is big enough
res
->
length
(
count
);
// Shorten result if longer
res
->
length
(
res
->
charpos
(
count
));
// Shorten result if longer
return
(
res
);
}
length_pad
=
rpad
->
length
();
if
((
ulong
)
count
>
current_thd
->
variables
.
max_allowed_packet
||
args
[
2
]
->
null_value
||
!
length_pad
)
pad_char_length
=
rpad
->
numchars
();
if
((
ulong
)
byte_
count
>
current_thd
->
variables
.
max_allowed_packet
||
args
[
2
]
->
null_value
||
!
pad_char_length
)
goto
err
;
if
(
!
(
res
=
alloc_buffer
(
res
,
str
,
&
tmp_value
,
count
)))
res_byte_length
=
res
->
length
();
/* Must be done before alloc_buffer */
if
(
!
(
res
=
alloc_buffer
(
res
,
str
,
&
tmp_value
,
byte_count
)))
goto
err
;
to
=
(
char
*
)
res
->
ptr
()
+
res_length
;
to
=
(
char
*
)
res
->
ptr
()
+
res_
byte_
length
;
ptr_pad
=
rpad
->
ptr
();
for
(
count
-=
res_length
;
(
uint32
)
count
>
length_pad
;
count
-=
length_pad
)
pad_byte_length
=
rpad
->
length
();
count
-=
res_char_length
;
for
(
;
(
uint32
)
count
>
pad_char_length
;
count
-=
pad_char_length
)
{
memcpy
(
to
,
ptr_pad
,
length_pad
);
to
+=
length_pad
;
memcpy
(
to
,
ptr_pad
,
pad_byte_length
);
to
+=
pad_byte_length
;
}
memcpy
(
to
,
ptr_pad
,(
size_t
)
count
);
if
(
count
)
{
pad_byte_length
=
rpad
->
charpos
(
count
);
memcpy
(
to
,
ptr_pad
,(
size_t
)
pad_byte_length
);
to
+=
pad_byte_length
;
}
res
->
length
(
to
-
(
char
*
)
res
->
ptr
());
return
(
res
);
err:
...
...
@@ -1951,7 +1961,7 @@ void Item_func_lpad::fix_length_and_dec()
if
(
args
[
1
]
->
const_item
())
{
uint32
length
=
(
uint32
)
args
[
1
]
->
val_int
();
uint32
length
=
(
uint32
)
args
[
1
]
->
val_int
()
*
collation
.
collation
->
mbmaxlen
;
max_length
=
max
(
args
[
0
]
->
max_length
,
length
);
if
(
max_length
>=
MAX_BLOB_WIDTH
)
{
...
...
@@ -1969,57 +1979,52 @@ void Item_func_lpad::fix_length_and_dec()
String
*
Item_func_lpad
::
val_str
(
String
*
str
)
{
uint32
res_length
,
length_pad
;
char
*
to
;
const
char
*
ptr_pad
;
ulong
count
=
(
long
)
args
[
1
]
->
val_int
();
String
*
res
=
args
[
0
]
->
val_str
(
str
);
String
*
lpad
=
args
[
2
]
->
val_str
(
str
);
uint32
res_byte_length
,
res_char_length
,
pad_byte_length
,
pad_char_length
;
ulong
count
=
(
long
)
args
[
1
]
->
val_int
(),
byte_count
;
String
a1
,
a3
;
String
*
res
=
args
[
0
]
->
val_str
(
&
a1
);
String
*
pad
=
args
[
2
]
->
val_str
(
&
a3
);
if
(
!
res
||
args
[
1
]
->
null_value
||
!
l
pad
)
if
(
!
res
||
args
[
1
]
->
null_value
||
!
pad
)
goto
err
;
null_value
=
0
;
if
(
count
<=
(
res_length
=
res
->
length
()))
{
// String to pad is big enough
res
->
length
(
count
);
// Shorten result if longer
return
(
res
);
}
length_pad
=
lpad
->
length
();
if
(
count
>
current_thd
->
variables
.
max_allowed_packet
||
args
[
2
]
->
null_value
||
!
length_pad
)
goto
err
;
res_byte_length
=
res
->
length
();
res_char_length
=
res
->
numchars
();
if
(
res
->
alloced_length
()
<
count
)
if
(
count
<=
res_char_length
)
{
if
(
str
->
alloced_length
()
>=
count
)
{
memcpy
((
char
*
)
str
->
ptr
()
+
(
count
-
res_length
),
res
->
ptr
(),
res_length
);
res
=
str
;
res
->
length
(
res
->
charpos
(
count
));
return
res
;
}
else
{
if
(
tmp_value
.
alloc
(
count
))
pad_byte_length
=
pad
->
length
();
pad_char_length
=
pad
->
numchars
();
byte_count
=
count
*
collation
.
collation
->
mbmaxlen
;
if
(
byte_count
>
current_thd
->
variables
.
max_allowed_packet
||
args
[
2
]
->
null_value
||
!
pad_char_length
||
str
->
alloc
(
byte_count
))
goto
err
;
memcpy
((
char
*
)
tmp_value
.
ptr
()
+
(
count
-
res_length
),
res
->
ptr
(),
res_length
);
res
=&
tmp_value
;
}
}
else
bmove_upp
((
char
*
)
res
->
ptr
()
+
count
,
res
->
ptr
()
+
res_length
,
res_length
);
res
->
length
(
count
);
to
=
(
char
*
)
res
->
ptr
();
ptr_pad
=
lpad
->
ptr
();
for
(
count
-=
res_length
;
count
>
length_pad
;
count
-=
length_pad
)
str
->
length
(
0
);
str
->
set_charset
(
collation
.
collation
);
count
-=
res_char_length
;
while
(
count
>=
pad_char_length
)
{
memcpy
(
to
,
ptr_pad
,
length_
pad
);
to
+=
length_pad
;
str
->
append
(
*
pad
);
count
-=
pad_char_length
;
}
memcpy
(
to
,
ptr_pad
,(
size_t
)
count
);
return
(
res
);
if
(
count
>
0
)
{
pad
->
length
(
pad
->
charpos
(
count
));
str
->
append
(
*
pad
);
}
str
->
append
(
*
res
);
null_value
=
0
;
return
str
;
err:
null_value
=
1
;
err:
null_value
=
1
;
return
0
;
}
...
...
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