Fork me on GitHub

source: git/classes/DelphesFactory.h@ 6ba7847

ImprovedOutputFile Timing dual_readout llp
Last change on this file since 6ba7847 was 0ccf6fd, checked in by Pavel Demin <pavel.demin@…>, 9 years ago

fix arguments in DelphesFactory::Clear()

  • Property mode set to 100644
File size: 1.8 KB
Line 
1/*
2 * Delphes: a framework for fast simulation of a generic collider experiment
3 * Copyright (C) 2012-2014 Universite catholique de Louvain (UCL), Belgium
4 *
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18
19#ifndef DelphesFactory_h
20#define DelphesFactory_h
21
22/** \class DelphesFactory
23 *
24 * Class handling creation of Candidate,
25 * TObjArray and all other objects.
26 *
27 * \author P. Demin - UCL, Louvain-la-Neuve
28 *
29 */
30
31#include "TNamed.h"
32
33#include <map>
34#include <set>
35
36class TObjArray;
37class Candidate;
38
39class ExRootTreeBranch;
40
41class DelphesFactory: public TNamed
42{
43public:
44
45 DelphesFactory(const char *name = "ObjectFactory");
46 ~DelphesFactory();
47
48 virtual void Clear(Option_t* option = "");
49
50 TObjArray *NewPermanentArray();
51
52 TObjArray *NewArray() { return New<TObjArray>(); }
53
54 Candidate *NewCandidate();
55
56 TObject *New(TClass *cl);
57
58 template<typename T>
59 T *New() { return static_cast<T *>(New(T::Class())); }
60
61private:
62
63 ExRootTreeBranch *fObjArrays; //!
64
65#if !defined(__CINT__) && !defined(__CLING__)
66 std::map< const TClass*, ExRootTreeBranch* > fBranches; //!
67#endif
68
69 std::set< TObject* > fPool; //!
70
71 ClassDef(DelphesFactory, 1)
72};
73
74#endif /* DelphesFactory */
75
Note: See TracBrowser for help on using the repository browser.