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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gdb-6.8/] [gdb/] [ada-lex.l] - Diff between revs 827 and 840

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 827 Rev 840
/* FLEX lexer for Ada expressions, for GDB.
/* FLEX lexer for Ada expressions, for GDB.
   Copyright (C) 1994, 1997, 1998, 2000, 2001, 2002, 2003, 2007, 2008
   Copyright (C) 1994, 1997, 1998, 2000, 2001, 2002, 2003, 2007, 2008
   Free Software Foundation, Inc.
   Free Software Foundation, Inc.
This file is part of GDB.
This file is part of GDB.
This program is free software; you can redistribute it and/or modify
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
(at your option) 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
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor,
Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.  */
Boston, MA 02110-1301, USA.  */
/*----------------------------------------------------------------------*/
/*----------------------------------------------------------------------*/
/* The converted version of this file is to be included in ada-exp.y, */
/* The converted version of this file is to be included in ada-exp.y, */
/* the Ada parser for gdb.  The function yylex obtains characters from */
/* the Ada parser for gdb.  The function yylex obtains characters from */
/* the global pointer lexptr.  It returns a syntactic category for */
/* the global pointer lexptr.  It returns a syntactic category for */
/* each successive token and places a semantic value into yylval */
/* each successive token and places a semantic value into yylval */
/* (ada-lval), defined by the parser.   */
/* (ada-lval), defined by the parser.   */
DIG     [0-9]
DIG     [0-9]
NUM10   ({DIG}({DIG}|_)*)
NUM10   ({DIG}({DIG}|_)*)
HEXDIG  [0-9a-f]
HEXDIG  [0-9a-f]
NUM16   ({HEXDIG}({HEXDIG}|_)*)
NUM16   ({HEXDIG}({HEXDIG}|_)*)
OCTDIG  [0-7]
OCTDIG  [0-7]
LETTER  [a-z_]
LETTER  [a-z_]
ID      ({LETTER}({LETTER}|{DIG})*|"<"{LETTER}({LETTER}|{DIG})*">")
ID      ({LETTER}({LETTER}|{DIG})*|"<"{LETTER}({LETTER}|{DIG})*">")
WHITE   [ \t\n]
WHITE   [ \t\n]
TICK    ("'"{WHITE}*)
TICK    ("'"{WHITE}*)
GRAPHIC [a-z0-9 #&'()*+,-./:;<>=_|!$%?@\[\]\\^`{}~]
GRAPHIC [a-z0-9 #&'()*+,-./:;<>=_|!$%?@\[\]\\^`{}~]
OPER    ([-+*/=<>&]|"<="|">="|"**"|"/="|"and"|"or"|"xor"|"not"|"mod"|"rem"|"abs")
OPER    ([-+*/=<>&]|"<="|">="|"**"|"/="|"and"|"or"|"xor"|"not"|"mod"|"rem"|"abs")
EXP     (e[+-]{NUM10})
EXP     (e[+-]{NUM10})
POSEXP  (e"+"?{NUM10})
POSEXP  (e"+"?{NUM10})
%{
%{
#define NUMERAL_WIDTH 256
#define NUMERAL_WIDTH 256
#define LONGEST_SIGN ((ULONGEST) 1 << (sizeof(LONGEST) * HOST_CHAR_BIT - 1))
#define LONGEST_SIGN ((ULONGEST) 1 << (sizeof(LONGEST) * HOST_CHAR_BIT - 1))
/* Temporary staging for numeric literals.  */
/* Temporary staging for numeric literals.  */
static char numbuf[NUMERAL_WIDTH];
static char numbuf[NUMERAL_WIDTH];
 static void canonicalizeNumeral (char *s1, const char *);
 static void canonicalizeNumeral (char *s1, const char *);
static struct stoken processString (const char*, int);
static struct stoken processString (const char*, int);
static int processInt (const char *, const char *, const char *);
static int processInt (const char *, const char *, const char *);
static int processReal (const char *);
static int processReal (const char *);
static struct stoken processId (const char *, int);
static struct stoken processId (const char *, int);
static int processAttribute (const char *);
static int processAttribute (const char *);
static int find_dot_all (const char *);
static int find_dot_all (const char *);
#undef YY_DECL
#undef YY_DECL
#define YY_DECL static int yylex ( void )
#define YY_DECL static int yylex ( void )
#undef YY_INPUT
#undef YY_INPUT
#define YY_INPUT(BUF, RESULT, MAX_SIZE) \
#define YY_INPUT(BUF, RESULT, MAX_SIZE) \
    if ( *lexptr == '\000' ) \
    if ( *lexptr == '\000' ) \
      (RESULT) = YY_NULL; \
      (RESULT) = YY_NULL; \
    else \
    else \
      { \
      { \
        *(BUF) = *lexptr; \
        *(BUF) = *lexptr; \
        (RESULT) = 1; \
        (RESULT) = 1; \
        lexptr += 1; \
        lexptr += 1; \
      }
      }
static int find_dot_all (const char *);
static int find_dot_all (const char *);
%}
%}
%option case-insensitive interactive nodefault
%option case-insensitive interactive nodefault
%s BEFORE_QUAL_QUOTE
%s BEFORE_QUAL_QUOTE
%%
%%
{WHITE}          { }
{WHITE}          { }
"--".*           { yyterminate(); }
"--".*           { yyterminate(); }
{NUM10}{POSEXP}  {
{NUM10}{POSEXP}  {
                   canonicalizeNumeral (numbuf, yytext);
                   canonicalizeNumeral (numbuf, yytext);
                   return processInt (NULL, numbuf, strrchr(numbuf, 'e')+1);
                   return processInt (NULL, numbuf, strrchr(numbuf, 'e')+1);
                 }
                 }
{NUM10}          {
{NUM10}          {
                   canonicalizeNumeral (numbuf, yytext);
                   canonicalizeNumeral (numbuf, yytext);
                   return processInt (NULL, numbuf, NULL);
                   return processInt (NULL, numbuf, NULL);
                 }
                 }
{NUM10}"#"{HEXDIG}({HEXDIG}|_)*"#"{POSEXP} {
{NUM10}"#"{HEXDIG}({HEXDIG}|_)*"#"{POSEXP} {
                   canonicalizeNumeral (numbuf, yytext);
                   canonicalizeNumeral (numbuf, yytext);
                   return processInt (numbuf,
                   return processInt (numbuf,
                                      strchr (numbuf, '#') + 1,
                                      strchr (numbuf, '#') + 1,
                                      strrchr(numbuf, '#') + 1);
                                      strrchr(numbuf, '#') + 1);
                 }
                 }
{NUM10}"#"{HEXDIG}({HEXDIG}|_)*"#" {
{NUM10}"#"{HEXDIG}({HEXDIG}|_)*"#" {
                   canonicalizeNumeral (numbuf, yytext);
                   canonicalizeNumeral (numbuf, yytext);
                   return processInt (numbuf, strchr (numbuf, '#') + 1, NULL);
                   return processInt (numbuf, strchr (numbuf, '#') + 1, NULL);
                 }
                 }
"0x"{HEXDIG}+   {
"0x"{HEXDIG}+   {
                  canonicalizeNumeral (numbuf, yytext+2);
                  canonicalizeNumeral (numbuf, yytext+2);
                  return processInt ("16#", numbuf, NULL);
                  return processInt ("16#", numbuf, NULL);
                }
                }
{NUM10}"."{NUM10}{EXP} {
{NUM10}"."{NUM10}{EXP} {
                   canonicalizeNumeral (numbuf, yytext);
                   canonicalizeNumeral (numbuf, yytext);
                   return processReal (numbuf);
                   return processReal (numbuf);
                }
                }
{NUM10}"."{NUM10} {
{NUM10}"."{NUM10} {
                   canonicalizeNumeral (numbuf, yytext);
                   canonicalizeNumeral (numbuf, yytext);
                   return processReal (numbuf);
                   return processReal (numbuf);
                }
                }
{NUM10}"#"{NUM16}"."{NUM16}"#"{EXP} {
{NUM10}"#"{NUM16}"."{NUM16}"#"{EXP} {
                   error (_("Based real literals not implemented yet."));
                   error (_("Based real literals not implemented yet."));
                }
                }
{NUM10}"#"{NUM16}"."{NUM16}"#" {
{NUM10}"#"{NUM16}"."{NUM16}"#" {
                   error (_("Based real literals not implemented yet."));
                   error (_("Based real literals not implemented yet."));
                }
                }
"'"({GRAPHIC}|\")"'" {
"'"({GRAPHIC}|\")"'" {
                   yylval.typed_val.type = type_char ();
                   yylval.typed_val.type = type_char ();
                   yylval.typed_val.val = yytext[1];
                   yylval.typed_val.val = yytext[1];
                   return CHARLIT;
                   return CHARLIT;
                }
                }
"'[\""{HEXDIG}{2}"\"]'"   {
"'[\""{HEXDIG}{2}"\"]'"   {
                   int v;
                   int v;
                   yylval.typed_val.type = type_char ();
                   yylval.typed_val.type = type_char ();
                   sscanf (yytext+3, "%2x", &v);
                   sscanf (yytext+3, "%2x", &v);
                   yylval.typed_val.val = v;
                   yylval.typed_val.val = v;
                   return CHARLIT;
                   return CHARLIT;
                }
                }
\"({GRAPHIC}|"[\""({HEXDIG}{2}|\")"\"]")*\"   {
\"({GRAPHIC}|"[\""({HEXDIG}{2}|\")"\"]")*\"   {
                   yylval.sval = processString (yytext+1, yyleng-2);
                   yylval.sval = processString (yytext+1, yyleng-2);
                   return STRING;
                   return STRING;
                }
                }
\"              {
\"              {
                   error (_("ill-formed or non-terminated string literal"));
                   error (_("ill-formed or non-terminated string literal"));
                }
                }
