Joedb 10.3.0
The Journal-Only Embedded Database
Loading...
Searching...
No Matches
Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
joedb::Readonly_Encoded_File Class Reference

#include <joedb/journal/Readonly_Encoded_File.h>

Inheritance diagram for joedb::Readonly_Encoded_File:
Inheritance graph
[legend]
Collaboration diagram for joedb::Readonly_Encoded_File:
Collaboration graph
[legend]

Public Member Functions

 Readonly_Encoded_File (Decoder &decoder, const db::encoded_file::Database &db, const Abstract_File &blob_reader)
 
int64_t get_size () const override
 Get the size of the file, or -1 if it is unknown.
 
- Public Member Functions inherited from joedb::Abstract_File
 Abstract_File (Open_Mode mode)
 
bool is_shared () const noexcept
 
bool is_readonly () const noexcept
 
Open_Mode get_mode () const noexcept
 
virtual void pwrite (const char *data, size_t size, int64_t offset)
 Write a range of bytes. Extend file size if necessary.
 
virtual void sync ()
 Write data durably (including file-size change)
 
virtual void datasync ()
 Write data durably (no file-size change)
 
virtual void shared_lock (int64_t start, int64_t size)
 Lock a range of bytes for reading (prevents writes, not reads)
 
virtual void exclusive_lock (int64_t start, int64_t size)
 Lock a range of bytes for writing (prevents both writes and reads)
 
virtual void unlock (int64_t start, int64_t size) noexcept
 Remove a lock. The range should match the range of a corresponding lock.
 
void exclusive_lock_tail ()
 
void unlock_tail () noexcept
 
void exclusive_lock_head ()
 
void shared_lock_head ()
 
void unlock_head () noexcept
 
std::string read_blob (Blob blob) const
 
virtual void copy_to (Abstract_File &destination, int64_t start, int64_t size) const
 
virtual bool equal_to (const Abstract_File &destination, int64_t from, int64_t until) const
 
void copy_to (Abstract_File &destination) const
 
virtual ~Abstract_File ()=default
 

Protected Member Functions

size_t pread (char *buffer, size_t size, int64_t offset) const override
 Read a range of bytes.
 
 Readonly_Encoded_File (Decoder &decoder, const db::encoded_file::Database &db, const Abstract_File &blob_reader, Open_Mode mode)
 
- Protected Member Functions inherited from joedb::Abstract_File
void make_readonly ()
 
void make_writable ()
 

Protected Attributes

Decoderdecoder
 

Additional Inherited Members

- Static Public Member Functions inherited from joedb::Abstract_File
static void reading_past_end_of_file ()
 
- Static Protected Attributes inherited from joedb::Abstract_File
static constexpr int64_t last_position = (1ULL << 63) - 1
 

Detailed Description

Definition at line 11 of file Readonly_Encoded_File.h.

Constructor & Destructor Documentation

◆ Readonly_Encoded_File() [1/2]

joedb::Readonly_Encoded_File::Readonly_Encoded_File ( Decoder decoder,
const db::encoded_file::Database db,
const Abstract_File blob_reader,
Open_Mode  mode 
)
protected

Definition at line 61 of file Readonly_Encoded_File.cpp.

◆ Readonly_Encoded_File() [2/2]

joedb::Readonly_Encoded_File::Readonly_Encoded_File ( Decoder decoder,
const db::encoded_file::Database db,
const Abstract_File blob_reader 
)

Definition at line 78 of file Readonly_Encoded_File.cpp.

Member Function Documentation

◆ get_size()

int64_t joedb::Readonly_Encoded_File::get_size ( ) const
overridevirtual

Reimplemented from joedb::Abstract_File.

Definition at line 90 of file Readonly_Encoded_File.cpp.

◆ pread()

size_t joedb::Readonly_Encoded_File::pread ( char *  data,
size_t  size,
int64_t  offset 
) const
overrideprotectedvirtual

For very large reads, the returned value may be less than size, even if the end of the file is not reached. It is assumed that small reads (such as the 41 bytes of the joedb header) will not be truncated. 0 is returned if the end of the file is reached.

Reimplemented from joedb::Abstract_File.

Definition at line 6 of file Readonly_Encoded_File.cpp.

Member Data Documentation

◆ decoder

Decoder& joedb::Readonly_Encoded_File::decoder
protected

Definition at line 21 of file Readonly_Encoded_File.h.


The documentation for this class was generated from the following files: