source: icGREP/icgrep-devel/icgrep/pablo/builder.hpp @ 5160

Last change on this file since 5160 was 5160, checked in by nmedfort, 3 years ago

Initial work for incorporating Types into Pablo AST.

File size: 8.8 KB
Line 
1#ifndef BUILDER_HPP
2#define BUILDER_HPP
3
4#include <pablo/codegenstate.h>
5#include <pablo/expression_map.hpp>
6
7namespace pablo {
8
9class PabloBuilder {
10public:
11
12    explicit PabloBuilder(PabloBlock * block) : mPb(block), mParent(nullptr), mExprTable(nullptr) {}
13
14    explicit PabloBuilder(PabloBlock * block, PabloBuilder & parent) : mPb(block), mParent(&parent), mExprTable(&(parent.mExprTable)) {}
15
16    PabloBuilder(PabloBuilder && builder) : mPb(builder.mPb), mParent(builder.mParent), mExprTable(std::move(builder.mExprTable)) {}
17
18    PabloBuilder & operator=(PabloBuilder) = delete;
19
20    PabloBuilder & operator=(PabloBuilder &) = delete;
21
22    PabloBuilder & operator=(PabloBuilder && builder) {
23        mPb = builder.mPb;
24        mParent = builder.mParent;
25        mExprTable = std::move(builder.mExprTable);
26        return *this;
27    }
28
29    using iterator = PabloBlock::iterator;
30
31    using const_iterator = PabloBlock::const_iterator;
32
33    inline static PabloBuilder Create(PabloBlock * block) noexcept {
34        return PabloBuilder(block);
35    }
36
37    inline static PabloBuilder Create(PabloBuilder & builder) noexcept {
38        return PabloBuilder(PabloBlock::Create(builder.getPabloBlock()), builder);
39    }
40
41    inline Zeroes * createZeroes(const PabloType * const type = nullptr) {
42        return mPb->createZeroes(type);
43    }
44
45    inline Ones * createOnes(const PabloType * const type = nullptr) {
46        return mPb->createOnes(type);
47    }
48
49    inline Var * createVar(const std::string name, const PabloType * const type) {
50        return mPb->createVar(name, type);
51    }
52
53    inline Var * createVar(String * const name, const PabloType * const type) {
54        return mPb->createVar(name, type);
55    }
56
57    inline Var * createVar(PabloAST * const name, const PabloType * const type) {
58        return mPb->createVar(name, type);
59    }
60
61    inline Call * createCall(Prototype * prototype, const std::vector<Var *> & args) {
62        return createCall(prototype, reinterpret_cast<const std::vector<PabloAST *> &>(args));
63    }
64
65    Call * createCall(Prototype * prototype, const std::vector<PabloAST *> &vars);
66
67    Assign * createAssign(const std::string && prefix, PabloAST * expr) {
68        return mPb->createAssign(std::move(prefix), expr);
69    }
70
71    inline PabloAST * createAdvance(PabloAST * expr, const Integer::Type shiftAmount) {
72        if (shiftAmount == 0) {
73            return expr;
74        }
75        return createAdvance(expr, mPb->getInteger(shiftAmount));
76    }
77
78    PabloAST * createAdvance(PabloAST * expr, PabloAST * shiftAmount);
79
80    inline PabloAST * createAdvance(PabloAST * expr, const Integer::Type shiftAmount, const std::string prefix) {
81        if (shiftAmount == 0) {
82            return expr;
83        }
84        return createAdvance(expr, mPb->getInteger(shiftAmount), prefix);
85    }
86
87    PabloAST * createAdvance(PabloAST * expr, PabloAST * shiftAmount, const std::string prefix);
88
89    inline PabloAST * createLookahead(PabloAST * expr, const Integer::Type shiftAmount) {
90        if (shiftAmount == 0) {
91            return expr;
92        }
93        return createLookahead(expr, mPb->getInteger(shiftAmount));
94    }
95
96    PabloAST * createLookahead(PabloAST * expr, PabloAST * shiftAmount);
97
98    inline PabloAST * createLookahead(PabloAST * expr, const Integer::Type shiftAmount, const std::string prefix) {
99        if (shiftAmount == 0) {
100            return expr;
101        }
102        return createLookahead(expr, mPb->getInteger(shiftAmount), prefix);
103    }
104
105    PabloAST * createLookahead(PabloAST * expr, PabloAST * shiftAmount, const std::string prefix);
106
107    inline Next * createNext(Assign * assign, PabloAST * expr) {
108        return mPb->createNext(assign, expr);
109    }
110
111    PabloAST * createAnd(PabloAST * expr1, PabloAST * expr2);
112
113    PabloAST * createAnd(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
114
115    PabloAST * createNot(PabloAST * expr);
116
117    PabloAST * createNot(PabloAST * expr, const std::string prefix);
118
119    PabloAST * createOr(PabloAST * expr1, PabloAST * expr2);
120
121    PabloAST * createOr(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
122
123    PabloAST * createXor(PabloAST * expr1, PabloAST * expr2);
124
125    PabloAST * createXor(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
126
127    PabloAST * createMatchStar(PabloAST * marker, PabloAST * charclass);
128
129    PabloAST * createMatchStar(PabloAST * marker, PabloAST * charclass, const std::string prefix);
130
131    PabloAST * createScanThru(PabloAST * from, PabloAST * thru);
132
133    PabloAST * createScanThru(PabloAST * from, PabloAST * thru, const std::string prefix);
134
135    PabloAST * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr);
136
137    PabloAST * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr, const std::string prefix);
138   
139    Count * createCount(const std::string counter, PabloAST * expr) {
140        return mPb->createCount(counter, expr);
141    }
142   
143    PabloAST * createInFile(PabloAST * expr);
144   
145    PabloAST * createInFile(PabloAST * expr, const std::string prefix);
146   
147    PabloAST * createAtEOF(PabloAST * expr);
148   
149    PabloAST * createAtEOF(PabloAST * expr, const std::string prefix);
150   
151    /// CreateIf Wrappers
152
153    inline If * createIf(PabloAST * condition, std::initializer_list<Assign *> definedVars, PabloBlock * body) {
154        return mPb->createIf(condition, std::move(definedVars), body);
155    }
156
157    inline If * createIf(PabloAST * condition, const std::vector<Assign *> & definedVars, PabloBlock * body) {
158        return mPb->createIf(condition, definedVars, body);
159    }
160
161    inline If * createIf(PabloAST * condition, std::vector<Assign *> && definedVars, PabloBlock * body) {
162        return mPb->createIf(condition, std::move(definedVars), body);
163    }
164
165    inline If * createIf(PabloAST * condition, std::initializer_list<Assign *> definedVars, PabloBuilder & builder) {
166        return mPb->createIf(condition, std::move(definedVars), builder.mPb);
167    }
168
169    inline If * createIf(PabloAST * condition, const std::vector<Assign *> & definedVars, PabloBuilder & builder) {
170        return mPb->createIf(condition, definedVars, builder.mPb);
171    }
172
173    inline If * createIf(PabloAST * condition, std::vector<Assign *> && definedVars, PabloBuilder & builder) {
174        return mPb->createIf(condition, std::move(definedVars), builder.mPb);
175    }
176
177    /// CreateWhile Wrappers
178
179    inline While * createWhile(PabloAST * condition, const std::initializer_list<Next *> nextVars, PabloBlock * body) {
180        return mPb->createWhile(condition, nextVars, body);
181    }
182
183    inline While * createWhile(PabloAST * condition, const std::vector<Next *> & nextVars, PabloBlock * body) {
184        return mPb->createWhile(condition, nextVars, body);
185    }
186
187    inline While * createWhile(PabloAST * condition, std::vector<Next *> && nextVars, PabloBlock * body) {
188        return mPb->createWhile(condition, std::move(nextVars), body);
189    }
190
191    inline While * createWhile(PabloAST * condition, const std::initializer_list<Next *> nextVars, PabloBuilder & builder) {
192        return mPb->createWhile(condition, std::move(nextVars), builder.mPb);
193    }
194
195    inline While * createWhile(PabloAST * condition, const std::vector<Next *> & nextVars, PabloBuilder & builder) {
196        return mPb->createWhile(condition, nextVars, builder.mPb);
197    }
198
199    inline While * createWhile(PabloAST * condition, std::vector<Next *> && nextVars, PabloBuilder & builder) {
200        return mPb->createWhile(condition, std::move(nextVars), builder.mPb);
201    }
202
203    /// Statement Iterator Wrappers
204
205    iterator begin() {
206        return mPb->begin();
207    }
208
209    iterator end() {
210        return mPb->end();
211    }
212
213    const_iterator begin() const {
214        return mPb->cbegin();
215    }
216
217    const_iterator end() const {
218        return mPb->cend();
219    }
220
221    const_iterator cbegin() const {
222        return mPb->cbegin();
223    }
224
225    const_iterator cend() const {
226        return mPb->cend();
227    }
228
229    inline Statement * front() const {
230        return mPb->front();
231    }
232
233    inline Statement * back() const {
234        return mPb->back();
235    }
236
237    inline String * getName(const std::string name, const bool generated = true) const {
238        return mPb->getName(std::move(name), generated);
239    }
240
241    inline String * makeName(const std::string prefix, const bool generated = true) const {
242        return mPb->makeName(std::move(prefix), generated);
243    }
244
245    inline Integer * getInteger(Integer::Type value) {
246        return mPb->getInteger(value);
247    }
248
249
250    inline Statement * getInsertPoint() const {
251        return mPb->getInsertPoint();
252    }
253
254    inline PabloBlock * getPabloBlock() {
255        return mPb;
256    }
257
258    inline PabloBuilder * getParent() {
259        return mParent;
260    }
261
262    inline void record(Statement * stmt) {
263        mExprTable.findOrAdd(stmt);
264    }
265
266private:
267
268    PabloBlock *        mPb;
269    PabloBuilder *      mParent;
270    ExpressionTable     mExprTable;
271};
272
273
274}
275
276
277#endif // BUILDER_HPP
Note: See TracBrowser for help on using the repository browser.