Embedded Artistry libc
C Standard Library Support for Bare-metal Systems
strncpy.c
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2011 Apple, Inc. All rights reserved.
3  *
4  * @APPLE_LICENSE_HEADER_START@
5  *
6  * This file contains Original Code and/or Modifications of Original Code
7  * as defined in and that are subject to the Apple Public Source License
8  * Version 2.0 (the 'License'). You may not use this file except in
9  * compliance with the License. Please obtain a copy of the License at
10  * http://www.opensource.apple.com/apsl/ and read it before using this
11  * file.
12  *
13  * The Original Code and all software distributed under the License are
14  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18  * Please see the License for the specific language governing rights and
19  * limitations under the License.
20  *
21  * @APPLE_LICENSE_HEADER_END@
22  */
23 
24 #include <string.h>
25 
26 char* strncpy(char* __restrict dst, const char* __restrict src, size_t maxlen)
27 {
28  const size_t srclen = strnlen(src, maxlen);
29  if(srclen < maxlen)
30  {
31  // The stpncpy() and strncpy() functions copy at most maxlen
32  // characters from src into dst.
33  memcpy(dst, src, srclen);
34  // If src is less than maxlen characters long, the remainder
35  // of dst is filled with '\0' characters.
36  memset(dst + srclen, 0, maxlen - srclen);
37  }
38  else
39  {
40  // Otherwise, dst is not terminated.
41  memcpy(dst, src, maxlen);
42  }
43  // The strcpy() and strncpy() functions return dst.
44  return dst;
45 }
char * strncpy(char *__restrict dst, const char *__restrict src, size_t maxlen)
Copies at most maxlen characters of the character array pointed to by src to character array pointed ...
Definition: strncpy.c:26
size_t strnlen(const char *str, size_t maxlen)
Returns the length of the given null-terminated byte string.
Definition: strnlen.c:21
void * memset(void *dest, int c, size_t n)
Copies the value c into each of the first n characters of the object pointed to by dest.
void * memcpy(void *__restrict dest, const void *__restrict src, size_t n)
Copies n characters from the object pointed to by src to the object pointed to by dest.