Fork me on GitHub

source: git/classes/DelphesFactory.h@ a190d94

ImprovedOutputFile Timing dual_readout llp
Last change on this file since a190d94 was 1fa50c2, checked in by Pavel Demin <pavel.demin@…>, 10 years ago

fix GPLv3 header

  • 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 * $Date: 2008-06-04 13:57:25 $
28 * $Revision: 1.1 $
29 *
30 *
31 * \author P. Demin - UCL, Louvain-la-Neuve
32 *
33 */
34
35#include "TNamed.h"
36
37#include <map>
38#include <set>
39
40class TObjArray;
41class Candidate;
42
43class ExRootTreeBranch;
44
45class DelphesFactory: public TNamed
46{
47public:
48
49 DelphesFactory(const char *name = "ObjectFactory");
50 ~DelphesFactory();
51
52 void Clear();
53
54 TObjArray *NewPermanentArray();
55
56 TObjArray *NewArray() { return New<TObjArray>(); }
57
58 Candidate *NewCandidate();
59
60 TObject *New(TClass *cl);
61
62 template<typename T>
63 T *New() { return static_cast<T *>(New(T::Class())); }
64
65private:
66
67 ExRootTreeBranch *fObjArrays; //!
68
69#if !defined(__CINT__) && !defined(__CLING__)
70 std::map< const TClass*, ExRootTreeBranch* > fBranches; //!
71#endif
72
73 std::set< TObject* > fPool; //!
74
75 ClassDef(DelphesFactory, 1)
76};
77
78#endif /* DelphesFactory */
79
Note: See TracBrowser for help on using the repository browser.