source: icGREP/icgrep-devel/icgrep/re/re_rep.h @ 4272

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

Implemented slab allocator based on the original Parabix StringPool?; intergrated it with RE and Pablo AST nodes.

File size: 1.5 KB
Line 
1/*
2 *  Copyright (c) 2014 International Characters.
3 *  This software is licensed to the public under the Open Software License 3.0.
4 *  icgrep is a trademark of International Characters.
5 */
6
7#ifndef RE_REP_H
8#define RE_REP_H
9
10#include "re_re.h"
11
12namespace re {
13
14class Rep : public RE {
15public:
16    static inline bool classof(const RE * re) {
17        return re->getClassTypeId() == ClassTypeId::Rep;
18    }
19    static inline bool classof(const void *) {
20        return false;
21    }
22    enum { UNBOUNDED_REP = -1 };
23    RE * getRE() const;
24    void setRE(RE * re = nullptr);
25    int getLB() const;
26    void setLB(const int lb);
27    int getUB() const;
28    void setUB(const int ub);
29    virtual ~Rep();
30protected:
31    friend RE * makeRep(RE *, const int, const int);
32    void* operator new (std::size_t size) noexcept {
33        return mAllocator.allocate(size);
34    }
35    Rep(RE * re, const int lb, const int ub);
36private:
37    RE* mRE;
38    int mLB;
39    int mUB;
40};
41
42inline Rep::Rep(RE * re, const int lb, const int ub)
43: RE(ClassTypeId::Rep)
44, mRE(re)
45, mLB(lb)
46, mUB(ub)
47{
48
49}
50
51inline Rep::~Rep() {
52    delete mRE;
53}
54
55inline RE * Rep::getRE() const {
56    return mRE;
57}
58
59inline void Rep::setRE(RE * re) {
60    mRE = re;
61}
62
63inline int Rep::getLB() const {
64    return mLB;
65}
66
67inline void Rep::setLB(const int lb) {
68    mLB = lb;
69}
70
71inline int Rep::getUB() const {
72    return mUB;
73}
74
75inline void Rep::setUB(const int ub) {
76    mUB = ub;
77}
78
79RE * makeRep(RE * re, const int lower_bound, const int upper_bound);
80
81}
82
83#endif
Note: See TracBrowser for help on using the repository browser.