diff options
| author | Kelly Rauchenberger <fefferburbia@gmail.com> | 2017-01-21 18:51:41 -0500 |
|---|---|---|
| committer | Kelly Rauchenberger <fefferburbia@gmail.com> | 2017-01-21 18:51:41 -0500 |
| commit | e02e3d57dc090c8fd333812b84e91805921e398c (patch) | |
| tree | cd88280d698a920ca11419309bd743ddd9fc1b32 /generator/selrestr.cpp | |
| parent | 104587ba8f0ce51e0dfbc2916aee97ce3f8c3a8a (diff) | |
| download | verbly-e02e3d57dc090c8fd333812b84e91805921e398c.tar.gz verbly-e02e3d57dc090c8fd333812b84e91805921e398c.tar.bz2 verbly-e02e3d57dc090c8fd333812b84e91805921e398c.zip | |
Moved some generator classes into the main namespace
Diffstat (limited to 'generator/selrestr.cpp')
| -rw-r--r-- | generator/selrestr.cpp | 288 |
1 files changed, 0 insertions, 288 deletions
| diff --git a/generator/selrestr.cpp b/generator/selrestr.cpp deleted file mode 100644 index 8bdd3f6..0000000 --- a/generator/selrestr.cpp +++ /dev/null | |||
| @@ -1,288 +0,0 @@ | |||
| 1 | #include "selrestr.h" | ||
| 2 | |||
| 3 | namespace verbly { | ||
| 4 | namespace generator { | ||
| 5 | |||
| 6 | selrestr::selrestr(const selrestr& other) | ||
| 7 | { | ||
| 8 | type_ = other.type_; | ||
| 9 | |||
| 10 | switch (type_) | ||
| 11 | { | ||
| 12 | case type::singleton: | ||
| 13 | { | ||
| 14 | singleton_.pos = other.singleton_.pos; | ||
| 15 | new(&singleton_.restriction) std::string(other.singleton_.restriction); | ||
| 16 | |||
| 17 | break; | ||
| 18 | } | ||
| 19 | |||
| 20 | case type::group: | ||
| 21 | { | ||
| 22 | new(&group_.children) std::list<selrestr>(other.group_.children); | ||
| 23 | group_.orlogic = other.group_.orlogic; | ||
| 24 | |||
| 25 | break; | ||
| 26 | } | ||
| 27 | |||
| 28 | case type::empty: | ||
| 29 | { | ||
| 30 | break; | ||
| 31 | } | ||
| 32 | } | ||
| 33 | } | ||
| 34 | |||
| 35 | selrestr::selrestr(selrestr&& other) : selrestr() | ||
| 36 | { | ||
| 37 | swap(*this, other); | ||
| 38 | } | ||
| 39 | |||
| 40 | selrestr& selrestr::operator=(selrestr other) | ||
| 41 | { | ||
| 42 | swap(*this, other); | ||
| 43 | |||
| 44 | return *this; | ||
| 45 | } | ||
| 46 | |||
| 47 | void swap(selrestr& first, selrestr& second) | ||
| 48 | { | ||
| 49 | using type = selrestr::type; | ||
| 50 | |||
| 51 | type tempType = first.type_; | ||
| 52 | int tempPos; | ||
| 53 | std::string tempRestriction; | ||
| 54 | std::list<selrestr> tempChildren; | ||
| 55 | bool tempOrlogic; | ||
| 56 | |||
| 57 | switch (tempType) | ||
| 58 | { | ||
| 59 | case type::singleton: | ||
| 60 | { | ||
| 61 | tempPos = first.singleton_.pos; | ||
| 62 | tempRestriction = std::move(first.singleton_.restriction); | ||
| 63 | |||
| 64 | break; | ||
| 65 | } | ||
| 66 | |||
| 67 | case type::group: | ||
| 68 | { | ||
| 69 | tempChildren = std::move(first.group_.children); | ||
| 70 | tempOrlogic = first.group_.orlogic; | ||
| 71 | |||
| 72 | break; | ||
| 73 | } | ||
| 74 | |||
| 75 | case type::empty: | ||
| 76 | { | ||
| 77 | break; | ||
| 78 | } | ||
| 79 | } | ||
| 80 | |||
| 81 | first.~selrestr(); | ||
| 82 | |||
| 83 | first.type_ = second.type_; | ||
| 84 | |||
| 85 | switch (first.type_) | ||
| 86 | { | ||
| 87 | case type::singleton: | ||
| 88 | { | ||
| 89 | first.singleton_.pos = second.singleton_.pos; | ||
| 90 | new(&first.singleton_.restriction) std::string(std::move(second.singleton_.restriction)); | ||
| 91 | |||
| 92 | break; | ||
| 93 | } | ||
| 94 | |||
| 95 | case type::group: | ||
| 96 | { | ||
| 97 | new(&first.group_.children) std::list<selrestr>(std::move(second.group_.children)); | ||
| 98 | first.group_.orlogic = second.group_.orlogic; | ||
| 99 | |||
| 100 | break; | ||
| 101 | } | ||
| 102 | |||
| 103 | case type::empty: | ||
| 104 | { | ||
| 105 | break; | ||
| 106 | } | ||
| 107 | } | ||
| 108 | |||
| 109 | second.~selrestr(); | ||
| 110 | |||
| 111 | second.type_ = tempType; | ||
| 112 | |||
| 113 | switch (second.type_) | ||
| 114 | { | ||
| 115 | case type::singleton: | ||
| 116 | { | ||
| 117 | second.singleton_.pos = tempPos; | ||
| 118 | new(&second.singleton_.restriction) std::string(std::move(tempRestriction)); | ||
| 119 | |||
| 120 | break; | ||
| 121 | } | ||
| 122 | |||
| 123 | case type::group: | ||
| 124 | { | ||
| 125 | new(&second.group_.children) std::list<selrestr>(std::move(tempChildren)); | ||
| 126 | second.group_.orlogic = tempOrlogic; | ||
| 127 | |||
| 128 | break; | ||
| 129 | } | ||
| 130 | |||
| 131 | case type::empty: | ||
| 132 | { | ||
| 133 | break; | ||
| 134 | } | ||
| 135 | } | ||
| 136 | } | ||
| 137 | |||
| 138 | selrestr::~selrestr() | ||
| 139 | { | ||
| 140 | switch (type_) | ||
| 141 | { | ||
| 142 | case type::singleton: | ||
| 143 | { | ||
| 144 | using string_type = std::string; | ||
| 145 | singleton_.restriction.~string_type(); | ||
| 146 | |||
| 147 | break; | ||
| 148 | } | ||
| 149 | |||
| 150 | case type::group: | ||
| 151 | { | ||
| 152 | using list_type = std::list<selrestr>; | ||
| 153 | group_.children.~list_type(); | ||
| 154 | |||
| 155 | break; | ||
| 156 | } | ||
| 157 | |||
| 158 | case type::empty: | ||
| 159 | { | ||
| 160 | break; | ||
| 161 | } | ||
| 162 | } | ||
| 163 | } | ||
| 164 | |||
| 165 | selrestr::selrestr() : type_(type::empty) | ||
| 166 | { | ||
| 167 | } | ||
| 168 | |||
| 169 | selrestr::selrestr( | ||
| 170 | std::string restriction, | ||
| 171 | bool pos) : | ||
| 172 | type_(type::singleton) | ||
| 173 | { | ||
| 174 | new(&singleton_.restriction) std::string(std::move(restriction)); | ||
| 175 | singleton_.pos = pos; | ||
| 176 | } | ||
| 177 | |||
| 178 | std::string selrestr::getRestriction() const | ||
| 179 | { | ||
| 180 | if (type_ == type::singleton) | ||
| 181 | { | ||
| 182 | return singleton_.restriction; | ||
| 183 | } else { | ||
| 184 | throw std::domain_error("Only singleton selrestrs have restrictions"); | ||
| 185 | } | ||
| 186 | } | ||
| 187 | |||
| 188 | bool selrestr::getPos() const | ||
| 189 | { | ||
| 190 | if (type_ == type::singleton) | ||
| 191 | { | ||
| 192 | return singleton_.pos; | ||
| 193 | } else { | ||
| 194 | throw std::domain_error("Only singleton selrestrs have positivity flags"); | ||
| 195 | } | ||
| 196 | } | ||
| 197 | |||
| 198 | selrestr::selrestr( | ||
| 199 | std::list<selrestr> children, | ||
| 200 | bool orlogic) : | ||
| 201 | type_(type::group) | ||
| 202 | { | ||
| 203 | new(&group_.children) std::list<selrestr>(std::move(children)); | ||
| 204 | group_.orlogic = orlogic; | ||
| 205 | } | ||
| 206 | |||
| 207 | std::list<selrestr> selrestr::getChildren() const | ||
| 208 | { | ||
| 209 | if (type_ == type::group) | ||
| 210 | { | ||
| 211 | return group_.children; | ||
| 212 | } else { | ||
| 213 | throw std::domain_error("Only group selrestrs have children"); | ||
| 214 | } | ||
| 215 | } | ||
| 216 | |||
| 217 | std::list<selrestr>::const_iterator selrestr::begin() const | ||
| 218 | { | ||
| 219 | if (type_ == type::group) | ||
| 220 | { | ||
| 221 | return std::begin(group_.children); | ||
| 222 | } else { | ||
| 223 | throw std::domain_error("Only group selrestrs have children"); | ||
| 224 | } | ||
| 225 | } | ||
| 226 | |||
| 227 | std::list<selrestr>::const_iterator selrestr::end() const | ||
| 228 | { | ||
| 229 | if (type_ == type::group) | ||
| 230 | { | ||
| 231 | return std::end(group_.children); | ||
| 232 | } else { | ||
| 233 | throw std::domain_error("Only group selrestrs have children"); | ||
| 234 | } | ||
| 235 | } | ||
| 236 | |||
| 237 | bool selrestr::getOrlogic() const | ||
| 238 | { | ||
| 239 | if (type_ == type::group) | ||
| 240 | { | ||
| 241 | return group_.orlogic; | ||
| 242 | } else { | ||
| 243 | throw std::domain_error("Only group selrestrs have logic"); | ||
| 244 | } | ||
| 245 | } | ||
| 246 | |||
| 247 | nlohmann::json selrestr::toJson() const | ||
| 248 | { | ||
| 249 | switch (type_) | ||
| 250 | { | ||
| 251 | case type::empty: | ||
| 252 | { | ||
| 253 | return {}; | ||
| 254 | } | ||
| 255 | |||
| 256 | case type::singleton: | ||
| 257 | { | ||
| 258 | return { | ||
| 259 | {"type", singleton_.restriction}, | ||
| 260 | {"pos", singleton_.pos} | ||
| 261 | }; | ||
| 262 | } | ||
| 263 | |||
| 264 | case type::group: | ||
| 265 | { | ||
| 266 | std::string logic; | ||
| 267 | if (group_.orlogic) | ||
| 268 | { | ||
| 269 | logic = "or"; | ||
| 270 | } else { | ||
| 271 | logic = "and"; | ||
| 272 | } | ||
| 273 | |||
| 274 | std::list<nlohmann::json> children; | ||
| 275 | std::transform(std::begin(group_.children), std::end(group_.children), std::back_inserter(children), [] (const selrestr& child) { | ||
| 276 | return child.toJson(); | ||
| 277 | }); | ||
| 278 | |||
| 279 | return { | ||
| 280 | {"logic", logic}, | ||
| 281 | {"children", children} | ||
| 282 | }; | ||
| 283 | } | ||
| 284 | } | ||
| 285 | } | ||
| 286 | |||
| 287 | }; | ||
| 288 | }; | ||
