OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gdb-6.8/] [intl/] [plural-exp.c] - Diff between revs 827 and 840

Only display areas with differences | Details | Blame | View Log

Rev 827 Rev 840
/* Expression parsing for plural form selection.
/* Expression parsing for plural form selection.
   Copyright (C) 2000, 2001 Free Software Foundation, Inc.
   Copyright (C) 2000, 2001 Free Software Foundation, Inc.
   Written by Ulrich Drepper <drepper@cygnus.com>, 2000.
   Written by Ulrich Drepper <drepper@cygnus.com>, 2000.
 
 
   This program is free software; you can redistribute it and/or modify it
   This program is free software; you can redistribute it and/or modify it
   under the terms of the GNU Library General Public License as published
   under the terms of the GNU Library General Public License as published
   by the Free Software Foundation; either version 2, or (at your option)
   by the Free Software Foundation; either version 2, or (at your option)
   any later version.
   any later version.
 
 
   This program is distributed in the hope that it will be useful,
   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Library General Public License for more details.
   Library General Public License for more details.
 
 
   You should have received a copy of the GNU Library General Public
   You should have received a copy of the GNU Library General Public
   License along with this program; if not, write to the Free Software
   License along with this program; if not, write to the Free Software
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301,
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301,
   USA.  */
   USA.  */
 
 
#ifdef HAVE_CONFIG_H
#ifdef HAVE_CONFIG_H
# include <config.h>
# include <config.h>
#endif
#endif
 
 
#include <ctype.h>
#include <ctype.h>
#include <stdlib.h>
#include <stdlib.h>
#include <string.h>
#include <string.h>
 
 
#include "plural-exp.h"
#include "plural-exp.h"
 
 
#if (defined __GNUC__ && !defined __APPLE_CC__) \
#if (defined __GNUC__ && !defined __APPLE_CC__) \
    || (defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L)
    || (defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L)
 
 
/* These structs are the constant expression for the germanic plural
/* These structs are the constant expression for the germanic plural
   form determination.  It represents the expression  "n != 1".  */
   form determination.  It represents the expression  "n != 1".  */
static const struct expression plvar =
static const struct expression plvar =
{
{
  .nargs = 0,
  .nargs = 0,
  .operation = var,
  .operation = var,
};
};
static const struct expression plone =
static const struct expression plone =
{
{
  .nargs = 0,
  .nargs = 0,
  .operation = num,
  .operation = num,
  .val =
  .val =
  {
  {
    .num = 1
    .num = 1
  }
  }
};
};
struct expression GERMANIC_PLURAL =
struct expression GERMANIC_PLURAL =
{
{
  .nargs = 2,
  .nargs = 2,
  .operation = not_equal,
  .operation = not_equal,
  .val =
  .val =
  {
  {
    .args =
    .args =
    {
    {
      [0] = (struct expression *) &plvar,
      [0] = (struct expression *) &plvar,
      [1] = (struct expression *) &plone
      [1] = (struct expression *) &plone
    }
    }
  }
  }
};
};
 
 
# define INIT_GERMANIC_PLURAL()
# define INIT_GERMANIC_PLURAL()
 
 
#else
#else
 
 
/* For compilers without support for ISO C 99 struct/union initializers:
/* For compilers without support for ISO C 99 struct/union initializers:
   Initialization at run-time.  */
   Initialization at run-time.  */
 
 
