libcryfs/implementations/onblocks/BlobOnBlocks.h

46 lines
1.2 KiB
C
Raw Normal View History

#pragma once
#ifndef BLOBSTORE_IMPLEMENTATIONS_ONBLOCKS_BLOBONBLOCKS_H_
#define BLOBSTORE_IMPLEMENTATIONS_ONBLOCKS_BLOBONBLOCKS_H_
2015-02-17 00:40:34 +01:00
#include "../../interface/Blob.h"
2014-12-09 17:56:48 +01:00
#include <memory>
namespace blobstore {
namespace onblocks {
namespace datanodestore {
class DataLeafNode;
}
namespace cachingdatatreestore {
class CachedDataTreeRef;
}
2014-12-09 17:56:48 +01:00
class BlobOnBlocks: public Blob {
public:
BlobOnBlocks(std::unique_ptr<cachingdatatreestore::CachedDataTreeRef> datatree);
virtual ~BlobOnBlocks();
2014-12-09 17:56:48 +01:00
2015-02-27 00:18:26 +01:00
blockstore::Key key() const override;
uint64_t size() const override;
void resize(uint64_t numBytes) override;
2014-12-09 17:56:48 +01:00
void read(void *target, uint64_t offset, uint64_t size) const override;
2015-03-11 01:04:48 +01:00
uint64_t tryRead(void *target, uint64_t offset, uint64_t size) const override;
void write(const void *source, uint64_t offset, uint64_t size) override;
std::unique_ptr<cachingdatatreestore::CachedDataTreeRef> releaseTree();
2014-12-09 17:56:48 +01:00
private:
void traverseLeaves(uint64_t offsetBytes, uint64_t sizeBytes, std::function<void (uint64_t, datanodestore::DataLeafNode *, uint32_t, uint32_t)>) const;
void resizeIfSmallerThan(uint64_t neededSize);
std::unique_ptr<cachingdatatreestore::CachedDataTreeRef> _datatree;
};
}
}
#endif