if              {
if              {
                  while (*lexptr != 'i' && *lexptr != 'I')
                  while (*lexptr != 'i' && *lexptr != 'I')
                    lexptr -= 1;
                    lexptr -= 1;
                  yyrestart(NULL);
                  yyrestart(NULL);
                  return 0;
                  return 0;
                }
                }
        /* ADA KEYWORDS */
        /* ADA KEYWORDS */
abs             { return ABS; }
abs             { return ABS; }
and             { return _AND_; }
and             { return _AND_; }
else            { return ELSE; }
else            { return ELSE; }
in              { return IN; }
in              { return IN; }
mod             { return MOD; }
mod             { return MOD; }
new             { return NEW; }
new             { return NEW; }
not             { return NOT; }
not             { return NOT; }
null            { return NULL_PTR; }
null            { return NULL_PTR; }
or              { return OR; }
or              { return OR; }
others          { return OTHERS; }
others          { return OTHERS; }
rem             { return REM; }
rem             { return REM; }
then            { return THEN; }
then            { return THEN; }
xor             { return XOR; }
xor             { return XOR; }
        /* ATTRIBUTES */
        /* ATTRIBUTES */
{TICK}[a-zA-Z][a-zA-Z]+ { return processAttribute (yytext+1); }
{TICK}[a-zA-Z][a-zA-Z]+ { return processAttribute (yytext+1); }
        /* PUNCTUATION */
        /* PUNCTUATION */
