Kodi Documentation 22.0
Kodi is an open source media player and entertainment hub.
Loading...
Searching...
No Matches
XFILE::COverrideFile Class Referenceabstract

#include <OverrideFile.h>

Inheritance diagram for XFILE::COverrideFile:
XFILE::IFile XFILE::CBlurayFile XFILE::CMultiPathFile XFILE::CPluginFile XFILE::CResourceFile XFILE::CSpecialProtocolFile XFILE::CVideoDatabaseFile

Public Member Functions

 COverrideFile (bool writable)
 
 ~COverrideFile () override
 
bool Open (const CURL &url) override
 
bool Exists (const CURL &url) override
 
int Stat (const CURL &url, struct __stat64 *buffer) override
 
int Stat (struct __stat64 *buffer) override
 
bool OpenForWrite (const CURL &url, bool bOverWrite=false) override
 
bool Delete (const CURL &url) override
 
bool Rename (const CURL &url, const CURL &urlnew) override
 
ssize_t Read (void *lpBuf, size_t uiBufSize) override
 
ssize_t Write (const void *lpBuf, size_t uiBufSize) override
 
int64_t Seek (int64_t iFilePosition, int iWhence=SEEK_SET) override
 
void Close () override
 
int64_t GetPosition () override
 
int64_t GetLength () override
 
- Public Member Functions inherited from XFILE::IFile
 IFile ()
 
virtual ~IFile ()
 
virtual bool ReOpen (const CURL &url)
 
virtual ReadLineResult ReadLine (char *buffer, std::size_t bufferSize)
 
virtual void Flush ()
 
virtual int Truncate (int64_t size)
 
virtual int GetChunkSize ()
 
virtual double GetDownloadSpeed ()
 
virtual bool SetHidden (const CURL &url, bool hidden)
 
virtual int IoControl (EIoControl request, void *param)
 
virtual const std::string GetProperty (XFILE::FileProperty type, const std::string &name="") const
 
virtual const std::vector< std::string > GetPropertyValues (XFILE::FileProperty type, const std::string &name="") const
 

Protected Member Functions

virtual std::string TranslatePath (const CURL &url)=0
 

Protected Attributes

CFile m_file
 
bool m_writable
 

Constructor & Destructor Documentation

◆ COverrideFile()

COverrideFile::COverrideFile ( bool writable)
explicit

◆ ~COverrideFile()

COverrideFile::~COverrideFile ( )
override

Member Function Documentation

◆ Close()

void COverrideFile::Close ( )
overridevirtual

Implements XFILE::IFile.

◆ Delete()

bool COverrideFile::Delete ( const CURL & url)
overridevirtual

Reimplemented from XFILE::IFile.

Reimplemented in XFILE::CPluginFile.

◆ Exists()

bool COverrideFile::Exists ( const CURL & url)
overridevirtual

Implements XFILE::IFile.

Reimplemented in XFILE::CPluginFile.

◆ GetLength()

int64_t COverrideFile::GetLength ( )
overridevirtual

Implements XFILE::IFile.

◆ GetPosition()

int64_t COverrideFile::GetPosition ( )
overridevirtual

Implements XFILE::IFile.

◆ Open()

bool COverrideFile::Open ( const CURL & url)
overridevirtual

Implements XFILE::IFile.

Reimplemented in XFILE::CPluginFile.

◆ OpenForWrite()

bool COverrideFile::OpenForWrite ( const CURL & url,
bool bOverWrite = false )
overridevirtual

Reimplemented from XFILE::IFile.

Reimplemented in XFILE::CPluginFile.

◆ Read()

ssize_t COverrideFile::Read ( void * bufPtr,
size_t bufSize )
overridevirtual

Attempt to read bufSize bytes from currently opened file into buffer bufPtr.

Parameters
bufPtrpointer to buffer
bufSizesize of the buffer
Returns
number of successfully read bytes if any bytes were read and stored in buffer, zero if no bytes are available to read (end of file was reached) or undetectable error occur, -1 in case of any explicit error

Implements XFILE::IFile.

◆ Rename()

bool COverrideFile::Rename ( const CURL & url,
const CURL & urlnew )
overridevirtual

Reimplemented from XFILE::IFile.

Reimplemented in XFILE::CPluginFile.

◆ Seek()

int64_t COverrideFile::Seek ( int64_t iFilePosition,
int iWhence = SEEK_SET )
overridevirtual

Implements XFILE::IFile.

◆ Stat() [1/2]

int COverrideFile::Stat ( const CURL & url,
struct __stat64 * buffer )
overridevirtual

Fills struct __stat64 with information about file specified by url. For st_mode function will set correctly _S_IFDIR (directory) flag and may set _S_IREAD (read permission), _S_IWRITE (write permission) flags if such information is available. Function may set st_size (file size), st_atime, st_mtime, st_ctime (access, modification, creation times). Any other flags and members of __stat64 that didn't updated with actual file information will be set to zero (st_nlink can be set ether to 1 or zero).

Parameters
urlspecifies requested file
bufferpointer to __stat64 buffer to receive information about file
Returns
zero of success, -1 otherwise.

Implements XFILE::IFile.

Reimplemented in XFILE::CPluginFile.

◆ Stat() [2/2]

int COverrideFile::Stat ( struct __stat64 * buffer)
overridevirtual

Fills struct __stat64 with information about currently open file For st_mode function will set correctly _S_IFDIR (directory) flag and may set _S_IREAD (read permission), _S_IWRITE (write permission) flags if such information is available. Function may set st_size (file size), st_atime, st_mtime, st_ctime (access, modification, creation times). Any other flags and members of __stat64 that didn't updated with actual file information will be set to zero (st_nlink can be set ether to 1 or zero).

Parameters
bufferpointer to __stat64 buffer to receive information about file
Returns
zero of success, -1 otherwise.

Reimplemented from XFILE::IFile.

Reimplemented in XFILE::CPluginFile.

◆ TranslatePath()

virtual std::string XFILE::COverrideFile::TranslatePath ( const CURL & url)
protectedpure virtual

◆ Write()

ssize_t COverrideFile::Write ( const void * bufPtr,
size_t bufSize )
overridevirtual

Attempt to write bufSize bytes from buffer bufPtr into currently opened file.

Parameters
bufPtrpointer to buffer
bufSizesize of the buffer
Returns
number of successfully written bytes if any bytes were written, zero if no bytes were written and no detectable error occur, -1 in case of any explicit error

Reimplemented from XFILE::IFile.

Member Data Documentation

◆ m_file

CFile XFILE::COverrideFile::m_file
protected

◆ m_writable

bool XFILE::COverrideFile::m_writable
protected

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