diff options
author | unknown <monty@hundin.mysql.fi> | 2001-06-28 10:49:16 +0300 |
---|---|---|
committer | unknown <monty@hundin.mysql.fi> | 2001-06-28 10:49:16 +0300 |
commit | 833f353e34653e8deb8fc7df556398a526b0cb40 (patch) | |
tree | 739c3565fe5148ff499bf5daae2a711768b66e2f /sql | |
parent | f246b619153704f78ecc60361470f3f664fc6493 (diff) | |
download | mariadb-git-833f353e34653e8deb8fc7df556398a526b0cb40.tar.gz |
Changed safe_mysqld -> mysqld_safe
Added some alias to SHOW commands
Prepare for dynamic changing of MySQL variables
man/Makefile.am:
Changed safe_mysqld -> mysqld_safe
man/isamchk.1:
Changed safe_mysqld -> mysqld_safe
man/isamlog.1:
Changed safe_mysqld -> mysqld_safe
man/mysql.1:
Changed safe_mysqld -> mysqld_safe
man/mysql_zap.1:
Changed safe_mysqld -> mysqld_safe
man/mysqlaccess.1:
Changed safe_mysqld -> mysqld_safe
man/mysqladmin.1:
Changed safe_mysqld -> mysqld_safe
man/mysqld.1:
Changed safe_mysqld -> mysqld_safe
man/mysqld_multi.1:
Changed safe_mysqld -> mysqld_safe
man/mysqld_safe.1:
Changed safe_mysqld -> mysqld_safe
man/mysqldump.1:
Changed safe_mysqld -> mysqld_safe
man/mysqlshow.1:
Changed safe_mysqld -> mysqld_safe
man/perror.1:
Changed safe_mysqld -> mysqld_safe
man/replace.1:
Changed safe_mysqld -> mysqld_safe
man/which.2:
Changed safe_mysqld -> mysqld_safe
myisam/mi_search.c:
Fixed bug when using packed keys.
scripts/Makefile.am:
Changed safe_mysqld -> mysqld_safe
scripts/make_binary_distribution.sh:
Changed safe_mysqld -> mysqld_safe
scripts/mysql_install_db.sh:
Changed safe_mysqld -> mysqld_safe
scripts/mysqld_multi.sh:
Changed safe_mysqld -> mysqld_safe
scripts/mysqld_safe-watch.sh:
Changed safe_mysqld -> mysqld_safe
scripts/mysqld_safe.sh:
Changed safe_mysqld -> mysqld_safe
sql/lex.h:
Addex SHOW INDEXES as an alias for SHOW INDEX
sql/sql_class.cc:
Prepare for dynamic changing of MySQL variables
sql/sql_lex.h:
Prepare for dynamic changing of MySQL variables
sql/sql_yacc.yy:
Some changes to SHOW commands.
support-files/binary-configure.sh:
Changed safe_mysqld -> mysqld_safe
support-files/mysql-max.spec.sh:
Changed safe_mysqld -> mysqld_safe
support-files/mysql-multi.server.sh:
Changed safe_mysqld -> mysqld_safe
support-files/mysql.server.sh:
Changed safe_mysqld -> mysqld_safe
support-files/mysql.spec.sh:
Changed safe_mysqld -> mysqld_safe
Diffstat (limited to 'sql')
-rw-r--r-- | sql/lex.h | 1 | ||||
-rw-r--r-- | sql/sql_class.cc | 2 | ||||
-rw-r--r-- | sql/sql_lex.h | 15 | ||||
-rw-r--r-- | sql/sql_yacc.yy | 37 |
4 files changed, 52 insertions, 3 deletions
diff --git a/sql/lex.h b/sql/lex.h index 48352d3e702..e9ab150f5b2 100644 --- a/sql/lex.h +++ b/sql/lex.h @@ -170,6 +170,7 @@ static SYMBOL symbols[] = { { "IGNORE", SYM(IGNORE_SYM),0,0}, { "IN", SYM(IN_SYM),0,0}, { "INDEX", SYM(INDEX),0,0}, + { "INDEXES", SYM(INDEXES),0,0}, { "INFILE", SYM(INFILE),0,0}, { "INNER", SYM(INNER_SYM),0,0}, { "INNOBASE", SYM(INNOBASE_SYM),0,0}, diff --git a/sql/sql_class.cc b/sql/sql_class.cc index b6cba673bea..f196e4ff852 100644 --- a/sql/sql_class.cc +++ b/sql/sql_class.cc @@ -49,6 +49,8 @@ template class List<Alter_drop>; template class List_iterator<Alter_drop>; template class List<Alter_column>; template class List_iterator<Alter_column>; +template class List<Set_option>; +template class List_iterator<Set_option>; #endif /**************************************************************************** diff --git a/sql/sql_lex.h b/sql/sql_lex.h index a7b7f75f4a2..e585ec65191 100644 --- a/sql/sql_lex.h +++ b/sql/sql_lex.h @@ -120,6 +120,18 @@ typedef struct st_select_lex { } SELECT_LEX; +class Set_option :public Sql_alloc { +public: + const char *name; + Item *item; + uint name_length; + bool type; /* 1 if global */ + Set_option(bool par_type, const char *par_name, uint length, + Item *par_item) + :name(par_name), item(par_item), name_length(length), type(par_type) {} +}; + + /* The state of the lex parsing. This is saved in the THD struct */ typedef struct st_lex { @@ -143,6 +155,7 @@ typedef struct st_lex { List<create_field> create_list; List<Item> *insert_list,field_list,value_list; List<List_item> many_values; + List<Set_option> option_list; SQL_LIST proc_list, auxilliary_table_list; TYPELIB *interval; create_field *last_field; @@ -167,7 +180,7 @@ typedef struct st_lex { uint grant,grant_tot_col,which_columns; thr_lock_type lock_option; bool drop_primary,drop_if_exists,local_file; - bool in_comment,ignore_space,verbose,simple_alter; + bool in_comment,ignore_space,verbose,simple_alter, option_type; } LEX; diff --git a/sql/sql_yacc.yy b/sql/sql_yacc.yy index 8877d7eb08c..c013ebe1c8c 100644 --- a/sql/sql_yacc.yy +++ b/sql/sql_yacc.yy @@ -197,6 +197,7 @@ bool my_yyoverflow(short **a, YYSTYPE **b,int *yystacksize); %token IDENT %token IGNORE_SYM %token INDEX +%token INDEXES %token INFILE %token INNER_SYM %token INNOBASE_SYM @@ -1047,6 +1048,7 @@ key_or_index: keys_or_index: KEYS {} | INDEX {} + | INDEXES {} opt_unique_or_fulltext: /* empty */ { $$= Key::MULTIPLE; } @@ -2392,7 +2394,7 @@ show_param: lex->select->db= $3; lex->select->options=0; } - | opt_full COLUMNS FROM table_ident opt_db wild + | opt_full COLUMNS from_or_in table_ident opt_db wild { Lex->sql_command= SQLCOM_SHOW_FIELDS; if ($5) @@ -2452,7 +2454,7 @@ show_param: opt_db: /* empty */ { $$= 0; } - | FROM ident { $$= $2.str; } + | from_or_in ident { $$= $2.str; } wild: /* empty */ @@ -2462,6 +2464,10 @@ opt_full: /* empty */ { Lex->verbose=0; } | FULL { Lex->verbose=1; } +from_or_in: + FROM + | IN_SYM + binlog_in: /* empty */ { Lex->mi.log_file_name = 0; } | IN_SYM TEXT_STRING { Lex->mi.log_file_name = $2.str; } @@ -2818,6 +2824,7 @@ keyword: | HOSTS_SYM {} | HOUR_SYM {} | IDENTIFIED_SYM {} + | INDEXES {} | ISOLATION {} | ISAM_SYM {} | INNOBASE_SYM {} @@ -2901,6 +2908,8 @@ set: lex->select->select_limit=lex->thd->default_select_limit; lex->gemini_spin_retries=lex->thd->gemini_spin_retries; lex->tx_isolation=lex->thd->tx_isolation; + lex->option_type=0; + lex->option_list.empty() } option_value_list @@ -2910,6 +2919,8 @@ opt_option: option_value_list: option_value + | GLOBAL_SYM { Lex->option_type=1; } option_value + | LOCAL_SYM { Lex->option_type=0; } option_value | option_value_list ',' option_value option_value: @@ -3017,6 +3028,28 @@ option_value: slave_skip_counter = $3; pthread_mutex_unlock(&LOCK_slave); } + | ident equal DEFAULT + { + LEX *lex=Lex; + lex->option_list.push_back(new Set_option(lex->option_type, + $1.str,$1.length, + (Item*) 0)); + } + | ident equal expr + { + THD *thd=current_thd; + Item *item= $3; + if (item->fix_fields(current_thd,0)) + { + send_error(&thd->net, ER_SET_CONSTANTS_ONLY); + YYABORT; + } + thd->lex.option_list. + push_back(new Set_option(thd->lex.option_type, + $1.str,$1.length, + item)); + } + text_or_password: TEXT_STRING { $$=$1.str;} |