CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
Selection.cc
Go to the documentation of this file.
3 //
4 #include <sstream>
5 
6 std::vector<std::string>& ora::Selection::selectionTypes(){
7  static std::vector<std::string> types;
8  types.push_back("=");
9  types.push_back("!=");
10  types.push_back(">");
11  types.push_back(">=");
12  types.push_back("<");
13  types.push_back("<=");
14  return types;
15 }
16 
17 std::string ora::Selection::variableNameFromUniqueString(const std::string& uniqueString)
18 {
19  size_t ind = uniqueString.rfind("_");
20  return uniqueString.substr(0,ind);
21 }
22 
24  static std::string s_var("ora::ContainerIndex");
25  return s_var;
26 }
27 
28 ora::Selection::Selection():m_items(),m_data(){
29 }
30 
32 }
33 
34 std::string
35 ora::Selection::uniqueVariableName(const std::string& varName) const {
36  std::stringstream uniqueVarName;
37  unsigned int i = 0;
38  bool notUnique = true;
39  while(notUnique){
40  bool found = false;
41  uniqueVarName.str("");
42  uniqueVarName << varName;
43  uniqueVarName << "_" << i;
44  for(coral::AttributeList::const_iterator iAttr = m_data.begin();
45  iAttr!=m_data.end() && !found; ++iAttr){
46  if( iAttr->specification().name() == uniqueVarName.str() ) found = true;
47  }
48  notUnique = found;
49  i++;
50  }
51  return uniqueVarName.str();
52 }
53 
54 void ora::Selection::addIndexItem( int startIndex, int endIndex ){
55  if(endIndex<startIndex && endIndex>=0) {
56  throwException("Cannot select with endIndex<startIndex.",
57  "Selection::addIndexItem");
58  } else if( startIndex==endIndex && endIndex>=0){
59  std::string varName = uniqueVariableName( indexVariable() );
60  SelectionItemType selType = ora::EQ;
61  m_items.push_back(std::make_pair(varName,selectionTypes()[selType]));
62  m_data.extend<int>(varName);
63  m_data[varName].data<int>() = startIndex;
64  } else {
65  if(startIndex>0){
66  std::string varName0 = uniqueVariableName( indexVariable() );
67  SelectionItemType firstType = ora::GE;
68  m_items.push_back(std::make_pair(varName0,selectionTypes()[firstType]));
69  m_data.extend<int>(varName0);
70  m_data[varName0].data<int>() = startIndex;
71  }
72  if(endIndex>0){
73  std::string varName1 = uniqueVariableName( indexVariable() );
74  SelectionItemType secondType = ora::LE;
75  m_items.push_back(std::make_pair(varName1,selectionTypes()[secondType]));
76  m_data.extend<int>(varName1);
77  m_data[varName1].data<int>() = endIndex;
78  }
79  }
80 }
81 
82 bool
84  return m_items.empty();
85 }
86 
87 const std::vector<std::pair<std::string,std::string> >&
89  return m_items;
90 }
91 
92 const coral::AttributeList&
94  return m_data;
95 }
int i
Definition: DBlmapReader.cc:9
std::string uniqueVariableName(const std::string &varName) const
Definition: Selection.cc:35
const coral::AttributeList & data() const
Definition: Selection.cc:93
static std::string variableNameFromUniqueString(const std::string &uniqueString)
Definition: Selection.cc:17
static std::vector< std::string > & selectionTypes()
Definition: Selection.cc:6
static std::string indexVariable()
Definition: Selection.cc:23
void addIndexItem(int startIndex, int endIndex=endOfRange)
Definition: Selection.cc:54
virtual ~Selection()
Definition: Selection.cc:31
void throwException(const std::string &message, const std::string &methodName)
Definition: Exception.cc:10
const std::vector< std::pair< std::string, std::string > > & items() const
Definition: Selection.cc:88
bool isEmpty() const
Definition: Selection.cc:83
SelectionItemType
Definition: Selection.h:13