AmpTools
DataReader.h
Go to the documentation of this file.
1 #if !(defined DATAREADER)
2 #define DATAREADER
3 
4 //******************************************************************************
5 // This file is part of AmpTools, a package for performing Amplitude Analysis
6 //
7 // Copyright Trustees of Indiana University 2010, all rights reserved
8 //
9 // This software written by Matthew Shepherd, Ryan Mitchell, and
10 // Hrayr Matevosyan at Indiana University, Bloomington
11 //
12 // Redistribution and use in source and binary forms, with or without
13 // modification, are permitted provided that the following conditions
14 // are met:
15 // 1. Redistributions of source code must retain the above copyright
16 // notice and author attribution, this list of conditions and the
17 // following disclaimer.
18 // 2. Redistributions in binary form must reproduce the above copyright
19 // notice and author attribution, this list of conditions and the
20 // following disclaimer in the documentation and/or other materials
21 // provided with the distribution.
22 // 3. Neither the name of the University nor the names of its contributors
23 // may be used to endorse or promote products derived from this software
24 // without specific prior written permission.
25 //
26 // Creation of derivative forms of this software for commercial
27 // utilization may be subject to restriction; written permission may be
28 // obtained from the Trustees of Indiana University.
29 //
30 // INDIANA UNIVERSITY AND THE AUTHORS MAKE NO REPRESENTATIONS OR WARRANTIES,
31 // EXPRESS OR IMPLIED. By way of example, but not limitation, INDIANA
32 // UNIVERSITY MAKES NO REPRESENTATIONS OR WARRANTIES OF MERCANTABILITY OR
33 // FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF THIS SOFTWARE OR
34 // DOCUMENTATION WILL NOT INFRINGE ANY PATENTS, COPYRIGHTS, TRADEMARKS,
35 // OR OTHER RIGHTS. Neither Indiana University nor the authors shall be
36 // held liable for any liability with respect to any claim by the user or
37 // any other party arising from use of the program.
38 //******************************************************************************
39 
40 #include <string>
41 #include <vector>
42 
43 using namespace std;
44 
45 class Kinematics;
46 
58 {
59 
60 public:
61 
65  DataReader( ) :
66  m_isDefault(true) { }
67 
71  DataReader( const vector< string >& args ) :
72  m_isDefault(false),
73  m_args(args) { }
74 
78  virtual ~DataReader() {}
79 
95  virtual Kinematics* getEvent() = 0;
96 
107  virtual void resetSource() = 0;
108 
119  virtual unsigned int numEvents() const = 0;
120 
125  virtual string name() const = 0;
126 
133  virtual DataReader* newDataReader( const vector< string >& args ) const = 0;
134 
141  virtual DataReader* clone() const = 0;
142 
146  virtual vector<string> arguments() const { return m_args; }
147 
152  virtual bool isDefault() const { return ( m_isDefault == true ); }
153 
154 
155 private:
156 
157  bool m_isDefault;
158 
159  vector<string> m_args;
160 
161 
162 };
163 
164 #endif
DataReader(const vector< string > &args)
Definition: DataReader.h:71
virtual bool isDefault() const
Definition: DataReader.h:152
virtual vector< string > arguments() const
Definition: DataReader.h:146
virtual ~DataReader()
Definition: DataReader.h:78