home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / bsd_srcs / usr.bin / pascal / src / yyprint.c < prev    next >
Encoding:
C/C++ Source or Header  |  1991-04-16  |  3.6 KB  |  132 lines

  1. /*-
  2.  * Copyright (c) 1980 The Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice, this list of conditions and the following disclaimer.
  10.  * 2. Redistributions in binary form must reproduce the above copyright
  11.  *    notice, this list of conditions and the following disclaimer in the
  12.  *    documentation and/or other materials provided with the distribution.
  13.  * 3. All advertising materials mentioning features or use of this software
  14.  *    must display the following acknowledgement:
  15.  *    This product includes software developed by the University of
  16.  *    California, Berkeley and its contributors.
  17.  * 4. Neither the name of the University nor the names of its contributors
  18.  *    may be used to endorse or promote products derived from this software
  19.  *    without specific prior written permission.
  20.  *
  21.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31.  * SUCH DAMAGE.
  32.  */
  33.  
  34. #ifndef lint
  35. static char sccsid[] = "@(#)yyprint.c    5.2 (Berkeley) 4/16/91";
  36. #endif /* not lint */
  37.  
  38. #include "whoami.h"
  39. #include "0.h"
  40. #include "tree_ty.h"    /* must be included for yy.h */
  41. #include "yy.h"
  42.  
  43. char    *tokname();
  44.  
  45. STATIC    short bounce;
  46.  
  47. /*
  48.  * Printing representation of a
  49.  * "character" - a lexical token
  50.  * not in a yytok structure.
  51.  * 'which' indicates which char * you want
  52.  * should always be called as "charname(...,0),charname(...,1)"
  53.  */
  54. char *
  55. charname(ch , which )
  56.     int ch;
  57.     int which;
  58. {
  59.     struct yytok Ych;
  60.  
  61.     Ych.Yychar = ch;
  62.     Ych.Yylval = nullsem(ch);
  63.     return (tokname(&Ych , which ));
  64. }
  65.  
  66. /*
  67.  * Printing representation of a token
  68.  * 'which' as above.
  69.  */
  70. char *
  71. tokname(tp , which )
  72.     register struct yytok *tp;
  73.     int               which;
  74. {
  75.     register char *cp;
  76.     register struct kwtab *kp;
  77.     char    *cp2;
  78.  
  79.     cp2 = "";
  80.     switch (tp->Yychar) {
  81.         case YCASELAB:
  82.             cp = "case-label";
  83.             break;
  84.         case YEOF:
  85.             cp = "end-of-file";
  86.             break;
  87.         case YILLCH:
  88.             cp = "illegal character";
  89.             break;
  90.         case 256:
  91.             /* error token */
  92.             cp = "error";
  93.             break;
  94.         case YID:
  95.             cp = "identifier";
  96.             break;
  97.         case YNUMB:
  98.             cp = "real number";
  99.             break;
  100.         case YINT:
  101.         case YBINT:
  102.             cp = "number";
  103.             break;
  104.         case YSTRING:
  105.             cp = (char *) tp->Yylval;
  106.             cp = cp == NIL || cp[1] == 0 ? "character" : "string";
  107.             break;
  108.         case YDOTDOT:
  109.             cp = "'..'";
  110.             break;
  111.         default:
  112.             if (tp->Yychar < 256) {
  113.                 cp = "'x'\0'x'\0'x'\0'x'";
  114.                 /*
  115.                  * for four times reentrant code!
  116.                  * used to be:
  117.                  * if (bounce = ((bounce + 1) & 1))
  118.                  *    cp += 4;
  119.                  */
  120.                 bounce = ( bounce + 1 ) % 4;
  121.                 cp += (4 * bounce);    /* 'x'\0 is 4 chars */
  122.                 cp[1] = tp->Yychar;
  123.                 break;
  124.             }
  125.             for (kp = yykey; kp->kw_str != NIL && kp->kw_val != tp->Yychar; kp++)
  126.                 continue;
  127.             cp = "keyword ";
  128.             cp2 = kp->kw_str;
  129.     }
  130.     return ( which ? cp2 : cp );
  131. }
  132.