From ac26b7272357d9e3fced9dc24351cbb69f13d6fb Mon Sep 17 00:00:00 2001 From: Corinna Vinschen Date: Wed, 19 Dec 2007 17:33:12 +0000 Subject: * libc/include/wchar.h: Add prototypes for wcpcpy and wcpncpy. * libc/string/Makefile.am (ELIX_SOURCES): Add wcpcpy.c and wcpncpy.c. (CHEWOUT_FILES): Add wcpcpy.def and wcpncpy.def. * libc/string/Makefile.in: Regenerate. * libc/string/wcpcpy.c: New file. * libc/string/wcpncpy.c: New file. * libc/string/wcstrings.tex: Add wcpcpy and wcpncpy. --- newlib/libc/string/wcpncpy.c | 61 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 newlib/libc/string/wcpncpy.c (limited to 'newlib/libc/string/wcpncpy.c') diff --git a/newlib/libc/string/wcpncpy.c b/newlib/libc/string/wcpncpy.c new file mode 100644 index 000000000..654bdb78f --- /dev/null +++ b/newlib/libc/string/wcpncpy.c @@ -0,0 +1,61 @@ +/* +FUNCTION + <>---copy part of a wide-character string returning a pointer to its end + +ANSI_SYNOPSIS + #include + wchar_t *wcpncpy(wchar_t *<[s1]>, const wchar_t *<[s2]>, size_t <[n]>); + +TRAD_SYNOPSIS + wchar_t *wcpncpy(<[s1]>, <[s2]>, <[n]> + wchar_t *<[s1]>; + const wchar_t *<[s2]>; + size_t <[n]>; + +DESCRIPTION + The <> function copies not more than n wide-character codes + (wide-character codes that follow a null wide-character code are not + copied) from the array pointed to by <[s2]> to the array pointed to + by <[s1]>. If copying takes place between objects that overlap, the + behaviour is undefined. + + If the array pointed to by <[s2]> is a wide-character string that is + shorter than <[n]> wide-character codes, null wide-character codes are + appended to the copy in the array pointed to by <[s1]>, until <[n]> + wide-character codes in all are written. + +RETURNS + The <> function returns <[s1]>; no return value is reserved to + indicate an error. + +PORTABILITY +<> is ISO/IEC 9899/AMD1:1995 (ISO C). + +No supporting OS subroutines are required. +*/ + +#include <_ansi.h> +#include + +wchar_t * +_DEFUN (wcpncpy, (dst, src, count), + wchar_t * dst _AND + _CONST wchar_t * src _AND + size_t count) +{ + wchar_t *ret = NULL; + + while (count > 0) + { + --count; + if ((*dst++ = *src++) == L'\0') + { + ret = dst - 1; + break; + } + } + while (count-- > 0) + *dst++ = L'\0'; + + return ret ? ret : dst; +} -- cgit v1.2.3