X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstring%2Fmemcpy.c;h=ca460ef9b52de4f7fc399597b726a607caa5b98b;hb=ab9dfa663d4a2f62a8db2f113de4155a73cc3b0a;hp=4e7b63cc32a150dbad70e1e4825bca4c050f905d;hpb=1d9d92ba957a0b8307c9a65c35867fde68e6533b;p=pdclib diff --git a/functions/string/memcpy.c b/functions/string/memcpy.c index 4e7b63c..ca460ef 100644 --- a/functions/string/memcpy.c +++ b/functions/string/memcpy.c @@ -1,59 +1,40 @@ -/* ---------------------------------------------------------------------------- - * $Id$ - * ---------------------------------------------------------------------------- - * Public Domain C Library - http://pdclib.sourceforge.net - * This code is Public Domain. Use, modify, and redistribute at will. - * --------------------------------------------------------------------------*/ +/* $Id$ */ -#include <__size_t.h> +/* Release $Name$ */ -void * memcpy( void * restrict dest, const void * restrict src, size_t n ) +/* memcpy( void *, const void *, size_t ) + + This file is part of the Public Domain C Library (PDCLib). + Permission is granted to use, modify, and / or redistribute at will. +*/ + +#include <_PDCLIB_aux.h> +#include + +void * memcpy( void * _PDCLIB_restrict s1, const void * _PDCLIB_restrict s2, size_t n ) { - const char * src_p = (const char *) src; - char * dest_p = (char *) dest; + char * dest = (char *) s1; + const char * src = (const char *) s2; while ( n-- ) { - *dest_p++ = *src_p++; + *dest++ = *src++; } - return dest; + return s1; } -/* TODO: This is code from PDPC, optimizing for word access. +#ifdef TEST +#include <_PDCLIB_test.h> -void *memcpy(void *s1, const void *s2, size_t n) +int main() { - register unsigned int *p = (unsigned int *)s1; - register unsigned int *cs2 = (unsigned int *)s2; - register unsigned int *endi; - - endi = (unsigned int *)((char *)p + (n & ~0x03)); - while (p != endi) - { - *p++ = *cs2++; - } - switch (n & 0x03) - { - case 0: - break; - case 1: - *(char *)p = *(char *)cs2; - break; - case 2: - *(char *)p = *(char *)cs2; - p = (unsigned int *)((char *)p + 1); - cs2 = (unsigned int *)((char *)cs2 + 1); - *(char *)p = *(char *)cs2; - break; - case 3: - *(char *)p = *(char *)cs2; - p = (unsigned int *)((char *)p + 1); - cs2 = (unsigned int *)((char *)cs2 + 1); - *(char *)p = *(char *)cs2; - p = (unsigned int *)((char *)p + 1); - cs2 = (unsigned int *)((char *)cs2 + 1); - *(char *)p = *(char *)cs2; - break; - } - return (s1); + char s[11] = "xxxxxxxxxxx"; + BEGIN_TESTS; + TESTCASE( memcpy( s, abcde, 6 ) == s ); + TESTCASE( s[4] == 'e' ); + TESTCASE( s[5] == '\0' ); + TESTCASE( memcpy( s + 5, abcde, 5 ) == s + 5 ); + TESTCASE( s[9] == 'e' ); + TESTCASE( s[10] == 'x' ); + return TEST_RESULTS; } -*/ +#endif