diff options
author | Spartan322 <Megacake1234@gmail.com> | 2024-07-02 09:51:59 +0200 |
---|---|---|
committer | Spartan322 <Megacake1234@gmail.com> | 2024-07-05 19:17:25 +0200 |
commit | 3eb78b27505b602c1ccfa952c4cc00f942ccb2b9 (patch) | |
tree | 457b7fbda6d4470465c05d59b0ca51ed30628640 /src/openvic-dataloader/File.hpp | |
parent | deed8ec0ae23651529a58125012c1b4aab015d02 (diff) |
Fix string interning pointer invalidity for ASTsimplify-string-interning
Fix errorneous string intern compare
Add symbol interning tests
Optimize non-conversion identifier cases
Add `File::size()`
Add InstanceOf concept
Remove `FlatValue::value(const symbol_interner_type&)`
Add `AbstractSyntaxTree::intern/intern_cst(lexy::lexeme)` overload
Add `DiagnosticLogger::intern/intern_cstr(lexy::lexeme)` overload
Use pinned_vector to maintain string interning pointer validity for buffers
Add vmcontainer submodule for pinned_vector
pinned_vector reserves virtual memory at runtime using OS APIs to maintain pointer validity
Remove Exception and RTTI requirement from range-v3 submodule
Diffstat (limited to 'src/openvic-dataloader/File.hpp')
-rw-r--r-- | src/openvic-dataloader/File.hpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/src/openvic-dataloader/File.hpp b/src/openvic-dataloader/File.hpp index 90fcb11..ec25640 100644 --- a/src/openvic-dataloader/File.hpp +++ b/src/openvic-dataloader/File.hpp @@ -29,6 +29,8 @@ namespace ovdl { bool is_valid() const noexcept; + std::size_t size() const noexcept; + template<typename Encoding, typename MemoryResource = void> constexpr bool is_buffer() const { return buffer_ids::type_id<lexy::buffer<Encoding, MemoryResource>>() + 1 == _buffer.index(); @@ -104,6 +106,7 @@ namespace ovdl { protected: const char* _path; + std::size_t _buffer_size = 0; detail::type_prepend_t<buffer_ids::variant_type, std::monostate> _buffer; }; @@ -114,12 +117,14 @@ namespace ovdl { template<typename Encoding, typename MemoryResource = void> explicit BasicFile(const char* path, lexy::buffer<Encoding, MemoryResource>&& buffer) : File(path) { + _buffer_size = buffer.size(); _buffer = static_cast<std::remove_reference_t<decltype(buffer)>&&>(buffer); } template<typename Encoding, typename MemoryResource = void> explicit BasicFile(lexy::buffer<Encoding, MemoryResource>&& buffer) : File("") { + _buffer_size = buffer.size(); _buffer = static_cast<std::remove_reference_t<decltype(buffer)>&&>(buffer); } |