summaryrefslogtreecommitdiff
path: root/sql/set_var.h
diff options
context:
space:
mode:
authorunknown <bar@bar.mysql.r18.ru>2003-05-21 17:44:12 +0500
committerunknown <bar@bar.mysql.r18.ru>2003-05-21 17:44:12 +0500
commit1bc4c11354cf90bd457afb875d495e67cc291fdf (patch)
treec1d41d9ae86450c3c93a4424253c8553ffcec322 /sql/set_var.h
parent3987348526c78813dede74739d4ba21e1d2232a6 (diff)
downloadmariadb-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.h39
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);