source: icGREP/icgrep-devel/icgrep/re/re_cc.h

Last change on this file was 5278, checked in by cameron, 8 months ago

Alphabet class: initial check-in

File size: 3.6 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_CC_H
8#define RE_CC_H
9
10#include "re_re.h"
11#include <UCD/unicode_set.h>
12
13namespace re {
14
15using codepoint_t = UCD::codepoint_t;
16using interval_t = UCD::UnicodeSet::interval_t;
17
18enum CC_type {UnicodeClass, ByteClass};
19
20class CC : public RE, public UCD::UnicodeSet {
21public:
22
23    static inline bool classof(const RE * re) {
24        return re->getClassTypeId() == ClassTypeId::CC;
25    }
26    static inline bool classof(const void *) {
27        return false;
28    }
29
30
31    std::string canonicalName(const CC_type type) const;
32
33    inline codepoint_t min_codepoint() const {
34        return front().first;
35    }
36
37    inline codepoint_t max_codepoint() const {
38        return back().second;
39    }
40
41    virtual ~CC() {}
42
43protected:
44    friend CC * makeCC();
45    friend CC * makeCC(const codepoint_t codepoint);
46    friend CC * makeCC(const codepoint_t lo, const codepoint_t hi);
47    friend CC * makeCC(const CC * cc1, const CC * cc2);
48    friend CC * makeCC(std::initializer_list<interval_t> list);
49    friend CC * makeCC(std::vector<interval_t> && list);
50    friend CC * makeCC(UCD::UnicodeSet && set);
51    friend CC * subtractCC(const CC * a, const CC * b);
52    friend CC * intersectCC(const CC * a, const CC * b);
53
54    inline CC()
55    : RE(ClassTypeId::CC) {
56
57    }
58
59    CC(const CC & cc);
60
61    inline CC(const codepoint_t codepoint)
62    : RE(ClassTypeId::CC)
63    , UCD::UnicodeSet(codepoint) {
64
65    }
66
67    inline CC(const codepoint_t lo_codepoint, const codepoint_t hi_codepoint)
68    : RE(ClassTypeId::CC)
69    , UCD::UnicodeSet(lo_codepoint, hi_codepoint) {
70
71    }
72
73    CC(const CC * cc1, const CC * cc2);
74
75    inline CC(UCD::UnicodeSet && set)
76    : RE(ClassTypeId::CC)
77    , UCD::UnicodeSet(std::move(set)) {
78
79    }
80
81    CC(std::initializer_list<interval_t>::iterator begin, std::initializer_list<interval_t>::iterator end)
82    : RE(ClassTypeId::CC)
83    , UCD::UnicodeSet(begin, end)
84    {
85
86    }
87
88    CC(const std::vector<interval_t>::iterator begin, const std::vector<interval_t>::iterator end)
89    : RE(ClassTypeId::CC)
90    , UCD::UnicodeSet(begin, end)
91    {
92
93    }
94
95};
96
97inline static CC::iterator begin(const CC & cc) {
98    return cc.begin();
99}
100
101inline static CC::iterator end(const CC & cc) {
102    return cc.end();
103}
104
105inline codepoint_t lo_codepoint(const interval_t & i) {
106    return std::get<0>(i);
107}
108inline codepoint_t lo_codepoint(const CC::iterator i) {
109    return lo_codepoint(*i);
110}
111
112inline codepoint_t hi_codepoint(const interval_t & i) {
113    return std::get<1>(i);
114}
115inline codepoint_t hi_codepoint(const CC::iterator i) {
116    return hi_codepoint(*i);
117}
118
119/**
120 * @brief RE::makeCC
121 *
122 * Various factory constructors for the RE CC class
123 *
124 * @return a CC object
125 */
126
127inline CC * makeCC() {
128    return new CC();
129}
130
131inline CC * makeCC(const codepoint_t codepoint) {
132    return new CC(codepoint);
133}
134
135inline CC * makeCC(const codepoint_t lo, const codepoint_t hi) {
136    return new CC(lo, hi);
137}
138
139inline CC * makeCC(const CC * cc1, const CC * cc2) {
140    return new CC(cc1, cc2);
141}
142
143inline CC * makeCC(std::initializer_list<interval_t> list) {
144    return new CC(list.begin(), list.end());
145}
146
147inline CC * makeCC(std::vector<interval_t> && list) {
148    return new CC(list.begin(), list.end());
149}
150
151inline CC * makeCC(UCD::UnicodeSet && set) {
152    return new CC(std::move(set));
153}
154
155inline CC * subtractCC(const CC * a, const CC * b) {
156    return new CC(*a - *b);
157}
158
159inline CC * intersectCC(const CC * a, const CC * b) {
160    return new CC(*a & *b);
161}
162
163CC * caseInsensitize(const CC * cc);
164
165}
166
167#endif // RE_CC_H
Note: See TracBrowser for help on using the repository browser.