Merge zippy.cornsilk.net:/home/cmiller/work/mysql/bug04053/my50-bug04053
into zippy.cornsilk.net:/home/cmiller/work/mysql/mysql-5.0-maint
This commit is contained in:
commit
1bbbc65cb5
@ -36,48 +36,51 @@
|
|||||||
|
|
||||||
uint my_read(File Filedes, byte *Buffer, uint Count, myf MyFlags)
|
uint my_read(File Filedes, byte *Buffer, uint Count, myf MyFlags)
|
||||||
{
|
{
|
||||||
uint readbytes,save_count;
|
uint readbytes, save_count;
|
||||||
DBUG_ENTER("my_read");
|
DBUG_ENTER("my_read");
|
||||||
DBUG_PRINT("my",("Fd: %d Buffer: 0x%lx Count: %u MyFlags: %d",
|
DBUG_PRINT("my",("Fd: %d Buffer: 0x%lx Count: %u MyFlags: %d",
|
||||||
Filedes, Buffer, Count, MyFlags));
|
Filedes, Buffer, Count, MyFlags));
|
||||||
save_count=Count;
|
save_count= Count;
|
||||||
|
|
||||||
for (;;)
|
for (;;)
|
||||||
{
|
{
|
||||||
errno=0; /* Linux doesn't reset this */
|
errno= 0; /* Linux doesn't reset this */
|
||||||
if ((readbytes = (uint) read(Filedes, Buffer, Count)) != Count)
|
if ((readbytes= (uint) read(Filedes, Buffer, Count)) != Count)
|
||||||
{
|
{
|
||||||
my_errno=errno ? errno : -1;
|
my_errno= errno ? errno : -1;
|
||||||
DBUG_PRINT("warning",("Read only %ld bytes off %ld from %d, errno: %d",
|
DBUG_PRINT("warning",("Read only %ld bytes off %ld from %d, errno: %d",
|
||||||
readbytes,Count,Filedes,my_errno));
|
readbytes, Count, Filedes, my_errno));
|
||||||
#ifdef THREAD
|
#ifdef THREAD
|
||||||
if (readbytes == 0 && errno == EINTR)
|
if ((int) readbytes <= 0 && errno == EINTR)
|
||||||
continue; /* Interrupted */
|
{
|
||||||
|
DBUG_PRINT("debug", ("my_read() was interrupted and returned %d", (int) readbytes));
|
||||||
|
continue; /* Interrupted */
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
if (MyFlags & (MY_WME | MY_FAE | MY_FNABP))
|
if (MyFlags & (MY_WME | MY_FAE | MY_FNABP))
|
||||||
{
|
{
|
||||||
if ((int) readbytes == -1)
|
if ((int) readbytes == -1)
|
||||||
my_error(EE_READ, MYF(ME_BELL+ME_WAITTANG),
|
my_error(EE_READ, MYF(ME_BELL+ME_WAITTANG),
|
||||||
my_filename(Filedes),my_errno);
|
my_filename(Filedes),my_errno);
|
||||||
else if (MyFlags & (MY_NABP | MY_FNABP))
|
else if (MyFlags & (MY_NABP | MY_FNABP))
|
||||||
my_error(EE_EOFERR, MYF(ME_BELL+ME_WAITTANG),
|
my_error(EE_EOFERR, MYF(ME_BELL+ME_WAITTANG),
|
||||||
my_filename(Filedes),my_errno);
|
my_filename(Filedes),my_errno);
|
||||||
}
|
}
|
||||||
if ((int) readbytes == -1 ||
|
if ((int) readbytes == -1 ||
|
||||||
((MyFlags & (MY_FNABP | MY_NABP)) && !(MyFlags & MY_FULL_IO)))
|
((MyFlags & (MY_FNABP | MY_NABP)) && !(MyFlags & MY_FULL_IO)))
|
||||||
DBUG_RETURN(MY_FILE_ERROR); /* Return with error */
|
DBUG_RETURN(MY_FILE_ERROR); /* Return with error */
|
||||||
if (readbytes > 0 && (MyFlags & MY_FULL_IO))
|
if (readbytes > 0 && (MyFlags & MY_FULL_IO))
|
||||||
{
|
{
|
||||||
Buffer+=readbytes;
|
Buffer+= readbytes;
|
||||||
Count-=readbytes;
|
Count-= readbytes;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (MyFlags & (MY_NABP | MY_FNABP))
|
if (MyFlags & (MY_NABP | MY_FNABP))
|
||||||
readbytes=0; /* Ok on read */
|
readbytes= 0; /* Ok on read */
|
||||||
else if (MyFlags & MY_FULL_IO)
|
else if (MyFlags & MY_FULL_IO)
|
||||||
readbytes=save_count;
|
readbytes= save_count;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
DBUG_RETURN(readbytes);
|
DBUG_RETURN(readbytes);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user