"=>"            { return ARROW; }
"=>"            { return ARROW; }
".."            { return DOTDOT; }
".."            { return DOTDOT; }
"**"            { return STARSTAR; }
"**"            { return STARSTAR; }
":="            { return ASSIGN; }
":="            { return ASSIGN; }
"/="            { return NOTEQUAL; }
"/="            { return NOTEQUAL; }
"<="            { return LEQ; }
"<="            { return LEQ; }
">="            { return GEQ; }
">="            { return GEQ; }
"'" { BEGIN INITIAL; return '\''; }
"'" { BEGIN INITIAL; return '\''; }
[-&*+./:<>=|;\[\]] { return yytext[0]; }
[-&*+./:<>=|;\[\]] { return yytext[0]; }
","             { if (paren_depth == 0 && comma_terminates)
","             { if (paren_depth == 0 && comma_terminates)
                    {
                    {
                      lexptr -= 1;
                      lexptr -= 1;
                      yyrestart(NULL);
                      yyrestart(NULL);
                      return 0;
                      return 0;
                    }
                    }
                  else
                  else
                    return ',';
                    return ',';
                }
                }
"("             { paren_depth += 1; return '('; }
"("             { paren_depth += 1; return '('; }
")"             { if (paren_depth == 0)
")"             { if (paren_depth == 0)
                    {
                    {
                      lexptr -= 1;
                      lexptr -= 1;
                      yyrestart(NULL);
                      yyrestart(NULL);
                      return 0;
                      return 0;
                    }
                    }
                  else
                  else
                    {
                    {
                      paren_depth -= 1;
                      paren_depth -= 1;
                      return ')';
                      return ')';
                    }
                    }
                }
                }
