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
56c88d4a
Commit
56c88d4a
authored
Oct 09, 2007
by
cmiller@zippy.cornsilk.net
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Doxygenize comments, a*.cc - field.cc .
parent
04296df3
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
313 additions
and
316 deletions
+313
-316
sql/derror.cc
sql/derror.cc
+24
-13
sql/des_key_file.cc
sql/des_key_file.cc
+10
-9
sql/discover.cc
sql/discover.cc
+28
-26
sql/field.cc
sql/field.cc
+251
-268
No files found.
sql/derror.cc
View file @
56c88d4a
...
@@ -14,7 +14,12 @@
...
@@ -14,7 +14,12 @@
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
/* Read language depeneded messagefile */
/**
@file
@brief
Read language depeneded messagefile
*/
#include "mysql_priv.h"
#include "mysql_priv.h"
#include "mysys_err.h"
#include "mysys_err.h"
...
@@ -23,20 +28,17 @@ static bool read_texts(const char *file_name,const char ***point,
...
@@ -23,20 +28,17 @@ static bool read_texts(const char *file_name,const char ***point,
uint
error_messages
);
uint
error_messages
);
static
void
init_myfunc_errs
(
void
);
static
void
init_myfunc_errs
(
void
);
/*
/*
*
Read messages from errorfile.
Read messages from errorfile.
SYNOPSIS
init_errmessage()
DESCRIPTION
This function can be called multiple times to reload the messages.
This function can be called multiple times to reload the messages.
If it fails to load the messages, it will fail softly by initializing
If it fails to load the messages, it will fail softly by initializing
the errmesg pointer to an array of empty strings or by keeping the
the errmesg pointer to an array of empty strings or by keeping the
old array if it exists.
old array if it exists.
RETURN
@retval
FALSE OK
FALSE OK
@retval
TRUE Error
TRUE Error
*/
*/
...
@@ -75,7 +77,14 @@ bool init_errmessage(void)
...
@@ -75,7 +77,14 @@ bool init_errmessage(void)
}
}
/* Read text from packed textfile in language-directory */
/**
Read text from packed textfile in language-directory.
If we can't read messagefile then it's panic- we can't continue.
@todo
Convert the character set to server system character set
*/
static
bool
read_texts
(
const
char
*
file_name
,
const
char
***
point
,
static
bool
read_texts
(
const
char
*
file_name
,
const
char
***
point
,
uint
error_messages
)
uint
error_messages
)
...
@@ -178,7 +187,9 @@ err1:
...
@@ -178,7 +187,9 @@ err1:
}
/* read_texts */
}
/* read_texts */
/* Initiates error-messages used by my_func-library */
/**
Initiates error-messages used by my_func-library.
*/
static
void
init_myfunc_errs
()
static
void
init_myfunc_errs
()
{
{
...
...
sql/des_key_file.cc
View file @
56c88d4a
...
@@ -21,17 +21,18 @@
...
@@ -21,17 +21,18 @@
struct
st_des_keyschedule
des_keyschedule
[
10
];
struct
st_des_keyschedule
des_keyschedule
[
10
];
uint
des_default_key
;
uint
des_default_key
;
/*
#define des_cs &my_charset_latin1
Function which loads DES keys from plaintext file into memory on MySQL
server startup and on command FLUSH DES_KEY_FILE.
/**
Blame tonu@spam.ee on bugs ;)
Load DES keys from plaintext file into
memory on MySQL server startup and on command FLUSH DES_KEY_FILE.
RETURN
@retval
0 ok
0 ok
@retval
1 Error
1 Error
*/
*/
#define des_cs &my_charset_latin1
bool
bool
load_des_key_file
(
const
char
*
file_name
)
load_des_key_file
(
const
char
*
file_name
)
...
...
sql/discover.cc
View file @
56c88d4a
...
@@ -14,29 +14,33 @@
...
@@ -14,29 +14,33 @@
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
/* Functions for discover of frm file from handler */
/**
@file
@brief
Functions for discover of frm file from handler
*/
#include "mysql_priv.h"
#include "mysql_priv.h"
#include <my_dir.h>
#include <my_dir.h>
/*
/*
*
Read the contents of a .frm file
Read the contents of a .frm file
.
SYNOPSIS
frmdata and len are set to 0 on error.
readfrm()
name path to table-file "db/name"
@param
name path to table-file "db/name"
frmdata frm data
@param
frmdata frm data
len length of the read frmdata
@param
len length of the read frmdata
RETURN VALUES
@retval
0 ok
0 ok
@retval
1 Could not open file
1 Could not open file
@retval
2 Could not stat file
2 Could not stat file
3 Could not allocate data for read
@retval
Could not read file
3 Could not allocate data for read. Could not read file
frmdata and len are set to 0 on error
*/
*/
int
readfrm
(
const
char
*
name
,
uchar
**
frmdata
,
size_t
*
len
)
int
readfrm
(
const
char
*
name
,
uchar
**
frmdata
,
size_t
*
len
)
...
@@ -87,17 +91,15 @@ int readfrm(const char *name, uchar **frmdata, size_t *len)
...
@@ -87,17 +91,15 @@ int readfrm(const char *name, uchar **frmdata, size_t *len)
/*
/*
Write the content of a frm data pointer
Write the content of a frm data pointer
to a frm file
to a frm file.
SYNOPSIS
writefrm()
name path to table-file "db/name"
@param
name path to table-file "db/name"
frmdata frm data
@param
frmdata frm data
len length of the frmdata
@param
len length of the frmdata
RETURN VALUES
@retval
0 ok
0 ok
@retval
2 Could not write file
2 Could not write file
*/
*/
...
...
sql/field.cc
View file @
56c88d4a
...
@@ -14,9 +14,12 @@
...
@@ -14,9 +14,12 @@
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
/*****************************************************************************
/**
** This file implements classes defined in field.h
@file
*****************************************************************************/
@brief
This file implements classes defined in field.h
*/
#ifdef USE_PRAGMA_IMPLEMENTATION
#ifdef USE_PRAGMA_IMPLEMENTATION
#pragma implementation // gcc: Class implementation
#pragma implementation // gcc: Class implementation
...
@@ -913,14 +916,13 @@ static enum_field_types field_types_merge_rules [FIELDTYPE_NUM][FIELDTYPE_NUM]=
...
@@ -913,14 +916,13 @@ static enum_field_types field_types_merge_rules [FIELDTYPE_NUM][FIELDTYPE_NUM]=
}
}
};
};
/*
/*
*
Return type of which can carry value of both given types in UNION result
Return type of which can carry value of both given types in UNION result
.
SYNOPSIS
@param a type for merging
Field::field_type_merge()
@param b type for merging
a, b types for merging
RETURN
@return
type of field
type of field
*/
*/
...
@@ -992,14 +994,12 @@ test_if_important_data(CHARSET_INFO *cs, const char *str, const char *strend)
...
@@ -992,14 +994,12 @@ test_if_important_data(CHARSET_INFO *cs, const char *str, const char *strend)
}
}
/*
/*
*
Detect Item_result by given field type of UNION merge result
Detect Item_result by given field type of UNION merge result
.
SYNOPSIS
@param field_type given field type
Field::result_merge_type()
field_type given field type
RETURN
@return
Item_result (type of internal MySQL expression result)
Item_result (type of internal MySQL expression result)
*/
*/
...
@@ -1015,18 +1015,17 @@ Item_result Field::result_merge_type(enum_field_types field_type)
...
@@ -1015,18 +1015,17 @@ Item_result Field::result_merge_type(enum_field_types field_type)
*****************************************************************************/
*****************************************************************************/
/*
/*
*
Check whether a field type can be partially indexed by a key
Check whether a field type can be partially indexed by a key
.
This is a static method, rather than a virtual function, because we need
This is a static method, rather than a virtual function, because we need
to check the type of a non-Field in mysql_alter_table().
to check the type of a non-Field in mysql_alter_table().
SYNOPSIS
@param type field type
type_can_have_key_part()
type field type
RETURN
@retval
TRUE Type can have a prefixed key
TRUE Type can have a prefixed key
@retval
FALSE Type can not have a prefixed key
FALSE Type can not have a prefixed key
*/
*/
...
@@ -1048,8 +1047,8 @@ bool Field::type_can_have_key_part(enum enum_field_types type)
...
@@ -1048,8 +1047,8 @@ bool Field::type_can_have_key_part(enum enum_field_types type)
}
}
/*
/*
*
Numeric fields base class constructor
Numeric fields base class constructor
.
*/
*/
Field_num
::
Field_num
(
uchar
*
ptr_arg
,
uint32
len_arg
,
uchar
*
null_ptr_arg
,
Field_num
::
Field_num
(
uchar
*
ptr_arg
,
uint32
len_arg
,
uchar
*
null_ptr_arg
,
uchar
null_bit_arg
,
utype
unireg_check_arg
,
uchar
null_bit_arg
,
utype
unireg_check_arg
,
...
@@ -1080,23 +1079,25 @@ void Field_num::prepend_zeros(String *value)
...
@@ -1080,23 +1079,25 @@ void Field_num::prepend_zeros(String *value)
}
}
}
}
/*
/*
*
Test if given number is a int.
Test if given number is a int.
SYNOPSIS
@todo
Field_num::check_int
Make this multi-byte-character safe
cs Character set
str String to test
end Pointer to char after last used digit
length String length
error Error returned by strntoull10rnd()
NOTE
@param str String to test
@param length Length of 'str'
@param int_end Pointer to char after last used digit
@param cs Character set
@note
This is called after one has called strntoull10rnd() function.
This is called after one has called strntoull10rnd() function.
RETURN
@retval
0 ok
0 OK
@retval
1 error: empty string or wrong integer.
1 error: empty string or wrong integer.
@retval
2 error: garbage at the end of string.
2 error: garbage at the end of string.
*/
*/
...
@@ -1191,16 +1192,15 @@ out_of_range:
...
@@ -1191,16 +1192,15 @@ out_of_range:
return
1
;
return
1
;
}
}
/*
/*
*
Process decimal library return codes and issue warnings for overflow and
Process decimal library return codes and issue warnings for overflow and
truncation.
truncation.
SYNOPSIS
@param op_result decimal library return code (E_DEC_* see include/decimal.h)
Field::warn_if_overflow()
op_result decimal library return code (E_DEC_* see include/decimal.h)
RETURN
@retval
1 there was overflow
1 there was overflow
@retval
0 no error or some other errors except overflow
0 no error or some other errors except overflow
*/
*/
...
@@ -1275,10 +1275,10 @@ static bool test_if_real(const char *str,int length, CHARSET_INFO *cs)
...
@@ -1275,10 +1275,10 @@ static bool test_if_real(const char *str,int length, CHARSET_INFO *cs)
#endif
#endif
/*
/*
*
Interpret field value as an integer but return the result as a string.
Interpret field value as an integer but return the result as a string.
This is used for printing bit_fields as numbers while debugging
This is used for printing bit_fields as numbers while debugging
.
*/
*/
String
*
Field
::
val_int_as_str
(
String
*
val_buffer
,
my_bool
unsigned_val
)
String
*
Field
::
val_int_as_str
(
String
*
val_buffer
,
my_bool
unsigned_val
)
...
@@ -1299,6 +1299,7 @@ String *Field::val_int_as_str(String *val_buffer, my_bool unsigned_val)
...
@@ -1299,6 +1299,7 @@ String *Field::val_int_as_str(String *val_buffer, my_bool unsigned_val)
}
}
/// This is used as a table name when the table structure is not set up
Field
::
Field
(
uchar
*
ptr_arg
,
uint32
length_arg
,
uchar
*
null_ptr_arg
,
Field
::
Field
(
uchar
*
ptr_arg
,
uint32
length_arg
,
uchar
*
null_ptr_arg
,
uchar
null_bit_arg
,
uchar
null_bit_arg
,
utype
unireg_check_arg
,
const
char
*
field_name_arg
)
utype
unireg_check_arg
,
const
char
*
field_name_arg
)
...
@@ -1474,17 +1475,15 @@ void Field::make_field(Send_field *field)
...
@@ -1474,17 +1475,15 @@ void Field::make_field(Send_field *field)
}
}
/*
/*
*
Conversion from decimal to longlong with checking overflow and
Conversion from decimal to longlong with checking overflow and
setting correct value (min/max) in case of overflow
setting correct value (min/max) in case of overflow
.
SYNOPSIS
@param val value which have to be converted
Field::convert_decimal2longlong()
@param unsigned_flag type of integer in which we convert val
val value which have to be converted
@param err variable to pass error code
unsigned_flag type of integer in which we convert val
err variable to pass error code
RETURN
@return
value converted from val
value converted from val
*/
*/
longlong
Field
::
convert_decimal2longlong
(
const
my_decimal
*
val
,
longlong
Field
::
convert_decimal2longlong
(
const
my_decimal
*
val
,
...
@@ -1518,19 +1517,18 @@ longlong Field::convert_decimal2longlong(const my_decimal *val,
...
@@ -1518,19 +1517,18 @@ longlong Field::convert_decimal2longlong(const my_decimal *val,
}
}
/*
/*
*
Storing decimal in integer fields.
Storing decimal in integer fields.
SYNOPSIS
@param val value for storing
Field_num::store_decimal()
val value for storing
NOTE
@note
This method is used by all integer fields, real/decimal redefine it
This method is used by all integer fields, real/decimal redefine it
RETURN
@retval
0 OK
0 OK
!= 0 error
@retval
!=0 error
*/
*/
int
Field_num
::
store_decimal
(
const
my_decimal
*
val
)
int
Field_num
::
store_decimal
(
const
my_decimal
*
val
)
...
@@ -1542,19 +1540,17 @@ int Field_num::store_decimal(const my_decimal *val)
...
@@ -1542,19 +1540,17 @@ int Field_num::store_decimal(const my_decimal *val)
}
}
/*
/*
*
Return decimal value of integer field
Return decimal value of integer field
.
SYNOPSIS
@param decimal_value buffer for storing decimal value
Field_num::val_decimal()
decimal_value buffer for storing decimal value
NOTE
@note
This method is used by all integer fields, real/decimal redefine it
This method is used by all integer fields, real/decimal redefine it
.
All longlong values fit in our decimal buffer which cal store 8*9=72
All longlong values fit in our decimal buffer which cal store 8*9=72
digits of integer number
digits of integer number
RETURN
@return
pointer to decimal buffer with value of field
pointer to decimal buffer with value of field
*/
*/
...
@@ -1587,22 +1583,24 @@ void Field_num::make_field(Send_field *field)
...
@@ -1587,22 +1583,24 @@ void Field_num::make_field(Send_field *field)
field
->
decimals
=
dec
;
field
->
decimals
=
dec
;
}
}
/*
/*
*
Decimal representation of Field_str
Decimal representation of Field_str
.
SYNOPSIS
@param d value for storing
Field_str::store_decimal()
d value for storing
NOTE
@note
Field_str is the base class for fields like Field_enum,
Field_date and some
Field_str is the base class for fields like Field_enum,
similar. Some dates use fraction and also string value should be
Field_date and some similar. Some dates use fraction and also
converted to floating point value according our rules, so we use double
string value should be converted to floating point value according
to store value of decimal in string
our rules, so we use double to store value of decimal in string.
RETURN
@todo
use decimal2string?
@retval
0 OK
0 OK
!= 0 error
@retval
!=0 error
*/
*/
int
Field_str
::
store_decimal
(
const
my_decimal
*
d
)
int
Field_str
::
store_decimal
(
const
my_decimal
*
d
)
...
@@ -1675,11 +1673,11 @@ bool Field::get_time(MYSQL_TIME *ltime)
...
@@ -1675,11 +1673,11 @@ bool Field::get_time(MYSQL_TIME *ltime)
return
0
;
return
0
;
}
}
/*
/*
*
This is called when storing a date in a string
This is called when storing a date in a string
.
NOTES
@note
Needs to be changed if/when we want to support different time formats
Needs to be changed if/when we want to support different time formats
.
*/
*/
int
Field
::
store_time
(
MYSQL_TIME
*
ltime
,
timestamp_type
type_arg
)
int
Field
::
store_time
(
MYSQL_TIME
*
ltime
,
timestamp_type
type_arg
)
...
@@ -2301,9 +2299,9 @@ String *Field_decimal::val_str(String *val_buffer __attribute__((unused)),
...
@@ -2301,9 +2299,9 @@ String *Field_decimal::val_str(String *val_buffer __attribute__((unused)),
return
val_ptr
;
return
val_ptr
;
}
}
/*
/*
*
**
Should be able to handle at least the following fixed decimal formats:
Should be able to handle at least the following fixed decimal formats:
**
5.00 , -1.0, 05, -05, +5 with optional pre/end space
5.00 , -1.0, 05, -05, +5 with optional pre/end space
*/
*/
int
Field_decimal
::
cmp
(
const
uchar
*
a_ptr
,
const
uchar
*
b_ptr
)
int
Field_decimal
::
cmp
(
const
uchar
*
a_ptr
,
const
uchar
*
b_ptr
)
...
@@ -2425,13 +2423,11 @@ int Field_new_decimal::reset(void)
...
@@ -2425,13 +2423,11 @@ int Field_new_decimal::reset(void)
}
}
/*
/*
*
Generate max/min decimal value in case of overflow.
Generate max/min decimal value in case of overflow.
SYNOPSIS
@param decimal_value buffer for value
Field_new_decimal::set_value_on_overflow();
@param sign sign of value which caused overflow
decimal_value buffer for value
sign sign of value which caused overflow
*/
*/
void
Field_new_decimal
::
set_value_on_overflow
(
my_decimal
*
decimal_value
,
void
Field_new_decimal
::
set_value_on_overflow
(
my_decimal
*
decimal_value
,
...
@@ -2450,20 +2446,18 @@ void Field_new_decimal::set_value_on_overflow(my_decimal *decimal_value,
...
@@ -2450,20 +2446,18 @@ void Field_new_decimal::set_value_on_overflow(my_decimal *decimal_value,
}
}
/*
/**
Store decimal value in the binary buffer
Store decimal value in the binary buffer.
SYNOPSIS
store_value(const my_decimal *decimal_value)
decimal_value my_decimal
DESCRIPTION
Checks if decimal_value fits into field size.
checks if decimal_value fits into field size.
If it does, stores the decimal in the buffer using binary format.
if it does, stores the decimal in the buffer using binary format.
Otherwise sets maximal number that can be stored in the field.
Otherwise sets maximal number that can be stored in the field.
RETURN
@param decimal_value my_decimal
@retval
0 ok
0 ok
@retval
1 error
1 error
*/
*/
...
@@ -2573,6 +2567,12 @@ int Field_new_decimal::store(const char *from, uint length,
...
@@ -2573,6 +2567,12 @@ int Field_new_decimal::store(const char *from, uint length,
}
}
/**
@todo
Fix following when double2my_decimal when double2decimal
will return E_DEC_TRUNCATED always correctly
*/
int
Field_new_decimal
::
store
(
double
nr
)
int
Field_new_decimal
::
store
(
double
nr
)
{
{
ASSERT_COLUMN_MARKED_FOR_WRITE
;
ASSERT_COLUMN_MARKED_FOR_WRITE
;
...
@@ -4546,9 +4546,8 @@ void Field_double::sql_type(String &res) const
...
@@ -4546,9 +4546,8 @@ void Field_double::sql_type(String &res) const
}
}
/*
/**
TIMESTAMP type.
TIMESTAMP type holds datetime values in range from 1970-01-01 00:00:01 UTC to
Holds datetime values in range from 1970-01-01 00:00:01 UTC to
2038-01-01 00:00:00 UTC stored as number of seconds since Unix
2038-01-01 00:00:00 UTC stored as number of seconds since Unix
Epoch in UTC.
Epoch in UTC.
...
@@ -4581,7 +4580,7 @@ void Field_double::sql_type(String &res) const
...
@@ -4581,7 +4580,7 @@ void Field_double::sql_type(String &res) const
NONE - field which is not auto-set on update with some other than NOW()
NONE - field which is not auto-set on update with some other than NOW()
default value (TIMESTAMP DEFAULT 0).
default value (TIMESTAMP DEFAULT 0).
Note that TIMESTAMP_OLD_FIELD
'
s are never created explicitly now, they are
Note that TIMESTAMP_OLD_FIELDs are never created explicitly now, they are
left only for preserving ability to read old tables. Such fields replaced
left only for preserving ability to read old tables. Such fields replaced
with their newer analogs in CREATE TABLE and in SHOW CREATE TABLE. This is
with their newer analogs in CREATE TABLE and in SHOW CREATE TABLE. This is
because we want to prefer NONE unireg_check before TIMESTAMP_OLD_FIELD for
because we want to prefer NONE unireg_check before TIMESTAMP_OLD_FIELD for
...
@@ -4623,13 +4622,9 @@ Field_timestamp::Field_timestamp(bool maybe_null_arg,
...
@@ -4623,13 +4622,9 @@ Field_timestamp::Field_timestamp(bool maybe_null_arg,
}
}
/*
/*
*
Get auto-set type for TIMESTAMP field.
Get auto-set type for TIMESTAMP field.
SYNOPSIS
get_auto_set_type()
DESCRIPTION
Returns value indicating during which operations this TIMESTAMP field
Returns value indicating during which operations this TIMESTAMP field
should be auto-set to current timestamp.
should be auto-set to current timestamp.
*/
*/
...
@@ -5114,7 +5109,8 @@ longlong Field_time::val_int(void)
...
@@ -5114,7 +5109,8 @@ longlong Field_time::val_int(void)
}
}
/*
/**
@note
This function is multi-byte safe as the result string is always of type
This function is multi-byte safe as the result string is always of type
my_charset_bin
my_charset_bin
*/
*/
...
@@ -5141,7 +5137,8 @@ String *Field_time::val_str(String *val_buffer,
...
@@ -5141,7 +5137,8 @@ String *Field_time::val_str(String *val_buffer,
}
}
/*
/**
@note
Normally we would not consider 'time' as a valid date, but we allow
Normally we would not consider 'time' as a valid date, but we allow
get_date() here to be able to do things like
get_date() here to be able to do things like
DATE_FORMAT(time, "%l.%i %p")
DATE_FORMAT(time, "%l.%i %p")
...
@@ -6243,15 +6240,12 @@ int Field_string::store(const char *from,uint length,CHARSET_INFO *cs)
...
@@ -6243,15 +6240,12 @@ int Field_string::store(const char *from,uint length,CHARSET_INFO *cs)
}
}
/*
/*
*
Store double value in Field_string or Field_varstring.
Store double value in Field_string or Field_varstring.
SYNOPSIS
store(double nr)
nr number
DESCRIPTION
Pretty prints double number into field_length characters buffer.
Pretty prints double number into field_length characters buffer.
@param nr number
*/
*/
int
Field_str
::
store
(
double
nr
)
int
Field_str
::
store
(
double
nr
)
...
@@ -6605,18 +6599,18 @@ int Field_string::pack_cmp(const uchar *a, const uchar *b, uint length,
...
@@ -6605,18 +6599,18 @@ int Field_string::pack_cmp(const uchar *a, const uchar *b, uint length,
}
}
/*
/*
*
Compare a packed key against row
Compare a packed key against row
.
SYNOPSIS
@param key Original key
pack_cmp()
@param length Key length. (May be less than field length)
key Original key
@param insert_or_update 1 if this is an insert or update
length Key length. (May be less than field length)
insert_or_update 1 if this is an insert or update
RETURN
@return
< 0 row < key
< 0 row < key
@return
0 row = key
0 row = key
@return
> 0 row > key
> 0 row > key
*/
*/
...
@@ -6859,8 +6853,9 @@ int Field_varstring::cmp_max(const uchar *a_ptr, const uchar *b_ptr,
...
@@ -6859,8 +6853,9 @@ int Field_varstring::cmp_max(const uchar *a_ptr, const uchar *b_ptr,
}
}
/*
/**
NOTE: varstring and blob keys are ALWAYS stored with a 2 byte length prefix
@note
varstring and blob keys are ALWAYS stored with a 2 byte length prefix
*/
*/
int
Field_varstring
::
key_cmp
(
const
uchar
*
key_ptr
,
uint
max_key_length
)
int
Field_varstring
::
key_cmp
(
const
uchar
*
key_ptr
,
uint
max_key_length
)
...
@@ -6880,10 +6875,10 @@ int Field_varstring::key_cmp(const uchar *key_ptr, uint max_key_length)
...
@@ -6880,10 +6875,10 @@ int Field_varstring::key_cmp(const uchar *key_ptr, uint max_key_length)
}
}
/*
/*
*
Compare to key segments (always 2 byte length prefix)
Compare to key segments (always 2 byte length prefix)
.
NOTE
@note
This is used only to compare key segments created for index_read().
This is used only to compare key segments created for index_read().
(keys are created and compared in key.cc)
(keys are created and compared in key.cc)
*/
*/
...
@@ -6995,21 +6990,18 @@ uchar *Field_varstring::pack_key(uchar *to, const uchar *key, uint max_length)
...
@@ -6995,21 +6990,18 @@ uchar *Field_varstring::pack_key(uchar *to, const uchar *key, uint max_length)
}
}
/*
/*
*
Unpack a key into a record buffer.
Unpack a key into a record buffer.
SYNOPSIS
unpack_key()
to Pointer into the record buffer.
key Pointer to the packed key.
max_length Key length limit from key description.
DESCRIPTION
A VARCHAR key has a maximum size of 64K-1.
A VARCHAR key has a maximum size of 64K-1.
In its packed form, the length field is one or two bytes long,
In its packed form, the length field is one or two bytes long,
depending on 'max_length'.
depending on 'max_length'.
RETURN
@param to Pointer into the record buffer.
@param key Pointer to the packed key.
@param max_length Key length limit from key description.
@return
Pointer to end of 'key' (To the next key part if multi-segment key)
Pointer to end of 'key' (To the next key part if multi-segment key)
*/
*/
...
@@ -7030,16 +7022,14 @@ const uchar *Field_varstring::unpack_key(uchar *to, const uchar *key,
...
@@ -7030,16 +7022,14 @@ const uchar *Field_varstring::unpack_key(uchar *to, const uchar *key,
return
key
+
length
;
return
key
+
length
;
}
}
/*
/*
*
Create a packed key that will be used for storage in the index tree
Create a packed key that will be used for storage in the index tree
.
SYNOPSIS
@param to Store packed key segment here
pack_key_from_key_image()
@param from Key segment (as given to index_read())
to Store packed key segment here
@param max_length Max length of key
from Key segment (as given to index_read())
max_length Max length of key
RETURN
@return
end of key storage
end of key storage
*/
*/
...
@@ -7389,21 +7379,15 @@ uint32 Field_blob::get_length(const uchar *pos, bool low_byte_first)
...
@@ -7389,21 +7379,15 @@ uint32 Field_blob::get_length(const uchar *pos, bool low_byte_first)
}
}
/*
/*
*
Put a blob length field into a record buffer.
Put a blob length field into a record buffer.
SYNOPSIS
Field_blob::put_length()
pos Pointer into the record buffer.
length The length value to put.
DESCRIPTION
Depending on the maximum length of a blob, its length field is
Depending on the maximum length of a blob, its length field is
put into 1 to 4 bytes. This is a property of the blob object,
put into 1 to 4 bytes. This is a property of the blob object,
described by 'packlength'.
described by 'packlength'.
RETURN
@param pos Pointer into the record buffer.
nothing
@param length The length value to put.
*/
*/
void
Field_blob
::
put_length
(
uchar
*
pos
,
uint32
length
)
void
Field_blob
::
put_length
(
uchar
*
pos
,
uint32
length
)
...
@@ -7891,7 +7875,7 @@ int Field_blob::pack_cmp(const uchar *b, uint key_length_arg,
...
@@ -7891,7 +7875,7 @@ int Field_blob::pack_cmp(const uchar *b, uint key_length_arg,
insert_or_update
);
insert_or_update
);
}
}
/*
Create a packed key that will be used for storage from a MySQL row
*/
/*
* Create a packed key that will be used for storage from a MySQL row.
*/
uchar
*
Field_blob
::
pack_key
(
uchar
*
to
,
const
uchar
*
from
,
uint
max_length
)
uchar
*
Field_blob
::
pack_key
(
uchar
*
to
,
const
uchar
*
from
,
uint
max_length
)
{
{
...
@@ -7915,16 +7899,9 @@ uchar *Field_blob::pack_key(uchar *to, const uchar *from, uint max_length)
...
@@ -7915,16 +7899,9 @@ uchar *Field_blob::pack_key(uchar *to, const uchar *from, uint max_length)
}
}
/*
/*
*
Unpack a blob key into a record buffer.
Unpack a blob key into a record buffer.
SYNOPSIS
Field_blob::unpack_key()
to Pointer into the record buffer.
from Pointer to the packed key.
max_length Key length limit from key description.
DESCRIPTION
A blob key has a maximum size of 64K-1.
A blob key has a maximum size of 64K-1.
In its packed form, the length field is one or two bytes long,
In its packed form, the length field is one or two bytes long,
depending on 'max_length'.
depending on 'max_length'.
...
@@ -7934,7 +7911,12 @@ uchar *Field_blob::pack_key(uchar *to, const uchar *from, uint max_length)
...
@@ -7934,7 +7911,12 @@ uchar *Field_blob::pack_key(uchar *to, const uchar *from, uint max_length)
Blobs are internally stored apart from the record buffer, which
Blobs are internally stored apart from the record buffer, which
contains a pointer to the blob buffer.
contains a pointer to the blob buffer.
RETURN
@param to Pointer into the record buffer.
@param from Pointer to the packed key.
@param max_length Key length limit from key description.
@return
Pointer into 'from' past the last byte copied from packed key.
Pointer into 'from' past the last byte copied from packed key.
*/
*/
...
@@ -7960,7 +7942,7 @@ const uchar *Field_blob::unpack_key(uchar *to, const uchar *from,
...
@@ -7960,7 +7942,7 @@ const uchar *Field_blob::unpack_key(uchar *to, const uchar *from,
}
}
/*
Create a packed key that will be used for storage from a MySQL key
*/
/*
* Create a packed key that will be used for storage from a MySQL key.
*/
uchar
*
Field_blob
::
pack_key_from_key_image
(
uchar
*
to
,
const
uchar
*
from
,
uchar
*
Field_blob
::
pack_key_from_key_image
(
uchar
*
to
,
const
uchar
*
from
,
uint
max_length
)
uint
max_length
)
...
@@ -8181,9 +8163,10 @@ void Field_enum::store_type(ulonglong value)
...
@@ -8181,9 +8163,10 @@ void Field_enum::store_type(ulonglong value)
}
}
/*
/**
** Note. Storing a empty string in a enum field gives a warning
@note
** (if there isn't a empty value in the enum)
Storing a empty string in a enum field gives a warning
(if there isn't a empty value in the enum)
*/
*/
int
Field_enum
::
store
(
const
char
*
from
,
uint
length
,
CHARSET_INFO
*
cs
)
int
Field_enum
::
store
(
const
char
*
from
,
uint
length
,
CHARSET_INFO
*
cs
)
...
@@ -8509,7 +8492,12 @@ void Field_set::sql_type(String &res) const
...
@@ -8509,7 +8492,12 @@ void Field_set::sql_type(String &res) const
res
.
append
(
')'
);
res
.
append
(
')'
);
}
}
/* returns 1 if the fields are equally defined */
/**
@retval
1 if the fields are equally defined
@retval
0 if the fields are unequally defined
*/
bool
Field
::
eq_def
(
Field
*
field
)
bool
Field
::
eq_def
(
Field
*
field
)
{
{
...
@@ -8519,6 +8507,10 @@ bool Field::eq_def(Field *field)
...
@@ -8519,6 +8507,10 @@ bool Field::eq_def(Field *field)
return
1
;
return
1
;
}
}
/**
@return
returns 1 if the fields are equally defined
*/
bool
Field_enum
::
eq_def
(
Field
*
field
)
bool
Field_enum
::
eq_def
(
Field
*
field
)
{
{
if
(
!
Field
::
eq_def
(
field
))
if
(
!
Field
::
eq_def
(
field
))
...
@@ -8537,6 +8529,10 @@ bool Field_enum::eq_def(Field *field)
...
@@ -8537,6 +8529,10 @@ bool Field_enum::eq_def(Field *field)
return
1
;
return
1
;
}
}
/**
@return
returns 1 if the fields are equally defined
*/
bool
Field_num
::
eq_def
(
Field
*
field
)
bool
Field_num
::
eq_def
(
Field
*
field
)
{
{
if
(
!
Field
::
eq_def
(
field
))
if
(
!
Field
::
eq_def
(
field
))
...
@@ -9113,14 +9109,8 @@ void Field_bit_as_char::sql_type(String &res) const
...
@@ -9113,14 +9109,8 @@ void Field_bit_as_char::sql_type(String &res) const
Handling of field and Create_field
Handling of field and Create_field
*****************************************************************************/
*****************************************************************************/
/*
/**
Convert Create_field::length from number of characters to number of bytes
Convert create_field::length from number of characters to number of bytes.
SYNOPSIS
Create_field::create_length_to_internal_length()
DESCRIPTION
Convert Create_field::length from number of characters to number of bytes.
*/
*/
void
Create_field
::
create_length_to_internal_length
(
void
)
void
Create_field
::
create_length_to_internal_length
(
void
)
...
@@ -9170,6 +9160,9 @@ void Create_field::create_length_to_internal_length(void)
...
@@ -9170,6 +9160,9 @@ void Create_field::create_length_to_internal_length(void)
}
}
/**
Init for a tmp table field. To be extended if need be.
*/
void
Create_field
::
init_for_tmp_table
(
enum_field_types
sql_type_arg
,
void
Create_field
::
init_for_tmp_table
(
enum_field_types
sql_type_arg
,
uint32
length_arg
,
uint32
decimals_arg
,
uint32
length_arg
,
uint32
decimals_arg
,
bool
maybe_null
,
bool
is_unsigned
)
bool
maybe_null
,
bool
is_unsigned
)
...
@@ -9188,26 +9181,26 @@ void Create_field::init_for_tmp_table(enum_field_types sql_type_arg,
...
@@ -9188,26 +9181,26 @@ void Create_field::init_for_tmp_table(enum_field_types sql_type_arg,
}
}
/*
/**
Initialize field definition for create
Initialize field definition for create.
SYNOPSIS
@param thd Thread handle
thd Thread handle
@param fld_name Field name
fld_name Field name
@param fld_type Field type
fld_type Field type
@param fld_length Field length
fld_length Field length
@param fld_decimals Decimal (if any)
fld_decimals Decimal (if any)
@param fld_type_modifier Additional type information
fld_type_modifier Additional type information
@param fld_default_value Field default value (if any)
fld_default_value Field default value (if any)
@param fld_on_update_value The value of ON UPDATE clause
fld_on_update_value The value of ON UPDATE clause
@param fld_comment Field comment
fld_comment Field comment
@param fld_change Field change
fld_change Field change
@param fld_interval_list Interval list (if any)
fld_interval_list Interval list (if any)
@param fld_charset Field charset
fld_charset Field charset
@param fld_geom_type Field geometry type (if any)
fld_geom_type Field geometry type (if any)
@retval
RETURN
FALSE on success
FALSE on success
@retval
TRUE on error
TRUE on error
*/
*/
...
@@ -9795,7 +9788,7 @@ Field *make_field(TABLE_SHARE *share, uchar *ptr, uint32 field_length,
...
@@ -9795,7 +9788,7 @@ Field *make_field(TABLE_SHARE *share, uchar *ptr, uint32 field_length,
}
}
/*
Create a field suitable for create of table
*/
/*
* Create a field suitable for create of table.
*/
Create_field
::
Create_field
(
Field
*
old_field
,
Field
*
orig_field
)
Create_field
::
Create_field
(
Field
*
old_field
,
Field
*
orig_field
)
{
{
...
@@ -9883,13 +9876,10 @@ Create_field::Create_field(Field *old_field,Field *orig_field)
...
@@ -9883,13 +9876,10 @@ Create_field::Create_field(Field *old_field,Field *orig_field)
}
}
/*
/**
maximum possible display length for blob
maximum possible display length for blob.
SYNOPSIS
Field_blob::max_display_length()
RETURN
@return
length
length
*/
*/
...
@@ -9916,24 +9906,23 @@ uint32 Field_blob::max_display_length()
...
@@ -9916,24 +9906,23 @@ uint32 Field_blob::max_display_length()
Warning handling
Warning handling
*****************************************************************************/
*****************************************************************************/
/*
/*
*
Produce warning or note about data saved into field
Produce warning or note about data saved into field
.
SYNOPSIS
@param level - level of message (Note/Warning/Error)
set_warning()
@param code - error code of message to be produced
level - level of message (Note/Warning/Error)
@param cuted_increment - whenever we should increase cut fields count or not
code - error code of message to be produced
cuted_increment - whenever we should increase cut fields count or not
NOTE
@note
This function won't produce warning and increase cut fields counter
This function won't produce warning and increase cut fields counter
if count_cuted_fields == CHECK_FIELD_IGNORE for current thread.
if count_cuted_fields == CHECK_FIELD_IGNORE for current thread.
if count_cuted_fields == CHECK_FIELD_IGNORE then we ignore notes.
if count_cuted_fields == CHECK_FIELD_IGNORE then we ignore notes.
This allows us to avoid notes in optimisation, like convert_constant_item().
This allows us to avoid notes in optimisation, like convert_constant_item().
RETURN VALUE
@retval
1 if count_cuted_fields == CHECK_FIELD_IGNORE and error level is not NOTE
1 if count_cuted_fields == CHECK_FIELD_IGNORE and error level is not NOTE
@retval
0 otherwise
0 otherwise
*/
*/
...
@@ -9957,21 +9946,19 @@ Field::set_warning(MYSQL_ERROR::enum_warning_level level, uint code,
...
@@ -9957,21 +9946,19 @@ Field::set_warning(MYSQL_ERROR::enum_warning_level level, uint code,
}
}
/*
/*
*
Produce warning or note about datetime string data saved into field
Produce warning or note about datetime string data saved into field
.
SYNOPSIS
@param level level of message (Note/Warning/Error)
set_datime_warning()
@param code error code of message to be produced
level - level of message (Note/Warning/Error)
@param str string value which we tried to save
code - error code of message to be produced
@param str_length length of string which we tried to save
str - string value which we tried to save
@param ts_type type of datetime value (datetime/date/time)
str_len - length of string which we tried to save
@param cuted_increment whenever we should increase cut fields count or not
ts_type - type of datetime value (datetime/date/time)
cuted_increment - whenever we should increase cut fields count or not
@note
NOTE
This function will always produce some warning but won't increase cut
This function will always produce some warning but won't increase cut
fields counter if count_cuted_fields ==
FIELD_CHECK_IGNORE for current
fields counter if count_cuted_fields ==
FIELD_CHECK_IGNORE for current
thread.
thread.
*/
*/
...
@@ -9989,18 +9976,16 @@ Field::set_datetime_warning(MYSQL_ERROR::enum_warning_level level, uint code,
...
@@ -9989,18 +9976,16 @@ Field::set_datetime_warning(MYSQL_ERROR::enum_warning_level level, uint code,
}
}
/*
/*
*
Produce warning or note about integer datetime value saved into field
Produce warning or note about integer datetime value saved into field
.
SYNOPSIS
@param level level of message (Note/Warning/Error)
set_warning()
@param code error code of message to be produced
level - level of message (Note/Warning/Error)
@param nr numeric value which we tried to save
code - error code of message to be produced
@param ts_type type of datetime value (datetime/date/time)
nr - numeric value which we tried to save
@param cuted_increment whenever we should increase cut fields count or not
ts_type - type of datetime value (datetime/date/time)
cuted_increment - whenever we should increase cut fields count or not
@note
NOTE
This function will always produce some warning but won't increase cut
This function will always produce some warning but won't increase cut
fields counter if count_cuted_fields == FIELD_CHECK_IGNORE for current
fields counter if count_cuted_fields == FIELD_CHECK_IGNORE for current
thread.
thread.
...
@@ -10023,17 +10008,15 @@ Field::set_datetime_warning(MYSQL_ERROR::enum_warning_level level, uint code,
...
@@ -10023,17 +10008,15 @@ Field::set_datetime_warning(MYSQL_ERROR::enum_warning_level level, uint code,
}
}
/*
/*
*
Produce warning or note about double datetime data saved into field
Produce warning or note about double datetime data saved into field
.
SYNOPSIS
@param level level of message (Note/Warning/Error)
set_warning()
@param code error code of message to be produced
level - level of message (Note/Warning/Error)
@param nr double value which we tried to save
code - error code of message to be produced
@param ts_type type of datetime value (datetime/date/time)
nr - double value which we tried to save
ts_type - type of datetime value (datetime/date/time)
NOTE
@note
This function will always produce some warning but won't increase cut
This function will always produce some warning but won't increase cut
fields counter if count_cuted_fields == FIELD_CHECK_IGNORE for current
fields counter if count_cuted_fields == FIELD_CHECK_IGNORE for current
thread.
thread.
...
...
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