xref: /minix3/lib/libc/string/strcat.3 (revision 2fe8fb192fe7e8720e3e7a77f928da545e872a6a)
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