BDSIM
BDSIM is a Geant4 extension toolkit for simulation of particle transport in accelerator beamlines.
BDSGeometryType.cc
1/*
2Beam Delivery Simulation (BDSIM) Copyright (C) Royal Holloway,
3University of London 2001 - 2022.
4
5This file is part of BDSIM.
6
7BDSIM is free software: you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published
9by the Free Software Foundation version 3 of the License.
10
11BDSIM is distributed in the hope that it will be useful, but
12WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with BDSIM. If not, see <http://www.gnu.org/licenses/>.
18*/
19#include "BDSGeometryType.hh"
20#include "BDSDebug.hh"
21#include "BDSException.hh"
22#include "BDSUtilities.hh"
23
24#include "globals.hh"
25#include "G4String.hh"
26
27#include <map>
28#include <string>
29
30// dictionary for BDSGeometryType
31template<>
32std::map<BDSGeometryType, std::string>* BDSGeometryType::dictionary =
33 new std::map<BDSGeometryType, std::string> ({
34 {BDSGeometryType::mokka, "mokka"},
35 {BDSGeometryType::gdml, "gdml"}
36});
37
39{
40 std::map<G4String, BDSGeometryType> types;
41 types["mokka"] = BDSGeometryType::mokka;
42 types["gdml"] = BDSGeometryType::gdml;
43
44 geometryType = BDS::LowerCase(geometryType);
45
46 auto result = types.find(geometryType);
47 if (result == types.end())
48 {// it's not a valid key
49 G4String msg = "\"" + geometryType + "\" is not a valid geometry type\n";
50 msg += "Available geometry types are:\n";
51 for (const auto& it : types)
52 {msg += "\"" + it.first + "\"\n";}
53 throw BDSException(__METHOD_NAME__, msg);
54 }
55
56#ifdef BDSDEBUG
57 G4cout << __METHOD_NAME__ << "determined geometry type to be " << result->second << G4endl;
58#endif
59 return result->second;
60}
61
General exception with possible name of object and message.
Definition: BDSException.hh:35
Improve type-safety of native enum data type in C++.
static std::map< BDSTypeSafeEnum< def, inner >, std::string > * dictionary
BDSGeometryType DetermineGeometryType(G4String geometryType)
function that gives corresponding enum value for string (case-insensitive)
G4String LowerCase(const G4String &str)
Utility function to simplify lots of syntax changes for pedantic g4 changes.