Logo ROOT   6.12/07
Reference Guide
copyFiles.C
Go to the documentation of this file.
1 /// \file
2 /// \ingroup tutorial_io
3 /// \notebook -nodraw
4 /// Example of script showing how to copy all objects (including directories)
5 /// from a source file.
6 /// For each input file, a new directory is created in the current directory
7 /// with the name of the source file.
8 /// After the execution of:
9 /// ~~~{.bash}
10 /// root [0] .x copyFiles.C
11 /// ~~~
12 /// the file result.root will contain 4 subdirectories:
13 /// "tot100.root", "hsimple.root", "hs1.root","hs2.root"
14 ///
15 /// \macro_code
16 ///
17 /// \author Rene Brun
18 
19 #include "TROOT.h"
20 #include "TKey.h"
21 #include "TFile.h"
22 #include "TSystem.h"
23 #include "TTree.h"
24 
25 void CopyDir(TDirectory *source) {
26  //copy all objects and subdirs of directory source as a subdir of the current directory
27  source->ls();
28  TDirectory *savdir = gDirectory;
29  TDirectory *adir = savdir->mkdir(source->GetName());
30  adir->cd();
31  //loop on all entries of this directory
32  TKey *key;
33  //Loop in reverse order to make sure that the order of cycles is
34  //preserved.
35  TIter nextkey(source->GetListOfKeys(),kIterBackward);
36  while ((key = (TKey*)nextkey())) {
37  const char *classname = key->GetClassName();
38  TClass *cl = gROOT->GetClass(classname);
39  if (!cl) continue;
40  if (cl->InheritsFrom(TDirectory::Class())) {
41  source->cd(key->GetName());
42  TDirectory *subdir = gDirectory;
43  adir->cd();
44  CopyDir(subdir);
45  adir->cd();
46  } else if (cl->InheritsFrom(TTree::Class())) {
47  TTree *T = (TTree*)source->Get(key->GetName());
48  // Avoid writing the data of a TTree more than once.
49  // Note this assume that older cycles are (as expected) older
50  // snapshots of the TTree meta data.
51  if (!adir->FindObject(key->GetName())) {
52  adir->cd();
53  TTree *newT = T->CloneTree(-1,"fast");
54  newT->Write();
55  }
56  } else {
57  source->cd();
58  TObject *obj = key->ReadObj();
59  adir->cd();
60  obj->Write();
61  delete obj;
62  }
63  }
64  adir->SaveSelf(kTRUE);
65  savdir->cd();
66 }
67 void CopyFile(const char *fname) {
68  //Copy all objects and subdirs of file fname as a subdir of the current directory
69  TDirectory *target = gDirectory;
70  TFile *f = TFile::Open(fname);
71  if (!f || f->IsZombie()) {
72  printf("Cannot copy file: %s\n",fname);
73  target->cd();
74  return;
75  }
76  target->cd();
77  CopyDir(f);
78  delete f;
79  target->cd();
80 }
81 void copyFiles() {
82  //prepare files to be copied
83  if(gSystem->AccessPathName("tot100.root")) {
84  gSystem->CopyFile("hsimple.root", "tot100.root");
85  gSystem->CopyFile("hsimple.root", "hs1.root");
86  gSystem->CopyFile("hsimple.root", "hs2.root");
87  }
88  //main function copying 4 files as subdirectories of a new file
89  TFile *f = new TFile("result.root","recreate");
90  CopyFile("tot100.root");
91  CopyFile("hsimple.root");
92  CopyFile("hs1.root");
93  CopyFile("hs2.root");
94  f->ls();
95  delete f;
96 }
virtual const char * GetName() const
Returns name of object.
Definition: TNamed.h:47
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write this object to the current directory.
Definition: TObject.cxx:785
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
Returns FALSE if one can access a file using the specified access mode.
Definition: TSystem.cxx:1276
virtual TList * GetListOfKeys() const
Definition: TDirectory.h:150
virtual TObject * Get(const char *namecycle)
Return pointer to object identified by namecycle.
Definition: TDirectory.cxx:805
double T(double x)
Definition: ChebyshevPol.h:34
virtual const char * GetClassName() const
Definition: TKey.h:71
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format...
Definition: TFile.h:46
virtual TObject * FindObject(const char *name) const
Find object by name in the list of memory objects.
Definition: TDirectory.cxx:723
#define gROOT
Definition: TROOT.h:402
virtual TDirectory * mkdir(const char *name, const char *title="")
Create a sub-directory "a" or a hierarchy of sub-directories "a/b/c/...".
virtual TTree * CloneTree(Long64_t nentries=-1, Option_t *option="")
Create a clone of this tree and copy nentries.
Definition: TTree.cxx:2961
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=1, Int_t netopt=0)
Create / open a file.
Definition: TFile.cxx:3950
void Class()
Definition: Class.C:29
Book space in a file, create I/O buffers, to fill them, (un)compress them.
Definition: TKey.h:24
R__ALWAYS_INLINE Bool_t IsZombie() const
Definition: TObject.h:134
virtual Int_t Write(const char *name=0, Int_t option=0, Int_t bufsize=0)
Write this object to the current directory.
Definition: TTree.cxx:9212
R__EXTERN TSystem * gSystem
Definition: TSystem.h:540
The ROOT global object gROOT contains a list of all defined classes.
Definition: TClass.h:75
Bool_t InheritsFrom(const char *cl) const
Return kTRUE if this class inherits from a class with name "classname".
Definition: TClass.cxx:4688
virtual void SaveSelf(Bool_t=kFALSE)
Definition: TDirectory.h:181
Describe directory structure in memory.
Definition: TDirectory.h:34
Mother of all ROOT objects.
Definition: TObject.h:37
virtual TObject * ReadObj()
To read a TObject* from the file.
Definition: TKey.cxx:722
virtual Bool_t cd(const char *path=0)
Change current directory to "this" directory.
Definition: TDirectory.cxx:497
virtual void ls(Option_t *option="") const
List Directory contents.
virtual int CopyFile(const char *from, const char *to, Bool_t overwrite=kFALSE)
Copy a file.
Definition: TSystem.cxx:1321
A TTree object has a header with a name and a title.
Definition: TTree.h:70
#define gDirectory
Definition: TDirectory.h:213
const Bool_t kIterBackward
Definition: TCollection.h:41
virtual void ls(Option_t *option="") const
List file contents.
Definition: TFile.cxx:1383
const Bool_t kTRUE
Definition: RtypesCore.h:87