mirror of
https://github.com/reactos/reactos.git
synced 2024-07-31 08:39:05 +00:00
Fixed a bug - memmove() couldn't handle overlapping buffers
svn path=/trunk/; revision=990
This commit is contained in:
parent
b0780ae5d6
commit
f28a023c99
|
@ -1,18 +1,36 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
|
||||||
void * memmove(void *dest,const void *src,size_t count)
|
void * memmove(void *dest,const void *src,size_t count)
|
||||||
{
|
{
|
||||||
char *char_dest = (char *)dest;
|
char *char_dest = (char *)dest;
|
||||||
char *char_src = (char *)src;
|
char *char_src = (char *)src;
|
||||||
|
|
||||||
while(count > 0 )
|
if ((char_dest <= char_src) || (char_dest >= (char_src+count)))
|
||||||
{
|
{
|
||||||
*char_dest = *char_src;
|
/* non-overlapping buffers */
|
||||||
char_dest++;
|
while(count > 0)
|
||||||
char_src++;
|
{
|
||||||
count--;
|
*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;
|
return dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,17 +1,34 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
|
||||||
void * memmove(void *dest,const void *src,size_t count)
|
void * memmove(void *dest,const void *src,size_t count)
|
||||||
{
|
{
|
||||||
char *char_dest = (char *)dest;
|
char *char_dest = (char *)dest;
|
||||||
char *char_src = (char *)src;
|
char *char_src = (char *)src;
|
||||||
|
|
||||||
while(count > 0 )
|
if ((char_dest <= char_src) || (char_dest >= (char_src+count)))
|
||||||
{
|
{
|
||||||
*char_dest = *char_src;
|
/* non-overlapping buffers */
|
||||||
char_dest++;
|
while(count > 0)
|
||||||
char_src++;
|
{
|
||||||
count--;
|
*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;
|
return dest;
|
||||||
|
|
Loading…
Reference in a new issue