1*2fe8fb19SBen Gras.\" Copyright (c) 1990, 1991, 1993 2*2fe8fb19SBen Gras.\" The Regents of the University of California. All rights reserved. 3*2fe8fb19SBen Gras.\" 4*2fe8fb19SBen Gras.\" This code is derived from software contributed to Berkeley by 5*2fe8fb19SBen Gras.\" Chris Torek and the American National Standards Committee X3, 6*2fe8fb19SBen Gras.\" on Information Processing Systems. 7*2fe8fb19SBen Gras.\" 8*2fe8fb19SBen Gras.\" Redistribution and use in source and binary forms, with or without 9*2fe8fb19SBen Gras.\" modification, are permitted provided that the following conditions 10*2fe8fb19SBen Gras.\" are met: 11*2fe8fb19SBen Gras.\" 1. Redistributions of source code must retain the above copyright 12*2fe8fb19SBen Gras.\" notice, this list of conditions and the following disclaimer. 13*2fe8fb19SBen Gras.\" 2. Redistributions in binary form must reproduce the above copyright 14*2fe8fb19SBen Gras.\" notice, this list of conditions and the following disclaimer in the 15*2fe8fb19SBen Gras.\" documentation and/or other materials provided with the distribution. 16*2fe8fb19SBen Gras.\" 3. Neither the name of the University nor the names of its contributors 17*2fe8fb19SBen Gras.\" may be used to endorse or promote products derived from this software 18*2fe8fb19SBen Gras.\" without specific prior written permission. 19*2fe8fb19SBen Gras.\" 20*2fe8fb19SBen Gras.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 21*2fe8fb19SBen Gras.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 22*2fe8fb19SBen Gras.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 23*2fe8fb19SBen Gras.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 24*2fe8fb19SBen Gras.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 25*2fe8fb19SBen Gras.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 26*2fe8fb19SBen Gras.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 27*2fe8fb19SBen Gras.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 28*2fe8fb19SBen Gras.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 29*2fe8fb19SBen Gras.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 30*2fe8fb19SBen Gras.\" SUCH DAMAGE. 31*2fe8fb19SBen Gras.\" 32*2fe8fb19SBen Gras.\" from: @(#)strcat.3 8.1 (Berkeley) 6/4/93 33*2fe8fb19SBen Gras.\" $NetBSD: strcat.3,v 1.16 2006/10/16 08:48:45 wiz Exp $ 34*2fe8fb19SBen Gras.\" 35*2fe8fb19SBen Gras.Dd August 11, 2002 36*2fe8fb19SBen Gras.Dt STRCAT 3 37*2fe8fb19SBen Gras.Os 38*2fe8fb19SBen Gras.Sh NAME 39*2fe8fb19SBen Gras.Nm strcat , 40*2fe8fb19SBen Gras.Nm strncat 41*2fe8fb19SBen Gras.Nd concatenate strings 42*2fe8fb19SBen Gras.Sh LIBRARY 43*2fe8fb19SBen Gras.Lb libc 44*2fe8fb19SBen Gras.Sh SYNOPSIS 45*2fe8fb19SBen Gras.In string.h 46*2fe8fb19SBen Gras.Ft char * 47*2fe8fb19SBen Gras.Fn strcat "char * restrict s" "const char * restrict append" 48*2fe8fb19SBen Gras.Ft char * 49*2fe8fb19SBen Gras.Fn strncat "char * restrict s" "const char * restrict append" "size_t count" 50*2fe8fb19SBen Gras.Sh DESCRIPTION 51*2fe8fb19SBen GrasThe 52*2fe8fb19SBen Gras.Fn strcat 53*2fe8fb19SBen Grasand 54*2fe8fb19SBen Gras.Fn strncat 55*2fe8fb19SBen Grasfunctions 56*2fe8fb19SBen Grasappend a copy of the nul-terminated string 57*2fe8fb19SBen Gras.Fa append 58*2fe8fb19SBen Grasto the end of the nul-terminated string 59*2fe8fb19SBen Gras.Fa s , 60*2fe8fb19SBen Grasthen add a terminating 61*2fe8fb19SBen Gras.Ql \e0 . 62*2fe8fb19SBen GrasThe string 63*2fe8fb19SBen Gras.Fa s 64*2fe8fb19SBen Grasmust have sufficient space to hold the result. 65*2fe8fb19SBen Gras.Pp 66*2fe8fb19SBen GrasThe 67*2fe8fb19SBen Gras.Fn strncat 68*2fe8fb19SBen Grasfunction 69*2fe8fb19SBen Grasappends not more than 70*2fe8fb19SBen Gras.Fa count 71*2fe8fb19SBen Grascharacters where space for the terminating 72*2fe8fb19SBen Gras.Ql \e0 73*2fe8fb19SBen Grasshould not be included in 74*2fe8fb19SBen Gras.Fa count . 75*2fe8fb19SBen Gras.Sh RETURN VALUES 76*2fe8fb19SBen GrasThe 77*2fe8fb19SBen Gras.Fn strcat 78*2fe8fb19SBen Grasand 79*2fe8fb19SBen Gras.Fn strncat 80*2fe8fb19SBen Grasfunctions 81*2fe8fb19SBen Grasreturn the pointer 82*2fe8fb19SBen Gras.Fa s . 83*2fe8fb19SBen Gras.Sh EXAMPLES 84*2fe8fb19SBen GrasThe following appends 85*2fe8fb19SBen Gras.Dq Li abc 86*2fe8fb19SBen Grasto 87*2fe8fb19SBen Gras.Dq Li chararray : 88*2fe8fb19SBen Gras.Bd -literal -offset indent 89*2fe8fb19SBen Graschar *letters = "abcdefghi"; 90*2fe8fb19SBen Gras 91*2fe8fb19SBen Gras(void)strncat(chararray, letters, 3); 92*2fe8fb19SBen Gras.Ed 93*2fe8fb19SBen Gras.Pp 94*2fe8fb19SBen GrasThe following example shows how to use 95*2fe8fb19SBen Gras.Fn strncat 96*2fe8fb19SBen Grassafely in conjunction with 97*2fe8fb19SBen Gras.Xr strncpy 3 . 98*2fe8fb19SBen Gras.Bd -literal -offset indent 99*2fe8fb19SBen Graschar buf[BUFSIZ]; 100*2fe8fb19SBen Graschar *input, *suffix; 101*2fe8fb19SBen Gras 102*2fe8fb19SBen Gras(void)strncpy(buf, input, sizeof(buf) - 1); 103*2fe8fb19SBen Grasbuf[sizeof(buf) - 1] = '\e0'; 104*2fe8fb19SBen Gras(void)strncat(buf, suffix, sizeof(buf) - 1 - strlen(buf)); 105*2fe8fb19SBen Gras.Ed 106*2fe8fb19SBen Gras.Pp 107*2fe8fb19SBen GrasThe above will copy as many characters from 108*2fe8fb19SBen Gras.Dq Li input 109*2fe8fb19SBen Grasto 110*2fe8fb19SBen Gras.Dq Li buf 111*2fe8fb19SBen Grasas will fit. 112*2fe8fb19SBen GrasIt then appends as many characters from suffix as will fit (or none 113*2fe8fb19SBen Grasif there is no space). 114*2fe8fb19SBen GrasFor operations like this, the 115*2fe8fb19SBen Gras.Xr strlcpy 3 116*2fe8fb19SBen Grasand 117*2fe8fb19SBen Gras.Xr strlcat 3 118*2fe8fb19SBen Grasfunctions are a better choice, as shown below. 119*2fe8fb19SBen Gras.Bd -literal -offset indent 120*2fe8fb19SBen Gras(void)strlcpy(buf, input, sizeof(buf)); 121*2fe8fb19SBen Gras(void)strlcat(buf, suffix, sizeof(buf)); 122*2fe8fb19SBen Gras.Ed 123*2fe8fb19SBen Gras.Sh SEE ALSO 124*2fe8fb19SBen Gras.Xr bcopy 3 , 125*2fe8fb19SBen Gras.Xr memccpy 3 , 126*2fe8fb19SBen Gras.Xr memcpy 3 , 127*2fe8fb19SBen Gras.Xr memmove 3 , 128*2fe8fb19SBen Gras.Xr strcpy 3 , 129*2fe8fb19SBen Gras.Xr strlcat 3 , 130*2fe8fb19SBen Gras.Xr strlcpy 3 131*2fe8fb19SBen Gras.Sh STANDARDS 132*2fe8fb19SBen GrasThe 133*2fe8fb19SBen Gras.Fn strcat 134*2fe8fb19SBen Grasand 135*2fe8fb19SBen Gras.Fn strncat 136*2fe8fb19SBen Grasfunctions 137*2fe8fb19SBen Grasconform to 138*2fe8fb19SBen Gras.St -isoC-99 . 139