Commit a9d4ba84 authored by Konstantin Osipov's avatar Konstantin Osipov

Backport to 5.4 the following changesets:

revno: 2476.785.24
committer: kostja@bodhi.(none)
timestamp: Tue 2007-10-16 20:19:00 +0400
message:
  Reflect a rename of a member in the client ABI (a compatible change).
----------------------------------------------------------
revno: 2476.423.26
committer: kostja@bodhi.(none)
timestamp: Tue 2007-10-16 20:12:37 +0400
message:
  Update the client ABI to reflect member rename
  (this is a backward-compatible change).
----------------------------------------------------------
revno: 2476.785.22
committer: kostja@bodhi.(none)
timestamp: Tue 2007-10-16 19:37:25 +0400
message:
  Remove some remains of support of 3.22 protocol. This was in fact dead code,
  since the option to talk 3.22 protocol was removed in 4.1 and there
  is no other protocol negotiation mechanism besides this option.

include/mysql.h.pp:
  Update ABI.
include/mysql_com.h:
  Remove an unused 3.22 protocol member.
sql/field.cc:
  Remove an unused 3.22 protocol check.
sql/mysqld.cc:
  Remove an unused 3.22 protocol check.
sql/net_serv.cc:
  Remove an unused 3.22 protocol variable initialization.
sql/protocol.cc:
  Remove an unused 3.22 protocol check.
