1*c33452fbSAndroid Build Coastguard Worker /* 2*c33452fbSAndroid Build Coastguard Worker * Copyright (c) 2011-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 #pragma once 31*c33452fbSAndroid Build Coastguard Worker 32*c33452fbSAndroid Build Coastguard Worker #include "AreaConfiguration.h" 33*c33452fbSAndroid Build Coastguard Worker #include "XmlDomainImportContext.h" 34*c33452fbSAndroid Build Coastguard Worker #include "XmlDomainExportContext.h" 35*c33452fbSAndroid Build Coastguard Worker #include "Element.h" 36*c33452fbSAndroid Build Coastguard Worker #include "Results.h" 37*c33452fbSAndroid Build Coastguard Worker #include <list> 38*c33452fbSAndroid Build Coastguard Worker #include <string> 39*c33452fbSAndroid Build Coastguard Worker #include <memory> 40*c33452fbSAndroid Build Coastguard Worker 41*c33452fbSAndroid Build Coastguard Worker class CConfigurableElement; 42*c33452fbSAndroid Build Coastguard Worker class CParameterBlackboard; 43*c33452fbSAndroid Build Coastguard Worker class CConfigurationAccessContext; 44*c33452fbSAndroid Build Coastguard Worker class CCompoundRule; 45*c33452fbSAndroid Build Coastguard Worker class CSyncerSet; 46*c33452fbSAndroid Build Coastguard Worker class CSelectionCriteriaDefinition; 47*c33452fbSAndroid Build Coastguard Worker 48*c33452fbSAndroid Build Coastguard Worker class CDomainConfiguration : public CElement 49*c33452fbSAndroid Build Coastguard Worker { 50*c33452fbSAndroid Build Coastguard Worker enum ChildElementType 51*c33452fbSAndroid Build Coastguard Worker { 52*c33452fbSAndroid Build Coastguard Worker ECompoundRule 53*c33452fbSAndroid Build Coastguard Worker }; 54*c33452fbSAndroid Build Coastguard Worker 55*c33452fbSAndroid Build Coastguard Worker public: 56*c33452fbSAndroid Build Coastguard Worker CDomainConfiguration(const std::string &strName); 57*c33452fbSAndroid Build Coastguard Worker 58*c33452fbSAndroid Build Coastguard Worker // Configurable Elements association 59*c33452fbSAndroid Build Coastguard Worker void addConfigurableElement(const CConfigurableElement *configurableElement, 60*c33452fbSAndroid Build Coastguard Worker const CSyncerSet *syncerSet); 61*c33452fbSAndroid Build Coastguard Worker void removeConfigurableElement(const CConfigurableElement *pConfigurableElement); 62*c33452fbSAndroid Build Coastguard Worker 63*c33452fbSAndroid Build Coastguard Worker /** 64*c33452fbSAndroid Build Coastguard Worker * Sequence management: Prepend provided elements into internal list in the same order than 65*c33452fbSAndroid Build Coastguard Worker * they appear in the sequence of element path. 66*c33452fbSAndroid Build Coastguard Worker * @param[in] newElementSequence sequence of path of new element 67*c33452fbSAndroid Build Coastguard Worker * @param[out] error human readable error 68*c33452fbSAndroid Build Coastguard Worker * @return true if the new sequence has been taken into account, false otherwise and error is 69*c33452fbSAndroid Build Coastguard Worker * set accordingly. 70*c33452fbSAndroid Build Coastguard Worker */ 71*c33452fbSAndroid Build Coastguard Worker bool setElementSequence(const std::vector<std::string> &newElementSequence, std::string &error); 72*c33452fbSAndroid Build Coastguard Worker void getElementSequence(std::string &strResult) const; 73*c33452fbSAndroid Build Coastguard Worker 74*c33452fbSAndroid Build Coastguard Worker // Application rule 75*c33452fbSAndroid Build Coastguard Worker bool setApplicationRule(const std::string &strApplicationRule, 76*c33452fbSAndroid Build Coastguard Worker const CSelectionCriteriaDefinition *pSelectionCriteriaDefinition, 77*c33452fbSAndroid Build Coastguard Worker std::string &strError); 78*c33452fbSAndroid Build Coastguard Worker void clearApplicationRule(); 79*c33452fbSAndroid Build Coastguard Worker std::string getApplicationRule() const; 80*c33452fbSAndroid Build Coastguard Worker 81*c33452fbSAndroid Build Coastguard Worker // Get Blackboard for an element of the domain 82*c33452fbSAndroid Build Coastguard Worker CParameterBlackboard *getBlackboard(const CConfigurableElement *pConfigurableElement) const; 83*c33452fbSAndroid Build Coastguard Worker 84*c33452fbSAndroid Build Coastguard Worker // Save data from current 85*c33452fbSAndroid Build Coastguard Worker void save(const CParameterBlackboard *pMainBlackboard); 86*c33452fbSAndroid Build Coastguard Worker 87*c33452fbSAndroid Build Coastguard Worker /** Restore the configuration 88*c33452fbSAndroid Build Coastguard Worker * 89*c33452fbSAndroid Build Coastguard Worker * @param[in] pMainBlackboard the application main blackboard 90*c33452fbSAndroid Build Coastguard Worker * @param[in] bSync indicates if a synchronisation has to be done 91*c33452fbSAndroid Build Coastguard Worker * @param[out] errors, errors encountered during restoration 92*c33452fbSAndroid Build Coastguard Worker * @return true if success false otherwise 93*c33452fbSAndroid Build Coastguard Worker */ 94*c33452fbSAndroid Build Coastguard Worker bool restore(CParameterBlackboard *pMainBlackboard, bool bSync, 95*c33452fbSAndroid Build Coastguard Worker core::Results *errors = nullptr) const; 96*c33452fbSAndroid Build Coastguard Worker 97*c33452fbSAndroid Build Coastguard Worker // Ensure validity for configurable element area configuration 98*c33452fbSAndroid Build Coastguard Worker void validate(const CConfigurableElement *pConfigurableElement, 99*c33452fbSAndroid Build Coastguard Worker const CParameterBlackboard *pMainBlackboard); 100*c33452fbSAndroid Build Coastguard Worker // Ensure validity of all area configurations 101*c33452fbSAndroid Build Coastguard Worker void validate(const CParameterBlackboard *pMainBlackboard); 102*c33452fbSAndroid Build Coastguard Worker // Return configuration validity for given configurable element 103*c33452fbSAndroid Build Coastguard Worker bool isValid(const CConfigurableElement *pConfigurableElement) const; 104*c33452fbSAndroid Build Coastguard Worker // Ensure validity of configurable element's area configuration by copying in from a valid one 105*c33452fbSAndroid Build Coastguard Worker void validateAgainst(const CDomainConfiguration *pValidDomainConfiguration, 106*c33452fbSAndroid Build Coastguard Worker const CConfigurableElement *pConfigurableElement); 107*c33452fbSAndroid Build Coastguard Worker // Ensure validity of all configurable element's area configuration by copying in from a valid 108*c33452fbSAndroid Build Coastguard Worker // ones 109*c33452fbSAndroid Build Coastguard Worker void validateAgainst(const CDomainConfiguration *validDomainConfiguration); 110*c33452fbSAndroid Build Coastguard Worker // Applicability checking 111*c33452fbSAndroid Build Coastguard Worker bool isApplicable() const; 112*c33452fbSAndroid Build Coastguard Worker // Merge existing configurations to given configurable element ones 113*c33452fbSAndroid Build Coastguard Worker void merge(CConfigurableElement *pToConfigurableElement, 114*c33452fbSAndroid Build Coastguard Worker CConfigurableElement *pFromConfigurableElement); 115*c33452fbSAndroid Build Coastguard Worker // Domain splitting 116*c33452fbSAndroid Build Coastguard Worker void split(CConfigurableElement *pFromConfigurableElement); 117*c33452fbSAndroid Build Coastguard Worker 118*c33452fbSAndroid Build Coastguard Worker // XML configuration settings parsing/composing 119*c33452fbSAndroid Build Coastguard Worker bool parseSettings(CXmlElement &xmlConfigurationSettingsElement, 120*c33452fbSAndroid Build Coastguard Worker CXmlDomainImportContext &context); 121*c33452fbSAndroid Build Coastguard Worker void composeSettings(CXmlElement &xmlConfigurationSettingsElement, 122*c33452fbSAndroid Build Coastguard Worker CXmlDomainExportContext &context) const; 123*c33452fbSAndroid Build Coastguard Worker 124*c33452fbSAndroid Build Coastguard Worker // Class kind 125*c33452fbSAndroid Build Coastguard Worker std::string getKind() const override; 126*c33452fbSAndroid Build Coastguard Worker 127*c33452fbSAndroid Build Coastguard Worker private: 128*c33452fbSAndroid Build Coastguard Worker using AreaConfiguration = std::unique_ptr<CAreaConfiguration>; 129*c33452fbSAndroid Build Coastguard Worker using AreaConfigurations = std::list<AreaConfiguration>; 130*c33452fbSAndroid Build Coastguard Worker 131*c33452fbSAndroid Build Coastguard Worker // Returns true if children dynamic creation is to be dealt with (here, will allow child 132*c33452fbSAndroid Build Coastguard Worker // deletion upon clean) 133*c33452fbSAndroid Build Coastguard Worker bool childrenAreDynamic() const override; 134*c33452fbSAndroid Build Coastguard Worker // XML configuration settings serializing 135*c33452fbSAndroid Build Coastguard Worker bool importOneConfigurableElementSettings(CAreaConfiguration *areaConfiguration, 136*c33452fbSAndroid Build Coastguard Worker CXmlElement &xmlConfigurableElementSettingsElement, 137*c33452fbSAndroid Build Coastguard Worker CXmlDomainImportContext &context); 138*c33452fbSAndroid Build Coastguard Worker bool exportOneConfigurableElementSettings(CAreaConfiguration *areaConfiguration, 139*c33452fbSAndroid Build Coastguard Worker CXmlElement &xmlConfigurableElementSettingsElement, 140*c33452fbSAndroid Build Coastguard Worker CXmlDomainExportContext &context) const; 141*c33452fbSAndroid Build Coastguard Worker // AreaConfiguration retrieval from configurable element 142*c33452fbSAndroid Build Coastguard Worker const AreaConfiguration &getAreaConfiguration( 143*c33452fbSAndroid Build Coastguard Worker const CConfigurableElement *pConfigurableElement) const; 144*c33452fbSAndroid Build Coastguard Worker 145*c33452fbSAndroid Build Coastguard Worker /** 146*c33452fbSAndroid Build Coastguard Worker * Returns the AreaConfiguration iterator associated to the Element refered by its path 147*c33452fbSAndroid Build Coastguard Worker * @param[in] configurableElementPath to check if found in current list of areaconfigurations 148*c33452fbSAndroid Build Coastguard Worker * @return iterator on the configuration associated to the Element with the given path, 149*c33452fbSAndroid Build Coastguard Worker * last if not found 150*c33452fbSAndroid Build Coastguard Worker */ 151*c33452fbSAndroid Build Coastguard Worker AreaConfigurations::iterator findAreaConfigurationByPath( 152*c33452fbSAndroid Build Coastguard Worker const std::string &configurableElementPath); 153*c33452fbSAndroid Build Coastguard Worker 154*c33452fbSAndroid Build Coastguard Worker // Rule 155*c33452fbSAndroid Build Coastguard Worker const CCompoundRule *getRule() const; 156*c33452fbSAndroid Build Coastguard Worker CCompoundRule *getRule(); 157*c33452fbSAndroid Build Coastguard Worker void setRule(CCompoundRule *pRule); 158*c33452fbSAndroid Build Coastguard Worker 159*c33452fbSAndroid Build Coastguard Worker AreaConfigurations mAreaConfigurationList; 160*c33452fbSAndroid Build Coastguard Worker }; 161