Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
G4GDMLWriteMaterials.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// G4GDMLWriteMaterials
27//
28// Class description:
29//
30// GDML class for writing materials definitions.
31
32// Author: Zoltan Torzsok, November 2007
33// --------------------------------------------------------------------
34#ifndef G4GDMLWRITEMATERIALS_HH
35#define G4GDMLWRITEMATERIALS_HH 1
36
37#include "G4Types.hh"
38#include <vector>
39
40#include "G4GDMLWriteDefine.hh"
41
42class G4Isotope;
43class G4Element;
44class G4Material;
47
49{
50 public:
51
52 void AddIsotope(const G4Isotope* const);
53 void AddElement(const G4Element* const);
54 void AddMaterial(const G4Material* const);
55
56 virtual void MaterialsWrite(xercesc::DOMElement*);
57
58 protected:
59
61 virtual ~G4GDMLWriteMaterials();
62
63 void AtomWrite(xercesc::DOMElement*, const G4double&);
64 void DWrite(xercesc::DOMElement*, const G4double&);
65 void PWrite(xercesc::DOMElement*, const G4double&);
66 void TWrite(xercesc::DOMElement*, const G4double&);
67 void MEEWrite(xercesc::DOMElement*, const G4double&);
68 void IsotopeWrite(const G4Isotope* const);
69 void ElementWrite(const G4Element* const);
70 void MaterialWrite(const G4Material* const);
71 void PropertyWrite(xercesc::DOMElement*, const G4Material* const);
72 void PropertyVectorWrite(const G4String&,
73 const G4PhysicsFreeVector* const);
74 void PropertyConstWrite(const G4String&, const G4double,
76
77 protected:
78
79 std::vector<const G4Isotope*> isotopeList;
80 std::vector<const G4Element*> elementList;
81 std::vector<const G4Material*> materialList;
82 std::vector<const G4PhysicsFreeVector*> propertyList;
83 xercesc::DOMElement* materialsElement = nullptr;
84};
85
86#endif
double G4double
Definition: G4Types.hh:83
void TWrite(xercesc::DOMElement *, const G4double &)
void MEEWrite(xercesc::DOMElement *, const G4double &)
void MaterialWrite(const G4Material *const)
void DWrite(xercesc::DOMElement *, const G4double &)
void AtomWrite(xercesc::DOMElement *, const G4double &)
virtual void MaterialsWrite(xercesc::DOMElement *)
void AddIsotope(const G4Isotope *const)
void AddMaterial(const G4Material *const)
void PropertyVectorWrite(const G4String &, const G4PhysicsFreeVector *const)
std::vector< const G4Element * > elementList
xercesc::DOMElement * materialsElement
std::vector< const G4Material * > materialList
std::vector< const G4PhysicsFreeVector * > propertyList
void PWrite(xercesc::DOMElement *, const G4double &)
void ElementWrite(const G4Element *const)
void AddElement(const G4Element *const)
void PropertyConstWrite(const G4String &, const G4double, const G4MaterialPropertiesTable *)
void PropertyWrite(xercesc::DOMElement *, const G4Material *const)
void IsotopeWrite(const G4Isotope *const)
std::vector< const G4Isotope * > isotopeList