"."{WHITE}*all  { return DOT_ALL; }
"."{WHITE}*all  { return DOT_ALL; }
"."{WHITE}*{ID} {
"."{WHITE}*{ID} {
                  yylval.sval = processId (yytext+1, yyleng-1);
                  yylval.sval = processId (yytext+1, yyleng-1);
                  return DOT_ID;
                  return DOT_ID;
                }
                }
{ID}({WHITE}*"."{WHITE}*({ID}|\"{OPER}\"))*(" "*"'")?  {
{ID}({WHITE}*"."{WHITE}*({ID}|\"{OPER}\"))*(" "*"'")?  {
                  int all_posn = find_dot_all (yytext);
                  int all_posn = find_dot_all (yytext);
                  if (all_posn == -1 && yytext[yyleng-1] == '\'')
                  if (all_posn == -1 && yytext[yyleng-1] == '\'')
                    {
                    {
                      BEGIN BEFORE_QUAL_QUOTE;
                      BEGIN BEFORE_QUAL_QUOTE;
                      yyless (yyleng-1);
                      yyless (yyleng-1);
                    }
                    }
                  else if (all_posn >= 0)
                  else if (all_posn >= 0)
                    yyless (all_posn);
                    yyless (all_posn);
                  yylval.sval = processId (yytext, yyleng);
                  yylval.sval = processId (yytext, yyleng);
                  return NAME;
                  return NAME;
               }
               }
        /* GDB EXPRESSION CONSTRUCTS  */
        /* GDB EXPRESSION CONSTRUCTS  */
"'"[^']+"'"{WHITE}*:: {
"'"[^']+"'"{WHITE}*:: {
                  yyless (yyleng - 2);
                  yyless (yyleng - 2);
                  yylval.sval = processId (yytext, yyleng);
                  yylval.sval = processId (yytext, yyleng);
                  return NAME;
                  return NAME;
                }
                }
"::"            { return COLONCOLON; }
"::"            { return COLONCOLON; }
[{}@]           { return yytext[0]; }
[{}@]           { return yytext[0]; }
        /* REGISTERS AND GDB CONVENIENCE VARIABLES */
        /* REGISTERS AND GDB CONVENIENCE VARIABLES */
"$"({LETTER}|{DIG}|"$")*  {
"$"({LETTER}|{DIG}|"$")*  {
                  yylval.sval.ptr = yytext;
                  yylval.sval.ptr = yytext;
                  yylval.sval.length = yyleng;
                  yylval.sval.length = yyleng;
                  return SPECIAL_VARIABLE;
                  return SPECIAL_VARIABLE;
                }
                }
        /* CATCH-ALL ERROR CASE */
        /* CATCH-ALL ERROR CASE */
.               { error (_("Invalid character '%s' in expression."), yytext); }
.               { error (_("Invalid character '%s' in expression."), yytext); }
%%
%%
#include 
#include 
#include "gdb_string.h"
#include "gdb_string.h"
/* Initialize the lexer for processing new expression. */
/* Initialize the lexer for processing new expression. */
void
void
lexer_init (FILE *inp)
lexer_init (FILE *inp)
{
{
  BEGIN INITIAL;
  BEGIN INITIAL;
  yyrestart (inp);
  yyrestart (inp);
}
}
/* Copy S2 to S1, removing all underscores, and downcasing all letters.  */
/* Copy S2 to S1, removing all underscores, and downcasing all letters.  */
static void
static void
canonicalizeNumeral (char *s1, const char *s2)
canonicalizeNumeral (char *s1, const char *s2)
{
{
  for (; *s2 != '\000'; s2 += 1)
  for (; *s2 != '\000'; s2 += 1)
    {
    {
      if (*s2 != '_')
      if (*s2 != '_')
        {
        {
          *s1 = tolower(*s2);
          *s1 = tolower(*s2);
          s1 += 1;
          s1 += 1;
        }
        }
    }
    }
  s1[0] = '\000';
  s1[0] = '\000';
}
}
/* Interprets the prefix of NUM that consists of digits of the given BASE
/* Interprets the prefix of NUM that consists of digits of the given BASE
   as an integer of that BASE, with the string EXP as an exponent.
   as an integer of that BASE, with the string EXP as an exponent.
   Puts value in yylval, and returns INT, if the string is valid.  Causes
   Puts value in yylval, and returns INT, if the string is valid.  Causes
   an error if the number is improperly formated.   BASE, if NULL, defaults
   an error if the number is improperly formated.   BASE, if NULL, defaults
   to "10", and EXP to "1".  The EXP does not contain a leading 'e' or 'E'.
   to "10", and EXP to "1".  The EXP does not contain a leading 'e' or 'E'.
 */
 */
static int
static int
processInt (const char *base0, const char *num0, const char *exp0)
processInt (const char *base0, const char *num0, const char *exp0)
{
{
  ULONGEST result;
  ULONGEST result;
  long exp;
  long exp;
  int base;
  int base;
  char *trailer;
  char *trailer;
  if (base0 == NULL)
  if (base0 == NULL)
    base = 10;
    base = 10;
  else
  else
    {
    {
      base = strtol (base0, (char **) NULL, 10);
      base = strtol (base0, (char **) NULL, 10);
      if (base < 2 || base > 16)
      if (base < 2 || base > 16)
        error (_("Invalid base: %d."), base);
        error (_("Invalid base: %d."), base);
    }
    }
  if (exp0 == NULL)
  if (exp0 == NULL)
    exp = 0;
    exp = 0;
  else
  else
    exp = strtol(exp0, (char **) NULL, 10);
    exp = strtol(exp0, (char **) NULL, 10);
  errno = 0;
  errno = 0;
  result = strtoulst (num0, (const char **) &trailer, base);
  result = strtoulst (num0, (const char **) &trailer, base);
  if (errno == ERANGE)
  if (errno == ERANGE)
    error (_("Integer literal out of range"));
    error (_("Integer literal out of range"));
  if (isxdigit(*trailer))
  if (isxdigit(*trailer))
    error (_("Invalid digit `%c' in based literal"), *trailer);
    error (_("Invalid digit `%c' in based literal"), *trailer);
  while (exp > 0)
  while (exp > 0)
    {
    {
      if (result > (ULONG_MAX / base))
      if (result > (ULONG_MAX / base))
        error (_("Integer literal out of range"));
        error (_("Integer literal out of range"));
      result *= base;
      result *= base;
      exp -= 1;
      exp -= 1;
    }
    }
  if ((result >> (gdbarch_int_bit (current_gdbarch)-1)) == 0)
  if ((result >> (gdbarch_int_bit (current_gdbarch)-1)) == 0)
    yylval.typed_val.type = type_int ();
    yylval.typed_val.type = type_int ();
  else if ((result >> (gdbarch_long_bit (current_gdbarch)-1)) == 0)
  else if ((result >> (gdbarch_long_bit (current_gdbarch)-1)) == 0)
    yylval.typed_val.type = type_long ();
    yylval.typed_val.type = type_long ();
  else if (((result >> (gdbarch_long_bit (current_gdbarch)-1)) >> 1) == 0)
  else if (((result >> (gdbarch_long_bit (current_gdbarch)-1)) >> 1) == 0)
    {
    {
      /* We have a number representable as an unsigned integer quantity.
      /* We have a number representable as an unsigned integer quantity.
         For consistency with the C treatment, we will treat it as an
         For consistency with the C treatment, we will treat it as an
         anonymous modular (unsigned) quantity.  Alas, the types are such
         anonymous modular (unsigned) quantity.  Alas, the types are such
         that we need to store .val as a signed quantity.  Sorry
         that we need to store .val as a signed quantity.  Sorry
         for the mess, but C doesn't officially guarantee that a simple
         for the mess, but C doesn't officially guarantee that a simple
         assignment does the trick (no, it doesn't; read the reference manual).
         assignment does the trick (no, it doesn't; read the reference manual).
       */
       */
      yylval.typed_val.type = builtin_type_unsigned_long;
      yylval.typed_val.type = builtin_type_unsigned_long;
      if (result & LONGEST_SIGN)
      if (result & LONGEST_SIGN)
        yylval.typed_val.val =
        yylval.typed_val.val =
          (LONGEST) (result & ~LONGEST_SIGN)
          (LONGEST) (result & ~LONGEST_SIGN)
          - (LONGEST_SIGN>>1) - (LONGEST_SIGN>>1);
          - (LONGEST_SIGN>>1) - (LONGEST_SIGN>>1);
      else
      else
        yylval.typed_val.val = (LONGEST) result;
        yylval.typed_val.val = (LONGEST) result;
      return INT;
      return INT;
    }
    }
  else
  else
    yylval.typed_val.type = type_long_long ();
    yylval.typed_val.type = type_long_long ();
  yylval.typed_val.val = (LONGEST) result;
  yylval.typed_val.val = (LONGEST) result;
  return INT;
  return INT;
}
}
static int
static int
processReal (const char *num0)
processReal (const char *num0)
{
{
  sscanf (num0, "%" DOUBLEST_SCAN_FORMAT, &yylval.typed_val_float.dval);
  sscanf (num0, "%" DOUBLEST_SCAN_FORMAT, &yylval.typed_val_float.dval);
  yylval.typed_val_float.type = type_float ();
  yylval.typed_val_float.type = type_float ();
  if (sizeof(DOUBLEST) >= gdbarch_double_bit (current_gdbarch)
  if (sizeof(DOUBLEST) >= gdbarch_double_bit (current_gdbarch)
                            / TARGET_CHAR_BIT)
                            / TARGET_CHAR_BIT)
    yylval.typed_val_float.type = type_double ();
    yylval.typed_val_float.type = type_double ();
  if (sizeof(DOUBLEST) >= gdbarch_long_double_bit (current_gdbarch)
  if (sizeof(DOUBLEST) >= gdbarch_long_double_bit (current_gdbarch)
                            / TARGET_CHAR_BIT)
                            / TARGET_CHAR_BIT)
    yylval.typed_val_float.type = type_long_double ();
    yylval.typed_val_float.type = type_long_double ();
  return FLOAT;
  return FLOAT;
}
}
/* Store a canonicalized version of NAME0[0..LEN-1] in yylval.ssym.  The
/* Store a canonicalized version of NAME0[0..LEN-1] in yylval.ssym.  The
   resulting string is valid until the next call to ada_parse.  It differs
   resulting string is valid until the next call to ada_parse.  It differs
   from NAME0 in that:
   from NAME0 in that:
    + Characters between '...' or <...> are transfered verbatim to
    + Characters between '...' or <...> are transfered verbatim to
      yylval.ssym.
      yylval.ssym.
    + <, >, and trailing "'" characters in quoted sequences are removed
    + <, >, and trailing "'" characters in quoted sequences are removed
      (a leading quote is preserved to indicate that the name is not to be
      (a leading quote is preserved to indicate that the name is not to be
      GNAT-encoded).
      GNAT-encoded).
    + Unquoted whitespace is removed.
    + Unquoted whitespace is removed.
    + Unquoted alphabetic characters are mapped to lower case.
    + Unquoted alphabetic characters are mapped to lower case.
   Result is returned as a struct stoken, but for convenience, the string
   Result is returned as a struct stoken, but for convenience, the string
   is also null-terminated.  Result string valid until the next call of
   is also null-terminated.  Result string valid until the next call of
   ada_parse.
   ada_parse.
 */
 */
static struct stoken
static struct stoken
processId (const char *name0, int len)
processId (const char *name0, int len)
{
{
  char *name = obstack_alloc (&temp_parse_space, len + 11);
  char *name = obstack_alloc (&temp_parse_space, len + 11);
  int i0, i;
  int i0, i;
  struct stoken result;
  struct stoken result;
  while (len > 0 && isspace (name0[len-1]))
  while (len > 0 && isspace (name0[len-1]))
    len -= 1;
    len -= 1;
  i = i0 = 0;
  i = i0 = 0;
  while (i0 < len)
  while (i0 < len)
    {
    {
      if (isalnum (name0[i0]))
      if (isalnum (name0[i0]))
        {
        {
          name[i] = tolower (name0[i0]);
          name[i] = tolower (name0[i0]);
          i += 1; i0 += 1;
          i += 1; i0 += 1;
        }
        }
      else switch (name0[i0])
      else switch (name0[i0])
        {
        {
        default:
        default:
          name[i] = name0[i0];
          name[i] = name0[i0];
          i += 1; i0 += 1;
          i += 1; i0 += 1;
          break;
          break;
        case ' ': case '\t':
        case ' ': case '\t':
          i0 += 1;
          i0 += 1;
          break;
          break;
        case '\'':
        case '\'':
          do
          do
            {
            {
              name[i] = name0[i0];
              name[i] = name0[i0];
              i += 1; i0 += 1;
              i += 1; i0 += 1;
            }
            }
          while (i0 < len && name0[i0] != '\'');
          while (i0 < len && name0[i0] != '\'');
          i0 += 1;
          i0 += 1;
          break;
          break;
        case '<':
        case '<':
          i0 += 1;
          i0 += 1;
          while (i0 < len && name0[i0] != '>')
          while (i0 < len && name0[i0] != '>')
            {
            {
              name[i] = name0[i0];
              name[i] = name0[i0];
              i += 1; i0 += 1;
              i += 1; i0 += 1;
            }
            }
          i0 += 1;
          i0 += 1;
          break;
          break;
        }
        }
    }
    }
  name[i] = '\000';
  name[i] = '\000';
  result.ptr = name;
  result.ptr = name;
  result.length = i;
  result.length = i;
  return result;
  return result;
}
}
/* Return TEXT[0..LEN-1], a string literal without surrounding quotes,
/* Return TEXT[0..LEN-1], a string literal without surrounding quotes,
   with special hex character notations replaced with characters.
   with special hex character notations replaced with characters.
   Result valid until the next call to ada_parse.  */
   Result valid until the next call to ada_parse.  */
static struct stoken
static struct stoken
processString (const char *text, int len)
processString (const char *text, int len)
{
{
  const char *p;
  const char *p;
  char *q;
  char *q;
  const char *lim = text + len;
  const char *lim = text + len;
  struct stoken result;
  struct stoken result;
  q = result.ptr = obstack_alloc (&temp_parse_space, len);
  q = result.ptr = obstack_alloc (&temp_parse_space, len);
  p = text;
  p = text;
  while (p < lim)
  while (p < lim)
    {
    {
      if (p[0] == '[' && p[1] == '"' && p+2 < lim)
      if (p[0] == '[' && p[1] == '"' && p+2 < lim)
         {
         {
           if (p[2] == '"')  /* "...["""]... */
           if (p[2] == '"')  /* "...["""]... */
             {
             {
               *q = '"';
               *q = '"';
               p += 4;
               p += 4;
             }
             }
           else
           else
             {
             {
               int chr;
               int chr;
               sscanf (p+2, "%2x", &chr);
               sscanf (p+2, "%2x", &chr);
               *q = (char) chr;
               *q = (char) chr;
               p += 5;
               p += 5;
             }
             }
         }
         }
       else
       else
         *q = *p;
         *q = *p;
       q += 1;
       q += 1;
       p += 1;
       p += 1;
     }
     }
  result.length = q - result.ptr;
  result.length = q - result.ptr;
  return result;
  return result;
}
}
/* Returns the position within STR of the '.' in a
/* Returns the position within STR of the '.' in a
   '.{WHITE}*all' component of a dotted name, or -1 if there is none.
   '.{WHITE}*all' component of a dotted name, or -1 if there is none.
   Note: we actually don't need this routine, since 'all' can never be an
   Note: we actually don't need this routine, since 'all' can never be an
   Ada identifier.  Thus, looking up foo.all or foo.all.x as a name
   Ada identifier.  Thus, looking up foo.all or foo.all.x as a name
   must fail, and will eventually be interpreted as (foo).all or
   must fail, and will eventually be interpreted as (foo).all or
   (foo).all.x.  However, this does avoid an extraneous lookup. */
   (foo).all.x.  However, this does avoid an extraneous lookup. */
static int
static int
find_dot_all (const char *str)
find_dot_all (const char *str)
{
{
  int i;
  int i;
  for (i = 0; str[i] != '\000'; i += 1)
  for (i = 0; str[i] != '\000'; i += 1)
    {
    {
      if (str[i] == '.')
      if (str[i] == '.')
        {
        {
          int i0 = i;
          int i0 = i;
          do
          do
            i += 1;
            i += 1;
          while (isspace (str[i]));
          while (isspace (str[i]));
          if (strncmp (str+i, "all", 3) == 0
          if (strncmp (str+i, "all", 3) == 0
              && ! isalnum (str[i+3]) && str[i+3] != '_')
              && ! isalnum (str[i+3]) && str[i+3] != '_')
            return i0;
            return i0;
        }
        }
    }
    }
  return -1;
  return -1;
}
}
/* Returns non-zero iff string SUBSEQ matches a subsequence of STR, ignoring
/* Returns non-zero iff string SUBSEQ matches a subsequence of STR, ignoring
   case.  */
   case.  */
static int
static int
subseqMatch (const char *subseq, const char *str)
subseqMatch (const char *subseq, const char *str)
{
{
  if (subseq[0] == '\0')
  if (subseq[0] == '\0')
    return 1;
    return 1;
  else if (str[0] == '\0')
  else if (str[0] == '\0')
    return 0;
    return 0;
  else if (tolower (subseq[0]) == tolower (str[0]))
  else if (tolower (subseq[0]) == tolower (str[0]))
    return subseqMatch (subseq+1, str+1) || subseqMatch (subseq, str+1);
    return subseqMatch (subseq+1, str+1) || subseqMatch (subseq, str+1);
  else
  else
    return subseqMatch (subseq, str+1);
    return subseqMatch (subseq, str+1);
}
}
static struct { const char *name; int code; }
static struct { const char *name; int code; }
attributes[] = {
attributes[] = {
  { "address", TICK_ADDRESS },
  { "address", TICK_ADDRESS },
  { "unchecked_access", TICK_ACCESS },
  { "unchecked_access", TICK_ACCESS },
  { "unrestricted_access", TICK_ACCESS },
  { "unrestricted_access", TICK_ACCESS },
  { "access", TICK_ACCESS },
  { "access", TICK_ACCESS },
  { "first", TICK_FIRST },
  { "first", TICK_FIRST },
  { "last", TICK_LAST },
  { "last", TICK_LAST },
  { "length", TICK_LENGTH },
  { "length", TICK_LENGTH },
  { "max", TICK_MAX },
  { "max", TICK_MAX },
  { "min", TICK_MIN },
  { "min", TICK_MIN },
  { "modulus", TICK_MODULUS },
  { "modulus", TICK_MODULUS },
  { "pos", TICK_POS },
  { "pos", TICK_POS },
  { "range", TICK_RANGE },
  { "range", TICK_RANGE },
  { "size", TICK_SIZE },
  { "size", TICK_SIZE },
  { "tag", TICK_TAG },
  { "tag", TICK_TAG },
  { "val", TICK_VAL },
  { "val", TICK_VAL },
  { NULL, -1 }
  { NULL, -1 }
};
};
/* Return the syntactic code corresponding to the attribute name or
/* Return the syntactic code corresponding to the attribute name or
   abbreviation STR.  */
   abbreviation STR.  */
static int
static int
processAttribute (const char *str)
processAttribute (const char *str)
{
{
  int i, k;
  int i, k;
  for (i = 0; attributes[i].code != -1; i += 1)
  for (i = 0; attributes[i].code != -1; i += 1)
    if (strcasecmp (str, attributes[i].name) == 0)
    if (strcasecmp (str, attributes[i].name) == 0)
      return attributes[i].code;
      return attributes[i].code;
  for (i = 0, k = -1; attributes[i].code != -1; i += 1)
  for (i = 0, k = -1; attributes[i].code != -1; i += 1)
    if (subseqMatch (str, attributes[i].name))
    if (subseqMatch (str, attributes[i].name))
      {
      {
        if (k == -1)
        if (k == -1)
          k = i;
          k = i;
        else
        else
          error (_("ambiguous attribute name: `%s'"), str);
          error (_("ambiguous attribute name: `%s'"), str);
      }
      }
  if (k == -1)
  if (k == -1)
    error (_("unrecognized attribute: `%s'"), str);
    error (_("unrecognized attribute: `%s'"), str);
  return attributes[k].code;
  return attributes[k].code;
}
}
int
int
yywrap(void)
yywrap(void)
{
{
  return 1;
  return 1;
}
}
/* Dummy definition to suppress warnings about unused static definitions. */
/* Dummy definition to suppress warnings about unused static definitions. */
typedef void (*dummy_function) ();
typedef void (*dummy_function) ();
dummy_function ada_flex_use[] =
dummy_function ada_flex_use[] =
{
{
  (dummy_function) yyunput
  (dummy_function) yyunput
};
};
 
 

powered by: WebSVN 2.1.0

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