Commit bd5dc451 authored by jan@hundin.mysql.fi's avatar jan@hundin.mysql.fi

Added more comments on the code and made some code polishing.

parent aaf661fc
...@@ -5272,32 +5272,16 @@ ulonglong ha_innobase::get_mysql_bin_log_pos() ...@@ -5272,32 +5272,16 @@ ulonglong ha_innobase::get_mysql_bin_log_pos()
} }
extern "C" { extern "C" {
/*********************************************************************** /**********************************************************************
This function finds charset information and returns the character This function is used to find storage length of prefix_len characters
length for multibyte character set. */ in bytes for prefix indexes using multibyte character set.
Function finds charset information and returns length of
ulint innobase_get_charset_mbmaxlen( prefix_len characters in the index field in bytes. */
ulint charset_id) /* in: charset id */
{
CHARSET_INFO* charset; /* charset used in the field */
charset = get_charset(charset_id,MYF(MY_WME));
ut_ad(charset);
ut_ad(charset->mbmaxlen);
return charset->mbmaxlen;
}
}
extern "C" {
/***********************************************************************
This function finds charset information and returns position the nth
character for multibyte character set.*/
ulint innobase_get_at_most_n_mbchars( ulint innobase_get_at_most_n_mbchars(
/*=================================*/
ulint charset_id, /* in: character set id */ ulint charset_id, /* in: character set id */
ulint nth, /* in: nth character */ ulint prefix_len, /* in: prefix length of the index */
ulint data_len, /* in: length of the sting in bytes */ ulint data_len, /* in: length of the sting in bytes */
const char *pos) /* in: character string */ const char *pos) /* in: character string */
{ {
...@@ -5313,16 +5297,24 @@ ulint innobase_get_at_most_n_mbchars( ...@@ -5313,16 +5297,24 @@ ulint innobase_get_at_most_n_mbchars(
ut_ad(charset); ut_ad(charset);
ut_ad(charset->mbmaxlen); ut_ad(charset->mbmaxlen);
char_length= byte_length / charset->mbmaxlen; /* Calculate the storage length of the one character in bytes and
nth = nth / charset->mbmaxlen; how many characters the prefix index contains */
if (byte_length > char_length) char_length = byte_length / charset->mbmaxlen;
{ prefix_len = prefix_len / charset->mbmaxlen;
char_length= my_charpos(charset, pos, pos + byte_length, nth);
/* If length of the string is greater than storage length of the
one character, we have to find the storage position of the
prefix_len character in the string */
if (byte_length > char_length) {
char_length = my_charpos(charset, pos,
pos + byte_length, prefix_len);
set_if_smaller(char_length, byte_length); set_if_smaller(char_length, byte_length);
} }
else else {
char_length = nth; char_length = prefix_len;
}
return char_length; return char_length;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment