Rev 424 | Blame | Compare with Previous | Last modification | View Log | RSS feed
/*FUNCTION<<strcpy>>---copy stringINDEXstrcpyANSI_SYNOPSIS#include <string.h>char *strcpy(char *<[dst]>, const char *<[src]>);TRAD_SYNOPSIS#include <string.h>char *strcpy(<[dst]>, <[src]>)char *<[dst]>;char *<[src]>;DESCRIPTION<<strcpy>> copies the string pointed to by <[src]>(including the terminating null character) to the arraypointed to by <[dst]>.RETURNSThis function returns the initial value of <[dst]>.PORTABILITY<<strcpy>> is ANSI C.<<strcpy>> requires no supporting OS subroutines.QUICKREFstrcpy ansi pure*/#include "global.h"#include "include/string.h"#include <limits.h>/*SUPPRESS 560*//*SUPPRESS 530*//* Nonzero if either X or Y is not aligned on a "long" boundary. */#define UNALIGNED(X, Y) \(((long)X & (sizeof (long) - 1)) | ((long)Y & (sizeof (long) - 1)))#if LONG_MAX == 2147483647L#define DETECTNULL(X) (((X) - 0x01010101) & ~(X) & 0x80808080)#else#if LONG_MAX == 9223372036854775807L/* Nonzero if X (a long int) contains a NULL byte. */#define DETECTNULL(X) (((X) - 0x0101010101010101) & ~(X) & 0x8080808080808080)#else#error long int is not a 32bit or 64bit type.#endif#endif#ifndef DETECTNULL#error long int is not a 32bit or 64bit byte#endifchar*_DEFUN (strcpy, (dst0, src0),char *dst0 _AND_CONST char *src0){#if defined(PREFER_SIZE_OVER_SPEED)char *s = dst0;while ((*dst0++ = *src0++));return s;#elsechar *dst = dst0;_CONST char *src = src0;long *aligned_dst;_CONST long *aligned_src;/* If SRC or DEST is unaligned, then copy bytes. */if (!UNALIGNED (src, dst)){aligned_dst = (long*)dst;aligned_src = (long*)src;/* SRC and DEST are both "long int" aligned, try to do "long int"sized copies. */while (!DETECTNULL(*aligned_src)){*aligned_dst++ = *aligned_src++;}dst = (char*)aligned_dst;src = (char*)aligned_src;}while ((*dst++ = *src++));return dst0;#endif /* not PREFER_SIZE_OVER_SPEED */}