SingleTypeVariantList.cpp
Go to the documentation of this file.
1/*
2 * This file is part of ArmarX.
3 *
4 * Copyright (C) 2011-2016, High Performance Humanoid Technologies (H2T), Karlsruhe Institute of Technology (KIT), all rights reserved.
5 *
6 * ArmarX is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
9 *
10 * ArmarX is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 *
18 * @package ArmarXCore::core
19 * @author Kai Welke (welke at kit dot edu)
20 * @date 2011
21 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
22 * GNU General Public License
23 */
24
25
26#include <Ice/ObjectAdapter.h>
27#include <Ice/ValueFactory.h>
28#include <IceUtil/UUID.h>
29
33
34namespace armarx
35{
40
42
43 {
44 this->typeContainer = VariantType::List(subType).clone();
45 }
46
48 {
49 this->typeContainer = VariantType::List(subType).clone();
50 }
51
53 IceUtil::Shared(source), VariantContainerBase(source), SingleTypeVariantListBase(source)
54 {
55 *this = source;
56 }
57
60 {
61 typeContainer = ContainerTypePtr::dynamicCast(source.typeContainer->clone());
62 elements.clear();
63
64 for (unsigned int i = 0; i < source.elements.size(); i++)
65 {
66 elements.push_back(source.elements[i]->cloneContainer());
67 }
68
69 return *this;
70 }
71
72 VariantContainerBasePtr
73 SingleTypeVariantList::cloneContainer(const Ice::Current& c) const
74 {
75 VariantContainerBasePtr result = new SingleTypeVariantList(*this);
76 return result;
77 }
78
79 Ice::ObjectPtr
81 {
82 return this->clone();
83 }
84
85 void
86 SingleTypeVariantList::addElement(const VariantContainerBasePtr& variantContainer,
87 const Ice::Current& c)
88 {
89 if (!VariantContainerType::compare(variantContainer->getContainerType(),
90 getContainerType()->subType) &&
92 {
94 getContainerType()->subType->typeId, variantContainer->getContainerType()->typeId);
95 }
96
98 {
99 getContainerType()->subType = variantContainer->getContainerType()->clone();
100 }
101
102 elements.push_back(variantContainer->cloneContainer());
103 }
104
105 void
107 {
109 {
110 getContainerType()->subType = new ContainerTypeI(variant.getType());
111 }
112 else if (!getContainerType()->subType ||
113 getContainerType()->subType->typeId != Variant::typeToString(variant.getType()))
114 {
116 Variant::typeToString(variant.getType()));
117 }
118
119 addElement(new SingleVariant(variant));
120 }
121
122 void
123 SingleTypeVariantList::clear(const Ice::Current& c)
124 {
125 elements.clear();
126 }
127
130 {
132 }
133
134 int
135 SingleTypeVariantList::getSize(const Ice::Current& c) const
136 {
137 return int(elements.size());
138 }
139
140 bool
142 {
143 VariantContainerBaseList::iterator it = elements.begin();
144 bool result = true;
145
146 for (; it != elements.end(); it++)
147 {
148 result = result && (*it)->validateElements();
149 }
150
151 return result;
152 }
153
154 VariantContainerBasePtr
155 SingleTypeVariantList::getElementBase(int index, const Ice::Current& c) const
156 {
157 if (index >= getSize(c))
158 {
159 throw IndexOutOfBoundsException();
160 }
161
162 return elements.at(index);
163 }
164
167 {
169
170 if (!ptr)
171 {
172 throw InvalidTypeException();
173 }
174
175 return ptr;
176 }
177
178 void
179 SingleTypeVariantList::serialize(const ObjectSerializerBasePtr& serializer,
180 const Ice::Current&) const
181 {
182 AbstractObjectSerializerPtr obj = AbstractObjectSerializerPtr::dynamicCast(serializer);
183 AbstractObjectSerializerPtr arr = obj->createElement();
184 arr->setElementType(ElementTypes::eArray);
185
186 for (size_t i = 0; i < elements.size(); i++)
187 {
188 arr->setIceObject(i, elements.at(i));
189 }
190
191 obj->setString("type", ice_id());
192 obj->setElement("array", arr);
193 }
194
195 void
196 SingleTypeVariantList::deserialize(const ObjectSerializerBasePtr& serializer,
197 const Ice::Current&)
198 {
199 AbstractObjectSerializerPtr obj = AbstractObjectSerializerPtr::dynamicCast(serializer);
200 AbstractObjectSerializerPtr arr = obj->getElement("array");
201
202 for (size_t i = 0; i < arr->size(); i++)
203 {
204 VariantContainerBasePtr c = VariantContainerBasePtr::dynamicCast(arr->getIceObject(i));
205
206 if (c)
207 {
208 addElement(c);
209 }
210 else
211 {
212 throw LocalException("Could not cast to VariantContainerBasePtr");
213 }
214 }
215 }
216
217 std::string
219 {
220 return "::armarx::SingleTypeVariantListBase";
221 }
222
223 std::string
224 SingleTypeVariantList::toString(const Ice::Current&) const
225 {
226 std::stringstream ss;
227
228 for (const auto& element : elements)
229 {
230 if (elements[elements.size() - 1] != element)
231 {
232 ss << element->toString() << "\n";
233 }
234 else
235 {
236 ss << element->toString();
237 }
238 }
239
240 return ss.str();
241 }
242
243 Ice::Int
244 armarx::SingleTypeVariantList::getType(const Ice::Current&) const
245 {
247 }
248} // namespace armarx
uint8_t index
constexpr T c
The SingleTypeVariantList class is a subclass of VariantContainer and is comparable to a std::vector<...
void addVariant(const Variant &variant)
static VariantTypeId getStaticType(const Ice::Current &c=Ice::emptyCurrent)
IceInternal::Handle< ContainerType > getElement(int index) const
VariantPtr getVariant(int index) const
std::string toString(const Ice::Current &=Ice::emptyCurrent) const override
VariantContainerBasePtr cloneContainer(const Ice::Current &c=Ice::emptyCurrent) const override
VariantContainerBasePtr getElementBase(int index, const Ice::Current &c=Ice::emptyCurrent) const override
getElementBase is the slice-interface implementation for getting an Element and only returns a basepo...
bool validateElements(const Ice::Current &c=Ice::emptyCurrent) override
void deserialize(const ObjectSerializerBasePtr &serializer, const ::Ice::Current &=Ice::emptyCurrent) override
int getSize(const Ice::Current &c=Ice::emptyCurrent) const override
Ice::Int getType(const Ice::Current &c=Ice::emptyCurrent) const override
Ice::ObjectPtr ice_clone() const override
void serialize(const ObjectSerializerBasePtr &serializer, const ::Ice::Current &=Ice::emptyCurrent) const override
void clear(const Ice::Current &c=Ice::emptyCurrent) override
void addElement(const VariantContainerBasePtr &variantContainer, const Ice::Current &c=Ice::emptyCurrent) override
SingleTypeVariantList & operator=(const SingleTypeVariantList &source)
The SingleVariant class is required to store single Variant instances in VariantContainer subclasses.
static bool compare(const ContainerTypePtr &type1, const ContainerTypePtr &secondType)
VariantDataClassPtr clone(const Ice::Current &c=Ice::emptyCurrent) const override
ContainerTypePtr getContainerType(const Ice::Current &c=Ice::emptyCurrent) const override
The Variant class is described here: Variants.
Definition Variant.h:224
VariantTypeId getType(const Ice::Current &c=Ice::emptyCurrent) const override
Return the Variant's internal type.
Definition Variant.cpp:679
static VariantTypeId addTypeName(const std::string &typeName)
Register a new type for the use in a Variant.
Definition Variant.cpp:869
static std::string typeToString(VariantTypeId typeId)
Return the name of the registered type typeId.
Definition Variant.cpp:848
const VariantTypeId Invalid
Definition Variant.h:915
const VariantContainerType List
This file offers overloads of toIce() and fromIce() functions for STL container types.
IceInternal::Handle< Variant > VariantPtr
Definition Variant.h:41
IceInternal::Handle< AbstractObjectSerializer > AbstractObjectSerializerPtr
Ice::Int VariantTypeId
Definition Variant.h:43