You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-06-12 05:01:56 +03:00
Checkpointing some stuff. No way it'll build yet.
This commit is contained in:
106
utils/cloudio/SMDataFile.cpp
Normal file
106
utils/cloudio/SMDataFile.cpp
Normal file
@ -0,0 +1,106 @@
|
||||
// copy licensing stuff here
|
||||
|
||||
|
||||
|
||||
#include "SMDataFile.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
namespace idbdatafile
|
||||
{
|
||||
|
||||
SMDataFile::SMDataFile(const char *name, int _openmode, const struct stat &_stat) :
|
||||
IDBDataFile(name)
|
||||
{
|
||||
openmode = _openmode;
|
||||
// the 'a' file open mode is the only one that starts at EOF
|
||||
if ((openmode & O_APPEND) && !(openmode & O_RDWR))
|
||||
position = _stat.st_size;
|
||||
else
|
||||
position = 0;
|
||||
comm = SMComm::get();
|
||||
}
|
||||
|
||||
ssize_t SMDataFile::pread(void *buf, off64_t offset, size_t count)
|
||||
{
|
||||
return comm->pread(name(), buf, count, offset);
|
||||
}
|
||||
|
||||
ssize_t SMDataFile::read(void *buf, size_t count)
|
||||
{
|
||||
ssize_t ret = comm->pread(name(), buf, count, position);
|
||||
position += ret;
|
||||
return ret;
|
||||
}
|
||||
|
||||
ssize_t SMDataFile::write(const void *buf, size_t count)
|
||||
{
|
||||
if (openmode & O_APPEND)
|
||||
return comm->append(name(), buf, count);
|
||||
ssize_t ret = comm->pwrite(name(), buf, count, position);
|
||||
position += ret;
|
||||
return ret;
|
||||
}
|
||||
|
||||
int SMDataFile::seek(off64_t offset, int whence)
|
||||
{
|
||||
switch (whence) {
|
||||
case SEEK_SET:
|
||||
position = offset;
|
||||
break;
|
||||
case SEEK_CUR:
|
||||
position += offset;
|
||||
break;
|
||||
case SEEK_END:
|
||||
struct stat _stat;
|
||||
int err = comm->stat(name(), &_stat);
|
||||
if (err)
|
||||
return err;
|
||||
position = _stat.st_size + offset;
|
||||
break;
|
||||
default:
|
||||
errno = EINVAL;
|
||||
return -1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int SMDataFile::truncate(off64_t length)
|
||||
{
|
||||
return comm->truncate(name(), length);
|
||||
}
|
||||
|
||||
off64_t SMDataFile::size()
|
||||
{
|
||||
struct stat _stat;
|
||||
int err = comm->stat(name(), &_stat);
|
||||
|
||||
if (err)
|
||||
return err;
|
||||
return _stat.st_size;
|
||||
}
|
||||
|
||||
off64_t SMDataFile::tell()
|
||||
{
|
||||
return position;
|
||||
}
|
||||
|
||||
int SMDataFile::flush()
|
||||
{
|
||||
return 0; // writes are synchronous b/c of replication. If we allow asynchronous replication,
|
||||
// then we need to implement a flush() cmd in SMComm.
|
||||
}
|
||||
|
||||
time_t SMDataFile::mtime()
|
||||
{
|
||||
struct stat _stat;
|
||||
int err = comm->stat(name(), &_stat);
|
||||
|
||||
if (err)
|
||||
return (time_t) err;
|
||||
return _stat.st_mtime;
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
Reference in New Issue
Block a user