Blame gnulib-tests/test-mbsstr2.c

Packit 709fb3
/* Test of searching in a string.
Packit 709fb3
   Copyright (C) 2007-2017 Free Software Foundation, Inc.
Packit 709fb3
Packit 709fb3
   This program is free software: you can redistribute it and/or modify
Packit 709fb3
   it under the terms of the GNU General Public License as published by
Packit 709fb3
   the Free Software Foundation; either version 3 of the License, or
Packit 709fb3
   (at your option) any later version.
Packit 709fb3
Packit 709fb3
   This program is distributed in the hope that it will be useful,
Packit 709fb3
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 709fb3
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 709fb3
   GNU General Public License for more details.
Packit 709fb3
Packit 709fb3
   You should have received a copy of the GNU General Public License
Packit 709fb3
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit 709fb3
Packit 709fb3
/* Written by Bruno Haible <bruno@clisp.org>, 2007.  */
Packit 709fb3
Packit 709fb3
#include <config.h>
Packit 709fb3
Packit 709fb3
#include <string.h>
Packit 709fb3
Packit 709fb3
#include <locale.h>
Packit 709fb3
#include <stdlib.h>
Packit 709fb3
Packit 709fb3
#include "macros.h"
Packit 709fb3
Packit 709fb3
int
Packit 709fb3
main ()
Packit 709fb3
{
Packit 709fb3
  /* configure should already have checked that the locale is supported.  */
Packit 709fb3
  if (setlocale (LC_ALL, "") == NULL)
Packit 709fb3
    return 1;
Packit 709fb3
Packit 709fb3
  {
Packit 709fb3
    const char input[] = "f\303\266\303\266";
Packit 709fb3
    const char *result = mbsstr (input, "");
Packit 709fb3
    ASSERT (result == input);
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  {
Packit 709fb3
    const char input[] = "f\303\266\303\266";
Packit 709fb3
    const char *result = mbsstr (input, "\303\266");
Packit 709fb3
    ASSERT (result == input + 1);
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  {
Packit 709fb3
    const char input[] = "f\303\266\303\266";
Packit 709fb3
    const char *result = mbsstr (input, "\266\303");
Packit 709fb3
    ASSERT (result == NULL);
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  {
Packit 709fb3
    const char input[] = "\303\204BC \303\204BCD\303\204B \303\204BCD\303\204BCD\303\204BDE"; /* "ÄBC ÄBCDÄB ÄBCDÄBCDÄBDE" */
Packit 709fb3
    const char *result = mbsstr (input, "\303\204BCD\303\204BD"); /* "ÄBCDÄBD" */
Packit 709fb3
    ASSERT (result == input + 19);
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  {
Packit 709fb3
    const char input[] = "\303\204BC \303\204BCD\303\204B \303\204BCD\303\204BCD\303\204BDE"; /* "ÄBC ÄBCDÄB ÄBCDÄBCDÄBDE" */
Packit 709fb3
    const char *result = mbsstr (input, "\303\204BCD\303\204BE"); /* "ÄBCDÄBE" */
Packit 709fb3
    ASSERT (result == NULL);
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  /* Check that a very long haystack is handled quickly if the needle is
Packit 709fb3
     short and occurs near the beginning.  */
Packit 709fb3
  {
Packit 709fb3
    size_t repeat = 10000;
Packit 709fb3
    size_t m = 1000000;
Packit 709fb3
    const char *needle =
Packit 709fb3
      "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
Packit 709fb3
      "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA";
Packit 709fb3
    char *haystack = (char *) malloc (m + 1);
Packit 709fb3
    if (haystack != NULL)
Packit 709fb3
      {
Packit 709fb3
        memset (haystack, 'A', m);
Packit 709fb3
        haystack[0] = '\303'; haystack[1] = '\204';
Packit 709fb3
        haystack[m] = '\0';
Packit 709fb3
Packit 709fb3
        for (; repeat > 0; repeat--)
Packit 709fb3
          {
Packit 709fb3
            ASSERT (mbsstr (haystack, needle) == haystack + 2);
Packit 709fb3
          }
Packit 709fb3
Packit 709fb3
        free (haystack);
Packit 709fb3
      }
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  /* Check that a very long needle is discarded quickly if the haystack is
Packit 709fb3
     short.  */
Packit 709fb3
  {
Packit 709fb3
    size_t repeat = 10000;
Packit 709fb3
    size_t m = 1000000;
Packit 709fb3
    const char *haystack =
Packit 709fb3
      "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
Packit 709fb3
      "A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207"
Packit 709fb3
      "A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207"
Packit 709fb3
      "A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207"
Packit 709fb3
      "A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207"
Packit 709fb3
      "A\303\207A\303\207A\303\207A\303\207A\303\207A\303\207";
Packit 709fb3
    char *needle = (char *) malloc (m + 1);
Packit 709fb3
    if (needle != NULL)
Packit 709fb3
      {
Packit 709fb3
        memset (needle, 'A', m);
Packit 709fb3
        needle[m] = '\0';
Packit 709fb3
Packit 709fb3
        for (; repeat > 0; repeat--)
Packit 709fb3
          {
Packit 709fb3
            ASSERT (mbsstr (haystack, needle) == NULL);
Packit 709fb3
          }
Packit 709fb3
Packit 709fb3
        free (needle);
Packit 709fb3
      }
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  /* Check that the asymptotic worst-case complexity is not quadratic.  */
Packit 709fb3
  {
Packit 709fb3
    size_t m = 1000000;
Packit 709fb3
    char *haystack = (char *) malloc (2 * m + 3);
Packit 709fb3
    char *needle = (char *) malloc (m + 3);
Packit 709fb3
    if (haystack != NULL && needle != NULL)
Packit 709fb3
      {
Packit 709fb3
        const char *result;
Packit 709fb3
Packit 709fb3
        memset (haystack, 'A', 2 * m);
Packit 709fb3
        haystack[2 * m] = '\303'; haystack[2 * m + 1] = '\207';
Packit 709fb3
        haystack[2 * m + 2] = '\0';
Packit 709fb3
Packit 709fb3
        memset (needle, 'A', m);
Packit 709fb3
        needle[m] = '\303'; needle[m + 1] = '\207';
Packit 709fb3
        needle[m + 2] = '\0';
Packit 709fb3
Packit 709fb3
        result = mbsstr (haystack, needle);
Packit 709fb3
        ASSERT (result == haystack + m);
Packit 709fb3
      }
Packit 709fb3
    free (needle);
Packit 709fb3
    free (haystack);
Packit 709fb3
  }
Packit 709fb3
Packit 709fb3
  return 0;
Packit 709fb3
}