a68g-keywords.c

     
   1  //! @file a68g-keywords.c
   2  //! @author J. Marcel van der Veer
   3  
   4  //! @section Copyright
   5  //!
   6  //! This file is part of Algol68G - an Algol 68 compiler-interpreter.
   7  //! Copyright 2001-2024 J. Marcel van der Veer [algol68g@xs4all.nl].
   8  
   9  //! @section License
  10  //!
  11  //! This program is free software; you can redistribute it and/or modify it 
  12  //! under the terms of the GNU General Public License as published by the 
  13  //! Free Software Foundation; either version 3 of the License, or 
  14  //! (at your option) any later version.
  15  //!
  16  //! This program is distributed in the hope that it will be useful, but 
  17  //! WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 
  18  //! or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 
  19  //! more details. You should have received a copy of the GNU General Public 
  20  //! License along with this program. If not, see [http://www.gnu.org/licenses/].
  21  
  22  //! @section Synopsis
  23  //!
  24  //! Algol 68 keyword tables.
  25  
  26  #include "a68g.h"
  27  #include "a68g-parser.h"
  28  
  29  //! @brief Add token to the token tree.
  30  
  31  TOKEN_T *add_token (TOKEN_T ** p, char *t)
  32  {
  33    char *z = new_fixed_string (t);
  34    while (*p != NO_TOKEN) {
  35      int k = strcmp (z, TEXT (*p));
  36      if (k < 0) {
  37        p = &LESS (*p);
  38      } else if (k > 0) {
  39        p = &MORE (*p);
  40      } else {
  41        return *p;
  42      }
  43    }
  44    *p = (TOKEN_T *) get_fixed_heap_space ((size_t) SIZE_ALIGNED (TOKEN_T));
  45    TEXT (*p) = z;
  46    LESS (*p) = MORE (*p) = NO_TOKEN;
  47    return *p;
  48  }
  49  
  50  //! @brief Find keyword, from token name.
  51  
  52  KEYWORD_T *find_keyword (KEYWORD_T * p, char *t)
  53  {
  54    while (p != NO_KEYWORD) {
  55      int k = strcmp (t, TEXT (p));
  56      if (k < 0) {
  57        p = LESS (p);
  58      } else if (k > 0) {
  59        p = MORE (p);
  60      } else {
  61        return p;
  62      }
  63    }
  64    return NO_KEYWORD;
  65  }
  66  
  67  //! @brief Find keyword, from attribute.
  68  
  69  KEYWORD_T *find_keyword_from_attribute (KEYWORD_T * p, int a)
  70  {
  71    if (p == NO_KEYWORD) {
  72      return NO_KEYWORD;
  73    } else if (a == ATTRIBUTE (p)) {
  74      return p;
  75    } else {
  76      KEYWORD_T *z;
  77      if ((z = find_keyword_from_attribute (LESS (p), a)) != NO_KEYWORD) {
  78        return z;
  79      } else if ((z = find_keyword_from_attribute (MORE (p), a)) != NO_KEYWORD) {
  80        return z;
  81      } else {
  82        return NO_KEYWORD;
  83      }
  84    }
  85  }
  86  
  87  //! @brief Add keyword to the tree.
  88  
  89  void add_keyword (KEYWORD_T ** p, int a, char *t)
  90  {
  91    while (*p != NO_KEYWORD) {
  92      int k = strcmp (t, TEXT (*p));
  93      if (k < 0) {
  94        p = &LESS (*p);
  95      } else {
  96        p = &MORE (*p);
  97      }
  98    }
  99    *p = (KEYWORD_T *) get_fixed_heap_space ((size_t) SIZE_ALIGNED (KEYWORD_T));
 100    ATTRIBUTE (*p) = a;
 101    TEXT (*p) = t;
 102    LESS (*p) = MORE (*p) = NO_KEYWORD;
 103  }
 104  
 105  //! @brief Make tables of keywords and non-terminals.
 106  
 107  void set_up_tables (void)
 108  {
 109  // Entries are randomised to balance the tree.
 110    if (OPTION_STRICT (&A68_JOB) == A68_FALSE) {
 111      add_keyword (&A68 (top_keyword), ENVIRON_SYMBOL, "ENVIRON");
 112      add_keyword (&A68 (top_keyword), DOWNTO_SYMBOL, "DOWNTO");
 113      add_keyword (&A68 (top_keyword), UNTIL_SYMBOL, "UNTIL");
 114      add_keyword (&A68 (top_keyword), CLASS_SYMBOL, "CLASS");
 115      add_keyword (&A68 (top_keyword), NEW_SYMBOL, "NEW");
 116      add_keyword (&A68 (top_keyword), DIAGONAL_SYMBOL, "DIAG");
 117      add_keyword (&A68 (top_keyword), TRANSPOSE_SYMBOL, "TRNSP");
 118      add_keyword (&A68 (top_keyword), ROW_SYMBOL, "ROW");
 119      add_keyword (&A68 (top_keyword), COLUMN_SYMBOL, "COL");
 120      add_keyword (&A68 (top_keyword), CODE_SYMBOL, "CODE");
 121      add_keyword (&A68 (top_keyword), EDOC_SYMBOL, "EDOC");
 122      add_keyword (&A68 (top_keyword), ANDF_SYMBOL, "THEF");
 123      add_keyword (&A68 (top_keyword), ORF_SYMBOL, "ELSF");
 124      add_keyword (&A68 (top_keyword), ANDF_SYMBOL, "ANDTH");
 125      add_keyword (&A68 (top_keyword), ORF_SYMBOL, "OREL");
 126      add_keyword (&A68 (top_keyword), ANDF_SYMBOL, "ANDF");
 127      add_keyword (&A68 (top_keyword), ORF_SYMBOL, "ORF");
 128      add_keyword (&A68 (top_keyword), ALIF_SYMBOL, "ALIF");
 129    }
 130    add_keyword (&A68 (top_keyword), POINT_SYMBOL, ".");
 131    add_keyword (&A68 (top_keyword), COMPLEX_SYMBOL, "COMPLEX");
 132    add_keyword (&A68 (top_keyword), ACCO_SYMBOL, "{");
 133    add_keyword (&A68 (top_keyword), OCCA_SYMBOL, "}");
 134    add_keyword (&A68 (top_keyword), SOUND_SYMBOL, "SOUND");
 135    add_keyword (&A68 (top_keyword), COLON_SYMBOL, ":");
 136    add_keyword (&A68 (top_keyword), THEN_BAR_SYMBOL, "|");
 137    add_keyword (&A68 (top_keyword), SUB_SYMBOL, "[");
 138    add_keyword (&A68 (top_keyword), BY_SYMBOL, "BY");
 139    add_keyword (&A68 (top_keyword), OP_SYMBOL, "OP");
 140    add_keyword (&A68 (top_keyword), COMMA_SYMBOL, ",");
 141    add_keyword (&A68 (top_keyword), AT_SYMBOL, "AT");
 142    add_keyword (&A68 (top_keyword), PRIO_SYMBOL, "PRIO");
 143    add_keyword (&A68 (top_keyword), STYLE_I_COMMENT_SYMBOL, "CO");
 144    add_keyword (&A68 (top_keyword), END_SYMBOL, "END");
 145    add_keyword (&A68 (top_keyword), GO_SYMBOL, "GO");
 146    add_keyword (&A68 (top_keyword), TO_SYMBOL, "TO");
 147    add_keyword (&A68 (top_keyword), ELSE_BAR_SYMBOL, "|:");
 148    add_keyword (&A68 (top_keyword), THEN_SYMBOL, "THEN");
 149    add_keyword (&A68 (top_keyword), TRUE_SYMBOL, "TRUE");
 150    add_keyword (&A68 (top_keyword), PROC_SYMBOL, "PROC");
 151    add_keyword (&A68 (top_keyword), FOR_SYMBOL, "FOR");
 152    add_keyword (&A68 (top_keyword), GOTO_SYMBOL, "GOTO");
 153    add_keyword (&A68 (top_keyword), WHILE_SYMBOL, "WHILE");
 154    add_keyword (&A68 (top_keyword), IS_SYMBOL, ":=:");
 155    add_keyword (&A68 (top_keyword), ASSIGN_TO_SYMBOL, "=:");
 156    add_keyword (&A68 (top_keyword), COMPL_SYMBOL, "COMPL");
 157    add_keyword (&A68 (top_keyword), FROM_SYMBOL, "FROM");
 158    add_keyword (&A68 (top_keyword), BOLD_PRAGMAT_SYMBOL, "PRAGMAT");
 159    add_keyword (&A68 (top_keyword), BOLD_COMMENT_SYMBOL, "COMMENT");
 160    add_keyword (&A68 (top_keyword), DO_SYMBOL, "DO");
 161    add_keyword (&A68 (top_keyword), STYLE_II_COMMENT_SYMBOL, "#");
 162    add_keyword (&A68 (top_keyword), CASE_SYMBOL, "CASE");
 163    add_keyword (&A68 (top_keyword), LOC_SYMBOL, "LOC");
 164    add_keyword (&A68 (top_keyword), CHAR_SYMBOL, "CHAR");
 165    add_keyword (&A68 (top_keyword), ISNT_SYMBOL, ":/=:");
 166    add_keyword (&A68 (top_keyword), REF_SYMBOL, "REF");
 167    add_keyword (&A68 (top_keyword), NIL_SYMBOL, "NIL");
 168    add_keyword (&A68 (top_keyword), ASSIGN_SYMBOL, ":=");
 169    add_keyword (&A68 (top_keyword), FI_SYMBOL, "FI");
 170    add_keyword (&A68 (top_keyword), FILE_SYMBOL, "FILE");
 171    add_keyword (&A68 (top_keyword), PAR_SYMBOL, "PAR");
 172    add_keyword (&A68 (top_keyword), ASSERT_SYMBOL, "ASSERT");
 173    add_keyword (&A68 (top_keyword), OUSE_SYMBOL, "OUSE");
 174    add_keyword (&A68 (top_keyword), IN_SYMBOL, "IN");
 175    add_keyword (&A68 (top_keyword), LONG_SYMBOL, "LONG");
 176    add_keyword (&A68 (top_keyword), SEMI_SYMBOL, ";");
 177    add_keyword (&A68 (top_keyword), EMPTY_SYMBOL, "EMPTY");
 178    add_keyword (&A68 (top_keyword), MODE_SYMBOL, "MODE");
 179    add_keyword (&A68 (top_keyword), IF_SYMBOL, "IF");
 180    add_keyword (&A68 (top_keyword), OD_SYMBOL, "OD");
 181    add_keyword (&A68 (top_keyword), OF_SYMBOL, "OF");
 182    add_keyword (&A68 (top_keyword), STRUCT_SYMBOL, "STRUCT");
 183    add_keyword (&A68 (top_keyword), STYLE_I_PRAGMAT_SYMBOL, "PR");
 184    add_keyword (&A68 (top_keyword), BUS_SYMBOL, "]");
 185    add_keyword (&A68 (top_keyword), SKIP_SYMBOL, "SKIP");
 186    add_keyword (&A68 (top_keyword), SHORT_SYMBOL, "SHORT");
 187    add_keyword (&A68 (top_keyword), IS_SYMBOL, "IS");
 188    add_keyword (&A68 (top_keyword), ESAC_SYMBOL, "ESAC");
 189    add_keyword (&A68 (top_keyword), CHANNEL_SYMBOL, "CHANNEL");
 190    add_keyword (&A68 (top_keyword), REAL_SYMBOL, "REAL");
 191    add_keyword (&A68 (top_keyword), STRING_SYMBOL, "STRING");
 192    add_keyword (&A68 (top_keyword), BOOL_SYMBOL, "BOOL");
 193    add_keyword (&A68 (top_keyword), ISNT_SYMBOL, "ISNT");
 194    add_keyword (&A68 (top_keyword), FALSE_SYMBOL, "FALSE");
 195    add_keyword (&A68 (top_keyword), UNION_SYMBOL, "UNION");
 196    add_keyword (&A68 (top_keyword), OUT_SYMBOL, "OUT");
 197    add_keyword (&A68 (top_keyword), OPEN_SYMBOL, "(");
 198    add_keyword (&A68 (top_keyword), BEGIN_SYMBOL, "BEGIN");
 199    add_keyword (&A68 (top_keyword), FLEX_SYMBOL, "FLEX");
 200    add_keyword (&A68 (top_keyword), VOID_SYMBOL, "VOID");
 201    add_keyword (&A68 (top_keyword), BITS_SYMBOL, "BITS");
 202    add_keyword (&A68 (top_keyword), ELSE_SYMBOL, "ELSE");
 203    add_keyword (&A68 (top_keyword), EXIT_SYMBOL, "EXIT");
 204    add_keyword (&A68 (top_keyword), HEAP_SYMBOL, "HEAP");
 205    add_keyword (&A68 (top_keyword), INT_SYMBOL, "INT");
 206    add_keyword (&A68 (top_keyword), BYTES_SYMBOL, "BYTES");
 207    add_keyword (&A68 (top_keyword), PIPE_SYMBOL, "PIPE");
 208    add_keyword (&A68 (top_keyword), FORMAT_SYMBOL, "FORMAT");
 209    add_keyword (&A68 (top_keyword), SEMA_SYMBOL, "SEMA");
 210    add_keyword (&A68 (top_keyword), CLOSE_SYMBOL, ")");
 211    add_keyword (&A68 (top_keyword), AT_SYMBOL, "@");
 212    add_keyword (&A68 (top_keyword), ELIF_SYMBOL, "ELIF");
 213    add_keyword (&A68 (top_keyword), FORMAT_DELIMITER_SYMBOL, "$");
 214  }