From 32181c449c78f8cc3548a02e172fd0a5a8f6d965 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Torbj=C3=B6rn=20Rathsman?= Date: Wed, 23 Nov 2022 19:05:36 +0100 Subject: [PATCH] Store vtable outside class --- lib/io_policy.hpp | 47 +++++++++++++++++++++++++++++++---------------- 1 file changed, 31 insertions(+), 16 deletions(-) diff --git a/lib/io_policy.hpp b/lib/io_policy.hpp index f83b239..8ca14dd 100644 --- a/lib/io_policy.hpp +++ b/lib/io_policy.hpp @@ -84,6 +84,25 @@ namespace Wad64 { return std::nullopt; } + + struct file_reference_vtable + { + size_t (*read)(void const*, std::span, int64_t offset); + size_t (*write)(void*, std::span, int64_t offset); + size_t (*write_from_fd)(void*, FdAdapter, int64_t); + void (*truncate)(void*, int64_t new_size); + std::optional (*get_path)(void const*); + }; + + template + inline constexpr file_reference_vtable file_ref_vtable + { + read, + write, + write_from_fd, + truncate, + get_path + }; } class FileReference @@ -92,39 +111,35 @@ namespace Wad64 template explicit FileReference(std::reference_wrapper file) : m_ref{&file.get()} - , m_read{detail::read} - , m_write{detail::write} - , m_truncate{detail::truncate} - , m_write_from_fd{detail::write_from_fd} - , m_get_path(detail::get_path) + , m_vt{std::ref(detail::file_ref_vtable)} { } size_t read(std::span buffer, int64_t offset) const { - return m_read(m_ref, buffer, offset); + return m_vt.get().read(m_ref, buffer, offset); } size_t write(std::span buffer, int64_t offset) const { - return m_write(m_ref, buffer, offset); + return m_vt.get().write(m_ref, buffer, offset); } - size_t write(FdAdapter src, int64_t offset) { return m_write_from_fd(m_ref, src, offset); } + size_t write(FdAdapter src, int64_t offset) const + { return m_vt.get().write_from_fd(m_ref, src, offset); } - void* handle() const { return m_ref; } + void truncate(int64_t new_size) const + { m_vt.get().truncate(m_ref, new_size); } - void truncate(int64_t new_size) { m_truncate(m_ref, new_size); } + std::optional getPath() const + { return m_vt.get().get_path(m_ref); } - std::optional getPath() const { return m_get_path(m_ref); } + void* handle() const + { return m_ref; } private: void* m_ref; - size_t (*m_read)(void const*, std::span, int64_t offset); - size_t (*m_write)(void*, std::span, int64_t offset); - void (*m_truncate)(void*, int64_t new_size); - size_t (*m_write_from_fd)(void*, FdAdapter, int64_t); - std::optional (*m_get_path)(void const*); + std::reference_wrapper m_vt; }; }