Geant4 11.2.2
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4VRFileManager.hh
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26
27// Base class for readers file managers.
28//
29// Author: Ivana Hrivnacova, 06/08/2021 ([email protected])
30
31#ifndef G4VRFileManager_h
32#define G4VRFileManager_h 1
33
34#include "G4BaseFileManager.hh"
35#include "G4VTHnRFileManager.hh"
36
37#include <memory>
38#include <string_view>
39
40namespace tools {
41namespace histo {
42class h1d;
43class h2d;
44class h3d;
45class p1d;
46class p2d;
47}
48}
49
51{
52 public:
54 : G4BaseFileManager(state) {}
55 G4VRFileManager() = delete;
56 ~G4VRFileManager() override = default;
57
58 // Methods applied to all registered files
59 virtual void CloseFiles() = 0;
60
61 // Access to helpers
62 template <typename HT>
63 std::shared_ptr<G4VTHnRFileManager<HT>> GetHnRFileManager() const;
64
65 protected:
66 // Static data members
67 static constexpr std::string_view fkClass { "G4VRFileManager" };
68
69 // Data members
70 // FileManagers per object type
71 std::shared_ptr<G4VTHnRFileManager<tools::histo::h1d>> fH1RFileManager { nullptr };
72 std::shared_ptr<G4VTHnRFileManager<tools::histo::h2d>> fH2RFileManager { nullptr };
73 std::shared_ptr<G4VTHnRFileManager<tools::histo::h3d>> fH3RFileManager { nullptr };
74 std::shared_ptr<G4VTHnRFileManager<tools::histo::p1d>> fP1RFileManager { nullptr };
75 std::shared_ptr<G4VTHnRFileManager<tools::histo::p2d>> fP2RFileManager { nullptr };
76};
77
78// inline functions
79
80template <>
81inline
82std::shared_ptr<G4VTHnRFileManager<tools::histo::h1d>>
83G4VRFileManager::GetHnRFileManager<tools::histo::h1d>() const
84{ return fH1RFileManager; }
85
86template <>
87inline
88std::shared_ptr<G4VTHnRFileManager<tools::histo::h2d>>
89G4VRFileManager::GetHnRFileManager<tools::histo::h2d>() const
90{ return fH2RFileManager; }
91
92template <>
93inline
94std::shared_ptr<G4VTHnRFileManager<tools::histo::h3d>>
95G4VRFileManager::GetHnRFileManager<tools::histo::h3d>() const
96{ return fH3RFileManager; }
97
98template <>
99inline
100std::shared_ptr<G4VTHnRFileManager<tools::histo::p1d>>
101G4VRFileManager::GetHnRFileManager<tools::histo::p1d>() const
102{ return fP1RFileManager; }
103
104template <>
105inline
106std::shared_ptr<G4VTHnRFileManager<tools::histo::p2d>>
107G4VRFileManager::GetHnRFileManager<tools::histo::p2d>() const
108{ return fP2RFileManager; }
109
110#endif
std::shared_ptr< G4VTHnRFileManager< tools::histo::h2d > > fH2RFileManager
virtual void CloseFiles()=0
std::shared_ptr< G4VTHnRFileManager< tools::histo::p2d > > fP2RFileManager
std::shared_ptr< G4VTHnRFileManager< tools::histo::h3d > > fH3RFileManager
G4VRFileManager()=delete
G4VRFileManager(const G4AnalysisManagerState &state)
std::shared_ptr< G4VTHnRFileManager< HT > > GetHnRFileManager() const
~G4VRFileManager() override=default
std::shared_ptr< G4VTHnRFileManager< tools::histo::p1d > > fP1RFileManager
static constexpr std::string_view fkClass
std::shared_ptr< G4VTHnRFileManager< tools::histo::h1d > > fH1RFileManager