xref: /aosp_15_r20/external/parameter-framework/upstream/parameter/ElementHandle.cpp (revision c33452fb792a5495ec310a9626f2638b053af5dd)
1*c33452fbSAndroid Build Coastguard Worker /*
2*c33452fbSAndroid Build Coastguard Worker  * Copyright (c) 2015, Intel Corporation
3*c33452fbSAndroid Build Coastguard Worker  * All rights reserved.
4*c33452fbSAndroid Build Coastguard Worker  *
5*c33452fbSAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without modification,
6*c33452fbSAndroid Build Coastguard Worker  * are permitted provided that the following conditions are met:
7*c33452fbSAndroid Build Coastguard Worker  *
8*c33452fbSAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright notice, this
9*c33452fbSAndroid Build Coastguard Worker  * list of conditions and the following disclaimer.
10*c33452fbSAndroid Build Coastguard Worker  *
11*c33452fbSAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright notice,
12*c33452fbSAndroid Build Coastguard Worker  * this list of conditions and the following disclaimer in the documentation and/or
13*c33452fbSAndroid Build Coastguard Worker  * other materials provided with the distribution.
14*c33452fbSAndroid Build Coastguard Worker  *
15*c33452fbSAndroid Build Coastguard Worker  * 3. Neither the name of the copyright holder nor the names of its contributors
16*c33452fbSAndroid Build Coastguard Worker  * may be used to endorse or promote products derived from this software without
17*c33452fbSAndroid Build Coastguard Worker  * specific prior written permission.
18*c33452fbSAndroid Build Coastguard Worker  *
19*c33452fbSAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20*c33452fbSAndroid Build Coastguard Worker  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21*c33452fbSAndroid Build Coastguard Worker  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22*c33452fbSAndroid Build Coastguard Worker  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
23*c33452fbSAndroid Build Coastguard Worker  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24*c33452fbSAndroid Build Coastguard Worker  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25*c33452fbSAndroid Build Coastguard Worker  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
26*c33452fbSAndroid Build Coastguard Worker  * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27*c33452fbSAndroid Build Coastguard Worker  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28*c33452fbSAndroid Build Coastguard Worker  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29*c33452fbSAndroid Build Coastguard Worker  */
30*c33452fbSAndroid Build Coastguard Worker #include "ElementHandle.h"
31*c33452fbSAndroid Build Coastguard Worker #include "ParameterAccessContext.h"
32*c33452fbSAndroid Build Coastguard Worker #include "BaseParameter.h"
33*c33452fbSAndroid Build Coastguard Worker #include "XmlParameterSerializingContext.h"
34*c33452fbSAndroid Build Coastguard Worker #include "Subsystem.h"
35*c33452fbSAndroid Build Coastguard Worker #include <assert.h>
36*c33452fbSAndroid Build Coastguard Worker #include "ParameterMgr.h"
37*c33452fbSAndroid Build Coastguard Worker 
38*c33452fbSAndroid Build Coastguard Worker #include <mutex>
39*c33452fbSAndroid Build Coastguard Worker 
40*c33452fbSAndroid Build Coastguard Worker using std::string;
41*c33452fbSAndroid Build Coastguard Worker using std::mutex;
42*c33452fbSAndroid Build Coastguard Worker using std::lock_guard;
43*c33452fbSAndroid Build Coastguard Worker 
44*c33452fbSAndroid Build Coastguard Worker /** @return 0 by default, ie for non overloaded types. */
45*c33452fbSAndroid Build Coastguard Worker template <class T>
getUserInputSize(const T &)46*c33452fbSAndroid Build Coastguard Worker static size_t getUserInputSize(const T & /*scalar*/)
47*c33452fbSAndroid Build Coastguard Worker {
48*c33452fbSAndroid Build Coastguard Worker     return 0;
49*c33452fbSAndroid Build Coastguard Worker }
50*c33452fbSAndroid Build Coastguard Worker 
51*c33452fbSAndroid Build Coastguard Worker /** @return the vector's size. */
52*c33452fbSAndroid Build Coastguard Worker template <class T>
getUserInputSize(const std::vector<T> & vector)53*c33452fbSAndroid Build Coastguard Worker static size_t getUserInputSize(const std::vector<T> &vector)
54*c33452fbSAndroid Build Coastguard Worker {
55*c33452fbSAndroid Build Coastguard Worker     return vector.size();
56*c33452fbSAndroid Build Coastguard Worker }
57*c33452fbSAndroid Build Coastguard Worker 
ElementHandle(CConfigurableElement & element,CParameterMgr & parameterMgr)58*c33452fbSAndroid Build Coastguard Worker ElementHandle::ElementHandle(CConfigurableElement &element, CParameterMgr &parameterMgr)
59*c33452fbSAndroid Build Coastguard Worker     : mElement(element), mParameterMgr(parameterMgr)
60*c33452fbSAndroid Build Coastguard Worker {
61*c33452fbSAndroid Build Coastguard Worker }
62*c33452fbSAndroid Build Coastguard Worker 
getName() const63*c33452fbSAndroid Build Coastguard Worker string ElementHandle::getName() const
64*c33452fbSAndroid Build Coastguard Worker {
65*c33452fbSAndroid Build Coastguard Worker     return mElement.getName();
66*c33452fbSAndroid Build Coastguard Worker }
67*c33452fbSAndroid Build Coastguard Worker 
getSize() const68*c33452fbSAndroid Build Coastguard Worker size_t ElementHandle::getSize() const
69*c33452fbSAndroid Build Coastguard Worker {
70*c33452fbSAndroid Build Coastguard Worker     return mElement.getFootPrint();
71*c33452fbSAndroid Build Coastguard Worker }
72*c33452fbSAndroid Build Coastguard Worker 
isParameter() const73*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::isParameter() const
74*c33452fbSAndroid Build Coastguard Worker {
75*c33452fbSAndroid Build Coastguard Worker     return mElement.isParameter();
76*c33452fbSAndroid Build Coastguard Worker }
77*c33452fbSAndroid Build Coastguard Worker 
getDescription() const78*c33452fbSAndroid Build Coastguard Worker string ElementHandle::getDescription() const
79*c33452fbSAndroid Build Coastguard Worker {
80*c33452fbSAndroid Build Coastguard Worker     return mElement.getDescription();
81*c33452fbSAndroid Build Coastguard Worker }
82*c33452fbSAndroid Build Coastguard Worker 
83*c33452fbSAndroid Build Coastguard Worker // Parameter features
isRogue() const84*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::isRogue() const
85*c33452fbSAndroid Build Coastguard Worker {
86*c33452fbSAndroid Build Coastguard Worker     return mElement.isRogue();
87*c33452fbSAndroid Build Coastguard Worker }
88*c33452fbSAndroid Build Coastguard Worker 
isArray() const89*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::isArray() const
90*c33452fbSAndroid Build Coastguard Worker {
91*c33452fbSAndroid Build Coastguard Worker     return getArrayLength() != 0;
92*c33452fbSAndroid Build Coastguard Worker }
93*c33452fbSAndroid Build Coastguard Worker 
getArrayLength() const94*c33452fbSAndroid Build Coastguard Worker size_t ElementHandle::getArrayLength() const
95*c33452fbSAndroid Build Coastguard Worker {
96*c33452fbSAndroid Build Coastguard Worker     // Only instances can be arrays, SystemClass can not, nor subsystems
97*c33452fbSAndroid Build Coastguard Worker     auto *instance = dynamic_cast<CInstanceConfigurableElement *>(&mElement);
98*c33452fbSAndroid Build Coastguard Worker     if (instance == nullptr) {
99*c33452fbSAndroid Build Coastguard Worker         return 0;
100*c33452fbSAndroid Build Coastguard Worker     }
101*c33452fbSAndroid Build Coastguard Worker     return instance->getArrayLength();
102*c33452fbSAndroid Build Coastguard Worker }
103*c33452fbSAndroid Build Coastguard Worker 
getPath() const104*c33452fbSAndroid Build Coastguard Worker string ElementHandle::getPath() const
105*c33452fbSAndroid Build Coastguard Worker {
106*c33452fbSAndroid Build Coastguard Worker     return mElement.getPath();
107*c33452fbSAndroid Build Coastguard Worker }
108*c33452fbSAndroid Build Coastguard Worker 
getKind() const109*c33452fbSAndroid Build Coastguard Worker string ElementHandle::getKind() const
110*c33452fbSAndroid Build Coastguard Worker {
111*c33452fbSAndroid Build Coastguard Worker     return mElement.getKind();
112*c33452fbSAndroid Build Coastguard Worker }
113*c33452fbSAndroid Build Coastguard Worker 
getChildren()114*c33452fbSAndroid Build Coastguard Worker std::vector<ElementHandle> ElementHandle::getChildren()
115*c33452fbSAndroid Build Coastguard Worker {
116*c33452fbSAndroid Build Coastguard Worker     size_t nbChildren = mElement.getNbChildren();
117*c33452fbSAndroid Build Coastguard Worker 
118*c33452fbSAndroid Build Coastguard Worker     std::vector<ElementHandle> children;
119*c33452fbSAndroid Build Coastguard Worker     children.reserve(nbChildren);
120*c33452fbSAndroid Build Coastguard Worker 
121*c33452fbSAndroid Build Coastguard Worker     for (size_t childIndex = 0; childIndex < nbChildren; ++childIndex) {
122*c33452fbSAndroid Build Coastguard Worker         auto *child = static_cast<CConfigurableElement *>(mElement.getChild(childIndex));
123*c33452fbSAndroid Build Coastguard Worker         // Can not use emplace back as the constructor is private
124*c33452fbSAndroid Build Coastguard Worker         children.push_back({*child, mParameterMgr});
125*c33452fbSAndroid Build Coastguard Worker     }
126*c33452fbSAndroid Build Coastguard Worker     return children;
127*c33452fbSAndroid Build Coastguard Worker }
128*c33452fbSAndroid Build Coastguard Worker 
getMappingData(const string & strKey,string & strValue) const129*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getMappingData(const string &strKey, string &strValue) const
130*c33452fbSAndroid Build Coastguard Worker {
131*c33452fbSAndroid Build Coastguard Worker     const std::string *pStrValue;
132*c33452fbSAndroid Build Coastguard Worker 
133*c33452fbSAndroid Build Coastguard Worker     // Seach for the key in self and ancestors
134*c33452fbSAndroid Build Coastguard Worker     auto elements = mElement.getConfigurableElementContext();
135*c33452fbSAndroid Build Coastguard Worker 
136*c33452fbSAndroid Build Coastguard Worker     for (auto *element : elements)
137*c33452fbSAndroid Build Coastguard Worker         if (element->getMappingData(strKey, pStrValue)) {
138*c33452fbSAndroid Build Coastguard Worker             strValue = *pStrValue;
139*c33452fbSAndroid Build Coastguard Worker             return true;
140*c33452fbSAndroid Build Coastguard Worker         }
141*c33452fbSAndroid Build Coastguard Worker 
142*c33452fbSAndroid Build Coastguard Worker     return false;
143*c33452fbSAndroid Build Coastguard Worker }
144*c33452fbSAndroid Build Coastguard Worker 
getStructureAsXML(std::string & xmlSettings,std::string & error) const145*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getStructureAsXML(std::string &xmlSettings, std::string &error) const
146*c33452fbSAndroid Build Coastguard Worker {
147*c33452fbSAndroid Build Coastguard Worker     // Use default access context for structure export
148*c33452fbSAndroid Build Coastguard Worker     CParameterAccessContext accessContext(error);
149*c33452fbSAndroid Build Coastguard Worker     return mParameterMgr.exportElementToXMLString(
150*c33452fbSAndroid Build Coastguard Worker         &mElement, mElement.getXmlElementName(),
151*c33452fbSAndroid Build Coastguard Worker         CXmlParameterSerializingContext{accessContext, error}, xmlSettings);
152*c33452fbSAndroid Build Coastguard Worker }
153*c33452fbSAndroid Build Coastguard Worker 
154*c33452fbSAndroid Build Coastguard Worker template <class T>
155*c33452fbSAndroid Build Coastguard Worker struct isVector : std::false_type
156*c33452fbSAndroid Build Coastguard Worker {
157*c33452fbSAndroid Build Coastguard Worker };
158*c33452fbSAndroid Build Coastguard Worker template <class T>
159*c33452fbSAndroid Build Coastguard Worker struct isVector<std::vector<T>> : std::true_type
160*c33452fbSAndroid Build Coastguard Worker {
161*c33452fbSAndroid Build Coastguard Worker };
162*c33452fbSAndroid Build Coastguard Worker 
getAsXML(std::string & xmlValue,std::string & error) const163*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsXML(std::string &xmlValue, std::string &error) const
164*c33452fbSAndroid Build Coastguard Worker {
165*c33452fbSAndroid Build Coastguard Worker     std::string result;
166*c33452fbSAndroid Build Coastguard Worker     if (not mParameterMgr.getSettingsAsXML(&mElement, result)) {
167*c33452fbSAndroid Build Coastguard Worker         error = result;
168*c33452fbSAndroid Build Coastguard Worker         return false;
169*c33452fbSAndroid Build Coastguard Worker     }
170*c33452fbSAndroid Build Coastguard Worker 
171*c33452fbSAndroid Build Coastguard Worker     xmlValue = result;
172*c33452fbSAndroid Build Coastguard Worker     return true;
173*c33452fbSAndroid Build Coastguard Worker }
174*c33452fbSAndroid Build Coastguard Worker 
setAsXML(const std::string & xmlValue,std::string & error)175*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsXML(const std::string &xmlValue, std::string &error)
176*c33452fbSAndroid Build Coastguard Worker {
177*c33452fbSAndroid Build Coastguard Worker     return mParameterMgr.setSettingsAsXML(&mElement, xmlValue, error);
178*c33452fbSAndroid Build Coastguard Worker }
179*c33452fbSAndroid Build Coastguard Worker 
getAsBytes(std::vector<uint8_t> & bytesValue,std::string &) const180*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsBytes(std::vector<uint8_t> &bytesValue, std::string & /*error*/) const
181*c33452fbSAndroid Build Coastguard Worker {
182*c33452fbSAndroid Build Coastguard Worker     mParameterMgr.getSettingsAsBytes(mElement, bytesValue);
183*c33452fbSAndroid Build Coastguard Worker 
184*c33452fbSAndroid Build Coastguard Worker     // Currently this operation can not fail.
185*c33452fbSAndroid Build Coastguard Worker     // Nevertheless this is more a design than intrinsic property.
186*c33452fbSAndroid Build Coastguard Worker     // Use the same error reporting pattern to avoid breaking the api in future
187*c33452fbSAndroid Build Coastguard Worker     // release if an error need to be reported (and be consistent with all other getAs*).
188*c33452fbSAndroid Build Coastguard Worker     return true;
189*c33452fbSAndroid Build Coastguard Worker }
190*c33452fbSAndroid Build Coastguard Worker 
setAsBytes(const std::vector<uint8_t> & bytesValue,std::string & error)191*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsBytes(const std::vector<uint8_t> &bytesValue, std::string &error)
192*c33452fbSAndroid Build Coastguard Worker {
193*c33452fbSAndroid Build Coastguard Worker     return mParameterMgr.setSettingsAsBytes(mElement, bytesValue, error);
194*c33452fbSAndroid Build Coastguard Worker }
195*c33452fbSAndroid Build Coastguard Worker 
196*c33452fbSAndroid Build Coastguard Worker template <class T>
setAs(const T value,string & error) const197*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAs(const T value, string &error) const
198*c33452fbSAndroid Build Coastguard Worker {
199*c33452fbSAndroid Build Coastguard Worker     if (not checkSetValidity(getUserInputSize(value), error)) {
200*c33452fbSAndroid Build Coastguard Worker         return false;
201*c33452fbSAndroid Build Coastguard Worker     }
202*c33452fbSAndroid Build Coastguard Worker     // Safe downcast thanks to isParameter check in checkSetValidity
203*c33452fbSAndroid Build Coastguard Worker     auto &parameter = static_cast<CBaseParameter &>(mElement);
204*c33452fbSAndroid Build Coastguard Worker 
205*c33452fbSAndroid Build Coastguard Worker     // When in tuning mode, silently skip "set" requests
206*c33452fbSAndroid Build Coastguard Worker     if (mParameterMgr.tuningModeOn()) {
207*c33452fbSAndroid Build Coastguard Worker 
208*c33452fbSAndroid Build Coastguard Worker         return true;
209*c33452fbSAndroid Build Coastguard Worker     }
210*c33452fbSAndroid Build Coastguard Worker 
211*c33452fbSAndroid Build Coastguard Worker     CParameterAccessContext parameterAccessContext(error, mParameterMgr.getParameterBlackboard());
212*c33452fbSAndroid Build Coastguard Worker 
213*c33452fbSAndroid Build Coastguard Worker     // BaseParamere::access takes a non-const argument - therefore we need to
214*c33452fbSAndroid Build Coastguard Worker     // copy the value
215*c33452fbSAndroid Build Coastguard Worker     T copy = value;
216*c33452fbSAndroid Build Coastguard Worker 
217*c33452fbSAndroid Build Coastguard Worker     // Ensure we're safe against blackboard foreign access
218*c33452fbSAndroid Build Coastguard Worker     lock_guard<mutex> autoLock(mParameterMgr.getBlackboardMutex());
219*c33452fbSAndroid Build Coastguard Worker 
220*c33452fbSAndroid Build Coastguard Worker     return parameter.access(copy, true, parameterAccessContext);
221*c33452fbSAndroid Build Coastguard Worker }
222*c33452fbSAndroid Build Coastguard Worker 
223*c33452fbSAndroid Build Coastguard Worker template <class T>
getAs(T & value,string & error) const224*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAs(T &value, string &error) const
225*c33452fbSAndroid Build Coastguard Worker {
226*c33452fbSAndroid Build Coastguard Worker     if (not checkGetValidity(isVector<T>::value, error)) {
227*c33452fbSAndroid Build Coastguard Worker         return false;
228*c33452fbSAndroid Build Coastguard Worker     }
229*c33452fbSAndroid Build Coastguard Worker     // Safe downcast thanks to isParameter check in checkGetValidity
230*c33452fbSAndroid Build Coastguard Worker     auto &parameter = static_cast<const CBaseParameter &>(mElement);
231*c33452fbSAndroid Build Coastguard Worker 
232*c33452fbSAndroid Build Coastguard Worker     // Ensure we're safe against blackboard foreign access
233*c33452fbSAndroid Build Coastguard Worker     lock_guard<mutex> autoLock(mParameterMgr.getBlackboardMutex());
234*c33452fbSAndroid Build Coastguard Worker 
235*c33452fbSAndroid Build Coastguard Worker     CParameterAccessContext parameterAccessContext(error, mParameterMgr.getParameterBlackboard());
236*c33452fbSAndroid Build Coastguard Worker 
237*c33452fbSAndroid Build Coastguard Worker     return parameter.access(value, false, parameterAccessContext);
238*c33452fbSAndroid Build Coastguard Worker }
239*c33452fbSAndroid Build Coastguard Worker 
240*c33452fbSAndroid Build Coastguard Worker // Boolean access
setAsBoolean(bool value,string & error)241*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsBoolean(bool value, string &error)
242*c33452fbSAndroid Build Coastguard Worker {
243*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
244*c33452fbSAndroid Build Coastguard Worker }
245*c33452fbSAndroid Build Coastguard Worker 
getAsBoolean(bool & value,string & error) const246*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsBoolean(bool &value, string &error) const
247*c33452fbSAndroid Build Coastguard Worker {
248*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
249*c33452fbSAndroid Build Coastguard Worker }
250*c33452fbSAndroid Build Coastguard Worker 
setAsBooleanArray(const std::vector<bool> & value,string & error)251*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsBooleanArray(const std::vector<bool> &value, string &error)
252*c33452fbSAndroid Build Coastguard Worker {
253*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
254*c33452fbSAndroid Build Coastguard Worker }
255*c33452fbSAndroid Build Coastguard Worker 
getAsBooleanArray(std::vector<bool> & value,string & error) const256*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsBooleanArray(std::vector<bool> &value, string &error) const
257*c33452fbSAndroid Build Coastguard Worker {
258*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
259*c33452fbSAndroid Build Coastguard Worker }
260*c33452fbSAndroid Build Coastguard Worker 
261*c33452fbSAndroid Build Coastguard Worker // Integer Access
setAsInteger(uint32_t value,string & error)262*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsInteger(uint32_t value, string &error)
263*c33452fbSAndroid Build Coastguard Worker {
264*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
265*c33452fbSAndroid Build Coastguard Worker }
266*c33452fbSAndroid Build Coastguard Worker 
getAsInteger(uint32_t & value,string & error) const267*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsInteger(uint32_t &value, string &error) const
268*c33452fbSAndroid Build Coastguard Worker {
269*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
270*c33452fbSAndroid Build Coastguard Worker }
271*c33452fbSAndroid Build Coastguard Worker 
setAsIntegerArray(const std::vector<uint32_t> & value,string & error)272*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsIntegerArray(const std::vector<uint32_t> &value, string &error)
273*c33452fbSAndroid Build Coastguard Worker {
274*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
275*c33452fbSAndroid Build Coastguard Worker }
276*c33452fbSAndroid Build Coastguard Worker 
getAsIntegerArray(std::vector<uint32_t> & value,string & error) const277*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsIntegerArray(std::vector<uint32_t> &value, string &error) const
278*c33452fbSAndroid Build Coastguard Worker {
279*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
280*c33452fbSAndroid Build Coastguard Worker }
281*c33452fbSAndroid Build Coastguard Worker 
282*c33452fbSAndroid Build Coastguard Worker // Signed Integer Access
setAsSignedInteger(int32_t value,string & error)283*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsSignedInteger(int32_t value, string &error)
284*c33452fbSAndroid Build Coastguard Worker {
285*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
286*c33452fbSAndroid Build Coastguard Worker }
287*c33452fbSAndroid Build Coastguard Worker 
getAsSignedInteger(int32_t & value,string & error) const288*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsSignedInteger(int32_t &value, string &error) const
289*c33452fbSAndroid Build Coastguard Worker {
290*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
291*c33452fbSAndroid Build Coastguard Worker }
292*c33452fbSAndroid Build Coastguard Worker 
setAsSignedIntegerArray(const std::vector<int32_t> & value,string & error)293*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsSignedIntegerArray(const std::vector<int32_t> &value, string &error)
294*c33452fbSAndroid Build Coastguard Worker {
295*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
296*c33452fbSAndroid Build Coastguard Worker }
297*c33452fbSAndroid Build Coastguard Worker 
getAsSignedIntegerArray(std::vector<int32_t> & value,string & error) const298*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsSignedIntegerArray(std::vector<int32_t> &value, string &error) const
299*c33452fbSAndroid Build Coastguard Worker {
300*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
301*c33452fbSAndroid Build Coastguard Worker }
302*c33452fbSAndroid Build Coastguard Worker 
303*c33452fbSAndroid Build Coastguard Worker // Double Access
setAsDouble(double value,string & error)304*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsDouble(double value, string &error)
305*c33452fbSAndroid Build Coastguard Worker {
306*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
307*c33452fbSAndroid Build Coastguard Worker }
308*c33452fbSAndroid Build Coastguard Worker 
getAsDouble(double & value,string & error) const309*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsDouble(double &value, string &error) const
310*c33452fbSAndroid Build Coastguard Worker {
311*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
312*c33452fbSAndroid Build Coastguard Worker }
313*c33452fbSAndroid Build Coastguard Worker 
setAsDoubleArray(const std::vector<double> & value,string & error)314*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsDoubleArray(const std::vector<double> &value, string &error)
315*c33452fbSAndroid Build Coastguard Worker {
316*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
317*c33452fbSAndroid Build Coastguard Worker }
318*c33452fbSAndroid Build Coastguard Worker 
getAsDoubleArray(std::vector<double> & value,string & error) const319*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsDoubleArray(std::vector<double> &value, string &error) const
320*c33452fbSAndroid Build Coastguard Worker {
321*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
322*c33452fbSAndroid Build Coastguard Worker }
323*c33452fbSAndroid Build Coastguard Worker 
324*c33452fbSAndroid Build Coastguard Worker // String Access
setAsString(const string & value,string & error)325*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsString(const string &value, string &error)
326*c33452fbSAndroid Build Coastguard Worker {
327*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
328*c33452fbSAndroid Build Coastguard Worker }
329*c33452fbSAndroid Build Coastguard Worker 
getAsString(string & value,string & error) const330*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsString(string &value, string &error) const
331*c33452fbSAndroid Build Coastguard Worker {
332*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
333*c33452fbSAndroid Build Coastguard Worker }
334*c33452fbSAndroid Build Coastguard Worker 
setAsStringArray(const std::vector<string> & value,string & error)335*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::setAsStringArray(const std::vector<string> &value, string &error)
336*c33452fbSAndroid Build Coastguard Worker {
337*c33452fbSAndroid Build Coastguard Worker     return setAs(value, error);
338*c33452fbSAndroid Build Coastguard Worker }
339*c33452fbSAndroid Build Coastguard Worker 
getAsStringArray(std::vector<string> & value,string & error) const340*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::getAsStringArray(std::vector<string> &value, string &error) const
341*c33452fbSAndroid Build Coastguard Worker {
342*c33452fbSAndroid Build Coastguard Worker     return getAs(value, error);
343*c33452fbSAndroid Build Coastguard Worker }
344*c33452fbSAndroid Build Coastguard Worker 
checkGetValidity(bool asArray,string & error) const345*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::checkGetValidity(bool asArray, string &error) const
346*c33452fbSAndroid Build Coastguard Worker {
347*c33452fbSAndroid Build Coastguard Worker     if (not isParameter()) {
348*c33452fbSAndroid Build Coastguard Worker         error = "Can not set element " + getPath() + " as it is not a parameter.";
349*c33452fbSAndroid Build Coastguard Worker         return false;
350*c33452fbSAndroid Build Coastguard Worker     }
351*c33452fbSAndroid Build Coastguard Worker 
352*c33452fbSAndroid Build Coastguard Worker     if (asArray != isArray()) {
353*c33452fbSAndroid Build Coastguard Worker 
354*c33452fbSAndroid Build Coastguard Worker         auto toStr = [](bool array) { return array ? "an array" : "a scalar"; };
355*c33452fbSAndroid Build Coastguard Worker         error = "Can not get \"" + getPath() + "\" as " + toStr(asArray) + " because it is " +
356*c33452fbSAndroid Build Coastguard Worker                 toStr(isArray());
357*c33452fbSAndroid Build Coastguard Worker         return false;
358*c33452fbSAndroid Build Coastguard Worker     }
359*c33452fbSAndroid Build Coastguard Worker 
360*c33452fbSAndroid Build Coastguard Worker     return true;
361*c33452fbSAndroid Build Coastguard Worker }
362*c33452fbSAndroid Build Coastguard Worker 
363*c33452fbSAndroid Build Coastguard Worker // Access validity
checkSetValidity(size_t arrayLength,string & error) const364*c33452fbSAndroid Build Coastguard Worker bool ElementHandle::checkSetValidity(size_t arrayLength, string &error) const
365*c33452fbSAndroid Build Coastguard Worker {
366*c33452fbSAndroid Build Coastguard Worker     // Settings a parameter necessitates the right to get it
367*c33452fbSAndroid Build Coastguard Worker     if (not checkGetValidity(arrayLength != 0, error)) {
368*c33452fbSAndroid Build Coastguard Worker         return false;
369*c33452fbSAndroid Build Coastguard Worker     }
370*c33452fbSAndroid Build Coastguard Worker 
371*c33452fbSAndroid Build Coastguard Worker     if (!isRogue()) {
372*c33452fbSAndroid Build Coastguard Worker 
373*c33452fbSAndroid Build Coastguard Worker         error = "Can not set parameter \"" + getPath() + "\" as it is not rogue.";
374*c33452fbSAndroid Build Coastguard Worker         return false;
375*c33452fbSAndroid Build Coastguard Worker     }
376*c33452fbSAndroid Build Coastguard Worker 
377*c33452fbSAndroid Build Coastguard Worker     if (arrayLength && (arrayLength != getArrayLength())) {
378*c33452fbSAndroid Build Coastguard Worker 
379*c33452fbSAndroid Build Coastguard Worker         using std::to_string;
380*c33452fbSAndroid Build Coastguard Worker         error = "Array length mismatch for \"" + getPath() + "\", expected: " +
381*c33452fbSAndroid Build Coastguard Worker                 to_string(getArrayLength()) + ", got: " + to_string(arrayLength);
382*c33452fbSAndroid Build Coastguard Worker         return false;
383*c33452fbSAndroid Build Coastguard Worker     }
384*c33452fbSAndroid Build Coastguard Worker 
385*c33452fbSAndroid Build Coastguard Worker     return true;
386*c33452fbSAndroid Build Coastguard Worker }
387