Fixed a bug - memmove() couldn't handle overlapping buffers

svn path=/trunk/; revision=990
This commit is contained in:
Eric Kohl 2000-02-19 17:18:34 +00:00
parent b0780ae5d6
commit f28a023c99
2 changed files with 47 additions and 12 deletions

View file

@ -1,18 +1,36 @@
#include <string.h>
void * memmove(void *dest,const void *src,size_t count)
{
char *char_dest = (char *)dest;
char *char_src = (char *)src;
while(count > 0 )
if ((char_dest <= char_src) || (char_dest >= (char_src+count)))
{
*char_dest = *char_src;
char_dest++;
char_src++;
count--;
/* non-overlapping buffers */
while(count > 0)
{
*char_dest = *char_src;
char_dest++;
char_src++;
count--;
}
}
else
{
/* overlaping buffers */
char_dest = (char *)dest + count - 1;
char_src = (char *)src + count - 1;
while(count > 0)
{
*char_dest = *char_src;
char_dest--;
char_src--;
count--;
}
}
return dest;
}

View file

@ -1,17 +1,34 @@
#include <string.h>
void * memmove(void *dest,const void *src,size_t count)
{
char *char_dest = (char *)dest;
char *char_src = (char *)src;
while(count > 0 )
if ((char_dest <= char_src) || (char_dest >= (char_src+count)))
{
*char_dest = *char_src;
char_dest++;
char_src++;
count--;
/* non-overlapping buffers */
while(count > 0)
{
*char_dest = *char_src;
char_dest++;
char_src++;
count--;
}
}
else
{
/* overlaping buffers */
char_dest = (char *)dest + count - 1;
char_src = (char *)src + count - 1;
while(count > 0)
{
*char_dest = *char_src;
char_dest--;
char_src--;
count--;
}
}
return dest;