blob: 9d8f46f3918271045e0ce91c5ad938bc8d965bb8 [file] [log] [blame]
/*
* Copyright (c) 2011-2015, Intel Corporation
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation and/or
* other materials provided with the distribution.
*
* 3. Neither the name of the copyright holder nor the names of its contributors
* may be used to endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once
#include "parameter_export.h"
#include "Element.h"
#include <string>
class CMappingData;
class CInstanceConfigurableElement;
class PARAMETER_EXPORT CTypeElement : public CElement
{
public:
CTypeElement(const std::string &strName = "");
virtual ~CTypeElement();
// Instantiation
CInstanceConfigurableElement *instantiate() const;
// Mapping info
virtual bool getMappingData(const std::string &strKey, const std::string *&pStrValue) const;
virtual bool hasMappingData() const;
/**
* Returns the mapping associated to the current TypeElement instance
*
* @return A std::string containing the mapping as a comma separated key value pairs
*/
virtual std::string getFormattedMapping() const;
// Element properties
virtual void showProperties(std::string &strResult) const;
// From IXmlSink
virtual bool fromXml(const CXmlElement &xmlElement, CXmlSerializingContext &serializingContext);
// From IXmlSource
virtual void toXml(CXmlElement &xmlElement, CXmlSerializingContext &serializingContext) const;
// Scalar or Array?
bool isScalar() const;
// Array Length
size_t getArrayLength() const;
/**
* Converts size optimized integer input data (int8, int16, int32) to plain int
*
* @param[in] iSizeOptimizedData the data to convert
*
* @return the data with int type
*/
virtual int toPlainInteger(int iSizeOptimizedData) const;
protected:
// Object creation
virtual void populate(CElement *pElement) const;
/** @Returns the mapping associated to the current type and its predecessor
*
* The meaning of predecessor depends on the TypeElement type: e.g. for a
* component instance, the predecessor is the ComponentType; for a
* ComponentType, the predecessor is its base type.
*
* The predecessor's mapping comes first, then the current type's mapping.
*
* @param[in] predecessor A pointer to the predecessor or NULL.
*/
std::string getFormattedMapping(const CTypeElement *predecessor) const;
private:
CTypeElement(const CTypeElement &);
CTypeElement &operator=(const CTypeElement &);
// Actual instance creation
virtual CInstanceConfigurableElement *doInstantiate() const = 0;
// Mapping data creation and access
CMappingData *getMappingData();
// For Arrays. 0 means scalar
size_t _arrayLength{0};
// Mapping info
CMappingData *_pMappingData{nullptr};
};