LArSoft  v09_90_00
Liquid Argon Software toolkit - https://larsoft.org/
Row.h
Go to the documentation of this file.
1 #ifndef __DBIROW_HPP_
2 #define __DBIROW_HPP_
3 
4 #include <string>
5 #include <vector>
6 
9 
10 namespace nutools {
11  namespace dbi {
12 
19  class Row
20  {
21  public:
22  Row(int ncol) : fIsVldRow(false), fNModified(0), fCol(ncol) { };
23 
24  Row(const std::vector<Column>&);
25  Row(std::vector<ColumnDef>&);
26  ~Row();
27 
28  void Clear();
29 
30  template <class T>
31  bool Set(int idx, T value) {
32  if (idx < (int)fCol.size() && idx>=0)
33  return (fCol[idx].Set(value));
34  return false;
35  }
36 
37  template <class T>
38  bool Update(int idx, T value) {
39  if (idx < (int)fCol.size() && idx>=0) {
40  if (!fCol[idx].Modified()) fNModified++;
41  return (fCol[idx].Update(value));
42  }
43  return false;
44  }
45 
46  bool InDB() { return fInDB; }
47  void SetInDB() { fInDB = true; }
48 
49  int NModified() { return fNModified; }
50 
51  int NCol() { return fCol.size(); }
52 
53  Column& Col(int i) {return fCol[i]; }
54 
55  uint64_t Channel() { return fChannel; }
56  double VldTime() { return fVldTime; }
57  double VldTimeEnd() { return fVldTimeEnd; }
58  bool IsVldRow() { return fIsVldRow; }
59 
60  bool SetChannel(uint64_t ch) { fIsVldRow=true; return (fChannel=ch); }
61  bool SetVldTime(double t) { fIsVldRow=true; return (fVldTime=t); }
62  bool SetVldTimeEnd(double t) { fIsVldRow=true; return (fVldTime=t); }
63 
64  // bool operator==(const Row& other) const;
65 
66  friend std::ostream& operator<< (std::ostream& stream, const Row& row);
67  // friend std::istream& operator>> (std::istream& stream, Row& row);
68 
69  private:
70  bool fInDB;
71  bool fIsVldRow;
73  uint64_t fChannel;
74  double fVldTime;
75  double fVldTimeEnd;
76  std::vector<Column> fCol;
77 
78  }; // class end
79 
80  //************************************************************
81 
82  inline std::ostream& operator<< (std::ostream& stream, const Row& row) {
83  for (unsigned int i=0; i<row.fCol.size(); ++i) {
84  stream << row.fCol[i];
85  if (i < row.fCol.size()-1)
86  stream << ", ";
87  }
88  return stream;
89  }
90 
91  } // namespace dbi close
92 } // namespace nova close
93 
94 #endif
std::vector< Column > fCol
Definition: Row.h:76
bool Update(int idx, T value)
Definition: Row.h:38
c1 Modified()
uint64_t fChannel
Definition: Row.h:73
double fVldTime
Definition: Row.h:74
bool InDB()
Definition: Row.h:46
bool fIsVldRow
Definition: Row.h:71
bool SetVldTime(double t)
Definition: Row.h:61
uint64_t Channel()
Definition: Row.h:55
int NModified()
Definition: Row.h:49
Row(int ncol)
Definition: Row.h:22
int NCol()
Definition: Row.h:51
double VldTimeEnd()
Definition: Row.h:57
Simple service to provide a RunHistory configured to the right run.
Definition: Column.cpp:14
void SetInDB()
Definition: Row.h:47
bool Set(int idx, T value)
Definition: Row.h:31
bool IsVldRow()
Definition: Row.h:58
double value
Definition: spectrum.C:18
bool SetVldTimeEnd(double t)
Definition: Row.h:62
void Clear()
Definition: Row.cpp:40
bool fInDB
Definition: Row.h:70
friend std::ostream & operator<<(std::ostream &stream, const Row &row)
Definition: Row.h:82
double VldTime()
Definition: Row.h:56
int fNModified
Definition: Row.h:72
Column & Col(int i)
Definition: Row.h:53
bool SetChannel(uint64_t ch)
Definition: Row.h:60
double fVldTimeEnd
Definition: Row.h:75