11debfc3dSmrg /* Simple implementation of strstr for systems without it.
21debfc3dSmrg This function is in the public domain. */
31debfc3dSmrg
41debfc3dSmrg /*
51debfc3dSmrg
61debfc3dSmrg @deftypefn Supplemental char* strstr (const char *@var{string}, const char *@var{sub})
71debfc3dSmrg
81debfc3dSmrg This function searches for the substring @var{sub} in the string
91debfc3dSmrg @var{string}, not including the terminating null characters. A pointer
101debfc3dSmrg to the first occurrence of @var{sub} is returned, or @code{NULL} if the
111debfc3dSmrg substring is absent. If @var{sub} points to a string with zero
121debfc3dSmrg length, the function returns @var{string}.
131debfc3dSmrg
141debfc3dSmrg @end deftypefn
151debfc3dSmrg
161debfc3dSmrg
171debfc3dSmrg */
181debfc3dSmrg
191debfc3dSmrg
201debfc3dSmrg /* FIXME: The above description is ANSI compiliant. This routine has not
211debfc3dSmrg been validated to comply with it. -fnf */
221debfc3dSmrg
231debfc3dSmrg #include <stddef.h>
241debfc3dSmrg
251debfc3dSmrg extern char *strchr (const char *, int);
261debfc3dSmrg extern int strncmp (const void *, const void *, size_t);
271debfc3dSmrg extern size_t strlen (const char *);
281debfc3dSmrg
291debfc3dSmrg char *
strstr(const char * s1,const char * s2)301debfc3dSmrg strstr (const char *s1, const char *s2)
311debfc3dSmrg {
321debfc3dSmrg const char *p = s1;
331debfc3dSmrg const size_t len = strlen (s2);
341debfc3dSmrg
35*23f5f463Smrg if (!len)
36*23f5f463Smrg return s1;
37*23f5f463Smrg
381debfc3dSmrg for (; (p = strchr (p, *s2)) != 0; p++)
391debfc3dSmrg {
401debfc3dSmrg if (strncmp (p, s2, len) == 0)
411debfc3dSmrg return (char *)p;
421debfc3dSmrg }
431debfc3dSmrg return (0);
441debfc3dSmrg }
45