diff options
author | unknown <bar@bar.mysql.r18.ru> | 2003-05-21 17:44:12 +0500 |
---|---|---|
committer | unknown <bar@bar.mysql.r18.ru> | 2003-05-21 17:44:12 +0500 |
commit | 1bc4c11354cf90bd457afb875d495e67cc291fdf (patch) | |
tree | c1d41d9ae86450c3c93a4424253c8553ffcec322 /sql/set_var.h | |
parent | 3987348526c78813dede74739d4ba21e1d2232a6 (diff) | |
download | mariadb-git-1bc4c11354cf90bd457afb875d495e67cc291fdf.tar.gz |
Some SHOW VARIABLES have been renamed:
collation_client -> character_set_client
collation_results -> character_set_results
character_set -> character_set_server
SET NAMES now doesn't start client->server conversion
SET CHARACTER SET now starts both client->server and server->client conversion
Diffstat (limited to 'sql/set_var.h')
-rw-r--r-- | sql/set_var.h | 39 |
1 files changed, 27 insertions, 12 deletions
diff --git a/sql/set_var.h b/sql/set_var.h index 03cc3b30a03..d381843df0d 100644 --- a/sql/set_var.h +++ b/sql/set_var.h @@ -420,34 +420,49 @@ SHOW_TYPE type() { return SHOW_CHAR; } virtual void set_default(THD *thd, enum_var_type type)= 0; }; -class sys_var_collation_client :public sys_var_collation +class sys_var_character_set :public sys_var_thd { public: - sys_var_collation_client(const char *name_arg) :sys_var_collation(name_arg) {} + sys_var_character_set(const char *name_arg) :sys_var_thd(name_arg) {} + bool check(THD *thd, set_var *var); +SHOW_TYPE 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; } + virtual void set_default(THD *thd, enum_var_type type)= 0; +}; + +class sys_var_character_set_client :public sys_var_character_set +{ +public: + sys_var_character_set_client(const char *name_arg) : + sys_var_character_set(name_arg) {} bool update(THD *thd, set_var *var); void set_default(THD *thd, enum_var_type type); byte *value_ptr(THD *thd, enum_var_type type); }; -class sys_var_collation_connection :public sys_var_collation +class sys_var_character_set_results :public sys_var_character_set { public: - sys_var_collation_connection(const char *name_arg) :sys_var_collation(name_arg) {} + sys_var_character_set_results(const char *name_arg) : + sys_var_character_set(name_arg) {} bool update(THD *thd, set_var *var); void set_default(THD *thd, enum_var_type type); byte *value_ptr(THD *thd, enum_var_type type); }; -class sys_var_collation_results :public sys_var_collation +class sys_var_collation_connection :public sys_var_collation { public: - sys_var_collation_results(const char *name_arg) :sys_var_collation(name_arg) {} + sys_var_collation_connection(const char *name_arg) :sys_var_collation(name_arg) {} bool update(THD *thd, set_var *var); void set_default(THD *thd, enum_var_type type); byte *value_ptr(THD *thd, enum_var_type type); }; - /* Variable that you can only read from */ class sys_var_readonly: public sys_var @@ -555,16 +570,16 @@ public: class set_var_collation_client: public set_var_base { - CHARSET_INFO *collation_client; + CHARSET_INFO *character_set_client; + CHARSET_INFO *character_set_results; CHARSET_INFO *collation_connection; - CHARSET_INFO *collation_results; public: set_var_collation_client(CHARSET_INFO *client_coll_arg, CHARSET_INFO *connection_coll_arg, CHARSET_INFO *result_coll_arg) - :collation_client(client_coll_arg), - collation_connection(connection_coll_arg), - collation_results(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); |