36 Debug("TMemFile", "%s", x);
61 fPrevious(previous), fNext(0), fBuffer(0),
fSize(0)
74 fPrevious(nullptr), fNext(nullptr), fBuffer(
data),
fSize(size)
105 else if (
fOption ==
"RECREATE")
120 TFile(path,
"WEB",
"read-only memfile", 0 ),
126 SysError(
"TMemFile",
"file %s can not be opened", path);
143 const char *ftitle,
Int_t compress) :
144 TMemFile(path, nullptr, -1, option, ftitle, compress) {}
150 const char *ftitle,
Int_t compress):
151 TFile(path,
"WEB", ftitle, compress), fBlockList(size),
152 fSize(size), fSysOffset(0), fBlockSeek(&(fBlockList)), fBlockOffset(0)
157 Int_t mode = O_RDWR | O_CREAT;
160 fD =
SysOpen(path, O_RDWR | O_CREAT, 0644);
162 SysError(
"TMemFile",
"file %s can not be opened", path);
170 SysError(
"TMemFile",
"file %s can not be opened for reading", path);
193 TFile(orig.GetEndpointUrl()->GetUrl(),
"WEB", orig.GetTitle(),
194 orig.GetCompressionSettings() ), fBlockList(orig.GetEND()), fExternalData(orig.fExternalData),
195 fSize(orig.GetEND()), fSysOffset(0), fBlockSeek(&(fBlockList)), fBlockOffset(0)
261 current = current->
fNext;
279 if (strcmp(option,
"blocks")==0) {
283 Printf(
"TMemBlock: %d size=%lld addr=%p curr=%p prev=%p next=%p",
286 current = current->
fNext;
341 gROOT->GetListOfFiles()->Remove(
this);
352 while ((idcur = next())) {
370 while( (key = (
TKey*)next()) ) {
372 Warning(
"ResetObjects",
"Key/Object %s is not attached to the directory %s and can not be ResetAfterMerge correctly",
380 listHargs.
Form(
"(TFileMergeInfo*)0x%lx",(
ULong_t)info);
384 while ((idcur = next())) {
385 TClass *objcl = idcur->IsA();
390 }
else if (idcur->IsA()->GetMethodWithPrototype(
"ResetAfterMerge",
"TFileMergeInfo*") ) {
392 idcur->
Execute(
"ResetAfterMerge", listHargs.
Data(), &error);
394 Error(
"ResetObjects",
"calling ResetAfterMerge() on '%s' failed.",
436 buf = (
char*)buf + sublen;
437 Int_t len_left = len - sublen;
478 if (whence == SEEK_SET) {
488 }
else if (whence == SEEK_CUR) {
492 }
else if (offset > 0) {
512 SysError(
"TMemFile",
"Unable to seek past the beginning of file");
531 }
else if (whence == SEEK_END) {
533 SysError(
"TMemFile",
"Unable to seek past end of file");
537 SysError(
"TMemFile",
"Unable to seek to end of file");
542 SysError(
"TMemFile",
"Unknown whence!");
604 buf = (
char*)buf + sublen;
605 Int_t len_left = len - sublen;
void tobuf(char *&buf, Bool_t x)
R__EXTERN TVirtualMutex * gROOTMutex
R__EXTERN TSystem * gSystem
#define R__LOCKGUARD(mutex)
Buffer base class used for serializing objects.
The ROOT global object gROOT contains a list of all defined classes.
ROOT::ResetAfterMergeFunc_t GetResetAfterMerge() const
A ROOT file is structured in Directories (like a file system).
Int_t fNbytesKeys
Number of bytes for the keys.
Long64_t fSeekKeys
Location of Keys record on file.
Bool_t fWritable
True if directory is writable.
virtual TList * GetListOfKeys() const
virtual TList * GetList() const
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format.
Int_t fReadCalls
Number of read calls ( not counting the cache calls )
Long64_t fBytesRead
Number of bytes read from this file.
Double_t fSum2Buffer
Sum of squares of buffer sizes of objects written so far.
virtual void Close(Option_t *option="")
Close a file.
TArrayC * fClassIndex
!Index of TStreamerInfo classes written to this file
Long64_t fSeekInfo
Location on disk of StreamerInfo record.
Bool_t fMustFlush
!True if the file buffers must be flushed
Int_t fNbytesInfo
Number of bytes for StreamerInfo record.
virtual void Init(Bool_t create)
Initialize a TFile object.
TString fOption
File options.
TFileCacheRead * fCacheRead
!Pointer to the read cache (if any)
TObjArray * fProcessIDs
!Array of pointers to TProcessIDs
Long64_t fBytesReadExtra
Number of extra bytes (overhead) read by the readahead buffer.
Long64_t fBytesWrite
Number of bytes written to this file.
TList * fFree
Free segments linked list table.
Bool_t fInitDone
!True if the file has been initialized
TFileCacheWrite * fCacheWrite
!Pointer to the write cache (if any)
Option_t * GetOption() const
Long64_t fOffset
!Seek offset cache
Double_t fSumBuffer
Sum of buffer sizes of objects written so far.
Int_t fNProcessIDs
Number of TProcessID written to this file.
Int_t fWritten
Number of objects written so far.
Book space in a file, create I/O buffers, to fill them, (un)compress them.
virtual TObject * FindObject(const char *name) const
Delete a TObjLink object.
virtual void Delete(Option_t *option="")
Remove all objects from the list AND delete all heap based objects.
A TMemFile is like a normal TFile except that it reads and writes only from memory.
const ExternalDataPtr_t fExternalData
shared file data / content
bool NeedsExistingFile(EMode mode) const
Int_t SysRead(Int_t fd, void *buf, Int_t len)
Read specified number of bytes from current offset into the buffer.
Int_t SysStat(Int_t fd, Long_t *id, Long64_t *size, Long_t *flags, Long_t *modtime)
Perform a stat on the HDFS file; see TFile::SysStat().
Int_t SysClose(Int_t fd)
Close the mem file.
Long64_t fBlockOffset
Seek offset within the block.
EMode ParseOption(Option_t *option)
Parse option strings and set fOption.
TMemBlock * fBlockSeek
Pointer to the block we seeked to.
Long64_t fSize
Total file size (sum of the size of the chunks)
TMemBlock fBlockList
Collection of memory blocks of size fgDefaultBlockSize.
std::shared_ptr< const std::vector< char > > ExternalDataPtr_t
TMemFile(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=ROOT::RCompressionSetting::EDefaults::kUseGeneralPurpose)
Usual Constructor. See the TFile constructor for details.
Long64_t fSysOffset
Seek offset in file.
bool NeedsToWrite(EMode mode) const
Int_t SysSync(Int_t fd)
Sync remaining data to disk.
Int_t SysWriteImpl(Int_t fd, const void *buf, Long64_t len)
Write a buffer into the file.
Int_t SysWrite(Int_t fd, const void *buf, Int_t len)
Write a buffer into the file.
virtual void Print(Option_t *option="") const
Print all objects in the file.
static Long64_t fgDefaultBlockSize
void ResetErrno() const
Simply calls TSystem::ResetErrno().
Int_t SysOpen(const char *pathname, Int_t flags, UInt_t mode)
Open a file in 'MemFile'.
virtual Long64_t GetSize() const
Return the current size of the memory file.
void ResetObjects(TDirectoryFile *, TFileMergeInfo *) const
Wipe all the data from the permanent buffer but keep, the in-memory object alive.
void ResetAfterMerge(TFileMergeInfo *)
Wipe all the data from the permanent buffer but keep, the in-memory object alive.
virtual ~TMemFile()
Close and clean-up file.
Int_t SysReadImpl(Int_t fd, void *buf, Long64_t len)
Read specified number of bytes from current offset into the buffer.
virtual Long64_t CopyTo(void *to, Long64_t maxsize) const
Copy the binary representation of the TMemFile into the memory area starting at 'to' and of length at...
Long64_t SysSeek(Int_t fd, Long64_t offset, Int_t whence)
Seek to a specified position in the file.
virtual const char * GetTitle() const
Returns title of object.
virtual const char * GetName() const
Returns name of object.
Mother of all ROOT objects.
virtual const char * GetName() const
Returns name of object.
virtual void Execute(const char *method, const char *params, Int_t *error=0)
Execute method on this object with the given parameter string, e.g.
virtual void SysError(const char *method, const char *msgfmt,...) const
Issue system error message.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
void MayNotUse(const char *method) const
Use this method to signal that a method (defined in a base class) may not be called in a derived clas...
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
const char * Data() const
void ToUpper()
Change string to upper case.
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
static void ResetErrno()
Static function resetting system error number.
void SetErrorStr(const char *errstr)
Set the system error string.
~TMemBlock()
Usual destructors. Delete the block memory.
void CreateNext(Long64_t size)
TMemBlock()
Default constructor.