Geant4-11
G4XmlRNtupleManager.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// Manager class for Xml read ntuples.
28// It implements functions specific to Xml read ntuples.
29//
30// Author: Ivana Hrivnacova, 25/07/2014 (ivana@ipno.in2p3.fr)
31
32#ifndef G4XmlRNtupleManager_h
33#define G4XmlRNtupleManager_h 1
34
35#include "G4TRNtupleManager.hh"
36#include "globals.hh"
37
38#include "tools/raxml"
39
40#include <vector>
41#include <string_view>
42
44struct G4XmlRNtupleDescription;
45
46class G4XmlRNtupleManager : public G4TRNtupleManager<tools::aida::ntuple>
47{
48 friend class G4XmlAnalysisReader;
49
50 public:
51 explicit G4XmlRNtupleManager(const G4AnalysisManagerState& state);
53 virtual ~G4XmlRNtupleManager() = default;
54
55 protected:
56 // Set methods
57 void SetFileManager(std::shared_ptr<G4XmlRFileManager> fileManager);
58
59 // Methods from base classes
67
68 // Override base class functions for vector columns
69 // in order to fill the maps
70
71 virtual G4bool SetNtupleIColumn(G4int ntupleId, const G4String& columnName,
72 std::vector<G4int>& vector) final;
73 virtual G4bool SetNtupleFColumn(G4int ntupleId, const G4String& columnName,
74 std::vector<G4float>& vector) final;
75 virtual G4bool SetNtupleDColumn(G4int ntupleId, const G4String& columnName,
76 std::vector<G4double>& vector) final;
77 virtual G4bool SetNtupleSColumn(G4int ntupleId, const G4String& columnName,
78 std::vector<std::string>& vector) final;
79
80 private:
81 // Methods from the base class
82 virtual G4int ReadNtupleImpl(const G4String& ntupleName, const G4String& fileName,
83 const G4String& dirName, G4bool isUserFileName) final;
84 virtual G4bool GetTNtupleRow(G4TRNtupleDescription<tools::aida::ntuple>* ntupleDescription) final;
85
86 // Static data members
87 static constexpr std::string_view fkClass { "G4XmlRNtupleManager" };
88
89 // Data members
90 std::shared_ptr<G4XmlRFileManager> fFileManager { nullptr };
91};
92
93inline void
94G4XmlRNtupleManager::SetFileManager(std::shared_ptr<G4XmlRFileManager> fileManager)
95{ fFileManager = fileManager; }
96
97#endif
bool G4bool
Definition: G4Types.hh:86
int G4int
Definition: G4Types.hh:85
virtual G4bool SetNtupleFColumn(const G4String &columnName, G4float &value) final
virtual G4bool SetNtupleDColumn(const G4String &columnName, G4double &value) final
virtual G4bool SetNtupleIColumn(const G4String &columnName, G4int &value) final
virtual G4bool SetNtupleIColumn(G4int ntupleId, const G4String &columnName, std::vector< G4int > &vector) final
virtual G4bool SetNtupleFColumn(G4int ntupleId, const G4String &columnName, std::vector< G4float > &vector) final
virtual G4bool GetTNtupleRow(G4TRNtupleDescription< tools::aida::ntuple > *ntupleDescription) final
virtual G4bool SetNtupleSColumn(G4int ntupleId, const G4String &columnName, std::vector< std::string > &vector) final
virtual G4int ReadNtupleImpl(const G4String &ntupleName, const G4String &fileName, const G4String &dirName, G4bool isUserFileName) final
virtual G4bool SetNtupleDColumn(G4int ntupleId, const G4String &columnName, std::vector< G4double > &vector) final
virtual ~G4XmlRNtupleManager()=default
void SetFileManager(std::shared_ptr< G4XmlRFileManager > fileManager)
G4XmlRNtupleManager()=delete
static constexpr std::string_view fkClass
std::shared_ptr< G4XmlRFileManager > fFileManager