parent 510318ad
...@@ -28,15 +28,15 @@ typedef struct st_net { ...@@ -28,15 +28,15 @@ typedef struct st_net {
unsigned int *return_status; unsigned int *return_status;
unsigned char reading_or_writing; unsigned char reading_or_writing;
char save_char; char save_char;
my_bool unused0;
my_bool unused;
my_bool compress;
my_bool unused1; my_bool unused1;
my_bool unused2;
my_bool compress;
my_bool unused3;
unsigned char *query_cache_query; unsigned char *query_cache_query;
unsigned int last_errno; unsigned int last_errno;
unsigned char error; unsigned char error;
my_bool unused2; my_bool unused4;
my_bool return_errno; my_bool unused5;
char last_error[512]; char last_error[512];
char sqlstate[5 +1]; char sqlstate[5 +1];
void *extension; void *extension;
......
...@@ -254,10 +254,10 @@ typedef struct st_net { ...@@ -254,10 +254,10 @@ typedef struct st_net {
unsigned int *return_status; unsigned int *return_status;
unsigned char reading_or_writing; unsigned char reading_or_writing;
char save_char; char save_char;
my_bool unused0; /* Please remove with the next incompatible ABI change. */
my_bool unused; /* Please remove with the next incompatible ABI change */
my_bool compress;
my_bool unused1; /* Please remove with the next incompatible ABI change. */ my_bool unused1; /* Please remove with the next incompatible ABI change. */
my_bool unused2; /* Please remove with the next incompatible ABI change */
my_bool compress;
my_bool unused3; /* Please remove with the next incompatible ABI change. */
/* /*
Pointer to query object in query cache, do not equal NULL (0) for Pointer to query object in query cache, do not equal NULL (0) for
queries in cache that have not stored its results yet queries in cache that have not stored its results yet
...@@ -270,8 +270,8 @@ typedef struct st_net { ...@@ -270,8 +270,8 @@ typedef struct st_net {
unsigned char *query_cache_query; unsigned char *query_cache_query;
unsigned int last_errno; unsigned int last_errno;
unsigned char error; unsigned char error;
my_bool unused2; /* Please remove with the next incompatible ABI change. */ my_bool unused4; /* Please remove with the next incompatible ABI change. */
my_bool return_errno; my_bool unused5; /* Please remove with the next incompatible ABI change. */
/** Client library error message buffer. Actually belongs to struct MYSQL. */ /** Client library error message buffer. Actually belongs to struct MYSQL. */
char last_error[MYSQL_ERRMSG_SIZE]; char last_error[MYSQL_ERRMSG_SIZE];
/** Client library sqlstate buffer. Set along with the error message. */ /** Client library sqlstate buffer. Set along with the error message. */
......
...@@ -9828,8 +9828,7 @@ bool Create_field::init(THD *thd, char *fld_name, enum_field_types fld_type, ...@@ -9828,8 +9828,7 @@ bool Create_field::init(THD *thd, char *fld_name, enum_field_types fld_type,
break; break;
case MYSQL_TYPE_DATE: case MYSQL_TYPE_DATE:
/* Old date type. */ /* Old date type. */
if (protocol_version != PROTOCOL_VERSION-1) sql_type= MYSQL_TYPE_NEWDATE;
sql_type= MYSQL_TYPE_NEWDATE;
/* fall trough */ /* fall trough */
case MYSQL_TYPE_NEWDATE: case MYSQL_TYPE_NEWDATE:
length= 10; length= 10;
......
...@@ -4892,9 +4892,6 @@ static void create_new_thread(THD *thd) ...@@ -4892,9 +4892,6 @@ static void create_new_thread(THD *thd)
NET *net=&thd->net; NET *net=&thd->net;
DBUG_ENTER("create_new_thread"); DBUG_ENTER("create_new_thread");
if (protocol_version > 9)
net->return_errno=1;
/* /*
Don't allow too many connections. We roughly check here that we allow Don't allow too many connections. We roughly check here that we allow
only (max_connections + 1) connections. only (max_connections + 1) connections.
......
...@@ -125,7 +125,7 @@ my_bool my_net_init(NET *net, Vio* vio) ...@@ -125,7 +125,7 @@ my_bool my_net_init(NET *net, Vio* vio)
MYF(MY_WME)))) MYF(MY_WME))))
DBUG_RETURN(1); DBUG_RETURN(1);
net->buff_end=net->buff+net->max_packet; net->buff_end=net->buff+net->max_packet;
net->error=0; net->return_errno=0; net->return_status=0; net->error=0; net->return_status=0;
net->pkt_nr=net->compress_pkt_nr=0; net->pkt_nr=net->compress_pkt_nr=0;
net->write_pos=net->read_pos = net->buff; net->write_pos=net->read_pos = net->buff;
net->last_error[0]=0; net->last_error[0]=0;
......
...@@ -394,27 +394,19 @@ bool net_send_error_packet(THD *thd, uint sql_errno, const char *err, ...@@ -394,27 +394,19 @@ bool net_send_error_packet(THD *thd, uint sql_errno, const char *err,
DBUG_RETURN(FALSE); DBUG_RETURN(FALSE);
} }
if (net->return_errno) int2store(buff,sql_errno);
{ // new client code; Add errno before message pos= buff+2;
int2store(buff,sql_errno); if (thd->client_capabilities & CLIENT_PROTOCOL_41)
pos= buff+2;
if (thd->client_capabilities & CLIENT_PROTOCOL_41)
{
/* The first # is to make the protocol backward compatible */
buff[2]= '#';
pos= (uchar*) strmov((char*) buff+3, sqlstate);
}
length= (uint) (strmake((char*) pos, err, MYSQL_ERRMSG_SIZE-1) -
(char*) buff);
err= (char*) buff;
}
else
{ {
length=(uint) strlen(err); /* The first # is to make the protocol backward compatible */
set_if_smaller(length,MYSQL_ERRMSG_SIZE-1); buff[2]= '#';
pos= (uchar*) strmov((char*) buff+3, sqlstate);
} }
length= (uint) (strmake((char*) pos, err, MYSQL_ERRMSG_SIZE-1) -
(char*) buff);
err= (char*) buff;
DBUG_RETURN(net_write_command(net,(uchar) 255, (uchar*) "", 0, (uchar*) err, DBUG_RETURN(net_write_command(net,(uchar) 255, (uchar*) "", 0, (uchar*) err,
length)); length));
} }
#endif /* EMBEDDED_LIBRARY */ #endif /* EMBEDDED_LIBRARY */
......
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