Logo ROOT   6.30.04
Reference Guide
 All Namespaces Files Pages
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 }