158f0484fSRodney W. Grimes.\" Copyright (c) 1990, 1991, 1993 258f0484fSRodney W. Grimes.\" The Regents of the University of California. All rights reserved. 358f0484fSRodney W. Grimes.\" 458f0484fSRodney W. Grimes.\" This code is derived from software contributed to Berkeley by 558f0484fSRodney W. Grimes.\" Chris Torek and the American National Standards Committee X3, 658f0484fSRodney W. Grimes.\" on Information Processing Systems. 758f0484fSRodney W. Grimes.\" 858f0484fSRodney W. Grimes.\" Redistribution and use in source and binary forms, with or without 958f0484fSRodney W. Grimes.\" modification, are permitted provided that the following conditions 1058f0484fSRodney W. Grimes.\" are met: 1158f0484fSRodney W. Grimes.\" 1. Redistributions of source code must retain the above copyright 1258f0484fSRodney W. Grimes.\" notice, this list of conditions and the following disclaimer. 1358f0484fSRodney W. Grimes.\" 2. Redistributions in binary form must reproduce the above copyright 1458f0484fSRodney W. Grimes.\" notice, this list of conditions and the following disclaimer in the 1558f0484fSRodney W. Grimes.\" documentation and/or other materials provided with the distribution. 1658f0484fSRodney W. Grimes.\" 4. Neither the name of the University nor the names of its contributors 1758f0484fSRodney W. Grimes.\" may be used to endorse or promote products derived from this software 1858f0484fSRodney W. Grimes.\" without specific prior written permission. 1958f0484fSRodney W. Grimes.\" 2058f0484fSRodney W. Grimes.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 2158f0484fSRodney W. Grimes.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 2258f0484fSRodney W. Grimes.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 2358f0484fSRodney W. Grimes.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 2458f0484fSRodney W. Grimes.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 2558f0484fSRodney W. Grimes.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 2658f0484fSRodney W. Grimes.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2758f0484fSRodney W. Grimes.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 2858f0484fSRodney W. Grimes.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 2958f0484fSRodney W. Grimes.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 3058f0484fSRodney W. Grimes.\" SUCH DAMAGE. 3158f0484fSRodney W. Grimes.\" 3258f0484fSRodney W. Grimes.\" @(#)strcat.3 8.1 (Berkeley) 6/4/93 337f3dea24SPeter Wemm.\" $FreeBSD$ 3458f0484fSRodney W. Grimes.\" 35ef33e736SChristian Brueffer.Dd December 1, 2009 3658f0484fSRodney W. Grimes.Dt STRCAT 3 3758f0484fSRodney W. Grimes.Os 3858f0484fSRodney W. Grimes.Sh NAME 39ef33e736SChristian Brueffer.Nm strcat , 40ef33e736SChristian Brueffer.Nm strncat 4158f0484fSRodney W. Grimes.Nd concatenate strings 4225bb73e0SAlexey Zelkin.Sh LIBRARY 4325bb73e0SAlexey Zelkin.Lb libc 4458f0484fSRodney W. Grimes.Sh SYNOPSIS 4532eef9aeSRuslan Ermilov.In string.h 4658f0484fSRodney W. Grimes.Ft char * 47ad906968SRobert Drehmel.Fn strcat "char * restrict s" "const char * restrict append" 4858f0484fSRodney W. Grimes.Ft char * 49ad906968SRobert Drehmel.Fn strncat "char * restrict s" "const char * restrict append" "size_t count" 5058f0484fSRodney W. Grimes.Sh DESCRIPTION 5158f0484fSRodney W. GrimesThe 5258f0484fSRodney W. Grimes.Fn strcat 5358f0484fSRodney W. Grimesand 5458f0484fSRodney W. Grimes.Fn strncat 5558f0484fSRodney W. Grimesfunctions 5658f0484fSRodney W. Grimesappend a copy of the null-terminated string 5758f0484fSRodney W. Grimes.Fa append 5858f0484fSRodney W. Grimesto the end of the null-terminated string 5958f0484fSRodney W. Grimes.Fa s , 6058f0484fSRodney W. Grimesthen add a terminating 6158f0484fSRodney W. Grimes.Ql \e0 . 6258f0484fSRodney W. GrimesThe string 6358f0484fSRodney W. Grimes.Fa s 6458f0484fSRodney W. Grimesmust have sufficient space to hold the result. 6558f0484fSRodney W. Grimes.Pp 6658f0484fSRodney W. GrimesThe 6758f0484fSRodney W. Grimes.Fn strncat 6858f0484fSRodney W. Grimesfunction 6958f0484fSRodney W. Grimesappends not more than 7058f0484fSRodney W. Grimes.Fa count 7159f00bcdSMike Pritchardcharacters from 7259f00bcdSMike Pritchard.Fa append , 7359f00bcdSMike Pritchardand then adds a terminating 7459f00bcdSMike Pritchard.Ql \e0 . 7558f0484fSRodney W. Grimes.Sh RETURN VALUES 7658f0484fSRodney W. GrimesThe 7758f0484fSRodney W. Grimes.Fn strcat 7858f0484fSRodney W. Grimesand 7958f0484fSRodney W. Grimes.Fn strncat 8058f0484fSRodney W. Grimesfunctions 8158f0484fSRodney W. Grimesreturn the pointer 8258f0484fSRodney W. Grimes.Fa s . 8341f91cb4SChris Costello.Sh SECURITY CONSIDERATIONS 8441f91cb4SChris CostelloThe 8541f91cb4SChris Costello.Fn strcat 8641f91cb4SChris Costellofunction is easily misused in a manner 8741f91cb4SChris Costellowhich enables malicious users to arbitrarily change 8841f91cb4SChris Costelloa running program's functionality through a buffer overflow attack. 8941f91cb4SChris Costello(See 9041f91cb4SChris Costellothe FSA.) 9141f91cb4SChris Costello.Pp 9241f91cb4SChris CostelloAvoid using 9341f91cb4SChris Costello.Fn strcat . 9441f91cb4SChris CostelloInstead, use 9541f91cb4SChris Costello.Fn strncat 9641f91cb4SChris Costelloor 9741f91cb4SChris Costello.Fn strlcat 9841f91cb4SChris Costelloand ensure that no more characters are copied to the destination buffer 9941f91cb4SChris Costellothan it can hold. 10041f91cb4SChris Costello.Pp 10141f91cb4SChris CostelloNote that 10241f91cb4SChris Costello.Fn strncat 10341f91cb4SChris Costellocan also be problematic. 10441f91cb4SChris CostelloIt may be a security concern for a string to be truncated at all. 10541f91cb4SChris CostelloSince the truncated string will not be as long as the original, 10641f91cb4SChris Costelloit may refer to a completely different resource 10741f91cb4SChris Costelloand usage of the truncated resource 10841f91cb4SChris Costellocould result in very incorrect behavior. 10941f91cb4SChris CostelloExample: 11041f91cb4SChris Costello.Bd -literal 11141f91cb4SChris Costellovoid 11241f91cb4SChris Costellofoo(const char *arbitrary_string) 11341f91cb4SChris Costello{ 11441f91cb4SChris Costello char onstack[8]; 11541f91cb4SChris Costello 11641f91cb4SChris Costello#if defined(BAD) 11741f91cb4SChris Costello /* 11841f91cb4SChris Costello * This first strcat is bad behavior. Do not use strcat! 11941f91cb4SChris Costello */ 12041f91cb4SChris Costello (void)strcat(onstack, arbitrary_string); /* BAD! */ 12141f91cb4SChris Costello#elif defined(BETTER) 12241f91cb4SChris Costello /* 12341f91cb4SChris Costello * The following two lines demonstrate better use of 12441f91cb4SChris Costello * strncat(). 12541f91cb4SChris Costello */ 12641f91cb4SChris Costello (void)strncat(onstack, arbitrary_string, 12741f91cb4SChris Costello sizeof(onstack) - strlen(onstack) - 1); 12841f91cb4SChris Costello#elif defined(BEST) 12941f91cb4SChris Costello /* 13041f91cb4SChris Costello * These lines are even more robust due to testing for 13141f91cb4SChris Costello * truncation. 13241f91cb4SChris Costello */ 13341f91cb4SChris Costello if (strlen(arbitrary_string) + 1 > 13441f91cb4SChris Costello sizeof(onstack) - strlen(onstack)) 13541f91cb4SChris Costello err(1, "onstack would be truncated"); 13641f91cb4SChris Costello (void)strncat(onstack, arbitrary_string, 13741f91cb4SChris Costello sizeof(onstack) - strlen(onstack) - 1); 13841f91cb4SChris Costello#endif 13941f91cb4SChris Costello} 14041f91cb4SChris Costello.Ed 14158f0484fSRodney W. Grimes.Sh SEE ALSO 14258f0484fSRodney W. Grimes.Xr bcopy 3 , 14358f0484fSRodney W. Grimes.Xr memccpy 3 , 14458f0484fSRodney W. Grimes.Xr memcpy 3 , 14558f0484fSRodney W. Grimes.Xr memmove 3 , 1464e2abf95SWarner Losh.Xr strcpy 3 , 1474e2abf95SWarner Losh.Xr strlcat 3 , 1485174a6a2SEdward Tomasz Napierala.Xr strlcpy 3 , 1495174a6a2SEdward Tomasz Napierala.Xr wcscat 3 15058f0484fSRodney W. Grimes.Sh STANDARDS 15158f0484fSRodney W. GrimesThe 15258f0484fSRodney W. Grimes.Fn strcat 15358f0484fSRodney W. Grimesand 15458f0484fSRodney W. Grimes.Fn strncat 15558f0484fSRodney W. Grimesfunctions 15658f0484fSRodney W. Grimesconform to 157588a200cSRuslan Ermilov.St -isoC . 158