Commit 662510b9 authored by unknown's avatar unknown

Merge bk-internal.mysql.com:/home/bk/mysql-4.1

into mysql.com:/home/dlenev/src/mysql-4.1-bg2248

parents 8f5ad02a 6b86e0eb
...@@ -568,6 +568,8 @@ void Item_param::set_time(TIME *tm, timestamp_type type) ...@@ -568,6 +568,8 @@ void Item_param::set_time(TIME *tm, timestamp_type type)
ltime.second_part= tm->second_part; ltime.second_part= tm->second_part;
ltime.neg= tm->neg;
ltime.time_type= type; ltime.time_type= type;
item_is_time= true; item_is_time= true;
......
...@@ -313,6 +313,7 @@ send_ok(THD *thd, ha_rows affected_rows, ulonglong id, const char *message) ...@@ -313,6 +313,7 @@ send_ok(THD *thd, ha_rows affected_rows, ulonglong id, const char *message)
DBUG_VOID_RETURN; DBUG_VOID_RETURN;
} }
static char eof_buff[1]= { (char) 254 }; /* Marker for end of fields */
/* /*
Send eof (= end of result set) to the client Send eof (= end of result set) to the client
...@@ -339,12 +340,11 @@ send_ok(THD *thd, ha_rows affected_rows, ulonglong id, const char *message) ...@@ -339,12 +340,11 @@ send_ok(THD *thd, ha_rows affected_rows, ulonglong id, const char *message)
void void
send_eof(THD *thd, bool no_flush) send_eof(THD *thd, bool no_flush)
{ {
static char eof_buff[1]= { (char) 254 }; /* Marker for end of fields */
NET *net= &thd->net; NET *net= &thd->net;
DBUG_ENTER("send_eof"); DBUG_ENTER("send_eof");
if (net->vio != 0) if (net->vio != 0)
{ {
if (!no_flush && (thd->client_capabilities & CLIENT_PROTOCOL_41)) if (thd->client_capabilities & CLIENT_PROTOCOL_41)
{ {
uchar buff[5]; uchar buff[5];
uint tmp= min(thd->total_warn_count, 65535); uint tmp= min(thd->total_warn_count, 65535);
...@@ -384,9 +384,8 @@ send_eof(THD *thd, bool no_flush) ...@@ -384,9 +384,8 @@ send_eof(THD *thd, bool no_flush)
bool send_old_password_request(THD *thd) bool send_old_password_request(THD *thd)
{ {
static char buff[1]= { (char) 254 };
NET *net= &thd->net; NET *net= &thd->net;
return my_net_write(net, buff, 1) || net_flush(net); return my_net_write(net, eof_buff, 1) || net_flush(net);
} }
#endif /* EMBEDDED_LIBRARY */ #endif /* EMBEDDED_LIBRARY */
...@@ -585,7 +584,7 @@ bool Protocol::send_fields(List<Item> *list, uint flag) ...@@ -585,7 +584,7 @@ bool Protocol::send_fields(List<Item> *list, uint flag)
#endif #endif
} }
send_eof(thd, 1); my_net_write(&thd->net, eof_buff, 1);
DBUG_RETURN(prepare_for_send(list)); DBUG_RETURN(prepare_for_send(list));
err: err:
......
...@@ -695,7 +695,6 @@ struct show_var_st init_vars[]= { ...@@ -695,7 +695,6 @@ struct show_var_st init_vars[]= {
{"port", (char*) &mysqld_port, SHOW_INT}, {"port", (char*) &mysqld_port, SHOW_INT},
{"protocol_version", (char*) &protocol_version, SHOW_INT}, {"protocol_version", (char*) &protocol_version, SHOW_INT},
{sys_preload_buff_size.name, (char*) &sys_preload_buff_size, SHOW_SYS}, {sys_preload_buff_size.name, (char*) &sys_preload_buff_size, SHOW_SYS},
{sys_pseudo_thread_id.name, (char*) &sys_pseudo_thread_id, SHOW_SYS},
{sys_query_alloc_block_size.name, (char*) &sys_query_alloc_block_size, {sys_query_alloc_block_size.name, (char*) &sys_query_alloc_block_size,
SHOW_SYS}, SHOW_SYS},
#ifdef HAVE_QUERY_CACHE #ifdef HAVE_QUERY_CACHE
......
...@@ -193,6 +193,13 @@ static LEX_STRING get_token(LEX *lex,uint length) ...@@ -193,6 +193,13 @@ static LEX_STRING get_token(LEX *lex,uint length)
return tmp; return tmp;
} }
/*
todo:
There are no dangerous charsets in mysql for function
get_quoted_token yet. But it should be fixed in the
future to operate multichar strings (like ucs2)
*/
static LEX_STRING get_quoted_token(LEX *lex,uint length, char quote) static LEX_STRING get_quoted_token(LEX *lex,uint length, char quote)
{ {
LEX_STRING tmp; LEX_STRING tmp;
...@@ -670,37 +677,14 @@ int yylex(void *arg, void *yythd) ...@@ -670,37 +677,14 @@ int yylex(void *arg, void *yythd)
uint double_quotes= 0; uint double_quotes= 0;
char quote_char= c; // Used char char quote_char= c; // Used char
lex->tok_start=lex->ptr; // Skip first ` lex->tok_start=lex->ptr; // Skip first `
while ((c=yyGet()))
{
#ifdef USE_MB #ifdef USE_MB
if (use_mb(cs)) if (my_mbcharlen(cs, c) == 1)
{
while ((c= yyGet()))
{
if (c == quote_char)
{
if (yyPeek() != quote_char)
break;
c= yyGet();
double_quotes++;
continue;
}
if (c == (uchar) NAMES_SEP_CHAR)
break;
if (my_mbcharlen(cs, c) > 1)
{
int l;
if ((l = my_ismbchar(cs,
(const char *)lex->ptr-1,
(const char *)lex->end_of_query)) == 0)
break;
lex->ptr += l-1;
}
}
}
else
#endif #endif
{
while ((c=yyGet()))
{ {
if (c == (uchar) NAMES_SEP_CHAR)
break; /* Old .frm format can't handle this char */
if (c == quote_char) if (c == quote_char)
{ {
if (yyPeek() != quote_char) if (yyPeek() != quote_char)
...@@ -709,9 +693,18 @@ int yylex(void *arg, void *yythd) ...@@ -709,9 +693,18 @@ int yylex(void *arg, void *yythd)
double_quotes++; double_quotes++;
continue; continue;
} }
if (c == (uchar) NAMES_SEP_CHAR) }
#ifdef USE_MB
else
{
int l;
if ((l = my_ismbchar(cs,
(const char *)lex->ptr-1,
(const char *)lex->end_of_query)) == 0)
break; break;
lex->ptr += l-1;
} }
#endif
} }
if (double_quotes) if (double_quotes)
yylval->lex_str=get_quoted_token(lex,yyLength() - double_quotes, yylval->lex_str=get_quoted_token(lex,yyLength() - double_quotes,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment