/*-1* Copyright (c) 2001 Mike Barcroft <[email protected]>2* Copyright (c) 1990, 19933* The Regents of the University of California. All rights reserved.4*5* This code is derived from software contributed to Berkeley by6* Chris Torek.7*8* Redistribution and use in source and binary forms, with or without9* modification, are permitted provided that the following conditions10* are met:11* 1. Redistributions of source code must retain the above copyright12* notice, this list of conditions and the following disclaimer.13* 2. Redistributions in binary form must reproduce the above copyright14* notice, this list of conditions and the following disclaimer in the15* documentation and/or other materials provided with the distribution.16* 3. Neither the name of the University nor the names of its contributors17* may be used to endorse or promote products derived from this software18* without specific prior written permission.19*20* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND21* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE22* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE23* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE24* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL25* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS26* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)27* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT28* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY29* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF30* SUCH DAMAGE.31*/3233#include <string.h>3435#if !HAVE_STRNSTR36/*37* Find the first occurrence of find in s, where the search is limited to the38* first slen characters of s.39*/40char *41strnstr(const char *s, const char *find, size_t slen)42{43char c, sc;44size_t len;4546if ((c = *find++) != '\0') {47len = strlen(find);48do {49do {50if (slen-- < 1 || (sc = *s++) == '\0')51return (NULL);52} while (sc != c);53if (len > slen)54return (NULL);55} while (strncmp(s, find, len) != 0);56s--;57}58return ((char *)s);59}60#endif616263