Jpp 20.0.0-27-g39925593c-D
the software that should make you happy
Loading...
Searching...
No Matches
JPrintTreeScanner.cc
Go to the documentation of this file.
1
2#include <string>
3#include <iostream>
4#include <iomanip>
5#include <limits>
6
9
12#include "JSupport/JSupport.hh"
14
15#include "Jeep/JTimer.hh"
16#include "Jeep/JParser.hh"
17#include "Jeep/JMessage.hh"
18
19
20/**
21 * \file
22 *
23 * Program to test ordered reading using JSUPPORT::JTreeScanner.
24 * \author mdejong
25 */
26int main(int argc, char **argv)
27{
28 using namespace std;
29 using namespace JPP;
30 using namespace KM3NETDAQ;
31
32 JMultipleFileScanner<> inputFile;
33 JROOTClassSelector selector;
34 JLimit numberOfEvents;
35 int debug;
36
37 try {
38
39 JParser<> zap("Program to test ordered reading from a ROOT TTree.");
40
41 zap['f'] = make_field(inputFile);
43 zap['n'] = make_field(numberOfEvents) = JLimit();
44 zap['d'] = make_field(debug) = 2;
45
46 zap(argc, argv);
47 }
48 catch(const exception& error) {
49 FATAL(error.what() << endl);
50 }
51
52
54
56
57 JTreeScannerInterface<JDAQTimeslice>* ps = zmap[selector];
58
59 JTimer timer;
60
61 timer.start();
62
63 ps->configure(inputFile, numberOfEvents);
64
65 timer.stop();
66
67 timer.print(cout, milli_t);
68
69 while (ps->hasNext()) {
70
71 JDAQTimeslice* p = ps->next();
72
73 cout << *p << endl;
74 }
75}
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)
ROOT TTree parameter settings of various packages.
Auxiliary class for CPU timing and usage.
Definition JTimer.hh:33
void print(std::ostream &out, const JScale_t scale=milli_t) const
Print timer data.
Definition JTimer.hh:172
void stop()
Stop timer.
Definition JTimer.hh:127
void start()
Start timer.
Definition JTimer.hh:106
Template definition of a multi-dimensional oscillation probability interpolation table.
@ milli_t
milli
Definition JScale.hh:30
This name space includes all other name spaces (except KM3NETDAQ, KM3NET and ANTARES).
KM3NeT DAQ data structures and auxiliaries.
Definition DataQueue.cc:39
Auxiliary class to select ROOT class based on class name.
Auxiliary class for defining the range of iterations of objects.
Definition JLimit.hh:45