blob: 7beceecb57011353d54e42c22e5dee3aff8bc8b5 [file] [log] [blame]
Kevin Rocard93250d12012-07-19 17:48:30 +02001/*
David Wagnerb76c9d62014-02-05 18:30:24 +01002 * Copyright (c) 2011-2014, Intel Corporation
3 * All rights reserved.
Patrick Benavoli0bd50542011-11-29 11:10:27 +01004 *
David Wagnerb76c9d62014-02-05 18:30:24 +01005 * Redistribution and use in source and binary forms, with or without modification,
6 * are permitted provided that the following conditions are met:
Patrick Benavoli0bd50542011-11-29 11:10:27 +01007 *
David Wagnerb76c9d62014-02-05 18:30:24 +01008 * 1. Redistributions of source code must retain the above copyright notice, this
9 * list of conditions and the following disclaimer.
Patrick Benavoli0bd50542011-11-29 11:10:27 +010010 *
David Wagnerb76c9d62014-02-05 18:30:24 +010011 * 2. Redistributions in binary form must reproduce the above copyright notice,
12 * this list of conditions and the following disclaimer in the documentation and/or
13 * other materials provided with the distribution.
14 *
15 * 3. Neither the name of the copyright holder nor the names of its contributors
16 * may be used to endorse or promote products derived from this software without
17 * specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
23 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
26 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Patrick Benavoli0bd50542011-11-29 11:10:27 +010029 */
30#pragma once
31
32#include <string>
33#include <stdint.h>
34
35using namespace std;
36
37class CCompoundRule;
38class CSelectionCriteriaDefinition;
39
40class CRuleParser
41{
42public:
43 enum Status {
44 EInit,
45 EBeginCompoundRule,
46 EEndCompoundRule,
47 ECriterionRule,
48 EContinue,
49 EDone,
50
51 ENbStatuses
52 };
53
54 CRuleParser(const string& strApplicationRule, const CSelectionCriteriaDefinition* pSelectionCriteriaDefinition);
55 ~CRuleParser();
56
57 // Parse
58 bool parse(CCompoundRule* pParentRule, string& strError);
59
60 // Iterate
61 bool iterate(string& strError);
62
63 // Next word
64 bool next(string& strNext, string& strError);
65
66 // Rule type
67 const string& getType() const;
68
69 // Criteria defintion
70 const CSelectionCriteriaDefinition* getSelectionCriteriaDefinition() const;
71
72 // Root rule
73 CCompoundRule* grabRootRule();
74private:
75
JhinX Lee4ebc0982012-07-12 17:50:07 +020076 CRuleParser(const CRuleParser&);
77 CRuleParser& operator=(const CRuleParser&);
78
Patrick Benavoli0bd50542011-11-29 11:10:27 +010079 // Rule definition
80 string _strApplicationRule;
81 // Criteria defintion
82 const CSelectionCriteriaDefinition* _pSelectionCriteriaDefinition;
83 // Iterator
84 uint32_t _uiCurrentPos;
85 // Deepness
86 uint32_t _uiCurrentDeepness;
87 // Current Type
88 string _strRuleType;
89 // Status
90 Status _eStatus;
91 // Root rule
92 CCompoundRule* _pRootRule;
93 // Matches
94 static const char* _acDelimiters[ENbStatuses];
95};
96