summaryrefslogtreecommitdiff
path: root/sql/item_timefunc.h
diff options
context:
space:
mode:
authorunknown <monty@narttu.mysql.fi>2003-11-03 14:01:59 +0200
committerunknown <monty@narttu.mysql.fi>2003-11-03 14:01:59 +0200
commitbee5d9d4627a3b6d09430015357487c1c6c94bca (patch)
treef9406690fb9f579e21f4877826d439fb785d6902 /sql/item_timefunc.h
parentdd85b7602660a400f71d16d00bb8c869d4320c7a (diff)
downloadmariadb-git-bee5d9d4627a3b6d09430015357487c1c6c94bca.tar.gz
Simplified 'wrong xxx name' error messages by introducing 'general' ER_WRONG_NAME error
Cleaned up (and disabled part of) date/time/datetime format patch. One can't anymore change default read/write date/time/formats. This is becasue the non standard datetime formats can't be compared as strings and MySQL does still a lot of datetime comparisons as strings Changed flag argument to str_to_TIME() and get_date() from bool to uint Removed THD from str_to_xxxx functions and Item class. Fixed core dump when doing --print-defaults Move some common string functions to strfunc.cc Dates as strings are now of type my_charset_bin instead of default_charset() Introduce IDENT_QUOTED to not have to create an extra copy of simple identifiers (all chars < 128) Removed xxx_FORMAT_TYPE enums and replaced them with the old TIMESTAMP_xxx enums Renamed some TIMESTAMP_xxx enums to more appropriate names Use defines instead of integers for date/time/datetime string lengths Added to build system and use the new my_strtoll10() function. BUILD/compile-pentium-valgrind-max: Remove double printing of warning VC++Files/libmysqld/libmysqld.dsp: Added strfunc.cc VC++Files/sql/mysqld.dsp: Added strfunc.cc VC++Files/sql/mysqldmax.dsp: Added strfunc.cc VC++Files/strings/strings.dsp: added my_strtoll10.c include/m_ctype.h: Removed MY_LEX_FOUND_IDENT (not used) include/m_string.h: Added my_strtoll10() include/mysqld_error.h: simplified 'wrong xxx name' error messages include/sql_state.h: simplified 'wrong xxx name' error messages libmysqld/Makefile.am: Added strfunc.cc mysql-test/mysql-test-run.sh: Simplified some options changed $@ to "$@" in an attempt to handle options with space (Didn't succeed; Problem will disappear when mysql-test-run is rewritten in C) mysql-test/r/ctype_latin1_de.result: Added new tests mysql-test/r/ctype_recoding.result: Extended tests mysql-test/r/date_formats.result: Cleaned up tests Disabled some tests that can't yet be run mysql-test/r/func_compress.result: New error message mysql-test/r/rpl_temporary.result: Added new test mysql-test/t/create.test: Changed error numbers mysql-test/t/ctype_latin1_de.test: New tests mysql-test/t/ctype_recoding.test: Extended tests mysql-test/t/date_formats-master.opt: Removed datetime_format as we can't handle options with space in mysql-test-run mysql-test/t/date_formats.test: Cleaned up tests Disabled some tests that can't yet be run mysql-test/t/rpl_temporary.test: Added testing of open temporary table on slave shutdown mysql-test/t/symlink.test: Fixed error numbers mysys/default.c: Fixed core dump when doing --print-defaults sql/Makefile.am: Added strfunc.cc sql/derror.cc: Fixed compiler warning sql/field.cc: Changed argument to str_to_TIME() from bool to uint Removed THD argument from str_to_TIME() Moved find_enum() and find_set() to strfunc.cc sql/field.h: Changed type of last argument to get_date() to be able to handle more options sql/init.cc: Remove not used variable dayord sql/item.cc: Changed type of last argument to get_date() to be able to handle more options Removed THD* element from item. Don't use make_date_time() to generate date/time/datetimes sql/item.h: Changed type of last argument to get_date() to be able to handle more options Removed THD* from Item sql/item_create.cc: Indentation cleanup sql/item_func.cc: Use new find_type() sql/item_func.h: Changed type of last argument to get_date() to be able to handle more options sql/item_strfunc.h: space change sql/item_timefunc.cc: Changed month_names[] to be easier to use Moved check_names[] to strfunc.cc Added back old make_datetime() function Optimized extract_date_time() Use my_strtoll10() insetad of my_strntoll() Optimized make_date_time() Replaced short variable names with long ones. Use new functions make_time(), make_date() and make_datetime() Dates as strings are now of type my_charset_bin instead of default_charset() Changed Item_func_str_to_date() to by default return a date. sql/item_timefunc.h: Changed charset for date string from default_charset() to my_charset_bin Changed type of last argument to get_date() to be able to handle more options Use defines instead of integers for date/time/datetime string lengths sql/mysql_priv.h: Fixed/added new prototypes sql/mysqld.cc: Removed opt_datetime_format_names Cleaned up handling of date_time format handling. (Fixed core dump when mysqld had error on startup) Removed some unnecessary double init of collation variables sql/protocol.cc: Changed back protocol functions to always return dates in ISO format sql/set_var.cc: Added variables time_format, date_format and datetime_format This had to be recoded becasue checking was done in 'update' method and not in 'check' method. sql/set_var.h: Removed class sys_var_datetime_format() as this defined a variable (which doesn't work) instead of updating a variable sql/share/czech/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/danish/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/dutch/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/english/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/estonian/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/french/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/german/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/greek/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/hungarian/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/italian/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/japanese/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/korean/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/norwegian-ny/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/norwegian/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/polish/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/portuguese/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/romanian/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/russian/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/serbian/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/slovak/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/spanish/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/swedish/errmsg.txt: simplified 'wrong xxx name' error messages sql/share/ukrainian/errmsg.txt: simplified 'wrong xxx name' error messages sql/sql_base.cc: Use new find_type() sql/sql_class.cc: Allocate/free date_time format variables sql/sql_class.h: Define datetime_format variables sql/sql_db.cc: Use new ER_WRONG_NAME error sql/sql_lex.cc: Change lex to generate IDENT_QUOTED for quoted identifiers or identifers that are using characters > 128. This enabled us to not have to copy and convert the identifier to utf8 for simpe identifiers sql/sql_parse.cc: Use new ER_WRONG_NAME error Use new find_type() function sql/sql_prepare.cc: Use new defines sql/sql_table.cc: Use new ER_WRONG_NAME error sql/sql_yacc.yy: Don't copy and convert simple identifiers to utf8. Replace __FORMAT_TYPE defines with TIMESTAMP... defines sql/structs.h: Renamed DATETIME_FORMAT to DATE_TIME format to indicate that it's for date/time/datetime formats Renamed WRONT_TIMESTAMP_FULL to TIMESTAMP_DATETIME_ERROR and TIMESTAMP_FULL to TIMESTAMP_DATETIME Added KNOWN_DATE_TIME_FORMAT struct for Item_func_get_format sql/time.cc: Prepare str_to_TIME and str_to_time() for general date/time handling Removed THD from str_to... functions Renamed date/time/datetime functions to use 'date_time' instead of 'datetime' Added functions to make and copy DATE_TIME_FORMAT's Added trivial functions 'make_time()', 'make_date()' and 'make_datetime()' strings/Makefile.am: Added my_strtoll10() strings/ctype-bin.c: Cleared upper part of binary state map to be able to easily identify simple identifiers strings/my_vsnprintf.c: F
Diffstat (limited to 'sql/item_timefunc.h')
-rw-r--r--sql/item_timefunc.h127
1 files changed, 63 insertions, 64 deletions
diff --git a/sql/item_timefunc.h b/sql/item_timefunc.h
index b7bf294b83d..e98b5eb1f1d 100644
--- a/sql/item_timefunc.h
+++ b/sql/item_timefunc.h
@@ -29,7 +29,7 @@ public:
const char *func_name() const { return "period_add"; }
void fix_length_and_dec()
{
- max_length=6*default_charset()->mbmaxlen;
+ max_length=6*MY_CHARSET_BIN_MB_MAXLEN;
}
};
@@ -43,7 +43,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=6*default_charset()->mbmaxlen;
+ max_length=6*MY_CHARSET_BIN_MB_MAXLEN;
}
};
@@ -57,7 +57,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=6*default_charset()->mbmaxlen;
+ max_length=6*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -72,7 +72,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=2*default_charset()->mbmaxlen;
+ max_length=2*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -86,16 +86,16 @@ public:
double val() { return (double) Item_func_month::val_int(); }
String *val_str(String *str)
{
- str->set(val_int(), default_charset());
+ str->set(val_int(), &my_charset_bin);
return null_value ? 0 : str;
}
const char *func_name() const { return "month"; }
enum Item_result result_type () const { return INT_RESULT; }
void fix_length_and_dec()
{
- collation.set(default_charset());
+ collation.set(&my_charset_bin);
decimals=0;
- max_length=2*default_charset()->mbmaxlen;
+ max_length=2*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -110,9 +110,9 @@ public:
enum Item_result result_type () const { return STRING_RESULT; }
void fix_length_and_dec()
{
- collation.set(default_charset());
+ collation.set(&my_charset_bin);
decimals=0;
- max_length=10*default_charset()->mbmaxlen;
+ max_length=10*my_charset_bin.mbmaxlen;
maybe_null=1;
}
};
@@ -127,7 +127,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=3*default_charset()->mbmaxlen;
+ max_length=3*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -142,7 +142,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=2*default_charset()->mbmaxlen;
+ max_length=2*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -157,7 +157,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=2*default_charset()->mbmaxlen;
+ max_length=2*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -172,7 +172,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=1*default_charset()->mbmaxlen;
+ max_length=1*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -187,7 +187,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=2*default_charset()->mbmaxlen;
+ max_length=2*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -202,7 +202,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=2*default_charset()->mbmaxlen;
+ max_length=2*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -216,7 +216,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=6*default_charset()->mbmaxlen;
+ max_length=6*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -231,7 +231,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=4*default_charset()->mbmaxlen;
+ max_length=4*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -247,16 +247,16 @@ public:
double val() { return (double) val_int(); }
String *val_str(String *str)
{
- str->set(val_int(), default_charset());
+ str->set(val_int(), &my_charset_bin);
return null_value ? 0 : str;
}
const char *func_name() const { return "weekday"; }
enum Item_result result_type () const { return INT_RESULT; }
void fix_length_and_dec()
{
- collation.set(default_charset());
+ collation.set(&my_charset_bin);
decimals=0;
- max_length=1*default_charset()->mbmaxlen;
+ max_length=1*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -270,9 +270,9 @@ class Item_func_dayname :public Item_func_weekday
enum Item_result result_type () const { return STRING_RESULT; }
void fix_length_and_dec()
{
- collation.set(default_charset());
+ collation.set(&my_charset_bin);
decimals=0;
- max_length=9*default_charset()->mbmaxlen;
+ max_length=9*MY_CHARSET_BIN_MB_MAXLEN;
maybe_null=1;
}
};
@@ -289,7 +289,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=10*default_charset()->mbmaxlen;
+ max_length=10*MY_CHARSET_BIN_MB_MAXLEN;
}
};
@@ -303,7 +303,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=10*default_charset()->mbmaxlen;
+ max_length=10*MY_CHARSET_BIN_MB_MAXLEN;
}
};
@@ -322,14 +322,14 @@ public:
const char *func_name() const { return "date"; }
void fix_length_and_dec()
{
- collation.set(default_charset());
+ collation.set(&my_charset_bin);
decimals=0;
- max_length=10*default_charset()->mbmaxlen;
+ max_length=MAX_DATE_WIDTH*MY_CHARSET_BIN_MB_MAXLEN;
}
int save_in_field(Field *to, bool no_conversions);
Field *tmp_table_field(TABLE *t_arg)
{
- return (new Field_date(maybe_null, name, t_arg, default_charset()));
+ return (new Field_date(maybe_null, name, t_arg, &my_charset_bin));
}
};
@@ -343,7 +343,7 @@ public:
enum_field_types field_type() const { return MYSQL_TYPE_DATETIME; }
Field *tmp_table_field(TABLE *t_arg)
{
- return (new Field_datetime(maybe_null, name, t_arg, default_charset()));
+ return (new Field_datetime(maybe_null, name, t_arg, &my_charset_bin));
}
};
@@ -366,7 +366,7 @@ public:
void fix_length_and_dec();
Field *tmp_table_field(TABLE *t_arg)
{
- return (new Field_time(maybe_null, name, t_arg, default_charset()));
+ return (new Field_time(maybe_null, name, t_arg, &my_charset_bin));
}
/*
Abstract method that defines which time zone is used for conversion.
@@ -408,7 +408,7 @@ public:
void set_result_from_tm(struct tm *now);
longlong val_int() { return (value) ; }
void fix_length_and_dec();
- bool get_date(TIME *res,bool fuzzy_date);
+ bool get_date(TIME *res, uint fuzzy_date);
virtual void store_now_in_tm(time_t now, struct tm *now_tm)=0;
};
@@ -448,7 +448,7 @@ public:
int save_in_field(Field *to, bool no_conversions);
String *val_str(String *str);
void fix_length_and_dec();
- bool get_date(TIME *res,bool fuzzy_date);
+ bool get_date(TIME *res, uint fuzzy_date);
virtual void store_now_in_tm(time_t now, struct tm *now_tm)=0;
};
@@ -485,11 +485,11 @@ public:
class Item_func_date_format :public Item_str_func
{
int fixed_length;
- const bool date_or_time;
+ const bool is_time_format;
String value;
public:
- Item_func_date_format(Item *a,Item *b,bool date_or_time_arg)
- :Item_str_func(a,b),date_or_time(date_or_time_arg) {}
+ Item_func_date_format(Item *a,Item *b,bool is_time_format_arg)
+ :Item_str_func(a,b),is_time_format(is_time_format_arg) {}
String *val_str(String *str);
const char *func_name() const { return "date_format"; }
void fix_length_and_dec();
@@ -507,11 +507,11 @@ class Item_func_from_unixtime :public Item_date_func
const char *func_name() const { return "from_unixtime"; }
void fix_length_and_dec()
{
- collation.set(default_charset());
+ collation.set(&my_charset_bin);
decimals=0;
- max_length=19*default_charset()->mbmaxlen;
+ max_length=MAX_DATETIME_WIDTH*MY_CHARSET_BIN_MB_MAXLEN;
}
- bool get_date(TIME *res,bool fuzzy_date);
+ bool get_date(TIME *res, uint fuzzy_date);
};
@@ -524,15 +524,15 @@ public:
String *val_str(String *);
void fix_length_and_dec()
{
- collation.set(default_charset());
+ collation.set(&my_charset_bin);
maybe_null=1;
- max_length=13*default_charset()->mbmaxlen;
+ max_length=MAX_TIME_WIDTH*MY_CHARSET_BIN_MB_MAXLEN;
}
enum_field_types field_type() const { return MYSQL_TYPE_TIME; }
const char *func_name() const { return "sec_to_time"; }
Field *tmp_table_field(TABLE *t_arg)
{
- return (new Field_time(maybe_null, name, t_arg, default_charset()));
+ return (new Field_time(maybe_null, name, t_arg, &my_charset_bin));
}
};
@@ -567,7 +567,7 @@ public:
enum_field_types field_type() const { return cached_field_type; }
double val() { return (double) val_int(); }
longlong val_int();
- bool get_date(TIME *res,bool fuzzy_date);
+ bool get_date(TIME *res, uint fuzzy_date);
};
@@ -601,7 +601,7 @@ public:
}
void fix_length_and_dec()
{
- collation.set(default_charset());
+ collation.set(&my_charset_bin);
max_length=args[0]->max_length;
}
void print(String *str);
@@ -627,12 +627,12 @@ class Item_date_typecast :public Item_typecast
public:
Item_date_typecast(Item *a) :Item_typecast(a) {}
String *val_str(String *str);
- bool get_date(TIME *ltime, bool fuzzy_date);
+ bool get_date(TIME *ltime, uint fuzzy_date);
const char *func_name() const { return "date"; }
enum_field_types field_type() const { return MYSQL_TYPE_DATE; }
Field *tmp_table_field(TABLE *t_arg)
{
- return (new Field_date(maybe_null, name, t_arg, default_charset()));
+ return (new Field_date(maybe_null, name, t_arg, &my_charset_bin));
}
};
@@ -647,7 +647,7 @@ public:
enum_field_types field_type() const { return MYSQL_TYPE_TIME; }
Field *tmp_table_field(TABLE *t_arg)
{
- return (new Field_time(maybe_null, name, t_arg, default_charset()));
+ return (new Field_time(maybe_null, name, t_arg, &my_charset_bin));
}
};
@@ -661,7 +661,7 @@ public:
enum_field_types field_type() const { return MYSQL_TYPE_DATETIME; }
Field *tmp_table_field(TABLE *t_arg)
{
- return (new Field_datetime(maybe_null, name, t_arg, default_charset()));
+ return (new Field_datetime(maybe_null, name, t_arg, &my_charset_bin));
}
};
@@ -675,7 +675,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=8*MY_CHARSET_BIN_MB_MAXLEN;
+ max_length=MAX_DATE_WIDTH*MY_CHARSET_BIN_MB_MAXLEN;
}
Field *tmp_table_field(TABLE *t_arg)
{
@@ -724,7 +724,7 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=17*MY_CHARSET_BIN_MB_MAXLEN;
+ max_length=MAX_TIME_WIDTH*MY_CHARSET_BIN_MB_MAXLEN;
}
Field *tmp_table_field(TABLE *t_arg)
{
@@ -743,11 +743,11 @@ public:
void fix_length_and_dec()
{
decimals=0;
- max_length=8*MY_CHARSET_BIN_MB_MAXLEN;
+ max_length=MAX_TIME_WIDTH*MY_CHARSET_BIN_MB_MAXLEN;
}
Field *tmp_table_field(TABLE *t_arg)
{
- return (new Field_time(maybe_null, name, t_arg, &my_charset_bin));
+ return (new Field_time(maybe_null, name, t_arg, &my_charset_bin));
}
};
@@ -765,44 +765,43 @@ public:
};
-enum datetime_format
+enum date_time_format
{
USA_FORMAT, JIS_FORMAT, ISO_FORMAT, EUR_FORMAT, INTERNAL_FORMAT
};
-
-enum datetime_format_types
-{
- DATE_FORMAT_TYPE= 0, TIME_FORMAT_TYPE, DATETIME_FORMAT_TYPE
-};
-
-
class Item_func_get_format :public Item_str_func
{
- const datetime_format_types tm_format;
+ const timestamp_type type;
public:
- Item_func_get_format(datetime_format_types type_arg1, Item *a)
- :Item_str_func(a), tm_format(type_arg1) {}
+ Item_func_get_format(timestamp_type type_arg, Item *a)
+ :Item_str_func(a), type(type_arg)
+ {}
String *val_str(String *str);
const char *func_name() const { return "get_format"; }
void fix_length_and_dec()
{
+ maybe_null= 1;
decimals=0;
max_length=17*MY_CHARSET_BIN_MB_MAXLEN;
}
+ void print(String *str);
};
-class Item_func_str_to_date :public Item_str_func
+class Item_func_str_to_date :public Item_date_func
{
public:
Item_func_str_to_date(Item *a, Item *b)
- :Item_str_func(a, b) {}
+ :Item_date_func(a, b)
+ {}
String *val_str(String *str);
+ bool get_date(TIME *ltime, uint fuzzy_date);
const char *func_name() const { return "str_to_date"; }
void fix_length_and_dec()
{
+ maybe_null= 1;
decimals=0;
- max_length=29*MY_CHARSET_BIN_MB_MAXLEN;
+ max_length=MAX_DATETIME_FULL_WIDTH*MY_CHARSET_BIN_MB_MAXLEN;
}
};