gonzui


Format: Advanced Search

t2ex/bsd_source/lib/libc/src_bsd/string/strstr.cbare sourcepermlink (0.00 seconds)

Search this content:

    1: /*      $OpenBSD: strstr.c,v 1.5 2005/08/08 08:05:37 espie Exp $ */
    2: /*-
    3:  * Copyright (c) 1990 The Regents of the University of California.
    4:  * All rights reserved.
    5:  *
    6:  * This code is derived from software contributed to Berkeley by
    7:  * Chris Torek.
    8:  *
    9:  * Redistribution and use in source and binary forms, with or without
   10:  * modification, are permitted provided that the following conditions
   11:  * are met:
   12:  * 1. Redistributions of source code must retain the above copyright
   13:  *    notice, this list of conditions and the following disclaimer.
   14:  * 2. Redistributions in binary form must reproduce the above copyright
   15:  *    notice, this list of conditions and the following disclaimer in the
   16:  *    documentation and/or other materials provided with the distribution.
   17:  * 3. Neither the name of the University nor the names of its contributors
   18:  *    may be used to endorse or promote products derived from this software
   19:  *    without specific prior written permission.
   20:  *
   21:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
   22:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   23:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   24:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
   25:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
   26:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
   27:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   28:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
   29:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
   30:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   31:  * SUCH DAMAGE.
   32:  */
   33: 
   34: #include <string.h>
   35: 
   36: /*
   37:  * Find the first occurrence of find in s.
   38:  */
   39: char *
   40: strstr(const char *s, const char *find)
   41: {
   42:         char c, sc;
   43:         size_t len;
   44: 
   45:         if ((c = *find++) != 0) {
   46:                 len = strlen(find);
   47:                 do {
   48:                         do {
   49:                                 if ((sc = *s++) == 0)
   50:                                         return (NULL);
   51:                         } while (sc != c);
   52:                 } while (strncmp(s, find, len) != 0);
   53:                 s--;
   54:         }
   55:         return ((char *)s);
   56: }