xref: /aosp_15_r20/external/antlr/runtime/C/include/antlr3parsetree.h (revision 16467b971bd3e2009fad32dd79016f2c7e421deb)
1*16467b97STreehugger Robot /** \file
2*16467b97STreehugger Robot  *  Abstraction of Common tree to provide payload and string representation of node.
3*16467b97STreehugger Robot  *
4*16467b97STreehugger Robot  * \todo May not need this in the end
5*16467b97STreehugger Robot  */
6*16467b97STreehugger Robot 
7*16467b97STreehugger Robot #ifndef	ANTLR3_PARSETREE_H
8*16467b97STreehugger Robot #define	ANTLR3_PARSETREE_H
9*16467b97STreehugger Robot 
10*16467b97STreehugger Robot // [The "BSD licence"]
11*16467b97STreehugger Robot // Copyright (c) 2005-2009 Jim Idle, Temporal Wave LLC
12*16467b97STreehugger Robot // http://www.temporal-wave.com
13*16467b97STreehugger Robot // http://www.linkedin.com/in/jimidle
14*16467b97STreehugger Robot //
15*16467b97STreehugger Robot // All rights reserved.
16*16467b97STreehugger Robot //
17*16467b97STreehugger Robot // Redistribution and use in source and binary forms, with or without
18*16467b97STreehugger Robot // modification, are permitted provided that the following conditions
19*16467b97STreehugger Robot // are met:
20*16467b97STreehugger Robot // 1. Redistributions of source code must retain the above copyright
21*16467b97STreehugger Robot //    notice, this list of conditions and the following disclaimer.
22*16467b97STreehugger Robot // 2. Redistributions in binary form must reproduce the above copyright
23*16467b97STreehugger Robot //    notice, this list of conditions and the following disclaimer in the
24*16467b97STreehugger Robot //    documentation and/or other materials provided with the distribution.
25*16467b97STreehugger Robot // 3. The name of the author may not be used to endorse or promote products
26*16467b97STreehugger Robot //    derived from this software without specific prior written permission.
27*16467b97STreehugger Robot //
28*16467b97STreehugger Robot // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
29*16467b97STreehugger Robot // IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
30*16467b97STreehugger Robot // OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
31*16467b97STreehugger Robot // IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
32*16467b97STreehugger Robot // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
33*16467b97STreehugger Robot // NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
34*16467b97STreehugger Robot // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
35*16467b97STreehugger Robot // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
36*16467b97STreehugger Robot // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
37*16467b97STreehugger Robot // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
38*16467b97STreehugger Robot 
39*16467b97STreehugger Robot #include    <antlr3basetree.h>
40*16467b97STreehugger Robot 
41*16467b97STreehugger Robot #ifdef __cplusplus
42*16467b97STreehugger Robot extern "C" {
43*16467b97STreehugger Robot #endif
44*16467b97STreehugger Robot 
45*16467b97STreehugger Robot typedef struct ANTLR3_PARSE_TREE_struct
46*16467b97STreehugger Robot {
47*16467b97STreehugger Robot     /** Any interface that implements methods in this interface
48*16467b97STreehugger Robot      *  may need to point back to itself using this pointer to its
49*16467b97STreehugger Robot      *  super structure.
50*16467b97STreehugger Robot      */
51*16467b97STreehugger Robot     void    * super;
52*16467b97STreehugger Robot 
53*16467b97STreehugger Robot     /** The payload that the parse tree node passes around
54*16467b97STreehugger Robot      */
55*16467b97STreehugger Robot     void    * payload;
56*16467b97STreehugger Robot 
57*16467b97STreehugger Robot     /** An encapsulated BASE TREE strcuture (NOT a pointer)
58*16467b97STreehugger Robot       * that perfoms a lot of the dirty work of node management
59*16467b97STreehugger Robot       */
60*16467b97STreehugger Robot     ANTLR3_BASE_TREE	    baseTree;
61*16467b97STreehugger Robot 
62*16467b97STreehugger Robot     /** How to dup this node
63*16467b97STreehugger Robot      */
64*16467b97STreehugger Robot     pANTLR3_BASE_TREE	    (*dupNode)	(struct ANTLR3_PARSE_TREE_struct * tree);
65*16467b97STreehugger Robot 
66*16467b97STreehugger Robot     /** Return the type of this node
67*16467b97STreehugger Robot      */
68*16467b97STreehugger Robot     ANTLR3_UINT32	    (*getType)	(struct ANTLR3_PARSE_TREE_struct * tree);
69*16467b97STreehugger Robot 
70*16467b97STreehugger Robot     /** Return the string representation of the payload (must be installed
71*16467b97STreehugger Robot      *  when the payload is added and point to a function that knwos how to
72*16467b97STreehugger Robot      *  manifest a pANTLR3_STRING from a node.
73*16467b97STreehugger Robot      */
74*16467b97STreehugger Robot     pANTLR3_STRING	    (*toString)	(struct ANTLR3_PARSE_TREE_struct * payload);
75*16467b97STreehugger Robot 
76*16467b97STreehugger Robot     void		    (*free)	(struct ANTLR3_PARSE_TREE_struct * tree);
77*16467b97STreehugger Robot 
78*16467b97STreehugger Robot }
79*16467b97STreehugger Robot     ANTLR3_PARSE_TREE;
80*16467b97STreehugger Robot 
81*16467b97STreehugger Robot #ifdef __cplusplus
82*16467b97STreehugger Robot }
83*16467b97STreehugger Robot #endif
84*16467b97STreehugger Robot 
85*16467b97STreehugger Robot #endif
86