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

Last change on this file since 4718 was 4718, checked in by cameron, 4 years ago

add Pablo count operation - not yet functional

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