Classes | |
struct | CloseBeforeDelete |
Public Member Functions | |
DuplicateTreeSentry (TTree *tree) | |
TTree * | tree () const |
Private Member Functions | |
void | dup () |
DuplicateTreeSentry (DuplicateTreeSentry const &)=delete | |
DuplicateTreeSentry & | operator= (DuplicateTreeSentry const &)=delete |
Private Attributes | |
std::unique_ptr< TFile, CloseBeforeDelete > | file_ |
std::unique_ptr< TTree > | mytree_ = 0 |
TTree * | tree_ = 0 |
Currently, ROOT doesn't use any latency-hiding optimizations for fast-cloning. This causes a significant slowdown when doing fast-cloning over a high-latency network (30ms latency makes this multiple factors slower).
Accordingly, we allow sites to provide a separate hint on how to treat fast- cloning. The DuplicateTreeSentry allows us to implement it - given a tree we are about to clone, with the appropriate configs, this will re-open the file with lazy-download and re-open the tree. The new tree is appropriate for cloning. When the object is destroyed, the new file and tree are cleaned up.
Definition at line 39 of file RootOutputTree.cc.
|
inline |
Definition at line 42 of file RootOutputTree.cc.
|
privatedelete |
|
inlineprivate |
Definition at line 55 of file RootOutputTree.cc.
|
privatedelete |
|
inline |
Definition at line 48 of file RootOutputTree.cc.
Referenced by ZJetsTreeAnalyzer.ZJetsTreeAnalyzer::beginLoop(), MetTreeProducer.MetTreeProducer::declareVariables(), ZJetsTreeAnalyzer.ZJetsTreeAnalyzer::process(), and MetTreeProducer.MetTreeProducer::process().
|
private |
Note this relies on the implicit delete ordering - mytree_ (if non-null) must be deleted before file_. Do not reorder the class members!
Definition at line 82 of file RootOutputTree.cc.
|
private |
Definition at line 84 of file RootOutputTree.cc.
|
private |
Definition at line 83 of file RootOutputTree.cc.