summaryrefslogtreecommitdiffstats
path: root/parameter/RuleParser.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/RuleParser.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/RuleParser.cpp')
-rw-r--r--parameter/RuleParser.cpp252
1 files changed, 252 insertions, 0 deletions
diff --git a/parameter/RuleParser.cpp b/parameter/RuleParser.cpp
new file mode 100644
index 0000000..b72556b
--- /dev/null
+++ b/parameter/RuleParser.cpp
@@ -0,0 +1,252 @@
+/* <auto_header>
+ * <FILENAME>
+ *
+ * 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.
+ *
+ * AUTHOR: Patrick Benavoli (patrickx.benavoli@intel.com)
+ * CREATED: 2011-06-01
+ * UPDATED: 2011-07-27
+ *
+ *
+ * </auto_header>
+ */
+#include "RuleParser.h"
+#include "CompoundRule.h"
+#include "SelectionCriterionRule.h"
+#include <assert.h>
+
+// Matches
+const char* CRuleParser::_acDelimiters[CRuleParser::ENbStatuses] = {
+ "{", // EInit
+ "{} ", // EBeginCompoundRule
+ ",}", // EEndCompoundRule
+ ",}", // ECriterionRule
+ "{ ", // EContinue
+ "" // EDone
+};
+
+CRuleParser::CRuleParser(const string& strApplicationRule, const CSelectionCriteriaDefinition* pSelectionCriteriaDefinition) :
+ _strApplicationRule(strApplicationRule),
+ _pSelectionCriteriaDefinition(pSelectionCriteriaDefinition),
+ _uiCurrentPos(0),
+ _uiCurrentDeepness(0),
+ _eStatus(CRuleParser::EInit),
+ _pRootRule(NULL)
+{
+}
+
+CRuleParser::~CRuleParser()
+{
+ delete _pRootRule;
+}
+
+// Parse
+bool CRuleParser::parse(CCompoundRule* pParentRule, string& strError)
+{
+ while (true) {
+ // Iterate till next relevant delimiter
+ if (!iterate(strError)) {
+
+ return false;
+ }
+ switch(_eStatus) {
+ case EBeginCompoundRule: {
+
+ // Create new compound rule
+ CCompoundRule* pCompoundRule = new CCompoundRule;
+
+ // Parse
+ if (!pCompoundRule->parse(*this, strError)) {
+
+ delete pCompoundRule;
+
+ return false;
+ }
+ // Parent rule creation context?
+ if (pParentRule) {
+
+ // Chain
+ pParentRule->addChild(pCompoundRule);
+ } else {
+ // Root rule
+ delete _pRootRule;
+ _pRootRule = pCompoundRule;
+ }
+ // Parse
+ if (!parse(pCompoundRule, strError)) {
+
+ return false;
+ }
+ // Go on
+ break;
+ }
+ case EEndCompoundRule:
+ return true;
+ case EContinue:
+ // Seek for new rule
+ break;
+ case ECriterionRule: {
+ // Create new criterion rule
+ CSelectionCriterionRule* pCriterionRule = new CSelectionCriterionRule;
+
+ // Parse
+ if (!pCriterionRule->parse(*this, strError)) {
+
+ delete pCriterionRule;
+
+ return false;
+ }
+
+ // Chain
+ pParentRule->addChild(pCriterionRule);
+
+ // Go on
+ break;
+ }
+ case EDone:
+ return true;
+ default:
+ assert(0);
+ return false;
+ }
+ }
+
+ return true;
+}
+
+// Iterate
+bool CRuleParser::iterate(string& strError)
+{
+ string::size_type iDelimiter;
+
+ assert(_uiCurrentPos <= _strApplicationRule.length());
+
+ // Consume spaces
+ if ((iDelimiter = _strApplicationRule.find_first_not_of(" ", _uiCurrentPos)) != string::npos) {
+
+ // New pos
+ _uiCurrentPos = iDelimiter;
+ }
+
+ // Parse
+ if ((_uiCurrentPos != _strApplicationRule.length()) && ((iDelimiter = _strApplicationRule.find_first_of(_acDelimiters[_eStatus], _uiCurrentPos)) != string::npos)) {
+
+ switch(_strApplicationRule[iDelimiter]) {
+
+ case '{':
+ _eStatus = EBeginCompoundRule;
+ // Extract type
+ _strRuleType = _strApplicationRule.substr(_uiCurrentPos, iDelimiter - _uiCurrentPos);
+ _uiCurrentDeepness++;
+ break;
+ case '}':
+ _eStatus = EEndCompoundRule;
+
+ if (!_uiCurrentDeepness--) {
+
+ strError = "Missing opening brace";
+
+ return false;
+ }
+ break;
+ case ' ':
+ _eStatus = ECriterionRule;
+ // Extract type
+ _strRuleType = _strApplicationRule.substr(_uiCurrentPos, iDelimiter - _uiCurrentPos);
+ break;
+ case ',':
+ _eStatus = EContinue;
+ break;
+ }
+ // New pos
+ _uiCurrentPos = iDelimiter + 1;
+ } else {
+
+ if (_uiCurrentDeepness) {
+
+ strError = "Missing closing brace";
+
+ return false;
+ }
+
+ // Remaining characters
+ if (_uiCurrentPos != _strApplicationRule.length()) {
+
+ strError = "Syntax error";
+
+ return false;
+ }
+ // Done
+ _eStatus = EDone;
+ }
+ return true;
+}
+
+// Rule type
+const string& CRuleParser::getType() const
+{
+ return _strRuleType;
+}
+
+// Criteria defintion
+const CSelectionCriteriaDefinition* CRuleParser::getSelectionCriteriaDefinition() const
+{
+ return _pSelectionCriteriaDefinition;
+}
+
+// Root rule
+CCompoundRule* CRuleParser::grabRootRule()
+{
+ CCompoundRule* pRootRule = _pRootRule;
+
+ assert(pRootRule);
+
+ _pRootRule = NULL;
+
+ return pRootRule;
+}
+
+// Next word
+bool CRuleParser::next(string& strNext, string& strError)
+{
+ string::size_type iDelimiter;
+
+ // Consume spaces
+ if ((iDelimiter = _strApplicationRule.find_first_not_of(" ", _uiCurrentPos)) != string::npos) {
+
+ // New pos
+ _uiCurrentPos = iDelimiter;
+ }
+
+ if ((iDelimiter = _strApplicationRule.find_first_of("{} ,", _uiCurrentPos)) == string::npos) {
+
+ strError = "Syntax error";
+
+ return false;
+ }
+
+ strNext = _strApplicationRule.substr(_uiCurrentPos, iDelimiter - _uiCurrentPos);
+
+ // New pos
+ _uiCurrentPos = iDelimiter;
+
+ return true;
+}