lbug 0.16.0

An in-process property graph database management system built for query speed and scalability
Documentation
#pragma once

#include <vector>

#include "common/serializer/writer.h"
#include "storage/buffer_manager/memory_manager.h"

namespace lbug::storage {
struct PageRange;
class ShadowFile;
class PageAllocator;
} // namespace lbug::storage

namespace lbug {
namespace common {
class BufferedFileWriter;

class InMemFileWriter final : public Writer {
public:
    explicit InMemFileWriter(storage::MemoryManager& mm);

    void write(const uint8_t* data, uint64_t size) override;

    std::span<uint8_t> getPage(page_idx_t pageIdx) const {
        DASSERT(pageIdx < pages.size());
        return pages[pageIdx]->getBuffer();
    }

    storage::PageRange flush(storage::PageAllocator& pageAllocator,
        storage::ShadowFile& shadowFile) const;
    void flush(storage::PageRange allocatedPages, storage::FileHandle* fileHandle,
        storage::ShadowFile& shadowFile) const;

    page_idx_t getNumPagesToFlush() const { return pages.size(); }

    static uint64_t getPageSize();
    void flush(Writer& writer) const;

    uint64_t getSize() const override {
        uint64_t size = pages.size() > 1 ? LBUG_PAGE_SIZE * (pages.size() - 1) : 0;
        return size + pageOffset;
    }

    void clear() override {
        pages.clear();
        pageOffset = 0;
    }

    void flush() override {
        // DO NOTHING: InMemWriter does not need to flush.
    }
    void sync() override {
        // DO NOTHING: InMemWriter does not need to sync.
    }

private:
    bool needNewBuffer(uint64_t size) const;

private:
    std::vector<std::unique_ptr<storage::MemoryBuffer>> pages;
    storage::MemoryManager& mm;
    uint64_t pageOffset;
};

} // namespace common
} // namespace lbug