Jpp test-rotations-old
the software that should make you happy
Loading...
Searching...
No Matches
JPrintPDB.cc
Go to the documentation of this file.
1
2#include <string>
3#include <iostream>
4#include <iomanip>
5
6#include "JAAnet/JPDB.hh"
8
9#include "Jeep/JParser.hh"
10#include "Jeep/JMessage.hh"
11
12
13/**
14 * \file
15 *
16 * Auxiliary program to print particle codes and masses.
17 * \author mdejong
18 */
19int main(int argc, char **argv)
20{
21 using namespace std;
22
23 string key;
24 int debug;
25
26 try {
27
28 JParser<> zap("Auxiliary program to print particle codes and masses.");
29
30 zap['k'] = make_field(key) = "name", "geant", "pdg", "mass", "charge";
31 zap['d'] = make_field(debug) = 2;
32
33 zap(argc, argv);
34 }
35 catch(const exception& error) {
36 FATAL(error.what() << endl);
37 }
38
39 using namespace JPP;
40
41 JPDB pdb = JPDB::getInstance();
42
43 if (key == "name")
44 sort(pdb.begin(), pdb.end(), make_comparator(&JParticle::name));
45 else if (key == "pdg")
46 sort(pdb.begin(), pdb.end(), make_comparator(&JParticle::pdg));
47 else if (key == "geant")
48 sort(pdb.begin(), pdb.end(), make_comparator(&JParticle::geant));
49 else if (key == "mass")
50 sort(pdb.begin(), pdb.end(), make_comparator(&JParticle::mass));
51 else if (key == "mass")
52 sort(pdb.begin(), pdb.end(), make_comparator(&JParticle::charge));
53
54 cout << pdb << endl;
55}
General purpose messaging.
#define FATAL(A)
Definition JMessage.hh:67
int debug
debug level
Definition JSirene.cc:72
Utility class to parse command line options.
#define make_field(A,...)
macro to convert parameter to JParserTemplateElement object
Definition JParser.hh:2142
int main(int argc, char **argv)
Definition JPrintPDB.cc:19
Utility class to parse command line options.
Definition JParser.hh:1698
This name space includes all other name spaces (except KM3NETDAQ, KM3NET and ANTARES).
Collection of particles.
Definition JPDB.hh:117