diff options
author | Spartan322 <Megacake1234@gmail.com> | 2024-08-11 02:59:55 +0200 |
---|---|---|
committer | Spartan322 <Megacake1234@gmail.com> | 2024-08-11 03:46:58 +0200 |
commit | 9617863bbb82fbe5c3c203dec2b9a7d7f6a746d5 (patch) | |
tree | 05cb6ce7a3e4f5f5af01498e7ee0f95e4fea1692 /src | |
parent | efcc544bb36c80efb911390855c0123d5d11f742 (diff) |
Fix logger file invalid pointerfix/logger-invalidation
Add explicit move semantics to AbstractSyntaxTree
Add explicit move semantics to ParseState
Diffstat (limited to 'src')
-rw-r--r-- | src/openvic-dataloader/AbstractSyntaxTree.hpp | 23 | ||||
-rw-r--r-- | src/openvic-dataloader/ParseState.hpp | 14 |
2 files changed, 35 insertions, 2 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); } diff --git a/src/openvic-dataloader/ParseState.hpp b/src/openvic-dataloader/ParseState.hpp index 259f2a5..a9a9953 100644 --- a/src/openvic-dataloader/ParseState.hpp +++ b/src/openvic-dataloader/ParseState.hpp @@ -1,7 +1,5 @@ #pragma once -#include <utility> - #include <openvic-dataloader/detail/Encoding.hpp> #include <lexy/encoding.hpp> @@ -37,6 +35,18 @@ namespace ovdl { _logger { this->ast().file() }, BasicParseState(encoding) {} + ParseState(ParseState&& other) + : _ast { std::move(other._ast) }, + _logger { this->ast().file() }, + BasicParseState(other.encoding()) {} + + ParseState& operator=(ParseState&& rhs) { + this->~ParseState(); + new (this) ParseState(std::move(rhs)); + + return *this; + } + template<typename Encoding, typename MemoryResource = void> ParseState(lexy::buffer<Encoding, MemoryResource>&& buffer, detail::Encoding encoding) : ParseState(typename ast_type::file_type { std::move(buffer) }, encoding) {} |