solanaceae_util/solanaceae/file/file2_mem.cpp

60 lines
1.1 KiB
C++
Raw Normal View History

2024-04-03 21:03:04 +02:00
#include "./file2_mem.hpp"
File2MemW::File2MemW(std::vector<uint8_t>& mem) : File2I(true, false), _mem(mem) {
}
File2MemW::~File2MemW(void) {
}
bool File2MemW::isGood(void) {
// TODO: are there any error cases?
return true;
}
bool File2MemW::write(const ByteSpan data, int64_t pos) {
if (pos != -1) { // only support streaming
return false;
}
if (data.empty()) {
return false; // true instead?
}
_mem.insert(_mem.cend(), data.cbegin(), data.cend());
return isGood();
}
std::variant<ByteSpan, std::vector<uint8_t>> File2MemW::read(uint64_t size, int64_t pos) {
return {};
}
File2MemR::File2MemR(ByteSpan mem) : File2I(false, true), _mem(mem) {
}
File2MemR::~File2MemR(void) {
}
bool File2MemR::isGood(void) {
// TODO: return false if eof?
return true;
}
bool File2MemR::write(const ByteSpan data, int64_t pos) {
return false;
}
std::variant<ByteSpan, std::vector<uint8_t>> File2MemR::read(uint64_t size, int64_t pos) {
if (_read_pos >= _mem.size) {
return {};
}
ByteSpan ret {
_mem.ptr + _read_pos,
std::min(size, _mem.size - _read_pos)
};
_read_pos += ret.size;
return ret;
}