test
CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
hcalDeleteObject.cc
Go to the documentation of this file.
1 #include <stdlib.h>
2 
3 #include <iostream>
4 #include <fstream>
5 #include <vector>
6 #include <map>
7 #include <algorithm>
8 #include <string>
9 
10 // other
15 
16 
17 #include "CondCore/IOVService/interface/IOV.h"
18 
19 // Hcal calibrations
22 #include "CondTools/Hcal/interface/HcalDbOnline.h"
23 #include "CondTools/Hcal/interface/HcalDbTool.h"
32 
33 //using namespace cms;
34 
35 
37 typedef std::map<IOVRun,std::string> IOVCollection;
38 
39 
40 class Args {
41  public:
42  Args () {};
43  ~Args () {};
44  void defineOption (const std::string& fOption, const std::string& fComment = "");
45  void defineParameter (const std::string& fParameter, const std::string& fComment = "");
46  void parse (int nArgs, char* fArgs []);
47  void printOptionsHelp () const;
48  std::string command () const;
49  std::vector<std::string> arguments () const;
50  bool optionIsSet (const std::string& fOption) const;
51  std::string getParameter (const std::string& fKey);
52  private:
54  std::vector <std::string> mOptions;
55  std::vector <std::string> mParameters;
56  std::vector <std::string> mArgs;
57  std::map <std::string, std::string> mParsed;
58  std::map <std::string, std::string> mComments;
59 };
60 
61 void printHelp (const Args& args) {
62  char buffer [1024];
63  std::cout << "Tool to delete object from Hcal Calibrations" << std::endl;
64  std::cout << "CAUTION: Could cause inconsistency for running jobs using DB" << std::endl;
65  std::cout << " feedback -> ratnikov@fnal.gov" << std::endl;
66  std::cout << "Use:" << std::endl;
67  sprintf (buffer, " %s <what> <options> <parameters>\n", args.command ().c_str());
68  std::cout << buffer;
69  std::cout << " where <what> is: \n pedestals\n gains\n pwidths\n gwidths\n emap\n qie\n calibqie" << std::endl;
70  args.printOptionsHelp ();
71 }
72 
73 template <class T> bool deleteObject (T* fObject,
74  const std::string& fInput, const std::string& fInputTag, HcalDbTool::IOVRun fInputRun, bool fVerbose) {
75  HcalDbTool poolDb (fInput, fVerbose);
76  return poolDb.deleteObject (fObject, fInputTag, fInputRun);
77 }
78 
79 int main (int argn, char* argv []) {
80 
81  Args args;
82  args.defineParameter ("-db", "DB connection string, POOL format");
83  args.defineParameter ("-run", "run # for which constands should be deleted");
84  args.defineParameter ("-tag", "tag for the input constants set");
85  args.defineOption ("-verbose", "makes program verbose");
86 
87  args.parse (argn, argv);
88 
89  std::vector<std::string> arguments = args.arguments ();
90 
91  if (arguments.size () < 1 || args.optionIsSet ("-help")) {
92  printHelp (args);
93  return -1;
94  }
95 
96  std::string input = args.getParameter ("-db");
97 
98  unsigned inputRun = args.getParameter ("-run").empty () ? 0 : strtoull (args.getParameter ("-run").c_str (), 0, 0);
99  std::string inputTag = args.getParameter ("-tag");
100 
101  bool verbose = args.optionIsSet ("-verbose");
102 
103 
104  std::string what = arguments [0];
105 
106  if (what == "pedestals") {
107  HcalPedestals* object = 0;
108  deleteObject (object, input, inputTag, inputRun, verbose);
109  }
110  else if (what == "gains") {
111  HcalGains* object = 0;
112  }
113  else if (what == "pwidths") {
114  HcalPedestalWidths* object = 0;
115  }
116  else if (what == "gwidths") {
117  HcalGainWidths* object = 0;
118  }
119  else if (what == "emap") {
120  HcalElectronicsMap* object = 0;
121  }
122  else if (what == "qie") {
123  HcalQIEData* object = 0;
124  }
125  else if (what == "calibqie") {
126  HcalCalibrationQIEData* object = 0;
127  }
128 }
129 
130 
131 //==================== Args ===== BEGIN ==============================
132 void Args::defineOption (const std::string& fOption, const std::string& fComment) {
133  mOptions.push_back (fOption);
134  mComments [fOption] = fComment;
135 }
136 
137 void Args::defineParameter (const std::string& fParameter, const std::string& fComment) {
138  mParameters.push_back (fParameter);
139  mComments [fParameter] = fComment;
140 }
141 
142 void Args::parse (int nArgs, char* fArgs []) {
143  if (nArgs <= 0) return;
144  mProgramName = std::string (fArgs [0]);
145  int iarg = 0;
146  while (++iarg < nArgs) {
147  std::string arg (fArgs [iarg]);
148  if (arg [0] != '-') mArgs.push_back (arg);
149  else {
150  if (std::find (mOptions.begin(), mOptions.end (), arg) != mOptions.end ()) {
151  mParsed [arg] = "";
152  }
153  if (std::find (mParameters.begin(), mParameters.end (), arg) != mParameters.end ()) {
154  if (iarg >= nArgs) {
155  std::cerr << "ERROR: Parameter " << arg << " has no value specified. Ignore parameter." << std::endl;
156  }
157  else {
158  mParsed [arg] = std::string (fArgs [++iarg]);
159  }
160  }
161  }
162  }
163 }
164 
165 void Args::printOptionsHelp () const {
166  char buffer [1024];
167  std::cout << "Parameters:" << std::endl;
168  for (unsigned i = 0; i < mParameters.size (); i++) {
169  std::map<std::string, std::string>::const_iterator it = mComments.find (mParameters [i]);
170  std::string comment = it != mComments.end () ? it->second : "uncommented";
171  sprintf (buffer, " %-8s <value> : %s", (mParameters [i]).c_str(), comment.c_str());
172  std::cout << buffer << std::endl;
173  }
174  std::cout << "Options:" << std::endl;
175  for (unsigned i = 0; i < mOptions.size (); i++) {
176  std::map<std::string, std::string>::const_iterator it = mComments.find (mOptions [i]);
177  std::string comment = it != mComments.end () ? it->second : "uncommented";
178  sprintf (buffer, " %-8s : %s", (mOptions [i]).c_str(), comment.c_str());
179  std::cout << buffer << std::endl;
180  }
181 }
182 
184  int ipos = mProgramName.rfind ('/');
185  return std::string (mProgramName, ipos+1);
186 }
187 
188 std::vector<std::string> Args::arguments () const {return mArgs;}
189 
190 bool Args::optionIsSet (const std::string& fOption) const {
191  return mParsed.find (fOption) != mParsed.end ();
192 }
193 
195  if (optionIsSet (fKey)) return mParsed [fKey];
196  return "";
197 }
198 //==================== Args ===== END ==============================
int i
Definition: DBlmapReader.cc:9
std::string mProgramName
void defineOption(const std::string &fOption, const std::string &fComment="")
std::map< std::string, std::string > mComments
std::vector< std::string > arguments() const
std::vector< std::string > mOptions
std::map< IOVRun, std::string > IOVCollection
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:7
A arg
Definition: Factorize.h:36
static std::string const input
Definition: EdmProvDump.cc:44
std::vector< std::string > mParameters
std::vector< std::string > mArgs
void printOptionsHelp() const
void parse(int nArgs, char *fArgs[])
void printHelp(const Args &args)
std::string command() const
HcalDbTool::IOVRun IOVRun
tuple cout
Definition: gather_cfg.py:145
std::map< std::string, std::string > mParsed
bool deleteObject(T *fObject, const std::string &fInput, const std::string &fInputTag, HcalDbTool::IOVRun fInputRun, bool fVerbose)
void defineParameter(const std::string &fParameter, const std::string &fComment="")
long double T
bool optionIsSet(const std::string &fOption) const
std::string getParameter(const std::string &fKey)
#define comment(par)
Definition: vmac.h:161