Fix: parsing .eh_frame on binaries without .debug_frame.
[dyninst.git] / dataflowAPI / doc / AST.tex
1 \subsection{Class AST}
2 \label{sec:ast}
3 \definedin{DynAST.h}
4
5 We provide a generic AST framework to represent tree structures. 
6 One example use case is to represent instruction semantics with symbolic expressions. 
7 The AST framework includes the base class definitions for tree nodes and visitors.
8 Users can inherit tree node classes to create their own AST structure and 
9 AST visitors to write their own analyses for the AST. 
10
11 All AST node classes should be derived from the AST class.  Currently we have the
12 following types of AST nodes.
13
14 \begin{center}
15 \begin{tabular}{ll}
16 \toprule
17 AST::ID  & Meaning \\
18 \midrule 
19     V\_AST & Base class type \\
20     V\_BottomAST & Bottom AST node \\
21     V\_ConstantAST & Constant AST node \\
22     V\_VariableAST & Variable AST node \\
23     V\_RoseAST & ROSEOperation AST node \\
24     V\_StackAST & Stack AST node \\
25 \bottomrule
26 \end{tabular}
27 \end{center}
28
29 \begin{apient}
30 typedef boost::shared_ptr<AST> Ptr;
31 \end{apient}
32 \apidesc{Shared pointer for class AST.}
33
34 \begin{apient}
35 typedef std::vector<AST::Ptr> Children;      
36 \end{apient}
37 \apidesc{The container type for the children of this AST.}
38
39 \begin{apient}
40 bool operator==(const AST &rhs) const; 
41 bool equals(AST::Ptr rhs);
42 \end{apient}
43 \apidesc{Check whether two AST nodes are equal. Return \code{true} when two
44 nodes are in the same type and are equal according to the \code{==} operator of that type.}
45
46 \begin{apient}
47 virtual unsigned numChildren() const; 
48 \end{apient}
49 \apidesc{Return the number of children of this node.}
50
51 \begin{apient}
52 virtual AST::Ptr child(unsigned i) const;
53 \end{apient}
54 \apidesc{Return the \code{i}th child.}
55  
56 \begin{apient}
57 virtual const std::string format() const = 0;
58 \end{apient}
59 \apidesc{Return the string representation of the node.}
60
61 \begin{apient}
62 static AST::Ptr substitute(AST::Ptr in, AST::Ptr a, AST::Ptr b); 
63 \end{apient}
64 \apidesc{Substitute every occurrence of \code{a} with \code{b} in AST \code{in}.
65 Return a new AST after the substitution.}
66
67 \begin{apient} 
68 virtual AST::ID AST::getID() const;
69 \end{apient}
70 \apidesc{Return the class type ID of this node.}
71
72 \begin{apient}
73 virtual Ptr accept(ASTVisitor *v);
74 \end{apient}
75 \apidesc{Apply visitor \code{v} to this node. Note that this method will not
76 automatically apply the visitor to its children.}
77
78 \begin{apient}
79 virtual void AST::setChild(int i, AST::Ptr c);
80 \end{apient}
81 \apidesc{Set the \code{i}th child of this node to \code{c}.}