Jpp
Main Page
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Pages
software
JDetector
JConvertDetectorFormat.cc
Go to the documentation of this file.
1
#include <string>
2
3
#include "
JDetector/JDetector.hh
"
4
#include "
JDetector/JDetectorToolkit.hh
"
5
#include "
JSupport/JMeta.hh
"
6
7
#include "
Jeep/JParser.hh
"
8
#include "
Jeep/JMessage.hh
"
9
10
11
/**
12
* \file
13
*
14
* Auxiliary program to convert format of detector files.
15
*
16
* The following file name extensions are supported:
17
* <table>
18
* <tr><th> input </th><th> output </th></tr>
19
* <tr><td> detx </td><td> detx </td></tr>
20
* <tr><td> detx </td><td> dat </td></tr>
21
* <tr><td> detx </td><td> gdml </td></tr>
22
* <tr><td> dat </td><td> detx </td></tr>
23
* <tr><td> dat </td><td> dat </td></tr>
24
* <tr><td> dat </td><td> gdml </td></tr>
25
* <tr><td> det </td><td> detx </td></tr>
26
* <tr><td> det </td><td> dat </td></tr>
27
* <tr><td> det </td><td> gdml </td></tr>
28
* </table>
29
*
30
* Note that if the output file name is the same as the input file name,
31
* the original file will be overwritten.
32
* \author rbruijn
33
*/
34
int
main
(
int
argc,
char
**argv)
35
{
36
37
using namespace
std;
38
using namespace
JPP;
39
40
string
detectorFile;
41
string
outputFile
;
42
string
variant;
43
int
debug
;
44
45
try
{
46
47
JParser<>
zap(
"Auxiliary program to convert format of detector files."
);
48
49
zap[
'a'
] =
make_field
(detectorFile);
50
zap[
'o'
] =
make_field
(
outputFile
);
51
zap[
'V'
] =
make_field
(variant) =
""
, getDetectorVersions<string>();
52
zap[
'd'
] =
make_field
(
debug
) = 0;
53
54
zap(argc, argv);
55
}
56
catch
(
const
exception &error) {
57
FATAL
(error.what() << endl);
58
}
59
60
JDetector detector;
61
62
try
{
63
load
(detectorFile, detector);
64
}
65
catch
(
const
JException& error) {
66
FATAL
(error);
67
}
68
69
if
(variant !=
""
) {
70
detector.setVersion(variant);
71
}
72
73
detector.comment.add(JMeta(argc,argv));
74
75
try
{
76
store
(
outputFile
, detector);
77
}
78
catch
(
const
JException& error) {
79
FATAL
(error);
80
}
81
}
JPARSER::JParser
Utility class to parse command line options.
Definition:
JParser.hh:1410
outputFile
string outputFile
Definition:
JDAQTimesliceSelector.cc:37
JDetector.hh
Data structure for detector geometry and calibration.
make_field
#define make_field(A,...)
macro to convert parameter to JParserTemplateElement object
Definition:
JParser.hh:1836
JMeta.hh
ROOT I/O of application specific meta data.
JDETECTOR::load
void load(const JString &file_name, JDetector &detector)
Load detector from input file.
Definition:
JDetectorToolkit.hh:444
debug
int debug
debug level
Definition:
JSirene.cc:59
JMessage.hh
General purpose messaging.
FATAL
#define FATAL(A)
Definition:
JMessage.hh:65
JParser.hh
Utility class to parse command line options.
JDetectorToolkit.hh
JDETECTOR::store
void store(const JString &file_name, const JDetector &detector)
Store detector to output file.
Definition:
JDetectorToolkit.hh:520
main
int main(int argc, char *argv[])
Definition:
Main.cpp:15
Generated by
1.8.5