Blame gnulib-tests/test-mbsstr2.c

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