/* * INTEL CONFIDENTIAL * Copyright © 2011 Intel * Corporation All Rights Reserved. * * The source code contained or described herein and all documents related to * the source code ("Material") are owned by Intel Corporation or its suppliers * or licensors. Title to the Material remains with Intel Corporation or its * suppliers and licensors. The Material contains trade secrets and proprietary * and confidential information of Intel or its suppliers and licensors. The * Material is protected by worldwide copyright and trade secret laws and * treaty provisions. No part of the Material may be used, copied, reproduced, * modified, published, uploaded, posted, transmitted, distributed, or * disclosed in any way without Intel’s prior express written permission. * * No license under any patent, copyright, trade secret or other intellectual * property right is granted to or conferred upon you by disclosure or delivery * of the Materials, either expressly, by implication, inducement, estoppel or * otherwise. Any license under such intellectual property rights must be * express and approved by Intel in writing. * * CREATED: 2011-06-01 * UPDATED: 2011-07-27 */ #pragma once #include "BinarySerializableElement.h" #include "SyncerSet.h" #include #include #include class CConfigurableElement; class CDomainConfiguration; class CParameterBlackboard; class CSelectionCriteriaDefinition; class CConfigurableDomain : public CBinarySerializableElement { typedef list::const_iterator ConfigurableElementListIterator; typedef map::const_iterator ConfigurableElementToSyncerSetMapIterator; public: CConfigurableDomain(const string& strName); virtual ~CConfigurableDomain(); // Sequence awareness void setSequenceAwareness(bool bSequenceAware); bool getSequenceAwareness() const; // Configuration Management bool createConfiguration(const string& strName, const CParameterBlackboard* pMainBlackboard, string& strError); bool deleteConfiguration(const string& strName, string& strError); bool renameConfiguration(const string& strName, const string& strNewName, string& strError); bool restoreConfiguration(const string& strName, CParameterBlackboard* pMainBlackboard, bool bAutoSync, list& strError) const; bool saveConfiguration(const string& strName, const CParameterBlackboard* pMainBlackboard, string& strError); bool setElementSequence(const string& strConfiguration, const vector& astrNewElementSequence, string& strError); bool getElementSequence(const string& strConfiguration, string& strResult) const; bool setApplicationRule(const string& strConfiguration, const string& strApplicationRule, const CSelectionCriteriaDefinition* pSelectionCriteriaDefinition, string& strError); bool clearApplicationRule(const string& strConfiguration, string& strError); bool getApplicationRule(const string& strConfiguration, string& strResult) const; // Last applied configuration name string getLastAppliedConfigurationName() const; // Pending configuration name string getPendingConfigurationName() const; // Associated Configurable elements void gatherConfigurableElements(set& configurableElementSet) const; void listAssociatedToElements(string& strResult) const; // Configurable elements association bool addConfigurableElement(CConfigurableElement* pConfigurableElement, const CParameterBlackboard* pMainBlackboard, string& strError); bool removeConfigurableElement(CConfigurableElement* pConfigurableElement, string& strError); // Domain splitting bool split(CConfigurableElement* pConfigurableElement, string& strError); // Ensure validity on whole domain from main blackboard void validate(const CParameterBlackboard* pMainBlackboard); // Configuration application if required void apply(CParameterBlackboard* pParameterBlackboard, CSyncerSet* pSyncerSet, bool bForced) const; // Return applicable configuration validity for given configurable element bool isApplicableConfigurationValid(const CConfigurableElement* pConfigurableElement) const; // From IXmlSink virtual bool fromXml(const CXmlElement& xmlElement, CXmlSerializingContext& serializingContext); // From IXmlSource virtual void toXml(CXmlElement& xmlElement, CXmlSerializingContext& serializingContext) const; // Class kind virtual string getKind() const; protected: // Content dumping virtual void logValue(string& strValue, CErrorContext& errorContext) const; private: // Get pending configuration const CDomainConfiguration* getPendingConfiguration() const; // Search for an applicable configuration const CDomainConfiguration* findApplicableDomainConfiguration() const; // Returns true if children dynamic creation is to be dealt with (here, will allow child deletion upon clean) virtual bool childrenAreDynamic() const; // Ensure validity on areas related to configurable element void validateAreas(const CConfigurableElement* pConfigurableElement, const CParameterBlackboard* pMainBlackboard); // Attempt validation for all configurable element's areas, relying on already existing valid configuration inside domain void autoValidateAll(); // Attempt validation for one configurable element's areas, relying on already existing valid configuration inside domain void autoValidateAreas(const CConfigurableElement* pConfigurableElement); // Attempt configuration validation for all configurable elements' areas, relying on already existing valid configuration inside domain bool autoValidateConfiguration(CDomainConfiguration* pDomainConfiguration); // Search for a valid configuration for given configurable element const CDomainConfiguration* findValidDomainConfiguration(const CConfigurableElement* pConfigurableElement) const; // In case configurable element was removed void computeSyncSet(); // Check configurable element already attached bool containsConfigurableElement(const CConfigurableElement* pConfigurableCandidateElement) const; // Merge any descended configurable element to this one void mergeAlreadyAssociatedDescendantConfigurableElements(CConfigurableElement* pNewConfigurableElement); void mergeConfigurations(CConfigurableElement* pToConfigurableElement, CConfigurableElement* pFromConfigurableElement); // Configurable elements association void doAddConfigurableElement(CConfigurableElement* pConfigurableElement, const CParameterBlackboard* pMainBlackboard = NULL); void doRemoveConfigurableElement(CConfigurableElement* pConfigurableElement, bool bRecomputeSyncSet); // XML parsing bool parseDomainConfigurations(const CXmlElement& xmlElement, CXmlSerializingContext& serializingContext); bool parseConfigurableElements(const CXmlElement& xmlElement, CXmlSerializingContext& serializingContext); bool parseSettings(const CXmlElement& xmlElement, CXmlSerializingContext& serializingContext); // XML composing void composeDomainConfigurations(CXmlElement& xmlElement, CXmlSerializingContext& serializingContext) const; void composeConfigurableElements(CXmlElement& xmlElement) const; void composeSettings(CXmlElement& xmlElement, CXmlSerializingContext& serializingContext) const; // Syncer set retrieval from configurable element CSyncerSet* getSyncerSet(const CConfigurableElement* pConfigurableElement) const; // Configuration retrieval CDomainConfiguration* findConfiguration(const string& strConfiguration, string& strError); const CDomainConfiguration* findConfiguration(const string& strConfiguration, string& strError) const; // Configurable elements list _configurableElementList; // Associated syncer sets map _configurableElementToSyncerSetMap; // Sequence awareness bool _bSequenceAware; // Syncer set used to ensure propoer synchronization of restored configurable elements CSyncerSet _syncerSet; // Last applied configuration mutable const CDomainConfiguration* _pLastAppliedConfiguration; };