30namespace Experimental {
36class TFileStorageInterface {
38 virtual void Flush() = 0;
39 virtual void Close() = 0;
40 virtual ~TFileStorageInterface() =
default;
48 TFileSharedPtrCtor(std::unique_ptr<TFileStorageInterface> &&storage):
TFile(
std::move(storage)) {}
60static void AddFilesToClose(std::weak_ptr<ROOT::Experimental::TFile> pFile)
63 std::vector<std::weak_ptr<ROOT::Experimental::TFile>> fFiles;
67 for (
auto &wFile: fFiles) {
68 if (
auto sFile = wFile.lock()) {
74 static CloseFiles_t closer;
76 std::lock_guard<std::mutex> lock(closer.fMutex);
77 closer.fFiles.emplace_back(pFile);
83class TV6Storage:
public ROOT::Experimental::Internal::TFileStorageInterface {
87 TV6Storage(
const std::string &
name,
const std::string &mode): fOldFile(::
TFile::Open(
name.c_str(), mode.c_str())) {}
89 void Flush() final { fOldFile->
Flush(); }
91 void Close() final { fOldFile->
Close(); }
93 ~TV6Storage() {
delete fOldFile; }
104 AddFilesToClose(
fFile);
110 std::string ret(mode);
112 ret +=
" CACHEREAD ";
114 ret +=
" TIMEOUT=" + std::to_string(opts.
fAsyncTimeout) +
" ";
118static std::mutex &GetCacheDirMutex()
120 static std::mutex sMutex;
124static std::unique_ptr<ROOT::Experimental::Internal::TFileStorageInterface>
129 struct SetCacheDirRAII_t {
130 std::string fOldCacheDir;
131 std::lock_guard<std::mutex> fLock;
133 SetCacheDirRAII_t(
bool need): fLock(GetCacheDirMutex())
141 if (!fOldCacheDir.empty())
146 auto v6storage = std::make_unique<TV6Storage>(std::string(
name), GetV6TFileOpts(mode, opts));
149 return std::unique_ptr<TFileStorageInterface>{std::move(v6storage)};
157 using namespace Internal;
158 auto file = std::make_shared<TFileSharedPtrCtor>(OpenV6TFile(
name,
"READ", opts));
166 using namespace Internal;
167 auto file = std::make_shared<TFileSharedPtrCtor>(OpenV6TFile(
name,
"CREATE", opts));
175 using namespace Internal;
176 auto file = std::make_shared<TFileSharedPtrCtor>(OpenV6TFile(
name,
"RECREATE", opts));
184 using namespace Internal;
185 auto file = std::make_shared<TFileSharedPtrCtor>(OpenV6TFile(
name,
"UPDATE", opts));
191 std::lock_guard<std::mutex> lock(GetCacheDirMutex());
200 std::lock_guard<std::mutex> lock(GetCacheDirMutex());
201 return ::TFile::GetCacheFileDir();
207 : fStorage(
std::move(storage))
224 fStorage->WriteMemoryWithType(
name, address, cl);
Key/value store of objects.
static TDirectory & Heap()
Dedicated, process-wide TDirectory.
Points to an object that stores or reads objects in ROOT's binary format.
TFilePtr(std::shared_ptr< TFile > &&)
Constructed by Open etc.
std::shared_ptr< TFile > fFile
static TFilePtr Recreate(std::string_view name, const Options_t &opts=Options_t())
Open a file with name for reading and writing.
TFile(std::unique_ptr< Internal::TFileStorageInterface > &&storage)
static TFilePtr Create(std::string_view name, const Options_t &opts=Options_t())
Open a file with name for reading and writing.
void WriteMemoryWithType(std::string_view name, const void *address, TClass *cl)
Serialize the object at address, using the object's TClass.
void Close()
Flush() and make the file non-writable: close it.
static std::string GetCacheDir()
Get the directory used for cached reads.
static TFilePtr Open(std::string_view name, const Options_t &opts=Options_t())
Open a file with name for reading.
~TFile()
Must not call Write() of all attached objects: some might not be needed to be written or writing migh...
void Flush()
Save all objects associated with this directory (including file header) to the storage medium.
static std::string SetCacheDir(std::string_view path)
Set the new directory used for cached reads, returns the old directory.
static TFilePtr OpenForUpdate(std::string_view name, const Options_t &opts=Options_t())
Open an existing file with name for reading and writing.
The ROOT global object gROOT contains a list of all defined classes.
virtual Int_t WriteObjectAny(const void *obj, const char *classname, const char *name, Option_t *option="", Int_t bufsize=0)
Write object from pointer of class classname in this directory.
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format.
virtual void Close(Option_t *option="")
Close a file.
static const char * GetCacheFileDir()
Get the directory where to locally stage/cache remote files.
static Bool_t SetCacheFileDir(ROOT::Internal::TStringView cacheDir, Bool_t operateDisconnected=kTRUE, Bool_t forceCacheread=kFALSE)
virtual void Flush()
Synchronize a file's in-memory and on-disk states.
Namespace for new ROOT classes and functions.
basic_string_view< char > string_view
Options for TFile construction.
bool fCachedRead
Whether the file should be cached before reading.
int fAsyncTimeout
Timeout for asynchronous opening.
bool fAsynchronousOpen
Whether the file should be opened asynchronously, if available.