Blame stdio-common/tstscanf.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 <array_length.h>
Packit 6c4009
#ifdef	BSD
Packit 6c4009
#include </usr/include/stdio.h>
Packit 6c4009
#else
Packit 6c4009
#include <stdio.h>
Packit 6c4009
#endif
Packit 6c4009
#include <math.h>
Packit 6c4009
#include <stdlib.h>
Packit 6c4009
#include <string.h>
Packit 6c4009
Packit 6c4009
Packit 6c4009
int
Packit 6c4009
main (int argc, char **argv)
Packit 6c4009
{
Packit 6c4009
  char buf[BUFSIZ];
Packit 6c4009
  FILE *in = stdin, *out = stdout;
Packit 6c4009
  int x;
Packit 6c4009
  int result = 0;
Packit 6c4009
Packit 6c4009
  if (sscanf ("0", "%d", &x) != 1)
Packit 6c4009
    {
Packit 6c4009
      fputs ("test failed!\n", stdout);
Packit 6c4009
      result = 1;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  if (sscanf ("08905x", "%9[0-9]", buf) != 1
Packit 6c4009
      || strcmp (buf, "08905") != 0)
Packit 6c4009
    {
Packit 6c4009
      fputs ("test failed!\n", stdout);
Packit 6c4009
      result = 1;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  if (sscanf ("", "%10[a-z]", buf) != EOF)
Packit 6c4009
    {
Packit 6c4009
      fputs ("test failed!\n", stdout);
Packit 6c4009
      result = 1;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  sscanf ("conversion] Zero flag Ze]ro#\n", "%*[^]] %[^#]\n", buf);
Packit 6c4009
  if (strcmp (buf, "] Zero flag Ze]ro") != 0)
Packit 6c4009
    {
Packit 6c4009
      fputs ("test failed!\n", stdout);
Packit 6c4009
      result = 1;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  if (argc == 2 && !strcmp (argv[1], "-opipe"))
Packit 6c4009
    {
Packit 6c4009
      out = popen ("/bin/cat", "w");
Packit 6c4009
      if (out == NULL)
Packit 6c4009
	{
Packit 6c4009
	  perror ("popen: /bin/cat");
Packit 6c4009
	  result = 1;
Packit 6c4009
	}
Packit 6c4009
    }
Packit 6c4009
  else if (argc == 3 && !strcmp (argv[1], "-ipipe"))
Packit 6c4009
    {
Packit 6c4009
      sprintf (buf, "/bin/cat %s", argv[2]);
Packit 6c4009
      in = popen (buf, "r");
Packit 6c4009
      if (in == NULL)
Packit 6c4009
	{
Packit 6c4009
	  perror ("popen: /bin/cat");
Packit 6c4009
	  result = 1;
Packit 6c4009
	}
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  {
Packit 6c4009
    char name[50];
Packit 6c4009
    fprintf (out,
Packit 6c4009
	     "sscanf (\"thompson\", \"%%s\", name) == %d, name == \"%s\"\n",
Packit 6c4009
	     sscanf ("thompson", "%s", name),
Packit 6c4009
	     name);
Packit 6c4009
    if (strcmp (name, "thompson") != 0)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Testing scanf (vfscanf)\n", out);
Packit 6c4009
Packit 6c4009
  fputs ("Test 1:\n", out);
Packit 6c4009
  {
Packit 6c4009
    int n, i;
Packit 6c4009
    float x;
Packit 6c4009
    char name[50];
Packit 6c4009
    n = fscanf (in, "%d%f%s", &i, &x, name);
Packit 6c4009
    fprintf (out, "n = %d, i = %d, x = %f, name = \"%.50s\"\n",
Packit 6c4009
	     n, i, x, name);
Packit 6c4009
    if (n != 3 || i != 25 || x != 5.432F || strcmp (name, "thompson"))
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
  fprintf (out, "Residual: \"%s\"\n", fgets (buf, sizeof (buf), in));
Packit 6c4009
  if (strcmp (buf, "\n"))
Packit 6c4009
    {
Packit 6c4009
      fputs ("test failed!\n", stdout);
Packit 6c4009
      result = 1;
Packit 6c4009
    }
Packit 6c4009
  fputs ("Test 2:\n", out);
Packit 6c4009
  {
Packit 6c4009
    int i;
Packit 6c4009
    float x;
Packit 6c4009
    char name[50];
Packit 6c4009
    (void) fscanf (in, "%2d%f%*d %[0123456789]", &i, &x, name);
Packit 6c4009
    fprintf (out, "i = %d, x = %f, name = \"%.50s\"\n", i, x, name);
Packit 6c4009
    if (i != 56 || x != 789.0F || strcmp (name, "56"))
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
  fprintf (out, "Residual: \"%s\"\n", fgets (buf, sizeof (buf), in));
Packit 6c4009
  if (strcmp (buf, "a72\n"))
Packit 6c4009
    {
Packit 6c4009
      fputs ("test failed!\n", stdout);
Packit 6c4009
      result = 1;
Packit 6c4009
    }
Packit 6c4009
  fputs ("Test 3:\n", out);
Packit 6c4009
  {
Packit 6c4009
    static struct {
Packit 6c4009
      int count;
Packit 6c4009
      float quant;
Packit 6c4009
      const char *units;
Packit 6c4009
      const char *item;
Packit 6c4009
    } ok[] = {
Packit 6c4009
      { 3, 2.0F, "quarts", "oil" },
Packit 6c4009
      { 2, -12.8F, "degrees", "" },
Packit 6c4009
      { 0, 0.0F, "", "" },
Packit 6c4009
      { 3, 10.0F, "LBS", "fertilizer" },
Packit 6c4009
      { 3, 100.0F, "rgs", "energy" },
Packit 6c4009
      { -1, 0.0F, "", "" }};
Packit 6c4009
    size_t rounds = 0;
Packit 6c4009
    float quant;
Packit 6c4009
    char units[21], item[21];
Packit 6c4009
    while (!feof (in) && !ferror (in))
Packit 6c4009
      {
Packit 6c4009
	int count;
Packit 6c4009
Packit 6c4009
	if (rounds++ >= array_length (ok))
Packit 6c4009
	  {
Packit 6c4009
	    fputs ("test failed!\n", stdout);
Packit 6c4009
	    result = 1;
Packit 6c4009
	  }
Packit 6c4009
Packit 6c4009
	quant = 0.0;
Packit 6c4009
	units[0] = item[0] = '\0';
Packit 6c4009
	count = fscanf (in, "%f%20s of %20s", &quant, units, item);
Packit 6c4009
	(void) fscanf (in, "%*[^\n]");
Packit 6c4009
	fprintf (out, "count = %d, quant = %f, item = %.21s, units = %.21s\n",
Packit 6c4009
		 count, quant, item, units);
Packit 6c4009
	if (count != ok[rounds-1].count || quant != ok[rounds-1].quant
Packit 6c4009
	    || strcmp (item, ok[rounds-1].item)
Packit 6c4009
	    || strcmp (units, ok[rounds-1].units))
Packit 6c4009
	  {
Packit 6c4009
	    fputs ("test failed!\n", stdout);
Packit 6c4009
	    result = 1;
Packit 6c4009
	  }
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
  buf[0] = '\0';
Packit 6c4009
  fprintf (out, "Residual: \"%s\"\n", fgets (buf, sizeof (buf), in));
Packit 6c4009
  if (strcmp (buf, ""))
Packit 6c4009
    {
Packit 6c4009
      fputs ("test failed!\n", stdout);
Packit 6c4009
      result = 1;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  if (out != stdout)
Packit 6c4009
    pclose (out);
Packit 6c4009
Packit 6c4009
  fputs ("Test 4:\n", out);
Packit 6c4009
  {
Packit 6c4009
    int res, val, n;
Packit 6c4009
Packit 6c4009
    res = sscanf ("-242", "%3o%n", &val, &n);
Packit 6c4009
    printf ("res = %d, val = %d, n = %d\n", res, val, n);
Packit 6c4009
    if (res != 1 || val != -20 || n != 3)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 5:\n", out);
Packit 6c4009
  {
Packit 6c4009
    double a = 0, b = 0;
Packit 6c4009
    int res, n;
Packit 6c4009
Packit 6c4009
    res = sscanf ("1234567", "%3lg%3lg%n", &a, &b, &n);
Packit 6c4009
    printf ("res = %d, a = %g, b = %g, n = %d\n", res, a, b, n);
Packit 6c4009
Packit 6c4009
    if (res != 2 || a != 123 || b != 456 || n != 6)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
Packit 6c4009
    res = sscanf ("0", "%lg", &a);
Packit 6c4009
    printf ("res = %d, a = %g\n", res, a);
Packit 6c4009
Packit 6c4009
    if (res != 1 || a != 0)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
Packit 6c4009
    res = sscanf ("1e3", "%lg%n", &a, &n);
Packit 6c4009
    printf ("res = %d, a = %g, n = %d\n", res, a, n);
Packit 6c4009
Packit 6c4009
    if (res != 1 || a != 1000 || n != 3)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 6:\n", stdout);
Packit 6c4009
  {
Packit 6c4009
    char *p = (char *) -1;
Packit 6c4009
    int res;
Packit 6c4009
Packit 6c4009
    sprintf (buf, "%p", NULL);
Packit 6c4009
    res = sscanf (buf, "%p", &p);
Packit 6c4009
    printf ("sscanf (\"%s\", \"%%p\", &p) = %d, p == %p\n", buf, res, p);
Packit 6c4009
Packit 6c4009
    if (res != 1 || p != NULL)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 7:\n", stdout);
Packit 6c4009
  {
Packit 6c4009
    short a[2] = { -1, -1 };
Packit 6c4009
    int res;
Packit 6c4009
Packit 6c4009
    res = sscanf ("32767 1234", "%hd %hd", &a[0], &a[1]);
Packit 6c4009
    printf ("res = %d, a[0] = %d, a[1] = %d\n", res, a[0], a[1]);
Packit 6c4009
Packit 6c4009
    if (res != 2 || a[0] != 32767 || a[1] != 1234)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 8:\n", stdout);
Packit 6c4009
  {
Packit 6c4009
    double d = 123456.789;
Packit 6c4009
    int res;
Packit 6c4009
Packit 6c4009
    res = sscanf ("0x1234", "%lf", &d);
Packit 6c4009
    printf ("res = %d, d = %f\n", res, d);
Packit 6c4009
Packit 6c4009
    if (res != 1 || d != 4660)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 9:\n", stdout);
Packit 6c4009
  {
Packit 6c4009
    /* From PR libc/1313 reported by Ben Caradoc-Davies <bmcd@physics.otago.ac.nz>.  */
Packit 6c4009
    float value;
Packit 6c4009
    int res;
Packit 6c4009
Packit 6c4009
    res = sscanf ("0123", "%2f", &value);
Packit 6c4009
    if (res != 1 || value != 1.0)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 10:\n", stdout);
Packit 6c4009
  {
Packit 6c4009
    float value;
Packit 6c4009
    int res;
Packit 6c4009
Packit 6c4009
    res = sscanf ("--", "%f", &value);
Packit 6c4009
    if (res != 0)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 11:\n", stdout);
Packit 6c4009
  {
Packit 6c4009
    char uart[50];
Packit 6c4009
    int res;
Packit 6c4009
Packit 6c4009
    res = sscanf ("uart:16550A tx:0", "uart:%31s tx:%*u", uart);
Packit 6c4009
    if (res != 1)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 12:\n", stdout);
Packit 6c4009
  {
Packit 6c4009
    char uart[50];
Packit 6c4009
    int res;
Packit 6c4009
Packit 6c4009
    res = sscanf ("uart:16550A", "uart:%31s tx:%*u", uart);
Packit 6c4009
    if (res != 1)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  fputs ("Test 13:\n", stdout);
Packit 6c4009
  {
Packit 6c4009
    float value;
Packit 6c4009
    int res;
Packit 6c4009
Packit 6c4009
    res = sscanf ("-InF", "%f", &value);
Packit 6c4009
    if (res != 1 || isinf (value) != -1)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
Packit 6c4009
    res = sscanf ("+InfiNiTY", "%f", &value);
Packit 6c4009
    if (res != 1 || isinf (value) != 1)
Packit 6c4009
      {
Packit 6c4009
	fputs ("test failed!\n", stdout);
Packit 6c4009
	result = 1;
Packit 6c4009
      }
Packit 6c4009
  }
Packit 6c4009
Packit 6c4009
  return result;
Packit 6c4009
}