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

Last change on this file since 4870 was 4870, checked in by nmedfort, 4 years ago

Bug fix for Multiplexing. Added ability to set the body of a If/While? node after creation.

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 std::move(PabloBuilder(block));
35    }
36
37    inline static PabloBuilder Create(PabloBuilder & builder) noexcept {
38        return std::move(PabloBuilder(new PabloBlock(builder.mPb->mSymbolGenerator), builder));
39    }
40
41    static inline Zeroes * createZeroes() {
42        return PabloBlock::createZeroes();
43    }
44
45    static inline Ones * createOnes() {
46        return PabloBlock::createOnes();
47    }
48
49    inline Var * createVar(const std::string name) {
50        return mPb->createVar(name);
51    }
52
53    inline Var * createVar(String * const name) {
54        return mPb->createVar(name);
55    }
56
57    inline Var * createVar(PabloAST * const name) {
58        return mPb->createVar(name);
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 Next * createNext(Assign * assign, PabloAST * expr) {
90        return mPb->createNext(assign, expr);
91    }
92
93    PabloAST * createAnd(PabloAST * expr1, PabloAST * expr2);
94
95    PabloAST * createAnd(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
96
97    PabloAST * createNot(PabloAST * expr);
98
99    PabloAST * createNot(PabloAST * expr, const std::string prefix);
100
101    PabloAST * createOr(PabloAST * expr1, PabloAST * expr2);
102
103    PabloAST * createOr(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
104
105    PabloAST * createXor(PabloAST * expr1, PabloAST * expr2);
106
107    PabloAST * createXor(PabloAST * expr1, PabloAST * expr2, const std::string prefix);
108
109    PabloAST * createMatchStar(PabloAST * marker, PabloAST * charclass);
110
111    PabloAST * createMatchStar(PabloAST * marker, PabloAST * charclass, const std::string prefix);
112
113    PabloAST * createScanThru(PabloAST * from, PabloAST * thru);
114
115    PabloAST * createScanThru(PabloAST * from, PabloAST * thru, const std::string prefix);
116
117    PabloAST * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr);
118
119    PabloAST * createSel(PabloAST * condition, PabloAST * trueExpr, PabloAST * falseExpr, const std::string prefix);
120   
121    PabloAST * createCount(PabloAST * expr);
122   
123    PabloAST * createCount(PabloAST * expr, const std::string prefix);
124   
125    /// Mod64 approximate function wrappers.
126   
127    PabloAST * createMod64Advance(PabloAST * expr, PabloAST * shiftAmount);
128
129    inline PabloAST * createMod64Advance(PabloAST * expr, const Integer::Type shiftAmount) {
130        if (shiftAmount == 0) {
131            return expr;
132        }
133        return createMod64Advance(expr, mPb->getInteger(shiftAmount));
134    }
135
136    inline PabloAST * createMod64Advance(PabloAST * expr, const Integer::Type shiftAmount, const std::string prefix) {
137        if (shiftAmount == 0) {
138            return expr;
139        }
140        return createMod64Advance(expr, mPb->getInteger(shiftAmount), prefix);
141    }
142
143    PabloAST * createMod64Advance(PabloAST * expr, PabloAST * shiftAmount, const std::string prefix);
144
145    PabloAST * createMod64MatchStar(PabloAST * marker, PabloAST * charclass);
146
147    PabloAST * createMod64MatchStar(PabloAST * marker, PabloAST * charclass, const std::string prefix);
148
149    PabloAST * createMod64ScanThru(PabloAST * from, PabloAST * thru);
150
151    PabloAST * createMod64ScanThru(PabloAST * from, PabloAST * thru, const std::string prefix);
152
153
154    /// CreateIf Wrappers
155
156    inline If * createIf(PabloAST * condition, std::initializer_list<Assign *> definedVars, PabloBlock * body) {
157        return mPb->createIf(condition, std::move(definedVars), body);
158    }
159
160    inline If * createIf(PabloAST * condition, const std::vector<Assign *> & definedVars, PabloBlock * body) {
161        return mPb->createIf(condition, definedVars, body);
162    }
163
164    inline If * createIf(PabloAST * condition, std::vector<Assign *> && definedVars, PabloBlock * body) {
165        return mPb->createIf(condition, std::move(definedVars), body);
166    }
167
168    inline If * createIf(PabloAST * condition, std::initializer_list<Assign *> definedVars, PabloBuilder & builder) {
169        return mPb->createIf(condition, std::move(definedVars), builder.mPb);
170    }
171
172    inline If * createIf(PabloAST * condition, const std::vector<Assign *> & definedVars, PabloBuilder & builder) {
173        return mPb->createIf(condition, definedVars, builder.mPb);
174    }
175
176    inline If * createIf(PabloAST * condition, std::vector<Assign *> && definedVars, PabloBuilder & builder) {
177        return mPb->createIf(condition, std::move(definedVars), builder.mPb);
178    }
179
180    /// CreateWhile Wrappers
181
182    inline While * createWhile(PabloAST * condition, const std::initializer_list<Next *> nextVars, PabloBlock * body) {
183        return mPb->createWhile(condition, nextVars, body);
184    }
185
186    inline While * createWhile(PabloAST * condition, const std::vector<Next *> & nextVars, PabloBlock * body) {
187        return mPb->createWhile(condition, nextVars, body);
188    }
189
190    inline While * createWhile(PabloAST * condition, std::vector<Next *> && nextVars, PabloBlock * body) {
191        return mPb->createWhile(condition, std::move(nextVars), body);
192    }
193
194    inline While * createWhile(PabloAST * condition, const std::initializer_list<Next *> nextVars, PabloBuilder & builder) {
195        return mPb->createWhile(condition, std::move(nextVars), builder.mPb);
196    }
197
198    inline While * createWhile(PabloAST * condition, const std::vector<Next *> & nextVars, PabloBuilder & builder) {
199        return mPb->createWhile(condition, nextVars, builder.mPb);
200    }
201
202    inline While * createWhile(PabloAST * condition, std::vector<Next *> && nextVars, PabloBuilder & builder) {
203        return mPb->createWhile(condition, std::move(nextVars), builder.mPb);
204    }
205
206    /// Statement Iterator Wrappers
207
208    iterator begin() {
209        return mPb->begin();
210    }
211
212    iterator end() {
213        return mPb->end();
214    }
215
216    const_iterator begin() const {
217        return mPb->cbegin();
218    }
219
220    const_iterator end() const {
221        return mPb->cend();
222    }
223
224    const_iterator cbegin() const {
225        return mPb->cbegin();
226    }
227
228    const_iterator cend() const {
229        return mPb->cend();
230    }
231
232    inline Statement * front() const {
233        return mPb->front();
234    }
235
236    inline Statement * back() const {
237        return mPb->back();
238    }
239
240    inline String * getName(const std::string name, const bool generated = true) const {
241        return mPb->getName(std::move(name), generated);
242    }
243
244    inline String * makeName(const std::string prefix, const bool generated = true) const {
245        return mPb->makeName(std::move(prefix), generated);
246    }
247
248    inline Integer * getInteger(Integer::Type value) {
249        return mPb->getInteger(value);
250    }
251
252
253    inline Statement * getInsertPoint() const {
254        return mPb->getInsertPoint();
255    }
256
257    inline PabloBlock * getPabloBlock() {
258        return mPb;
259    }
260
261    inline PabloBuilder * getParent() {
262        return mParent;
263    }
264
265    inline void record(Statement * stmt) {
266        mExprTable.findOrAdd(stmt);
267    }
268
269private:
270
271    PabloBlock *        mPb;
272    PabloBuilder *      mParent;
273    ExpressionTable     mExprTable;
274};
275
276
277}
278
279
280#endif // BUILDER_HPP
Note: See TracBrowser for help on using the repository browser.