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 #include "CoralBase/AttributeList.h"
7 #include "CoralBase/Attribute.h"
8 
9 std::vector<std::string>& ora::Selection::selectionTypes(){
10  static std::vector<std::string> types;
11  types.push_back("=");
12  types.push_back("!=");
13  types.push_back(">");
14  types.push_back(">=");
15  types.push_back("<");
16  types.push_back("<=");
17  return types;
18 }
19 
20 std::string ora::Selection::variableNameFromUniqueString(const std::string& uniqueString)
21 {
22  size_t ind = uniqueString.rfind("_");
23  return uniqueString.substr(0,ind);
24 }
25 
27  static std::string s_var("ora::ContainerIndex");
28  return s_var;
29 }
30 
31 ora::Selection::Selection():m_items(),m_data( new coral::AttributeList ){
32 }
33 
35 }
36 
38  m_items( rhs.m_items ),
39  m_data( new coral::AttributeList( *rhs.m_data )){
40 }
41 
43  m_items = rhs.m_items;
44  m_data.reset( new coral::AttributeList( *rhs.m_data ) );
45  return *this;
46 }
47 
48 std::string
49 ora::Selection::uniqueVariableName(const std::string& varName) const {
50  std::stringstream uniqueVarName;
51  unsigned int i = 0;
52  bool notUnique = true;
53  while(notUnique){
54  bool found = false;
55  uniqueVarName.str("");
56  uniqueVarName << varName;
57  uniqueVarName << "_" << i;
58  for(coral::AttributeList::const_iterator iAttr = m_data->begin();
59  iAttr!=m_data->end() && !found; ++iAttr){
60  if( iAttr->specification().name() == uniqueVarName.str() ) found = true;
61  }
62  notUnique = found;
63  i++;
64  }
65  return uniqueVarName.str();
66 }
67 
68 void ora::Selection::addIndexItem( int startIndex,
69  int endIndex ){
70  if(endIndex<startIndex && endIndex>=0) {
71  throwException("Cannot select with endIndex<startIndex.",
72  "Selection::addIndexItem");
73  } else if( startIndex==endIndex && endIndex>=0){
74  std::string varName = uniqueVariableName( indexVariable() );
75  SelectionItemType selType = ora::EQ;
76  m_items.push_back(std::make_pair(varName,selectionTypes()[selType]));
77  m_data->extend<int>(varName);
78  (*m_data)[varName].data<int>() = startIndex;
79  } else {
80  if(startIndex>0){
81  std::string varName0 = uniqueVariableName( indexVariable() );
82  SelectionItemType firstType = ora::GE;
83  m_items.push_back(std::make_pair(varName0,selectionTypes()[firstType]));
84  m_data->extend<int>(varName0);
85  (*m_data)[varName0].data<int>() = startIndex;
86  }
87  if(endIndex>0){
88  std::string varName1 = uniqueVariableName( indexVariable() );
89  SelectionItemType secondType = ora::LE;
90  m_items.push_back(std::make_pair(varName1,selectionTypes()[secondType]));
91  m_data->extend<int>(varName1);
92  (*m_data)[varName1].data<int>() = endIndex;
93  }
94  }
95 }
96 
97 void ora::Selection::addUntypedDataItem( const std::string& dataMemberName,
98  SelectionItemType stype,
99  const std::type_info& primitiveType,
100  void* data ){
101  std::string varName = uniqueVariableName( dataMemberName );
102  m_items.push_back(std::make_pair(varName,selectionTypes()[stype]));
103  m_data->extend( varName, primitiveType );
104  (*m_data)[varName].setValueFromAddress( data );
105 }
106 
107 bool
109  return m_items.empty();
110 }
111 
112 const std::vector<std::pair<std::string,std::string> >&
114  return m_items;
115 }
116 
117 const coral::AttributeList&
119  return *m_data;
120 }
int i
Definition: DBlmapReader.cc:9
std::string uniqueVariableName(const std::string &varName) const
Definition: Selection.cc:49
const coral::AttributeList & data() const
Definition: Selection.cc:118
Selection & operator=(const Selection &rhs)
Definition: Selection.cc:42
static std::string variableNameFromUniqueString(const std::string &uniqueString)
Definition: Selection.cc:20
static std::vector< std::string > & selectionTypes()
Definition: Selection.cc:9
static std::string indexVariable()
Definition: Selection.cc:26
std::vector< std::pair< std::string, std::string > > m_items
Definition: Selection.h:54
void addIndexItem(int startIndex, int endIndex=endOfRange)
Definition: Selection.cc:68
std::auto_ptr< coral::AttributeList > m_data
Definition: Selection.h:55
void addUntypedDataItem(const std::string &dataMemberName, SelectionItemType stype, const std::type_info &primitiveType, void *data)
Definition: Selection.cc:97
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:82
virtual ~Selection()
Definition: Selection.cc:34
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:113
bool isEmpty() const
Definition: Selection.cc:108
SelectionItemType
Definition: Selection.h:16