Blame stdio-common/test-fseek.c

Packit 6c4009
/* Copyright (C) 1991-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#include <stdio.h>
Packit 6c4009
Packit 6c4009
#define TESTFILE OBJPFX "test.dat"
Packit 6c4009
Packit 6c4009
static int
Packit 6c4009
do_test (void)
Packit 6c4009
{
Packit 6c4009
  FILE *fp;
Packit 6c4009
  int i, j;
Packit 6c4009
Packit 6c4009
  puts ("\nFile seek test");
Packit 6c4009
  fp = fopen (TESTFILE, "w");
Packit 6c4009
  if (fp == NULL)
Packit 6c4009
    {
Packit 6c4009
      perror (TESTFILE);
Packit 6c4009
      return 1;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  for (i = 0; i < 256; i++)
Packit 6c4009
    putc (i, fp);
Packit 6c4009
  if (freopen (TESTFILE, "r", fp) != fp)
Packit 6c4009
    {
Packit 6c4009
      perror ("Cannot open file for reading");
Packit 6c4009
      return 1;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  for (i = 1; i <= 255; i++)
Packit 6c4009
    {
Packit 6c4009
      printf ("%3d\n", i);
Packit 6c4009
      fseek (fp, (long) -i, SEEK_END);
Packit 6c4009
      if ((j = getc (fp)) != 256 - i)
Packit 6c4009
	{
Packit 6c4009
	  printf ("SEEK_END failed %d\n", j);
Packit 6c4009
	  break;
Packit 6c4009
	}
Packit 6c4009
      if (fseek (fp, (long) i, SEEK_SET))
Packit 6c4009
	{
Packit 6c4009
	  puts ("Cannot SEEK_SET");
Packit 6c4009
	  break;
Packit 6c4009
	}
Packit 6c4009
      if ((j = getc (fp)) != i)
Packit 6c4009
	{
Packit 6c4009
	  printf ("SEEK_SET failed %d\n", j);
Packit 6c4009
	  break;
Packit 6c4009
	}
Packit 6c4009
      if (fseek (fp, (long) i, SEEK_SET))
Packit 6c4009
	{
Packit 6c4009
	  puts ("Cannot SEEK_SET");
Packit 6c4009
	  break;
Packit 6c4009
	}
Packit 6c4009
      if (fseek (fp, (long) (i >= 128 ? -128 : 128), SEEK_CUR))
Packit 6c4009
	{
Packit 6c4009
	  puts ("Cannot SEEK_CUR");
Packit 6c4009
	  break;
Packit 6c4009
	}
Packit 6c4009
      if ((j = getc (fp)) != (i >= 128 ? i - 128 : i + 128))
Packit 6c4009
	{
Packit 6c4009
	  printf ("SEEK_CUR failed %d\n", j);
Packit 6c4009
	  break;
Packit 6c4009
	}
Packit 6c4009
    }
Packit 6c4009
  fclose (fp);
Packit 6c4009
  remove (TESTFILE);
Packit 6c4009
Packit 6c4009
  puts ((i > 255) ? "Test succeeded." : "Test FAILED!");
Packit 6c4009
  return (i > 255) ? 0 : 1;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
#define TEST_FUNCTION do_test ()
Packit 6c4009
#include "../test-skeleton.c"