Blame libio/tst-ftell-partial-wide.c

Packit Service 82fcde
/* Verify that ftell does not go into an infinite loop when a conversion fails
Packit Service 82fcde
   due to insufficient space in the buffer.
Packit Service 82fcde
   Copyright (C) 2014-2018 Free Software Foundation, Inc.
Packit Service 82fcde
   This file is part of the GNU C Library.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is free software; you can redistribute it and/or
Packit Service 82fcde
   modify it under the terms of the GNU Lesser General Public
Packit Service 82fcde
   License as published by the Free Software Foundation; either
Packit Service 82fcde
   version 2.1 of the License, or (at your option) any later version.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is distributed in the hope that it will be useful,
Packit Service 82fcde
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 82fcde
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 82fcde
   Lesser General Public License for more details.
Packit Service 82fcde
Packit Service 82fcde
   You should have received a copy of the GNU Lesser General Public
Packit Service 82fcde
   License along with the GNU C Library; if not, see
Packit Service 82fcde
   <http://www.gnu.org/licenses/>.  */
Packit Service 82fcde
Packit Service 82fcde
#include <wchar.h>
Packit Service 82fcde
#include <stdio.h>
Packit Service 82fcde
#include <stdlib.h>
Packit Service 82fcde
#include <string.h>
Packit Service 82fcde
#include <locale.h>
Packit Service 82fcde
#include <errno.h>
Packit Service 82fcde
#include <unistd.h>
Packit Service 82fcde
Packit Service 82fcde
static int do_test (void);
Packit Service 82fcde
#define TEST_FUNCTION do_test ()
Packit Service 82fcde
#include "../test-skeleton.c"
Packit Service 82fcde
Packit Service 82fcde
/* Arbitrary number large enough so that the target buffer during conversion is
Packit Service 82fcde
   not large enough.  */
Packit Service 82fcde
#define STRING_SIZE (1400)
Packit Service 82fcde
#define NSTRINGS (2)
Packit Service 82fcde
Packit Service 82fcde
static int
Packit Service 82fcde
do_test (void)
Packit Service 82fcde
{
Packit Service 82fcde
  FILE *fp = NULL;
Packit Service 82fcde
  wchar_t *inputs[NSTRINGS] = {NULL};
Packit Service 82fcde
  int ret = 1;
Packit Service 82fcde
Packit Service 82fcde
  if (setlocale (LC_ALL, "en_US.UTF-8") == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("Cannot set en_US.UTF-8 locale.\n");
Packit Service 82fcde
      goto out;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
Packit Service 82fcde
  /* Generate input from one character, chosen because it has an odd number of
Packit Service 82fcde
     bytes in UTF-8, making it easier to reproduce the problem:
Packit Service 82fcde
Packit Service 82fcde
     NAME    Hiragana letter GO
Packit Service 82fcde
     CHAR    ご
Packit Service 82fcde
     UTF-8   E38194
Packit Service 82fcde
     UCS     3054
Packit Service 82fcde
     MARC-8  692434  */
Packit Service 82fcde
  wchar_t seed = L'ご';
Packit Service 82fcde
  for (int i = 0; i < NSTRINGS; i++)
Packit Service 82fcde
    {
Packit Service 82fcde
      inputs[i] = malloc (STRING_SIZE * sizeof (wchar_t));
Packit Service 82fcde
      if (inputs[i] == NULL)
Packit Service 82fcde
	{
Packit Service 82fcde
	  printf ("Failed to allocate memory for inputs: %m\n");
Packit Service 82fcde
	  goto out;
Packit Service 82fcde
	}
Packit Service 82fcde
      wmemset (inputs[i], seed, STRING_SIZE - 1);
Packit Service 82fcde
      inputs[i][STRING_SIZE - 1] = L'\0';
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  char *filename;
Packit Service 82fcde
  int fd = create_temp_file ("tst-fseek-wide-partial.out", &filename);
Packit Service 82fcde
Packit Service 82fcde
  if (fd == -1)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("create_temp_file: %m\n");
Packit Service 82fcde
      goto out;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  fp = fdopen (fd, "w+");
Packit Service 82fcde
  if (fp == NULL)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("fopen: %m\n");
Packit Service 82fcde
      close (fd);
Packit Service 82fcde
      goto out;
Packit Service 82fcde
    }
Packit Service 82fcde
Packit Service 82fcde
  for (int i = 0; i < NSTRINGS; i++)
Packit Service 82fcde
    {
Packit Service 82fcde
      printf ("offset: %ld\n", ftell (fp));
Packit Service 82fcde
      if (fputws (inputs[i], fp) == -1)
Packit Service 82fcde
	{
Packit Service 82fcde
	  perror ("fputws");
Packit Service 82fcde
	  goto out;
Packit Service 82fcde
	}
Packit Service 82fcde
    }
Packit Service 82fcde
  ret = 0;
Packit Service 82fcde
Packit Service 82fcde
out:
Packit Service 82fcde
  if (fp != NULL)
Packit Service 82fcde
    fclose (fp);
Packit Service 82fcde
  for (int i = 0; i < NSTRINGS; i++)
Packit Service 82fcde
    free (inputs[i]);
Packit Service 82fcde
Packit Service 82fcde
  return ret;
Packit Service 82fcde
}