Belle II Software  release-08-01-10
RootFileCreationManager Class Reference

This single instance class takes track of all open ROOT files open in "create" mode, usually meant for all the ntuple output modules. More...

#include <RootFileCreationManager.h>

Collaboration diagram for RootFileCreationManager:

Public Member Functions

std::shared_ptr< TFile > getFile (std::string, bool ignoreErrors=false)
 Get a file with a specific name, if is does not exist it will be created. More...
 

Static Public Member Functions

static RootFileCreationManagergetInstance ()
 Interface for the FileManager.
 

Private Member Functions

 RootFileCreationManager ()
 Constructor is private.
 
 RootFileCreationManager (RootFileCreationManager const &)=delete
 We so not want copy construction.
 
void operator= (RootFileCreationManager const &)=delete
 We do not need this interface.
 

Private Attributes

std::map< std::string, std::weak_ptr< TFile > > m_files
 store for the open files
 

Detailed Description

This single instance class takes track of all open ROOT files open in "create" mode, usually meant for all the ntuple output modules.

Multiple different users can use the same file if they provide the same filename. Currently there is no path name manipulation so "test.root" and "./test.root" are not the same filename. Please keep the shared_ptr returned by this class as long as you need the file to stay open. Temporary objects might not work.

The files are created and managed by this class. They get destroyed when the last user is freeing its copy. Users of this module should free their files in the terminate() function by just calling reset() on the shared_ptr.

Definition at line 35 of file RootFileCreationManager.h.


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