mariadb/client
Sujatha Sivakumar cf858b71ce BUG#11762670:MY_B_WRITE RETURN VALUE IGNORED
Problem:
=======
The return value from my_b_write is ignored by: `my_b_write_quoted',
`my_b_write_bit',`Query_log_event::print_query_header'

Most callers of `my_b_printf' ignore the return value. `log_event.cc' 
has many calls to it. 

Analysis:
========
`my_b_write' is used to write data into a file. If the write fails it
sets appropriate error number and error message through my_error()
function call and sets the IO_CACHE::error == -1.
`my_b_printf' function is also used to write data into a file, it
internally invokes my_b_write to do the write operation. Upon
success it returns number of characters written to file and on error
it returns -1 and sets the error through my_error() and also sets
IO_CACHE::error == -1.  Most of the event specific print functions
for example `Create_file_log_event::print', `Execute_load_log_event::print'
etc are the ones which make several calls to the above two functions and
they do not check for the return value after the 'print' call. All the above 
mentioned abuse cases deal with the client side.

Fix:
===
As part of bug fix a check for IO_CACHE::error == -1 has been added at 
a very high level after the call to the 'print' function.  There are 
few more places where the return value of "my_b_write" is ignored
those are mentioned below.

+++ mysys/mf_iocache2.c    2012-06-04 07:03:15 +0000
@@ -430,7 +430,8 @@
           memset(buffz, '0', minimum_width - length2);
         else
           memset(buffz, ' ', minimum_width - length2);
-        my_b_write(info, buffz, minimum_width - length2);

+++ sql/log.cc	2012-06-08 09:04:46 +0000
@@ -2388,7 +2388,12 @@
     {
       end= strxmov(buff, "# administrator command: ", NullS);
       buff_len= (ulong) (end - buff);
-      my_b_write(&log_file, (uchar*) buff, buff_len);

At these places appropriate return value handlers have been added.
2012-07-10 14:23:17 +05:30
..
.cvsignore
client_priv.h Updated/added copyright headers 2011-07-03 17:47:37 +02:00
CMakeLists.txt Updated/added copyright headers 2011-06-30 17:37:13 +02:00
completion_hash.cc WL#3817: Simplify string / memory area types and make things more consistent (first part) 2007-05-10 12:59:39 +03:00
completion_hash.h - Added/updated copyright headers 2010-12-28 19:57:23 +01:00
echo.c echo.c: 2007-03-20 18:31:49 +01:00
get_password.c fixes for build failures due to my yesterday's changeset forbidding 2008-02-19 18:45:11 +01:00
Makefile.am Updated/added copyright headers 2011-07-03 17:47:37 +02:00
my_readline.h Updated/added copyright headers 2011-06-30 17:37:13 +02:00
mysql.cc BUG#11758062 - 50206: ER_TOO_BIG_SELECT REFERS TO OUTMODED 2011-09-28 15:39:21 +05:30
mysql_upgrade.c Manual merge from mysql-5.0. 2011-07-22 11:46:45 +04:00
mysqladmin.cc Manual merge from mysql-5.0. 2011-07-22 11:46:45 +04:00
mysqlbinlog.cc BUG#11762670:MY_B_WRITE RETURN VALUE IGNORED 2012-07-10 14:23:17 +05:30
mysqlcheck.c Manual merge from mysql-5.0. 2011-07-22 11:46:45 +04:00
mysqldump.c Bug #11754178 45740: MYSQLDUMP DOESN'T DUMP GENERAL_LOG AND SLOW_QUERY 2012-05-07 16:46:44 +05:30
mysqlimport.c Manual merge from mysql-5.0. 2011-07-22 11:46:45 +04:00
mysqlshow.c Manual merge from mysql-5.0. 2011-07-22 11:46:45 +04:00
mysqlslap.c Bug #11766072 59107: MYSQLSLAP CRASHES IF STARTED WITH NO ARGUMENTS ON WINDOWS 2012-04-09 16:42:41 +05:30
mysqltest.cc Bug #13708485: malformed resultset packet crashes client 2012-06-28 18:38:55 +03:00
readline.cc Build broken for gcc 4.5.1 in optimized mode. 2011-11-29 15:52:47 +01:00
sql_string.cc Updated/added copyright headers 2012-02-15 17:21:38 +01:00
sql_string.h Updated/added copyright headers 2011-06-30 17:37:13 +02:00