[root] / trunk / tree / treeplayer / src / TBranchProxy.cxx Repository:
ViewVC logotype

Log of /trunk/tree/treeplayer/src/TBranchProxy.cxx

Parent Directory Parent Directory


Links to HEAD: (view) (download) (as text) (annotate)
Sticky Revision:

Revision 44507 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Mon Jun 4 12:30:41 2012 UTC (2 years, 7 months ago) by axel
File length: 14603 byte(s)
Diff to previous 43993
Remove
  using namespace std;
from Riostream.h, which has huge consequences for all of ROOT.
Riostream.h is now a simple wrapper for fstream, iostream, iomanip for backward compatibility; Riosfwd.h simply wraps iosfwd.

Because of templates and their inline functions, Riostream.h needed to be included in headers, too (e.g. TParameter.h), which violated the assumption that Riostream.h is not exposing its using namespace std to headers.
ROOT now requires R__ANSISTREAM, R__SSTREAM, which does not change the set of supported compilers.

Without "using namespace std", several identifiers are now prefixed by std::; e.g. roofit/* source files now have a using namespace std to keep their coding style.
TFile::MakeProject() now generates "using namespace std" to convert the CINT-style class names into C++ ones.

Revision 43993 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Fri Apr 27 16:23:16 2012 UTC (2 years, 8 months ago) by pcanal
File length: 14563 byte(s)
Diff to previous 41244
Fix coverity issues
Dereference null return:
32943,32945,36325,36329: TFormLeafInfo::GetLocalValuePointer
33253: TTreeFormula::EvalObject
33763: CloneTree
33258: GetBasket
34034: In DropBuffers (in addition avoid reading the basket when the intend is to drop the content from memory!)
36307: TTree::BuildIndex
36328: DrawCopy
36332: GetStreamerInfoCache
33025: BuildStreamerInfo
42469: Clone
33436: MakeIterator
Dereference after null check.
42470: in ImportStreamerInfo
33138: in TEntryListArray::Enter
Unchecked return value:
32049, 32050: TBranchProxy::Read and Setup
Mixed enums:
32705,32706: TClass::fStreamerType (and also name the enum type).

Revision 41244 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Thu Oct 6 19:42:35 2011 UTC (3 years, 3 months ago) by pcanal
File length: 14496 byte(s)
Diff to previous 36449
Fix Coverity issues:

TBranchSTL: cov 34339 Resource leak (false positive)
TTableDescriptor.cxx: cov 34219,34220 explicit null dereference
TSQLStructure.cxx: cov 34204,34205,34206 Explicit null dereferenced 
TTabCom.cxx: cov 34168 Explicit null dereferenced 
TClassRef.cxx: cove 34165 Explicit null dereferenced (false positive but still confusing coding).
TBufferXML.cxx: 34070 Explicit null dereferenced
TFriendProxyDescriptor.cxx: cov 34066 Uninitialized scalar field
TTreeCloner.cxx: cov 34034057 Dereference null return (stat) 63 Uninitialized scalar field 
TParallelCoordEditor.cxx: 34051,34059,34060,34061 Dereference null return value
TParallelCoord.cxx: 34050,34056, 34057 Dereference null return (stat) 
TBranchProxy.h: 34048 Dereference null return value 
TBranchProxy.cxx: 34043,34044,34045 Dereference null return value
TTree.cxx: 34039 Dereference null return value
TTreePlayer.cxx: 34037 Dereference null return value 
TLeafC.cxx: 34036 Dereference null return value

Revision 36449 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Thu Oct 28 20:52:17 2010 UTC (4 years, 2 months ago) by pcanal
File length: 14373 byte(s)
Diff to previous 36169
Fix several issues with then handling of vector of object related to the bug report:
<http://savannah.cern.ch/bugs/?74451>

Revision 36169 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Thu Oct 7 16:06:18 2010 UTC (4 years, 3 months ago) by pcanal
File length: 14342 byte(s)
Diff to previous 35450
Fix Coverity reports 21804 through 21812 (null returns)

Revision 35450 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Mon Sep 20 12:36:11 2010 UTC (4 years, 4 months ago) by pcanal
File length: 14104 byte(s)
Diff to previous 34239
Fix Coverity reports

TDatabasePDG.cxx: #11418 getc returns an int
TTree.cxx: #10577 unused variable
TTreeFormula.cxx: #10795,#10796,#13272,#13273,#13274,#14173 strcat -> strncat, strcpy -> strncpy
TTreePlayer.cxx: #10891,#10892,#14169,#14170,#14172 strcpy -> strncpy
TStreamerElement.cxx: #12537,#13200,#13318,#13586,#13587,#13588,#13589,#13590,#13591,#13596,#13597,#13598 strcpy,sprintf -> strncpy,snprintf (or TString)
TStreamerInfo.cxx: #13470,#13787,#13788 strcpy,sprintf -> strncpy,snprintf (or TString)
TBranchProxy.cxx: null pointer dereference.
TBranch.cxx: #10689 null pointer dereference.
loadfile.cxx: #10767,#12387.#12388,#12389,#12521,#12522,#13514,etc.. strcpy,sprintf -> strncpy,snprintf  (or TString)
TFileDrawMap.cxx: #10893,#10894,#10895,#13460,#14176,#14177,#14718,#14179 strcpy,sprintf -> strncpy,snprintf  (or TString)
TFile.cxx: #13789,#13193,#13450 strcpy,sprintf -> strncpy,snprintf  (or TString)
TMethod.cxx: #10802,#13310 strcpy,sprintf -> strncpy,snprintf  (or TString)
TClass.cxx: #10814,#13122,#13467,#13468,#13490 strcpy,sprintf -> strncpy,snprintf  (or TString)
TDataMember.cxx: #10825,#13241,#13329,#13330,#13584 strcpy,sprintf -> strncpy,snprintf  (or TString)
TFormula.cxx: #13263,#13783 sprintf -> snprintf or TString
stlLoader.cxx: #13599 static array -> G__FastAllocString

Revision 34239 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Wed Jun 30 12:59:51 2010 UTC (4 years, 6 months ago) by brun
File length: 13959 byte(s)
Diff to previous 32413
Fix missing armuments in format statements

Revision 32413 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Thu Feb 25 21:03:40 2010 UTC (4 years, 10 months ago) by pcanal
File length: 13949 byte(s)
Diff to previous 28356
Add missing re-initialization

Revision 28356 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Fri Apr 24 20:28:37 2009 UTC (5 years, 9 months ago) by pcanal
File length: 13929 byte(s)
Diff to previous 28346
additional fix needed for r28346

Revision 28346 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Fri Apr 24 12:39:14 2009 UTC (5 years, 9 months ago) by pcanal
File length: 13877 byte(s)
Diff to previous 23466
Correct MakeProxy's handling of a branch created with a leaflist with more than one leaf
(usually used for C-struct).  This fixes the Savannah report #42984.

Revision 23466 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Wed Apr 23 13:52:45 2008 UTC (6 years, 9 months ago) by brun
File length: 13595 byte(s)
Diff to previous 22902
Fix shadowed variables

Revision 22902 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Mon Mar 31 09:48:42 2008 UTC (6 years, 9 months ago) by rdm
File length: 13593 byte(s)
Diff to previous 21547
move tree, treeplayer and treeviewer under tree meta directory.

Revision 21547 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Thu Dec 20 18:19:50 2007 UTC (7 years, 1 month ago) by pcanal
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 13593 byte(s)
Diff to previous 20882
Add ClassImp and doc markers

Revision 20882 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Mon Nov 19 11:31:26 2007 UTC (7 years, 2 months ago) by rdm
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 13409 byte(s)
Diff to previous 19826
Set property svn:eol-style LF on all source and Makefiles. This should avoid
problems with Win32 line endings ending up in the repository. All MS tools
support LF eols fine.

Revision 19826 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Wed Sep 19 19:56:11 2007 UTC (7 years, 4 months ago) by rdm
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 13409 byte(s)
Diff to previous 19825
imported svn:keywords Id property

Revision 19825 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Wed Sep 19 19:49:10 2007 UTC (7 years, 4 months ago) by rdm
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 13466 byte(s)
Diff to previous 19540
remove :$ from tag line

Revision 19540 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Fri Aug 3 13:33:49 2007 UTC (7 years, 5 months ago) by pcanal
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 13476 byte(s)
Diff to previous 19438
Add support for STL containers in MakeProxy

Revision 19438 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Mon Jul 23 17:07:48 2007 UTC (7 years, 6 months ago) by pcanal
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 12249 byte(s)
Diff to previous 17615
Rewrite the parsing of the TBranchElement by looping over the TStreamerElement
instead of the TBranchElement (hence emulating somewhat unroll instead of
guessing the connection between branch and element)
Fix support for base class (in particular when inside a TClonesArray)
Fix support for sub-objects without their own branch ('missing node').

Revision 17615 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Thu Feb 1 15:26:19 2007 UTC (7 years, 11 months ago) by brun
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 11968 byte(s)
Diff to previous 17579
Use forward declarations instead of includes.

Revision 17579 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Tue Jan 30 11:24:32 2007 UTC (7 years, 11 months ago) by brun
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 11883 byte(s)
Diff to previous 15139
-Replace calls to gROOT->GetClass by TClass::GetClass
-Remove unused references to TROOT.h

Revision 15139 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Tue May 23 08:15:50 2006 UTC (8 years, 8 months ago) by brun
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 11879 byte(s)
Diff to previous 14745
Implement missing copy constructors and assignement operators

Revision 14745 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Wed Apr 19 08:22:26 2006 UTC (8 years, 9 months ago) by rdm
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 11883 byte(s)
Diff to previous 13210
Change the TError.h macros:
Assert   ->  R__ASSERT
Check    ->  R__CHECK
Change the TCollection.h macro:
ForEach  ->  R__FOR_EACH
This to avoid potential problems due too trivial macro names.
The old macros will be removed in the next release. Currently
they will print out warning messages with the advice to move
to the new macro names.

Revision 13210 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Fri Nov 11 23:21:43 2005 UTC (9 years, 2 months ago) by pcanal
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 11874 byte(s)
Diff to previous 12602
Update the spacing and documentation to match the coding rule

Revision 12602 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Sat Sep 3 02:26:31 2005 UTC (9 years, 4 months ago) by pcanal
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 12212 byte(s)
Diff to previous 9827
Fix to follow coding conventions

Revision 9827 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Mon Aug 23 19:27:33 2004 UTC (10 years, 5 months ago) by brun
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 12156 byte(s)
Diff to previous 9335
From Philippe:
The attached patch fixes a problem with counting the number
of branch used.  Some branches were counted twice as being
used and hence some branches where skipped.
This patch also fix a problem with the address calculation
for some (complex) object hierachy.

Revision 9335 - (view) (download) (as text) (annotate) - [select for diffs]
Modified Mon Jun 28 16:38:00 2004 UTC (10 years, 6 months ago) by brun
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 12087 byte(s)
Diff to previous 9323
From Philippe:
Fix a problem with CR/LF characters at the end of the lines
giving a problem with gcc2.95

Revision 9323 - (view) (download) (as text) (annotate) - [select for diffs]
Added Fri Jun 25 18:42:19 2004 UTC (10 years, 7 months ago) by brun
Original Path: trunk/treeplayer/src/TBranchProxy.cxx
File length: 12449 byte(s)
From Philippe:
This introduces the implementation of MakeProxy and Draw of a C++ function which
is run in a context where the name of the branches can be used as a C++ variable.

In TTree, we added a method MakeProxy and modified the behavior of TTree::Draw
(by modifying TTreePlayer::DrawSelect).
In TTreePlayer we added TTreePlayer::MakeProxy and TTreePlayer::DrawScript

TTreeProxyGenerator is a new class implementing the generation of the skeleton.
(TBranchProxyDescriptor and TBranchProxyClassDescriptor are helper class).

A priori the tree parsing done by TTreeProxyGenerator could be used to
re-implement improved an improve MakeClass/MakeSelector.

TBranchProxy is the base class of a new hierarchy of classes implementing the
indirect access to the branch of a TTree.  The main features are
        - protection against array out-of-bound
        - on-demand loading of branches
        - ability to use the 'branchname' as if it was a data member.
For example with Event.root:
                Double_t somepx = fTracks.fPx[2];
somepx is updated with the current fPx of the 3rd track.

TTree::Draw as been updated so that upon seeing
        tree->Draw("h1analysis.C+","")
        tree->Draw("h1analysis.C+","h1analysisCut.C")

If h1analysis.C (and h1analysisCut.C in the 2nd case) are readable files,
the new MakeProxy will be used __instead of__ TTreeFormula.  Currently
TTreeFormula and 'TBranchProxy' can not be used together.

In which case the means of parameters to TTree::Draw are more like:
   Int_t TTree::Draw(const char *filename, const char *cutfilename,
                     Option_t *option="",
                     Int_t nentries=1000000000, Int_t firstentry=0);

Both files are expected to be source file which contains at least a free
standing function with the signature:
        x_t filename();
and
        y_t cutfilename();

x_t and y_t needs to be type that can convert respectively to a double
and a bool (because the code does; if(cutfilename()) htemp->Fill(filename());

The 2 free standing function are run in a context such that the branch names
are available as locally avaiable variable of the correct (read-only) type.

If 'filename' is suffixes with an ACLiC mode, the ACLiC mode is inforced
(Note that at this time, interpreted mode is not supported and if no ACLiC
mode is specified, a '+' is used by default).

The generated script file (currently generatedSel.h but subject to change in
a future release) is intentionally __not__ deleted at the end of the processing.
Also if the file already exist, it is updated if and only if the new version
is different.  In particular this means issues twice in a row:
        tree->Draw("Script.C+");
does __not__ result in a second (useless) compilation.

For example to draw px in hsimple.root just have a hsimple.C file:
        double hsimple() {
           return px;
        }
and do:
        new TFile("hsimple.root")
        tree = ntuple
        draw(tree,"hsimple.C");
or
        draw(tree,"hsimple.C+");

I attached a few examples, including a full port of the h1analysis tutorials.

To use the h1analysis do:
        TChain chain("h42");
      chain.Add("$H1/dstarmb.root");  //  21330730 bytes  21920 events
        chain.Add("$H1/dstarp1a.root"); //  71464503 bytes  73243 events
      chain.Add("$H1/dstarp1b.root"); //  83827959 bytes  85597 events
      chain.Add("$H1/dstarp2.root");  // 100675234 bytes 103053 events

      chain.Draw("h1analysis.C+","h1analysisCut.C");
      h1analysis_Terminate();

I also have an example working of all the new Event files:

        new TFile("Event.new.split9.root");
        TTree * tree = (TTree*)file->Get("T");
        tree->Draw("script.C");

script0.C needs to be used for Event.new.split0.root.

Also you can just generate the skeleton by doing:
  tree->MakeProxy("mysel",scriptfilename,cutfilename,splitLevel);

Where the non-split branches, will be made to look as if there were
split up to 'splitLevel'. (i.e mean that their data members will
be syntactically available as if they were split).

This form allows you to request diffs between any two revisions of this file. For each of the two "sides" of the diff, enter a numeric revision.

  Diffs between and
  Type of Diff should be a

Sort log by:

Subversion Admin
ViewVC Help
Powered by ViewVC 1.0.9