[PATCH 3/7] Import strnstr.c from FreeBSD.

Aditya Upadhyay aadit0402 at gmail.com
Thu Aug 17 14:58:56 UTC 2017


Yes.. Definitely i will do. Sichen can directly send the patch for strnstr
to newlib ml.

Thanks,
Aditya Upadhyay

On 17 Aug 2017 7:03 p.m., "Joel Sherrill" <joel at rtems.org> wrote:

>
>
> On Aug 17, 2017 8:19 AM, "Gedare Bloom" <gedare at rtems.org> wrote:
>
> On Wed, Aug 16, 2017 at 8:14 PM, Sichen Zhao <1473996754 at qq.com> wrote:
> > ---
> >  freebsd/lib/libc/string/strnstr.c | 67 ++++++++++++++++++++++++++++++
> +++++++++
> >  1 file changed, 67 insertions(+)
> >  create mode 100644 freebsd/lib/libc/string/strnstr.c
> >
> > diff --git a/freebsd/lib/libc/string/strnstr.c
> b/freebsd/lib/libc/string/strnstr.c
> > new file mode 100644
> > index 0000000..247a2b5
> > --- /dev/null
> > +++ b/freebsd/lib/libc/string/strnstr.c
> > @@ -0,0 +1,67 @@
> > +#include <machine/rtems-bsd-user-space.h>
> > +
> > +/*-
> > + * Copyright (c) 2001 Mike Barcroft <mike at FreeBSD.org>
> > + * Copyright (c) 1990, 1993
> > + *     The Regents of the University of California.  All rights
> reserved.
> > + *
> > + * This code is derived from software contributed to Berkeley by
> > + * Chris Torek.
> > + *
> > + * Redistribution and use in source and binary forms, with or without
> > + * modification, are permitted provided that the following conditions
> > + * are met:
> > + * 1. Redistributions of source code must retain the above copyright
> > + *    notice, this list of conditions and the following disclaimer.
> > + * 2. Redistributions in binary form must reproduce the above copyright
> > + *    notice, this list of conditions and the following disclaimer in
> the
> > + *    documentation and/or other materials provided with the
> distribution.
> > + * 3. Neither the name of the University nor the names of its
> contributors
> > + *    may be used to endorse or promote products derived from this
> software
> > + *    without specific prior written permission.
> > + *
> > + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS''
> AND
> > + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
> > + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
> PURPOSE
> > + * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE
> LIABLE
> > + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
> CONSEQUENTIAL
> > + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
> GOODS
> > + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
> > + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
> STRICT
> > + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
> ANY WAY
> > + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
> OF
> > + * SUCH DAMAGE.
> > + */
> > +
> > +#if defined(LIBC_SCCS) && !defined(lint)
> > +static char sccsid[] = "@(#)strstr.c   8.1 (Berkeley) 6/4/93";
> > +#endif /* LIBC_SCCS and not lint */
> > +#include <sys/cdefs.h>
> > +__FBSDID("$FreeBSD$");
> > +
> > +#include <string.h>
> > +
> > +/*
> > + * Find the first occurrence of find in s, where the search is limited
> to the
> > + * first slen characters of s.
> > + */
> > +char *
> > +strnstr(const char *s, const char *find, size_t slen)
> > +{
> > +       char c, sc;
> > +       size_t len;
> > +
> > +       if ((c = *find++) != '\0') {
> > +               len = strlen(find);
> > +               do {
> > +                       do {
> > +                               if (slen-- < 1 || (sc = *s++) == '\0')
> > +                                       return (NULL);
> > +                       } while (sc != c);
> > +                       if (len > slen)
> > +                               return (NULL);
> > +               } while (strncmp(s, find, len) != 0);
> > +               s--;
> > +       }
> > +       return ((char *)s);
> > +}
>
> This can definitely be added in newlib. Aditya may be able to assist
> in the process?
>
>
> Agreed. This should be as widely available to RTEMS applications as
> possible.
>
>
>
> > --
> > 2.7.4
> >
> > _______________________________________________
> > devel mailing list
> > devel at rtems.org
> > http://lists.rtems.org/mailman/listinfo/devel
> _______________________________________________
> devel mailing list
> devel at rtems.org
> http://lists.rtems.org/mailman/listinfo/devel
>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.rtems.org/pipermail/devel/attachments/20170817/903b7987/attachment-0002.html>


More information about the devel mailing list