mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 08:44:33 +01:00
09a53f28a7
Faster thr_alarm() Added 'Opened_files' status variable to track calls to my_open() Don't give warnings when running mysql_install_db Added option --source-install to mysql_install_db I had to do the following renames() as used polymorphism didn't work with Forte compiler on 64 bit systems index_read() -> index_read_map() index_read_idx() -> index_read_idx_map() index_read_last() -> index_read_last_map() BUILD/compile-solaris-sparc-forte: Updated script to current Solaris installations Now we compile by default for 64 bits client/mysql.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) client/mysql_upgrade.c: Fixed compiler warning (on Forte) client/mysqladmin.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) client/mysqlcheck.c: Fixed compiler warning (on Forte) client/mysqldump.c: Fixed compiler warning (on Forte) client/mysqlslap.c: Fixed compiler warning (on Forte) client/mysqltest.c: Fixed compiler warning (on Forte) client/sql_string.cc: Avoid compiler warnings when using C function pointers in C++ configure.in: Added detection of mtmalloc and ieeefp.h extra/replace.c: Fixed compiler warning (on Forte) include/m_ctype.h: Added some typedef's to make it easy to use C function pointers in C++ include/my_sys.h: Added my_file_total_opened (counter for calls to my_open()) include/myisam.h: Fixed compiler warning (on Forte) libmysql/libmysql.c: Fixed compiler warning (on Forte) by adding casts and change types libmysql/manager.c: Fixed compiler warning (on Forte) by adding casts and change types mysql-test/r/ctype_cp932_binlog_stm.result: Updated positions (Needed because we didn't before correctly restore collation_database after running stored procedure mysys/my_fopen.c: Count number of opened files mysys/my_open.c: Count number of opened files mysys/my_static.c: Count number of opened files mysys/thr_alarm.c: Optimization to do less alarm() and pthread_sigmask() calls. Idea is to remember time for next pending alarm and not reschedule a new alarm if it's after the current one. Before we only did this if there was other pending alarms. We don't have to use pthread_sigmask() in case of 'USE_ONE_SIGNAL_HAND' as the alarm() signal will be blocked for the calling thread anyway and no other thread will have the alarm() signal enabled to call process_alarm() regex/regcomp.c: Fixed compiler warning (on Forte) by adding casts and change types scripts/mysql_install_db.sh: Added option --source-install to allow one to create a mysql database from the source tree without installing MySQL Don't give (unnecessary) warnings server-tools/instance-manager/angel.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) server-tools/instance-manager/thread_registry.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) sql/event_db_repository.cc: index_read() -> index_read_map() sql/event_queue.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) sql/field.cc: Fixed compiler warnings about hidden fields sql/ha_partition.cc: Fixed compiler warnings about hidden fields index_read() -> index_read_map() sql/ha_partition.h: index_read() -> index_read_map() sql/handler.cc: Added PAGE option to row types (to prepare for future) index_read() -> index_read_map() sql/handler.h: Added ROW_TYPE_PAGE (for future) Added flag to signal if table was to be created transactionally I had to do the following renames() as used polymorphism didn't work with Forte compiler on 64 bit systems index_read() -> index_read_map() index_read_idx() -> index_read_idx_map() index_read_last() -> index_read_last_map() sql/item.cc: Fixed indentation Renamed local variable to avoid hiding class variable sql/item_cmpfunc.cc: Renamed local variable to avoid hiding class variable sql/item_cmpfunc.h: Removed not used variable sql/item_func.cc: Renamed local variable to avoid hiding class variable sql/item_strfunc.cc: Moved functions from Item_strfunc.cc sql/item_strfunc.h: Move functions to item_strfunc.cc Use C function pointer type to avoid compiler warnings (with Forte) sql/item_subselect.cc: index_read() -> index_read_map() sql/item_xmlfunc.cc: Renamed local variable to avoid hiding class variable Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) sql/key.cc: Fixed indentation sql/log.cc: Renamed local variable to avoid hiding class variable sql/log_event.cc: Removed call to my_time() when creating class instance of Log_event() as this may have static instances. (One can't call my_time() before my_init()) index_read() -> index_read_map() Renamed local variable to avoid hiding class variable sql/log_event_old.cc: Renamed local variable to avoid hiding class variable sql/mysql_priv.h: Made all create_backup_ctx() declarations identical. This lifted up a bug where wrong create_backup_ctx() was called in some cases. Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) sql/mysqld.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) Fixed indentation Don't call end_thr_alarm() when calling unireg_abort() as unireg_abort() already calls end_thr_alarm() Added variable 'Opened_files' (number of calls to my_open() or my_fopen()) Don't print 'loose' warnings when using --bootstrap (to avoid warnings when running mysql_install_db) Fixed compiler warnings sql/opt_range.cc: index_read() -> index_read_map() sql/opt_sum.cc: index_read() -> index_read_map() sql/partition_info.cc: Renamed local variable to avoid hiding class variable sql/rpl_filter.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) sql/set_var.cc: Renamed local variable to avoid hiding class variable Added 'process_key_cache_t' type to avoid compiler warning (on Forte) sql/set_var.h: Added 'process_key_cache_t' type to avoid compiler warning (on Forte) sql/sp.cc: More debugging index_read() -> index_read_map() sql/sp_cache.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) sql/sp_head.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) Moved 'saved_creation_ctx' higher up to be able to free objects allocated by create_backup_ctx() sql/sql_acl.cc: index_read() -> index_read_map() sql/sql_class.cc: Renamed local variable to avoid hiding class variable Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) sql/sql_class.h: Renamed local variable to avoid hiding class variable sql/sql_db.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) sql/sql_delete.cc: Renamed local variable to avoid hiding class variable sql/sql_handler.cc: index_read() -> index_read_map() sql/sql_help.cc: index_read() -> index_read_map() sql/sql_insert.cc: index_read() -> index_read_map() Renamed local variable to avoid hiding class variable sql/sql_lex.cc: Renamed local variable to avoid hiding class variable sql/sql_plugin.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) index_read() -> index_read_map() Don't give warnings about not used plugins if we are using --warnings=0 sql/sql_select.cc: index_read() -> index_read_map() sql-common/client.c: Fixed compiler warning (on Forte) sql-common/my_time.c: Removed never accessed code Fixed compiler warning (on Forte) sql/sql_servers.cc: index_read() -> index_read_map() sql/sql_show.cc: Added TRANSACTIONAL to SHOW CREATE Fixed ROW_TYPE_PAGE sql/sql_string.cc: Avoid compiler warnings when using C function pointers in C++ sql/sql_table.cc: Set create_info->transactional if we used TRANSACTIONAL=1 sql/sql_udf.cc: index_read() -> index_read_map() sql/sql_yacc.yy: Added TRANSACTIONAL=0|1 to CREATE (for future) Added row type PAGE (was only partionally handled before) sql/strfunc.cc: Avoid compiler warnings when using C function pointers in C++ sql/table.cc: More DBUG statements Declare all create_backup_ctx() functions identically Remember if table was created with TRANSACTIONAL flag or not (future safe) Renamed local variable to avoid hiding class variable sql/table.h: Remember if table was created with TRANSACTIONAL=1 sql/tztime.cc: index_read() -> index_read_map() sql-common/pack.c: Fixed compiler warning (on Forte) storage/archive/archive_reader.c: Fixed compiler warning (on Forte) storage/archive/azio.c: Fixed compiler warning (on Forte) storage/blackhole/ha_blackhole.cc: index_read() -> index_read_map() storage/blackhole/ha_blackhole.h: index_read() -> index_read_map() storage/csv/ha_tina.cc: Declare functions sent to C code with extern "C" to avoid compiler warnings (on Forte) storage/example/ha_example.cc: index_read() -> index_read_map() storage/example/ha_example.h: index_read() -> index_read_map() storage/heap/ha_heap.cc: index_read() -> index_read_map() storage/heap/ha_heap.h: index_read() -> index_read_map() storage/heap/hp_test1.c: Fixed compiler warning (on Forte) storage/heap/hp_test2.c: Fixed compiler warning (on Forte) storage/myisam/ft_boolean_search.c: Fixed compiler warning (on Forte) storage/myisam/ft_nlq_search.c: Fixed compiler warning (on Forte) storage/myisam/ft_parser.c: Fixed compiler warning (on Forte) storage/myisam/ft_stopwords.c: Fixed compiler warning (on Forte) storage/myisam/ha_myisam.cc: index_read() -> index_read_map() storage/myisam/ha_myisam.h: index_read() -> index_read_map() storage/myisam/mi_check.c: Fixed compiler warning (on Forte) storage/myisam/mi_delete.c: Fixed compiler warning (on Forte) storage/myisam/mi_dynrec.c: Fixed compiler warning (on Forte) storage/myisam/mi_extra.c: Fixed compiler warning (on Forte) storage/myisam/mi_key.c: Fixed compiler warning (on Forte) storage/myisam/mi_keycache.c: Fixed compiler warning (on Forte) storage/myisam/mi_locking.c: Fixed compiler warning (on Forte) storage/myisam/mi_log.c: Fixed compiler warning (on Forte) storage/myisam/mi_open.c: Fixed compiler warning (on Forte) storage/myisam/mi_packrec.c: Fixed compiler warning (on Forte) storage/myisam/mi_page.c: Fixed compiler warning (on Forte) storage/myisam/mi_rkey.c: Added comment storage/myisam/mi_search.c: Fixed compiler warning (on Forte) storage/myisam/mi_statrec.c: Fixed compiler warning (on Forte) storage/myisam/mi_test1.c: Fixed compiler warning (on Forte) storage/myisam/mi_test2.c: Fixed compiler warning (on Forte) storage/myisam/mi_test3.c: Fixed compiler warning (on Forte) storage/myisam/mi_update.c: Fixed compiler warning (on Forte) storage/myisam/mi_write.c: Fixed compiler warning (on Forte) storage/myisam/myisamdef.h: Fixed that file_read/file_write returns type size_t Changed some functions to use uchar * as argument/return value instead of char* This fixed some compiler warnings on Forte storage/myisam/myisamlog.c: Fixed compiler warning (on Forte) storage/myisam/myisampack.c: Fixed compiler warning (on Forte) storage/myisam/rt_test.c: Fixed compiler warning (on Forte) storage/myisam/sort.c: Fixed compiler warning (on Forte) by adding casts or changing variables to uchar* storage/myisam/sp_test.c: Fixed compiler warning (on Forte) by adding casts or changing variables to uchar* storage/myisammrg/ha_myisammrg.cc: index_read() -> index_read_map() storage/myisammrg/ha_myisammrg.h: index_read() -> index_read_map() storage/myisammrg/myrg_create.c: Fixed compiler warning (on Forte) by adding casts or changing variable types storage/ndb/src/kernel/blocks/dbtup/DbtupExecQuery.cpp: Tdummy -> align (as in other part of cluster code) storage/ndb/src/kernel/vm/DynArr256.cpp: Removed not used variable storage/ndb/src/ndbapi/Ndb.cpp: Removed not used variable strings/strtod.c: Include ieeefp.h to avoid compiler warning tests/bug25714.c: Fixed compiler warning tests/mysql_client_test.c: Remove not used variable Fixed indentation Removed never reached code Fixed compiler warning (on Forte) by adding casts or changing variable types vio/viosocket.c: Fixed compiler warning (on Forte) by adding casts or changing variable types
1210 lines
37 KiB
C++
1210 lines
37 KiB
C++
/* Copyright (C) 2002-2006 MySQL AB
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
/* Classes to support the SET command */
|
|
|
|
#ifdef USE_PRAGMA_INTERFACE
|
|
#pragma interface /* gcc class implementation */
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
Variables that are changable runtime are declared using the
|
|
following classes
|
|
****************************************************************************/
|
|
|
|
class sys_var;
|
|
class set_var;
|
|
class sys_var_pluginvar; /* opaque */
|
|
typedef struct system_variables SV;
|
|
typedef struct my_locale_st MY_LOCALE;
|
|
|
|
extern TYPELIB bool_typelib, delay_key_write_typelib, sql_mode_typelib;
|
|
|
|
typedef int (*sys_check_func)(THD *, set_var *);
|
|
typedef bool (*sys_update_func)(THD *, set_var *);
|
|
typedef void (*sys_after_update_func)(THD *,enum_var_type);
|
|
typedef void (*sys_set_default_func)(THD *, enum_var_type);
|
|
typedef uchar *(*sys_value_ptr_func)(THD *thd);
|
|
|
|
struct sys_var_chain
|
|
{
|
|
sys_var *first;
|
|
sys_var *last;
|
|
};
|
|
|
|
class sys_var
|
|
{
|
|
public:
|
|
sys_var *next;
|
|
struct my_option *option_limits; /* Updated by by set_var_init() */
|
|
uint name_length; /* Updated by by set_var_init() */
|
|
const char *name;
|
|
|
|
sys_after_update_func after_update;
|
|
bool no_support_one_shot;
|
|
sys_var(const char *name_arg,sys_after_update_func func= NULL)
|
|
:name(name_arg), after_update(func)
|
|
, no_support_one_shot(1)
|
|
{}
|
|
virtual ~sys_var() {}
|
|
void chain_sys_var(sys_var_chain *chain_arg)
|
|
{
|
|
if (chain_arg->last)
|
|
chain_arg->last->next= this;
|
|
else
|
|
chain_arg->first= this;
|
|
chain_arg->last= this;
|
|
}
|
|
virtual bool check(THD *thd, set_var *var);
|
|
bool check_enum(THD *thd, set_var *var, const TYPELIB *enum_names);
|
|
bool check_set(THD *thd, set_var *var, TYPELIB *enum_names);
|
|
virtual bool update(THD *thd, set_var *var)=0;
|
|
virtual void set_default(THD *thd_arg, enum_var_type type) {}
|
|
virtual SHOW_TYPE show_type() { return SHOW_UNDEF; }
|
|
virtual uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{ return 0; }
|
|
virtual bool check_type(enum_var_type type)
|
|
{ return type != OPT_GLOBAL; } /* Error if not GLOBAL */
|
|
virtual bool check_update_type(Item_result type)
|
|
{ return type != INT_RESULT; } /* Assume INT */
|
|
virtual bool check_default(enum_var_type type)
|
|
{ return option_limits == 0; }
|
|
Item *item(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
virtual bool is_struct() { return 0; }
|
|
virtual bool is_readonly() const { return 0; }
|
|
virtual sys_var_pluginvar *cast_pluginvar() { return 0; }
|
|
};
|
|
|
|
|
|
/*
|
|
A base class for all variables that require its access to
|
|
be guarded with a mutex.
|
|
*/
|
|
|
|
class sys_var_global: public sys_var
|
|
{
|
|
protected:
|
|
pthread_mutex_t *guard;
|
|
public:
|
|
sys_var_global(const char *name_arg, sys_after_update_func after_update_arg,
|
|
pthread_mutex_t *guard_arg)
|
|
:sys_var(name_arg, after_update_arg), guard(guard_arg) {}
|
|
};
|
|
|
|
|
|
/*
|
|
A global-only ulong variable that requires its access to be
|
|
protected with a mutex.
|
|
*/
|
|
|
|
class sys_var_long_ptr_global: public sys_var_global
|
|
{
|
|
public:
|
|
ulong *value;
|
|
sys_var_long_ptr_global(sys_var_chain *chain, const char *name_arg,
|
|
ulong *value_ptr_arg,
|
|
pthread_mutex_t *guard_arg,
|
|
sys_after_update_func after_update_arg= NULL)
|
|
:sys_var_global(name_arg, after_update_arg, guard_arg),
|
|
value(value_ptr_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var);
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_LONG; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{ return (uchar*) value; }
|
|
};
|
|
|
|
|
|
/*
|
|
A global ulong variable that is protected by LOCK_global_system_variables
|
|
*/
|
|
|
|
class sys_var_long_ptr :public sys_var_long_ptr_global
|
|
{
|
|
public:
|
|
sys_var_long_ptr(sys_var_chain *chain, const char *name_arg, ulong *value_ptr,
|
|
sys_after_update_func after_update_arg= NULL);
|
|
};
|
|
|
|
|
|
class sys_var_ulonglong_ptr :public sys_var
|
|
{
|
|
public:
|
|
ulonglong *value;
|
|
sys_var_ulonglong_ptr(sys_var_chain *chain, const char *name_arg, ulonglong *value_ptr_arg)
|
|
:sys_var(name_arg),value(value_ptr_arg)
|
|
{ chain_sys_var(chain); }
|
|
sys_var_ulonglong_ptr(sys_var_chain *chain, const char *name_arg, ulonglong *value_ptr_arg,
|
|
sys_after_update_func func)
|
|
:sys_var(name_arg,func), value(value_ptr_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_LONGLONG; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{ return (uchar*) value; }
|
|
};
|
|
|
|
|
|
class sys_var_bool_ptr :public sys_var
|
|
{
|
|
public:
|
|
my_bool *value;
|
|
sys_var_bool_ptr(sys_var_chain *chain, const char *name_arg, my_bool *value_arg)
|
|
:sys_var(name_arg),value(value_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var)
|
|
{
|
|
return check_enum(thd, var, &bool_typelib);
|
|
}
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_MY_BOOL; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{ return (uchar*) value; }
|
|
bool check_update_type(Item_result type) { return 0; }
|
|
};
|
|
|
|
|
|
class sys_var_bool_ptr_readonly :public sys_var_bool_ptr
|
|
{
|
|
public:
|
|
sys_var_bool_ptr_readonly(sys_var_chain *chain, const char *name_arg,
|
|
my_bool *value_arg)
|
|
:sys_var_bool_ptr(chain, name_arg, value_arg)
|
|
{}
|
|
bool is_readonly() const { return 1; }
|
|
};
|
|
|
|
|
|
class sys_var_str :public sys_var
|
|
{
|
|
public:
|
|
char *value; // Pointer to allocated string
|
|
uint value_length;
|
|
sys_check_func check_func;
|
|
sys_update_func update_func;
|
|
sys_set_default_func set_default_func;
|
|
sys_var_str(sys_var_chain *chain, const char *name_arg,
|
|
sys_check_func check_func_arg,
|
|
sys_update_func update_func_arg,
|
|
sys_set_default_func set_default_func_arg,
|
|
char *value_arg)
|
|
:sys_var(name_arg), value(value_arg), check_func(check_func_arg),
|
|
update_func(update_func_arg),set_default_func(set_default_func_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var);
|
|
bool update(THD *thd, set_var *var)
|
|
{
|
|
return (*update_func)(thd, var);
|
|
}
|
|
void set_default(THD *thd, enum_var_type type)
|
|
{
|
|
(*set_default_func)(thd, type);
|
|
}
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{ return (uchar*) value; }
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return type != STRING_RESULT; /* Only accept strings */
|
|
}
|
|
bool check_default(enum_var_type type) { return 0; }
|
|
};
|
|
|
|
|
|
class sys_var_const_str :public sys_var
|
|
{
|
|
public:
|
|
char *value; // Pointer to const value
|
|
sys_var_const_str(sys_var_chain *chain, const char *name_arg, const char *value_arg)
|
|
:sys_var(name_arg),value((char*) value_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var)
|
|
{
|
|
return 1;
|
|
}
|
|
bool update(THD *thd, set_var *var)
|
|
{
|
|
return 1;
|
|
}
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{
|
|
return (uchar*) value;
|
|
}
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return 1;
|
|
}
|
|
bool check_default(enum_var_type type) { return 1; }
|
|
bool is_readonly() const { return 1; }
|
|
};
|
|
|
|
|
|
class sys_var_const_str_ptr :public sys_var
|
|
{
|
|
public:
|
|
char **value; // Pointer to const value
|
|
sys_var_const_str_ptr(sys_var_chain *chain, const char *name_arg, char **value_arg)
|
|
:sys_var(name_arg),value(value_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var)
|
|
{
|
|
return 1;
|
|
}
|
|
bool update(THD *thd, set_var *var)
|
|
{
|
|
return 1;
|
|
}
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{
|
|
return (uchar*) *value;
|
|
}
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return 1;
|
|
}
|
|
bool check_default(enum_var_type type) { return 1; }
|
|
bool is_readonly() const { return 1; }
|
|
};
|
|
|
|
|
|
class sys_var_enum :public sys_var
|
|
{
|
|
uint *value;
|
|
TYPELIB *enum_names;
|
|
public:
|
|
sys_var_enum(sys_var_chain *chain, const char *name_arg, uint *value_arg,
|
|
TYPELIB *typelib, sys_after_update_func func)
|
|
:sys_var(name_arg,func), value(value_arg), enum_names(typelib)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var)
|
|
{
|
|
return check_enum(thd, var, enum_names);
|
|
}
|
|
bool update(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
bool check_update_type(Item_result type) { return 0; }
|
|
};
|
|
|
|
|
|
class sys_var_thd :public sys_var
|
|
{
|
|
public:
|
|
sys_var_thd(const char *name_arg,
|
|
sys_after_update_func func= NULL)
|
|
:sys_var(name_arg,func)
|
|
{}
|
|
bool check_type(enum_var_type type) { return 0; }
|
|
bool check_default(enum_var_type type)
|
|
{
|
|
return type == OPT_GLOBAL && !option_limits;
|
|
}
|
|
};
|
|
|
|
|
|
class sys_var_thd_ulong :public sys_var_thd
|
|
{
|
|
sys_check_func check_func;
|
|
public:
|
|
ulong SV::*offset;
|
|
sys_var_thd_ulong(sys_var_chain *chain, const char *name_arg, ulong SV::*offset_arg)
|
|
:sys_var_thd(name_arg), check_func(0), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
sys_var_thd_ulong(sys_var_chain *chain, const char *name_arg, ulong SV::*offset_arg,
|
|
sys_check_func c_func, sys_after_update_func au_func)
|
|
:sys_var_thd(name_arg,au_func), check_func(c_func), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var);
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_LONG; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
|
|
class sys_var_thd_ha_rows :public sys_var_thd
|
|
{
|
|
public:
|
|
ha_rows SV::*offset;
|
|
sys_var_thd_ha_rows(sys_var_chain *chain, const char *name_arg,
|
|
ha_rows SV::*offset_arg)
|
|
:sys_var_thd(name_arg), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
sys_var_thd_ha_rows(sys_var_chain *chain, const char *name_arg,
|
|
ha_rows SV::*offset_arg,
|
|
sys_after_update_func func)
|
|
:sys_var_thd(name_arg,func), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_HA_ROWS; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
|
|
class sys_var_thd_ulonglong :public sys_var_thd
|
|
{
|
|
public:
|
|
ulonglong SV::*offset;
|
|
bool only_global;
|
|
sys_var_thd_ulonglong(sys_var_chain *chain, const char *name_arg,
|
|
ulonglong SV::*offset_arg)
|
|
:sys_var_thd(name_arg), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
sys_var_thd_ulonglong(sys_var_chain *chain, const char *name_arg,
|
|
ulonglong SV::*offset_arg,
|
|
sys_after_update_func func, bool only_global_arg)
|
|
:sys_var_thd(name_arg, func), offset(offset_arg),
|
|
only_global(only_global_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_LONGLONG; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
bool check_default(enum_var_type type)
|
|
{
|
|
return type == OPT_GLOBAL && !option_limits;
|
|
}
|
|
bool check_type(enum_var_type type)
|
|
{
|
|
return (only_global && type != OPT_GLOBAL);
|
|
}
|
|
};
|
|
|
|
|
|
class sys_var_thd_bool :public sys_var_thd
|
|
{
|
|
public:
|
|
my_bool SV::*offset;
|
|
sys_var_thd_bool(sys_var_chain *chain, const char *name_arg, my_bool SV::*offset_arg)
|
|
:sys_var_thd(name_arg), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
sys_var_thd_bool(sys_var_chain *chain, const char *name_arg, my_bool SV::*offset_arg,
|
|
sys_after_update_func func)
|
|
:sys_var_thd(name_arg,func), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_MY_BOOL; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
bool check(THD *thd, set_var *var)
|
|
{
|
|
return check_enum(thd, var, &bool_typelib);
|
|
}
|
|
bool check_update_type(Item_result type) { return 0; }
|
|
};
|
|
|
|
|
|
class sys_var_thd_enum :public sys_var_thd
|
|
{
|
|
protected:
|
|
ulong SV::*offset;
|
|
TYPELIB *enum_names;
|
|
sys_check_func check_func;
|
|
public:
|
|
sys_var_thd_enum(sys_var_chain *chain, const char *name_arg, ulong SV::*offset_arg,
|
|
TYPELIB *typelib)
|
|
:sys_var_thd(name_arg), offset(offset_arg), enum_names(typelib),
|
|
check_func(0)
|
|
{ chain_sys_var(chain); }
|
|
sys_var_thd_enum(sys_var_chain *chain, const char *name_arg, ulong SV::*offset_arg,
|
|
TYPELIB *typelib,
|
|
sys_after_update_func func)
|
|
:sys_var_thd(name_arg,func), offset(offset_arg), enum_names(typelib),
|
|
check_func(0)
|
|
{ chain_sys_var(chain); }
|
|
sys_var_thd_enum(sys_var_chain *chain, const char *name_arg, ulong SV::*offset_arg,
|
|
TYPELIB *typelib, sys_after_update_func func,
|
|
sys_check_func check)
|
|
:sys_var_thd(name_arg,func), offset(offset_arg), enum_names(typelib),
|
|
check_func(check)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var)
|
|
{
|
|
int ret= 0;
|
|
if (check_func)
|
|
ret= (*check_func)(thd, var);
|
|
return ret ? ret : check_enum(thd, var, enum_names);
|
|
}
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
bool check_update_type(Item_result type) { return 0; }
|
|
};
|
|
|
|
|
|
extern void fix_sql_mode_var(THD *thd, enum_var_type type);
|
|
|
|
class sys_var_thd_sql_mode :public sys_var_thd_enum
|
|
{
|
|
public:
|
|
sys_var_thd_sql_mode(sys_var_chain *chain, const char *name_arg,
|
|
ulong SV::*offset_arg)
|
|
:sys_var_thd_enum(chain, name_arg, offset_arg, &sql_mode_typelib,
|
|
fix_sql_mode_var)
|
|
{}
|
|
bool check(THD *thd, set_var *var)
|
|
{
|
|
return check_set(thd, var, enum_names);
|
|
}
|
|
void set_default(THD *thd, enum_var_type type);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
static bool symbolic_mode_representation(THD *thd, ulonglong sql_mode,
|
|
LEX_STRING *rep);
|
|
};
|
|
|
|
|
|
class sys_var_thd_storage_engine :public sys_var_thd
|
|
{
|
|
protected:
|
|
plugin_ref SV::*offset;
|
|
public:
|
|
sys_var_thd_storage_engine(sys_var_chain *chain, const char *name_arg,
|
|
plugin_ref SV::*offset_arg)
|
|
:sys_var_thd(name_arg), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return type != STRING_RESULT; /* Only accept strings */
|
|
}
|
|
void set_default(THD *thd, enum_var_type type);
|
|
bool update(THD *thd, set_var *var);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
class sys_var_thd_table_type :public sys_var_thd_storage_engine
|
|
{
|
|
public:
|
|
sys_var_thd_table_type(sys_var_chain *chain, const char *name_arg,
|
|
plugin_ref SV::*offset_arg)
|
|
:sys_var_thd_storage_engine(chain, name_arg, offset_arg)
|
|
{}
|
|
void warn_deprecated(THD *thd);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
bool update(THD *thd, set_var *var);
|
|
};
|
|
|
|
class sys_var_thd_bit :public sys_var_thd
|
|
{
|
|
sys_check_func check_func;
|
|
sys_update_func update_func;
|
|
public:
|
|
ulonglong bit_flag;
|
|
bool reverse;
|
|
sys_var_thd_bit(sys_var_chain *chain, const char *name_arg,
|
|
sys_check_func c_func, sys_update_func u_func,
|
|
ulonglong bit, bool reverse_arg=0)
|
|
:sys_var_thd(name_arg), check_func(c_func), update_func(u_func),
|
|
bit_flag(bit), reverse(reverse_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var);
|
|
bool update(THD *thd, set_var *var);
|
|
bool check_update_type(Item_result type) { return 0; }
|
|
bool check_type(enum_var_type type) { return type == OPT_GLOBAL; }
|
|
SHOW_TYPE show_type() { return SHOW_MY_BOOL; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
class sys_var_thd_dbug :public sys_var_thd
|
|
{
|
|
public:
|
|
sys_var_thd_dbug(sys_var_chain *chain, const char *name_arg)
|
|
:sys_var_thd(name_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check_update_type(Item_result type) { return type != STRING_RESULT; }
|
|
bool check(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type) { DBUG_POP(); }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *b);
|
|
};
|
|
|
|
|
|
|
|
/* some variables that require special handling */
|
|
|
|
class sys_var_timestamp :public sys_var
|
|
{
|
|
public:
|
|
sys_var_timestamp(sys_var_chain *chain, const char *name_arg)
|
|
:sys_var(name_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
bool check_type(enum_var_type type) { return type == OPT_GLOBAL; }
|
|
bool check_default(enum_var_type type) { return 0; }
|
|
SHOW_TYPE show_type() { return SHOW_LONG; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
|
|
class sys_var_last_insert_id :public sys_var
|
|
{
|
|
public:
|
|
sys_var_last_insert_id(sys_var_chain *chain, const char *name_arg)
|
|
:sys_var(name_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
bool check_type(enum_var_type type) { return type == OPT_GLOBAL; }
|
|
SHOW_TYPE show_type() { return SHOW_LONGLONG; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
|
|
class sys_var_insert_id :public sys_var
|
|
{
|
|
public:
|
|
sys_var_insert_id(sys_var_chain *chain, const char *name_arg)
|
|
:sys_var(name_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
bool check_type(enum_var_type type) { return type == OPT_GLOBAL; }
|
|
SHOW_TYPE show_type() { return SHOW_LONGLONG; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
|
|
class sys_var_rand_seed1 :public sys_var
|
|
{
|
|
public:
|
|
sys_var_rand_seed1(sys_var_chain *chain, const char *name_arg)
|
|
:sys_var(name_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
bool check_type(enum_var_type type) { return type == OPT_GLOBAL; }
|
|
};
|
|
|
|
class sys_var_rand_seed2 :public sys_var
|
|
{
|
|
public:
|
|
sys_var_rand_seed2(sys_var_chain *chain, const char *name_arg)
|
|
:sys_var(name_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var);
|
|
bool check_type(enum_var_type type) { return type == OPT_GLOBAL; }
|
|
};
|
|
|
|
|
|
class sys_var_collation :public sys_var_thd
|
|
{
|
|
public:
|
|
sys_var_collation(const char *name_arg)
|
|
:sys_var_thd(name_arg)
|
|
{
|
|
no_support_one_shot= 0;
|
|
}
|
|
bool check(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return ((type != STRING_RESULT) && (type != INT_RESULT));
|
|
}
|
|
bool check_default(enum_var_type type) { return 0; }
|
|
virtual void set_default(THD *thd, enum_var_type type)= 0;
|
|
};
|
|
|
|
class sys_var_character_set :public sys_var_thd
|
|
{
|
|
public:
|
|
bool nullable;
|
|
sys_var_character_set(const char *name_arg, bool is_nullable= 0) :
|
|
sys_var_thd(name_arg), nullable(is_nullable)
|
|
{
|
|
/*
|
|
In fact only almost all variables derived from sys_var_character_set
|
|
support ONE_SHOT; character_set_results doesn't. But that's good enough.
|
|
*/
|
|
no_support_one_shot= 0;
|
|
}
|
|
bool check(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return ((type != STRING_RESULT) && (type != INT_RESULT));
|
|
}
|
|
bool check_default(enum_var_type type) { return 0; }
|
|
bool update(THD *thd, set_var *var);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
virtual void set_default(THD *thd, enum_var_type type)= 0;
|
|
virtual CHARSET_INFO **ci_ptr(THD *thd, enum_var_type type)= 0;
|
|
};
|
|
|
|
class sys_var_character_set_sv :public sys_var_character_set
|
|
{
|
|
CHARSET_INFO *SV::*offset;
|
|
CHARSET_INFO **global_default;
|
|
public:
|
|
sys_var_character_set_sv(sys_var_chain *chain, const char *name_arg,
|
|
CHARSET_INFO *SV::*offset_arg,
|
|
CHARSET_INFO **global_default_arg,
|
|
bool is_nullable= 0)
|
|
: sys_var_character_set(name_arg, is_nullable),
|
|
offset(offset_arg), global_default(global_default_arg)
|
|
{ chain_sys_var(chain); }
|
|
void set_default(THD *thd, enum_var_type type);
|
|
CHARSET_INFO **ci_ptr(THD *thd, enum_var_type type);
|
|
};
|
|
|
|
|
|
class sys_var_character_set_database :public sys_var_character_set
|
|
{
|
|
public:
|
|
sys_var_character_set_database(sys_var_chain *chain, const char *name_arg) :
|
|
sys_var_character_set(name_arg)
|
|
{ chain_sys_var(chain); }
|
|
void set_default(THD *thd, enum_var_type type);
|
|
CHARSET_INFO **ci_ptr(THD *thd, enum_var_type type);
|
|
};
|
|
|
|
class sys_var_collation_sv :public sys_var_collation
|
|
{
|
|
CHARSET_INFO *SV::*offset;
|
|
CHARSET_INFO **global_default;
|
|
public:
|
|
sys_var_collation_sv(sys_var_chain *chain, const char *name_arg,
|
|
CHARSET_INFO *SV::*offset_arg,
|
|
CHARSET_INFO **global_default_arg)
|
|
:sys_var_collation(name_arg),
|
|
offset(offset_arg), global_default(global_default_arg)
|
|
{
|
|
chain_sys_var(chain);
|
|
}
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
|
|
class sys_var_key_cache_param :public sys_var
|
|
{
|
|
protected:
|
|
size_t offset;
|
|
public:
|
|
sys_var_key_cache_param(sys_var_chain *chain, const char *name_arg,
|
|
size_t offset_arg)
|
|
:sys_var(name_arg), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
bool check_default(enum_var_type type) { return 1; }
|
|
bool is_struct() { return 1; }
|
|
};
|
|
|
|
|
|
class sys_var_key_buffer_size :public sys_var_key_cache_param
|
|
{
|
|
public:
|
|
sys_var_key_buffer_size(sys_var_chain *chain, const char *name_arg)
|
|
:sys_var_key_cache_param(chain, name_arg,
|
|
offsetof(KEY_CACHE, param_buff_size))
|
|
{}
|
|
bool update(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_LONGLONG; }
|
|
};
|
|
|
|
|
|
class sys_var_key_cache_long :public sys_var_key_cache_param
|
|
{
|
|
public:
|
|
sys_var_key_cache_long(sys_var_chain *chain, const char *name_arg, size_t offset_arg)
|
|
:sys_var_key_cache_param(chain, name_arg, offset_arg)
|
|
{}
|
|
bool update(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_LONG; }
|
|
};
|
|
|
|
|
|
class sys_var_thd_date_time_format :public sys_var_thd
|
|
{
|
|
DATE_TIME_FORMAT *SV::*offset;
|
|
timestamp_type date_time_type;
|
|
public:
|
|
sys_var_thd_date_time_format(sys_var_chain *chain, const char *name_arg,
|
|
DATE_TIME_FORMAT *SV::*offset_arg,
|
|
timestamp_type date_time_type_arg)
|
|
:sys_var_thd(name_arg), offset(offset_arg),
|
|
date_time_type(date_time_type_arg)
|
|
{ chain_sys_var(chain); }
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return type != STRING_RESULT; /* Only accept strings */
|
|
}
|
|
bool check_default(enum_var_type type) { return 0; }
|
|
bool check(THD *thd, set_var *var);
|
|
bool update(THD *thd, set_var *var);
|
|
void update2(THD *thd, enum_var_type type, DATE_TIME_FORMAT *new_value);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
};
|
|
|
|
|
|
class sys_var_log_state :public sys_var_bool_ptr
|
|
{
|
|
uint log_type;
|
|
public:
|
|
sys_var_log_state(sys_var_chain *chain, const char *name_arg, my_bool *value_arg,
|
|
uint log_type_arg)
|
|
:sys_var_bool_ptr(chain, name_arg, value_arg), log_type(log_type_arg) {}
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
};
|
|
|
|
|
|
class sys_var_log_output :public sys_var
|
|
{
|
|
ulong *value;
|
|
TYPELIB *enum_names;
|
|
public:
|
|
sys_var_log_output(sys_var_chain *chain, const char *name_arg, ulong *value_arg,
|
|
TYPELIB *typelib, sys_after_update_func func)
|
|
:sys_var(name_arg,func), value(value_arg), enum_names(typelib)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var)
|
|
{
|
|
return check_set(thd, var, enum_names);
|
|
}
|
|
bool update(THD *thd, set_var *var);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
bool check_update_type(Item_result type) { return 0; }
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
};
|
|
|
|
|
|
/* Variable that you can only read from */
|
|
|
|
class sys_var_readonly: public sys_var
|
|
{
|
|
public:
|
|
enum_var_type var_type;
|
|
SHOW_TYPE show_type_value;
|
|
sys_value_ptr_func value_ptr_func;
|
|
sys_var_readonly(sys_var_chain *chain, const char *name_arg, enum_var_type type,
|
|
SHOW_TYPE show_type_arg,
|
|
sys_value_ptr_func value_ptr_func_arg)
|
|
:sys_var(name_arg), var_type(type),
|
|
show_type_value(show_type_arg), value_ptr_func(value_ptr_func_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool update(THD *thd, set_var *var) { return 1; }
|
|
bool check_default(enum_var_type type) { return 1; }
|
|
bool check_type(enum_var_type type) { return type != var_type; }
|
|
bool check_update_type(Item_result type) { return 1; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{
|
|
return (*value_ptr_func)(thd);
|
|
}
|
|
SHOW_TYPE show_type() { return show_type_value; }
|
|
bool is_readonly() const { return 1; }
|
|
};
|
|
|
|
|
|
class sys_var_have_option: public sys_var
|
|
{
|
|
protected:
|
|
virtual SHOW_COMP_OPTION get_option() = 0;
|
|
public:
|
|
sys_var_have_option(sys_var_chain *chain, const char *variable_name):
|
|
sys_var(variable_name)
|
|
{ chain_sys_var(chain); }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base)
|
|
{
|
|
return (uchar*) show_comp_option_name[get_option()];
|
|
}
|
|
bool update(THD *thd, set_var *var) { return 1; }
|
|
bool check_default(enum_var_type type) { return 1; }
|
|
bool check_type(enum_var_type type) { return type != OPT_GLOBAL; }
|
|
bool check_update_type(Item_result type) { return 1; }
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool is_readonly() const { return 1; }
|
|
};
|
|
|
|
|
|
class sys_var_have_variable: public sys_var_have_option
|
|
{
|
|
SHOW_COMP_OPTION *have_variable;
|
|
|
|
public:
|
|
sys_var_have_variable(sys_var_chain *chain, const char *variable_name,
|
|
SHOW_COMP_OPTION *have_variable_arg):
|
|
sys_var_have_option(chain, variable_name),
|
|
have_variable(have_variable_arg)
|
|
{ }
|
|
SHOW_COMP_OPTION get_option() { return *have_variable; }
|
|
};
|
|
|
|
|
|
class sys_var_have_plugin: public sys_var_have_option
|
|
{
|
|
const char *plugin_name_str;
|
|
const uint plugin_name_len;
|
|
const int plugin_type;
|
|
|
|
public:
|
|
sys_var_have_plugin(sys_var_chain *chain, const char *variable_name,
|
|
const char *plugin_name_str_arg, uint plugin_name_len_arg,
|
|
int plugin_type_arg):
|
|
sys_var_have_option(chain, variable_name),
|
|
plugin_name_str(plugin_name_str_arg), plugin_name_len(plugin_name_len_arg),
|
|
plugin_type(plugin_type_arg)
|
|
{ }
|
|
/* the following method is declared in sql_plugin.cc */
|
|
SHOW_COMP_OPTION get_option();
|
|
};
|
|
|
|
|
|
class sys_var_thd_time_zone :public sys_var_thd
|
|
{
|
|
public:
|
|
sys_var_thd_time_zone(sys_var_chain *chain, const char *name_arg):
|
|
sys_var_thd(name_arg)
|
|
{
|
|
no_support_one_shot= 0;
|
|
chain_sys_var(chain);
|
|
}
|
|
bool check(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return type != STRING_RESULT; /* Only accept strings */
|
|
}
|
|
bool check_default(enum_var_type type) { return 0; }
|
|
bool update(THD *thd, set_var *var);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
virtual void set_default(THD *thd, enum_var_type type);
|
|
};
|
|
|
|
|
|
class sys_var_max_user_conn : public sys_var_thd
|
|
{
|
|
public:
|
|
sys_var_max_user_conn(sys_var_chain *chain, const char *name_arg):
|
|
sys_var_thd(name_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var);
|
|
bool update(THD *thd, set_var *var);
|
|
bool check_default(enum_var_type type)
|
|
{
|
|
return type != OPT_GLOBAL || !option_limits;
|
|
}
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_INT; }
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
|
|
class sys_var_microseconds :public sys_var_thd
|
|
{
|
|
ulonglong SV::*offset;
|
|
public:
|
|
sys_var_microseconds(sys_var_chain *chain, const char *name_arg,
|
|
ulonglong SV::*offset_arg):
|
|
sys_var_thd(name_arg), offset(offset_arg)
|
|
{ chain_sys_var(chain); }
|
|
bool check(THD *thd, set_var *var) {return 0;}
|
|
bool update(THD *thd, set_var *var);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
SHOW_TYPE show_type() { return SHOW_DOUBLE; }
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return (type != INT_RESULT && type != REAL_RESULT && type != DECIMAL_RESULT);
|
|
}
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
};
|
|
|
|
|
|
class sys_var_trust_routine_creators :public sys_var_bool_ptr
|
|
{
|
|
/* We need a derived class only to have a warn_deprecated() */
|
|
public:
|
|
sys_var_trust_routine_creators(sys_var_chain *chain,
|
|
const char *name_arg, my_bool *value_arg) :
|
|
sys_var_bool_ptr(chain, name_arg, value_arg) {};
|
|
void warn_deprecated(THD *thd);
|
|
void set_default(THD *thd, enum_var_type type);
|
|
bool update(THD *thd, set_var *var);
|
|
};
|
|
|
|
|
|
/**
|
|
Handler for setting the system variable --read-only.
|
|
*/
|
|
|
|
class sys_var_opt_readonly :public sys_var_bool_ptr
|
|
{
|
|
public:
|
|
sys_var_opt_readonly(sys_var_chain *chain, const char *name_arg,
|
|
my_bool *value_arg) :
|
|
sys_var_bool_ptr(chain, name_arg, value_arg) {};
|
|
~sys_var_opt_readonly() {};
|
|
bool update(THD *thd, set_var *var);
|
|
};
|
|
|
|
|
|
class sys_var_thd_lc_time_names :public sys_var_thd
|
|
{
|
|
public:
|
|
sys_var_thd_lc_time_names(sys_var_chain *chain, const char *name_arg):
|
|
sys_var_thd(name_arg)
|
|
{
|
|
#if MYSQL_VERSION_ID < 50000
|
|
no_support_one_shot= 0;
|
|
#endif
|
|
chain_sys_var(chain);
|
|
}
|
|
bool check(THD *thd, set_var *var);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return ((type != STRING_RESULT) && (type != INT_RESULT));
|
|
}
|
|
bool check_default(enum_var_type type) { return 0; }
|
|
bool update(THD *thd, set_var *var);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
virtual void set_default(THD *thd, enum_var_type type);
|
|
};
|
|
|
|
|
|
class sys_var_event_scheduler :public sys_var_long_ptr
|
|
{
|
|
/* We need a derived class only to have a warn_deprecated() */
|
|
public:
|
|
sys_var_event_scheduler(sys_var_chain *chain, const char *name_arg) :
|
|
sys_var_long_ptr(chain, name_arg, NULL, NULL) {};
|
|
bool update(THD *thd, set_var *var);
|
|
uchar *value_ptr(THD *thd, enum_var_type type, LEX_STRING *base);
|
|
SHOW_TYPE show_type() { return SHOW_CHAR; }
|
|
bool check(THD *thd, set_var *var);
|
|
bool check_update_type(Item_result type)
|
|
{
|
|
return type != STRING_RESULT && type != INT_RESULT;
|
|
}
|
|
};
|
|
|
|
extern void fix_binlog_format_after_update(THD *thd, enum_var_type type);
|
|
|
|
class sys_var_thd_binlog_format :public sys_var_thd_enum
|
|
{
|
|
public:
|
|
sys_var_thd_binlog_format(sys_var_chain *chain, const char *name_arg,
|
|
ulong SV::*offset_arg)
|
|
:sys_var_thd_enum(chain, name_arg, offset_arg,
|
|
&binlog_format_typelib
|
|
, fix_binlog_format_after_update
|
|
)
|
|
{};
|
|
bool is_readonly() const;
|
|
};
|
|
|
|
/****************************************************************************
|
|
Classes for parsing of the SET command
|
|
****************************************************************************/
|
|
|
|
class set_var_base :public Sql_alloc
|
|
{
|
|
public:
|
|
set_var_base() {}
|
|
virtual ~set_var_base() {}
|
|
virtual int check(THD *thd)=0; /* To check privileges etc. */
|
|
virtual int update(THD *thd)=0; /* To set the value */
|
|
/* light check for PS */
|
|
virtual int light_check(THD *thd) { return check(thd); }
|
|
virtual bool no_support_one_shot() { return 1; }
|
|
};
|
|
|
|
|
|
/* MySQL internal variables, like query_cache_size */
|
|
|
|
class set_var :public set_var_base
|
|
{
|
|
public:
|
|
sys_var *var;
|
|
Item *value;
|
|
enum_var_type type;
|
|
union
|
|
{
|
|
CHARSET_INFO *charset;
|
|
ulong ulong_value;
|
|
ulonglong ulonglong_value;
|
|
plugin_ref plugin;
|
|
DATE_TIME_FORMAT *date_time_format;
|
|
Time_zone *time_zone;
|
|
MY_LOCALE *locale_value;
|
|
} save_result;
|
|
LEX_STRING base; /* for structs */
|
|
|
|
set_var(enum_var_type type_arg, sys_var *var_arg,
|
|
const LEX_STRING *base_name_arg, Item *value_arg)
|
|
:var(var_arg), type(type_arg), base(*base_name_arg)
|
|
{
|
|
/*
|
|
If the set value is a field, change it to a string to allow things like
|
|
SET table_type=MYISAM;
|
|
*/
|
|
if (value_arg && value_arg->type() == Item::FIELD_ITEM)
|
|
{
|
|
Item_field *item= (Item_field*) value_arg;
|
|
if (!(value=new Item_string(item->field_name,
|
|
(uint) strlen(item->field_name),
|
|
item->collation.collation)))
|
|
value=value_arg; /* Give error message later */
|
|
}
|
|
else
|
|
value=value_arg;
|
|
}
|
|
int check(THD *thd);
|
|
int update(THD *thd);
|
|
int light_check(THD *thd);
|
|
bool no_support_one_shot() { return var->no_support_one_shot; }
|
|
};
|
|
|
|
|
|
/* User variables like @my_own_variable */
|
|
|
|
class set_var_user: public set_var_base
|
|
{
|
|
Item_func_set_user_var *user_var_item;
|
|
public:
|
|
set_var_user(Item_func_set_user_var *item)
|
|
:user_var_item(item)
|
|
{}
|
|
int check(THD *thd);
|
|
int update(THD *thd);
|
|
int light_check(THD *thd);
|
|
};
|
|
|
|
/* For SET PASSWORD */
|
|
|
|
class set_var_password: public set_var_base
|
|
{
|
|
LEX_USER *user;
|
|
char *password;
|
|
public:
|
|
set_var_password(LEX_USER *user_arg,char *password_arg)
|
|
:user(user_arg), password(password_arg)
|
|
{}
|
|
int check(THD *thd);
|
|
int update(THD *thd);
|
|
};
|
|
|
|
|
|
/* For SET NAMES and SET CHARACTER SET */
|
|
|
|
class set_var_collation_client: public set_var_base
|
|
{
|
|
CHARSET_INFO *character_set_client;
|
|
CHARSET_INFO *character_set_results;
|
|
CHARSET_INFO *collation_connection;
|
|
public:
|
|
set_var_collation_client(CHARSET_INFO *client_coll_arg,
|
|
CHARSET_INFO *connection_coll_arg,
|
|
CHARSET_INFO *result_coll_arg)
|
|
:character_set_client(client_coll_arg),
|
|
character_set_results(result_coll_arg),
|
|
collation_connection(connection_coll_arg)
|
|
{}
|
|
int check(THD *thd);
|
|
int update(THD *thd);
|
|
};
|
|
|
|
|
|
extern "C"
|
|
{
|
|
typedef int (*process_key_cache_t) (const char *, KEY_CACHE *);
|
|
}
|
|
|
|
/* Named lists (used for keycaches) */
|
|
|
|
class NAMED_LIST :public ilink
|
|
{
|
|
const char *name;
|
|
uint name_length;
|
|
public:
|
|
uchar* data;
|
|
|
|
NAMED_LIST(I_List<NAMED_LIST> *links, const char *name_arg,
|
|
uint name_length_arg, uchar* data_arg)
|
|
:name_length(name_length_arg), data(data_arg)
|
|
{
|
|
name= my_strndup(name_arg, name_length, MYF(MY_WME));
|
|
links->push_back(this);
|
|
}
|
|
inline bool cmp(const char *name_cmp, uint length)
|
|
{
|
|
return length == name_length && !memcmp(name, name_cmp, length);
|
|
}
|
|
~NAMED_LIST()
|
|
{
|
|
my_free((uchar*) name, MYF(0));
|
|
}
|
|
friend bool process_key_caches(process_key_cache_t func);
|
|
friend void delete_elements(I_List<NAMED_LIST> *list,
|
|
void (*free_element)(const char*, uchar*));
|
|
};
|
|
|
|
/* updated in sql_acl.cc */
|
|
|
|
extern sys_var_thd_bool sys_old_alter_table;
|
|
extern sys_var_thd_bool sys_old_passwords;
|
|
extern LEX_STRING default_key_cache_base;
|
|
|
|
/* For sql_yacc */
|
|
struct sys_var_with_base
|
|
{
|
|
sys_var *var;
|
|
LEX_STRING base_name;
|
|
};
|
|
|
|
/*
|
|
Prototypes for helper functions
|
|
*/
|
|
|
|
int set_var_init();
|
|
void set_var_free();
|
|
int mysql_append_static_vars(const SHOW_VAR *show_vars, uint count);
|
|
SHOW_VAR* enumerate_sys_vars(THD *thd, bool sorted);
|
|
int mysql_add_sys_var_chain(sys_var *chain, struct my_option *long_options);
|
|
int mysql_del_sys_var_chain(sys_var *chain);
|
|
sys_var *find_sys_var(THD *thd, const char *str, uint length=0);
|
|
int sql_set_variables(THD *thd, List<set_var_base> *var_list);
|
|
bool not_all_support_one_shot(List<set_var_base> *var_list);
|
|
void fix_delay_key_write(THD *thd, enum_var_type type);
|
|
ulong fix_sql_mode(ulong sql_mode);
|
|
extern sys_var_const_str sys_charset_system;
|
|
extern sys_var_str sys_init_connect;
|
|
extern sys_var_str sys_init_slave;
|
|
extern sys_var_thd_time_zone sys_time_zone;
|
|
extern sys_var_thd_bit sys_autocommit;
|
|
CHARSET_INFO *get_old_charset_by_name(const char *old_name);
|
|
uchar* find_named(I_List<NAMED_LIST> *list, const char *name, uint length,
|
|
NAMED_LIST **found);
|
|
|
|
extern sys_var_str sys_var_general_log_path, sys_var_slow_log_path;
|
|
|
|
/* key_cache functions */
|
|
KEY_CACHE *get_key_cache(LEX_STRING *cache_name);
|
|
KEY_CACHE *get_or_create_key_cache(const char *name, uint length);
|
|
void free_key_cache(const char *name, KEY_CACHE *key_cache);
|
|
bool process_key_caches(process_key_cache_t func);
|
|
void delete_elements(I_List<NAMED_LIST> *list,
|
|
void (*free_element)(const char*, uchar*));
|