aboutsummaryrefslogtreecommitdiff
path: root/src/openvic-dataloader/AbstractSyntaxTree.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/openvic-dataloader/AbstractSyntaxTree.hpp')
-rw-r--r--src/openvic-dataloader/AbstractSyntaxTree.hpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/openvic-dataloader/AbstractSyntaxTree.hpp b/src/openvic-dataloader/AbstractSyntaxTree.hpp
index f2d941b..156b7d0 100644
--- a/src/openvic-dataloader/AbstractSyntaxTree.hpp
+++ b/src/openvic-dataloader/AbstractSyntaxTree.hpp
@@ -26,6 +26,14 @@ namespace ovdl {
AbstractSyntaxTree() = default;
explicit AbstractSyntaxTree(std::size_t max_elements) : _symbol_interner(max_elements) {}
+ AbstractSyntaxTree(AbstractSyntaxTree&& other) : _symbol_interner { std::move(other._symbol_interner) } {}
+ AbstractSyntaxTree& operator=(AbstractSyntaxTree&& rhs) {
+ this->~AbstractSyntaxTree();
+ new (this) AbstractSyntaxTree(std::move(rhs));
+
+ return *this;
+ }
+
symbol_type intern(const char* str, std::size_t length);
symbol_type intern(std::string_view str);
const char* intern_cstr(const char* str, std::size_t length);
@@ -63,6 +71,21 @@ namespace ovdl {
: AbstractSyntaxTree(buffer.size() * sizeof(Encoding::char_type)),
_file { std::move(buffer) } {}
+ BasicAbstractSyntaxTree(const BasicAbstractSyntaxTree&) = delete;
+ BasicAbstractSyntaxTree& operator=(const BasicAbstractSyntaxTree&) = delete;
+
+ BasicAbstractSyntaxTree(BasicAbstractSyntaxTree&& other)
+ : _tree { std::move(other._tree) },
+ _file { std::move(other._file) },
+ AbstractSyntaxTree(std::move(other)) {}
+
+ BasicAbstractSyntaxTree& operator=(AbstractSyntaxTree&& rhs) {
+ this->~BasicAbstractSyntaxTree();
+ new (this) BasicAbstractSyntaxTree(std::move(rhs));
+
+ return *this;
+ }
+
void set_location(const node_type* n, NodeLocation loc) {
_file.set_location(n, loc);
}