hc
2024-03-22 a0752693d998599af469473b8dc239ef973a012f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/* Abstract syntax tree
 *
 * SOFTWARE RIGHTS
 *
 * We reserve no LEGAL rights to the Purdue Compiler Construction Tool
 * Set (PCCTS) -- PCCTS is in the public domain.  An individual or
 * company may do whatever they wish with source code distributed with
 * PCCTS or the code generated by PCCTS, including the incorporation of
 * PCCTS, or its output, into commerical software.
 *
 * We encourage users to develop software with PCCTS.  However, we do ask
 * that credit is given to us for developing PCCTS.  By "credit",
 * we mean that if you incorporate our source code into one of your
 * programs (commercial product, research project, or otherwise) that you
 * acknowledge this fact somewhere in the documentation, research report,
 * etc...  If you like PCCTS and have developed a nice tool with the
 * output, please mention that you developed it using PCCTS.  In
 * addition, we ask that this header remain intact in our source code.
 * As long as these guidelines are kept, we expect to continue enhancing
 * this system and expect to make other tools available as they are
 * completed.
 *
 * ANTLR 1.33
 * Terence Parr
 * Parr Research Corporation
 * with Purdue University and AHPCRC, University of Minnesota
 * 1989-2000
 */
 
#ifndef ASTBase_H
#define ASTBase_H
 
#include "pcctscfg.h"
 
#include "pccts_stdio.h"
#include "pccts_stdlib.h"
 
PCCTS_NAMESPACE_STD
 
#ifndef PCCTS_NOT_USING_SOR
#include "PCCTSAST.h"
#endif
 
/*
 * Notes:
 *
 * To specify a copy constructor, subclass one of these classes and
 * give the copy constructor.  To use dup(), you must define shallowCopy().
 * shallowCopy() can use either a copy constructor or just copy the node
 * itself.
 */
 
#ifdef PCCTS_NOT_USING_SOR
class DllExportPCCTS ASTBase {
#else
class DllExportPCCTS ASTBase : public PCCTS_AST {
#endif
 
protected:
   ASTBase *_right, *_down;
 
public:
 
#ifdef PCCTS_NOT_USING_SOR
   ASTBase *right()    { return _right; }
   ASTBase *down()        { return _down; }
   void setRight(ASTBase *t)    { _right = (ASTBase *)t; }
   void setDown(ASTBase *t)    { _down = (ASTBase *)t; }
#else
   PCCTS_AST *right()    { return _right; }    // define the SORCERER interface
   PCCTS_AST *down()    { return _down; }
   void setRight(PCCTS_AST *t)    { _right = (ASTBase *)t; }
   void setDown(PCCTS_AST *t)    { _down = (ASTBase *)t; }
#endif
   ASTBase() { _right = _down = NULL; }
   virtual ~ASTBase() { ; }
#ifndef PCCTS_NOT_USING_SOR
   virtual ASTBase *dup();
#endif
   void destroy();
   void preorder(void* pData = NULL /* MR23 */);
   static ASTBase *tmake(ASTBase *, ...);
   static void link(ASTBase **, ASTBase **, ASTBase **);
   void subchild(ASTBase **, ASTBase **, ASTBase **);
   void subroot(ASTBase **, ASTBase **, ASTBase **);
   virtual void preorder_action(void* /*pData*/ = NULL /* MR23 */) { ; }
   virtual void preorder_before_action(void* /*pData*/ = NULL /* MR23 */) { /* MR23 */ printMessage(stdout, " ("); }
   virtual void preorder_after_action(void* /*pData*/ = NULL /* MR23 */) { /* MR23 */ printMessage(stdout, " )"); }
    virtual void panic(const char *msg);         /* MR21 */
    virtual void reportOverwriteOfDownPointer(); /* MR21 */
#ifdef PCCTS_NOT_USING_SOR
   virtual int printMessage(FILE* pFile, const char* pFormat, ...); // MR23
#endif
};
 
class DllExportPCCTS ASTDoublyLinkedBase : public ASTBase {
protected:
    ASTDoublyLinkedBase *_left, *_up;
 
public:
  void double_link(ASTBase *left, ASTBase *up);
 
#ifndef PCCTS_NOT_USING_SOR
  virtual ASTBase *dup();
#endif
 
#ifdef PCCTS_NOT_USING_SOR
  ASTBase *left() { return _left; }
  ASTBase *up() { return _up; }
  void setLeft(ASTBase *t) { _left = (ASTDoublyLinkedBase *)t; }    // MR6
  void setUp(ASTBase *t)   { _up = (ASTDoublyLinkedBase *)t; }        // MR6
#else
  PCCTS_AST *left() { return _left; }
  PCCTS_AST *up() { return _up; }
  void setLeft(PCCTS_AST *t) { _left = (ASTDoublyLinkedBase *)t; }  // MR6
  void setUp(PCCTS_AST *t)   { _up = (ASTDoublyLinkedBase *)t; }    // MR6
#endif
 
};
 
class AST;    // announce that this class will be coming along shortly
#endif