summaryrefslogtreecommitdiffstats
path: root/parameter/CompoundRule.cpp
diff options
context:
space:
mode:
authorPatrick Benavoli <patrickx.benavoli@intel.com>2011-11-29 11:10:27 +0100
committerDavid Wagner <david.wagner@intel.com>2014-02-10 17:15:01 +0100
commit0bd50546a8d06a6865d32c695adf8893fa71250a (patch)
tree966dc5c4c8143df983668db92db26129eafb1e3b /parameter/CompoundRule.cpp
parente7a903ef0a5ee2b9d51e6f86d32c704b9ff16c21 (diff)
downloadexternal_parameter-framework-0bd50546a8d06a6865d32c695adf8893fa71250a.zip
external_parameter-framework-0bd50546a8d06a6865d32c695adf8893fa71250a.tar.gz
external_parameter-framework-0bd50546a8d06a6865d32c695adf8893fa71250a.tar.bz2
PFW: Rule handling from CLI
BZ: 15689 These changes enable handling changing the rules for configuration application from the command line interface. It is possible to assign a new rule, to display the existing one or to clear it. Restriction: like in XML, root rule must be compound. Syntax is the following: - Criterion rule expression: <criterion> <verb> <object> - Compound rule expression (All|Any){<content>} where <content> is a comma separated list of any kind of rules. Example: All{Any{SelectedOutputDevice Includes Headphones, SelectedOutputDevice Includes Headset}, Any{Mode Is Normal, Mode Is RingTone}} means the pertaining configuration will be applied when Selected device includes either Headphones or Headset, while, ate the same time, Mode is either Normal or RingTone. Added dumpDomains remote command to show a summary of domains, configurations as well as their application conditions (tree view). Removed not anymore necessary guard against deletion of domains or configurations that contain rules, ad now they're controlled from the CLI. Change-Id: Iad2c183271b077b8bbc8ac2fc5f37c266004070f Signed-off-by: Patrick Benavoli <patrickx.benavoli@intel.com> Reviewed-on: http://android.intel.com:8080/26100 Reviewed-by: De Chivre, RenaudX <renaudx.de.chivre@intel.com> Tested-by: Barthes, FabienX <fabienx.barthes@intel.com> Reviewed-by: buildbot <buildbot@intel.com> Tested-by: buildbot <buildbot@intel.com>
Diffstat (limited to 'parameter/CompoundRule.cpp')
-rw-r--r--parameter/CompoundRule.cpp73
1 files changed, 71 insertions, 2 deletions
diff --git a/parameter/CompoundRule.cpp b/parameter/CompoundRule.cpp
index 6078a2d..e78a5df 100644
--- a/parameter/CompoundRule.cpp
+++ b/parameter/CompoundRule.cpp
@@ -29,9 +29,16 @@
* </auto_header>
*/
#include "CompoundRule.h"
+#include "RuleParser.h"
#define base CRule
+// Types
+const char* CCompoundRule::_apcTypes[2] = {
+ "Any",
+ "All"
+};
+
CCompoundRule::CCompoundRule() : _bTypeAll(false)
{
}
@@ -48,6 +55,68 @@ bool CCompoundRule::childrenAreDynamic() const
return true;
}
+// Content dumping
+void CCompoundRule::logValue(string& strValue, CErrorContext& errorContext) const
+{
+ (void)errorContext;
+
+ // Type
+ strValue = _apcTypes[_bTypeAll];
+}
+
+// Parse
+bool CCompoundRule::parse(CRuleParser& ruleParser, string& strError)
+{
+ // Get rule type
+ uint32_t uiType;
+
+ for (uiType = 0; uiType < 2; uiType++) {
+
+ if (ruleParser.getType() == _apcTypes[uiType]) {
+
+ // Set type
+ _bTypeAll = uiType != 0;
+
+ return true;
+ }
+ }
+
+ // Failed
+ strError = "Unknown compound rule type: ";
+ strError += ruleParser.getType();
+
+ return false;
+}
+
+// Dump
+void CCompoundRule::dump(string& strResult) const
+{
+ strResult += _apcTypes[_bTypeAll];
+ strResult += "{";
+
+ // Children
+ uint32_t uiChild;
+ uint32_t uiNbChildren = getNbChildren();
+ bool bFirst = true;
+
+ for (uiChild = 0; uiChild < uiNbChildren; uiChild++) {
+
+ if (!bFirst) {
+
+ strResult += ", ";
+ }
+
+ // Dump inner rule
+ const CRule* pRule = static_cast<const CRule*>(getChild(uiChild));
+
+ pRule->dump(strResult);
+
+ bFirst = false;
+ }
+
+ strResult += "}";
+}
+
// Rule check
bool CCompoundRule::matches() const
{
@@ -70,7 +139,7 @@ bool CCompoundRule::matches() const
bool CCompoundRule::fromXml(const CXmlElement& xmlElement, CXmlSerializingContext& serializingContext)
{
// Get type
- _bTypeAll = xmlElement.getAttributeBoolean("Type", "All");
+ _bTypeAll = xmlElement.getAttributeBoolean("Type", _apcTypes[true]);
// Base
return base::fromXml(xmlElement, serializingContext);
@@ -80,7 +149,7 @@ bool CCompoundRule::fromXml(const CXmlElement& xmlElement, CXmlSerializingContex
void CCompoundRule::toXml(CXmlElement& xmlElement, CXmlSerializingContext& serializingContext) const
{
// Set type
- xmlElement.setAttributeString("Type", _bTypeAll ? "All" : "Any");
+ xmlElement.setAttributeString("Type", _apcTypes[_bTypeAll]);
// Base
base::toXml(xmlElement, serializingContext);