static struct expression plvar;
static struct expression plvar;
static struct expression plone;
static struct expression plone;
struct expression GERMANIC_PLURAL;
struct expression GERMANIC_PLURAL;
 
 
static void
static void
init_germanic_plural ()
init_germanic_plural ()
{
{
  if (plone.val.num == 0)
  if (plone.val.num == 0)
    {
    {
      plvar.nargs = 0;
      plvar.nargs = 0;
      plvar.operation = var;
      plvar.operation = var;
 
 
      plone.nargs = 0;
      plone.nargs = 0;
      plone.operation = num;
      plone.operation = num;
      plone.val.num = 1;
      plone.val.num = 1;
 
 
      GERMANIC_PLURAL.nargs = 2;
      GERMANIC_PLURAL.nargs = 2;
      GERMANIC_PLURAL.operation = not_equal;
      GERMANIC_PLURAL.operation = not_equal;
      GERMANIC_PLURAL.val.args[0] = &plvar;
      GERMANIC_PLURAL.val.args[0] = &plvar;
      GERMANIC_PLURAL.val.args[1] = &plone;
      GERMANIC_PLURAL.val.args[1] = &plone;
    }
    }
}
}
 
 
# define INIT_GERMANIC_PLURAL() init_germanic_plural ()
# define INIT_GERMANIC_PLURAL() init_germanic_plural ()
 
 
#endif
#endif
 
 
void
void
internal_function
internal_function
EXTRACT_PLURAL_EXPRESSION (nullentry, pluralp, npluralsp)
EXTRACT_PLURAL_EXPRESSION (nullentry, pluralp, npluralsp)
     const char *nullentry;
     const char *nullentry;
     struct expression **pluralp;
     struct expression **pluralp;
     unsigned long int *npluralsp;
     unsigned long int *npluralsp;
{
{
  if (nullentry != NULL)
  if (nullentry != NULL)
    {
    {
      const char *plural;
      const char *plural;
      const char *nplurals;
      const char *nplurals;
 
 
      plural = strstr (nullentry, "plural=");
      plural = strstr (nullentry, "plural=");
      nplurals = strstr (nullentry, "nplurals=");
      nplurals = strstr (nullentry, "nplurals=");
      if (plural == NULL || nplurals == NULL)
      if (plural == NULL || nplurals == NULL)
        goto no_plural;
        goto no_plural;
      else
      else
        {
        {
          char *endp;
          char *endp;
          unsigned long int n;
          unsigned long int n;
          struct parse_args args;
          struct parse_args args;
 
 
          /* First get the number.  */
          /* First get the number.  */
          nplurals += 9;
          nplurals += 9;
          while (*nplurals != '\0' && isspace ((unsigned char) *nplurals))
          while (*nplurals != '\0' && isspace ((unsigned char) *nplurals))
            ++nplurals;
            ++nplurals;
          if (!(*nplurals >= '0' && *nplurals <= '9'))
          if (!(*nplurals >= '0' && *nplurals <= '9'))
            goto no_plural;
            goto no_plural;
#if defined HAVE_STRTOUL || defined _LIBC
#if defined HAVE_STRTOUL || defined _LIBC
          n = strtoul (nplurals, &endp, 10);
          n = strtoul (nplurals, &endp, 10);
#else
#else
          for (endp = nplurals, n = 0; *endp >= '0' && *endp <= '9'; endp++)
          for (endp = nplurals, n = 0; *endp >= '0' && *endp <= '9'; endp++)
            n = n * 10 + (*endp - '0');
            n = n * 10 + (*endp - '0');
#endif
#endif
          if (nplurals == endp)
          if (nplurals == endp)
            goto no_plural;
            goto no_plural;
          *npluralsp = n;
          *npluralsp = n;
 
 
          /* Due to the restrictions bison imposes onto the interface of the
          /* Due to the restrictions bison imposes onto the interface of the
             scanner function we have to put the input string and the result
             scanner function we have to put the input string and the result
             passed up from the parser into the same structure which address
             passed up from the parser into the same structure which address
             is passed down to the parser.  */
             is passed down to the parser.  */
          plural += 7;
          plural += 7;
          args.cp = plural;
          args.cp = plural;
          if (PLURAL_PARSE (&args) != 0)
          if (PLURAL_PARSE (&args) != 0)
            goto no_plural;
            goto no_plural;
          *pluralp = args.res;
          *pluralp = args.res;
        }
        }
    }
    }
  else
  else
    {
    {
      /* By default we are using the Germanic form: singular form only
      /* By default we are using the Germanic form: singular form only
         for `one', the plural form otherwise.  Yes, this is also what
         for `one', the plural form otherwise.  Yes, this is also what
         English is using since English is a Germanic language.  */
         English is using since English is a Germanic language.  */
    no_plural:
    no_plural:
      INIT_GERMANIC_PLURAL ();
      INIT_GERMANIC_PLURAL ();
      *pluralp = &GERMANIC_PLURAL;
      *pluralp = &GERMANIC_PLURAL;
      *npluralsp = 2;
      *npluralsp = 2;
    }
    }
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.