Blame view

src/expressionParser/ParserGrammar.hh 10.9 KB
a7f2648e   Benjamin Renard   Parser: First imp...
1
2
3
4
5
6
7
8
#ifndef PARSERGRAMMAR_HH_
#define PARSERGRAMMAR_HH_

#include <boost/spirit/include/qi.hpp>
#include <boost/spirit/include/phoenix.hpp>

#include "ExpressionContainer.hh"
#include "CustomFoldDirective.hh"
e58d7be4   Benjamin Renard   Parser: Add const...
9
10
#include "ParserToolbox.hh"
#include "Properties.hh"
36749bea   Benjamin Renard   Use a common cont...
11
#include "FunctionInfo.hh"
a7f2648e   Benjamin Renard   Parser: First imp...
12
13
14
15
16
17
18
19
20

namespace AMDA {
namespace parser {

namespace qi = boost::spirit::qi;

using namespace qi;
using namespace Expression;

c1f4db8e   Benjamin Renard   Add process to te...
21
22
#define PARSERGRAMMAR_ADD_OPERATOR(operation, next, operator) fold<operation>(next.alias())[operator >> next]

a7f2648e   Benjamin Renard   Parser: First imp...
23
template <typename It, typename Skipper = boost::spirit::standard_wide::space_type>
47755d13   Benjamin Renard   Minor changes
24
class ParserGrammar : public qi::grammar<It, Expression::ExpressionContainer(), Skipper>
a7f2648e   Benjamin Renard   Parser: First imp...
25
{
47755d13   Benjamin Renard   Minor changes
26
public:
e58d7be4   Benjamin Renard   Parser: Add const...
27
    ParserGrammar(AMDA::helpers::Properties& lProperties) : ParserGrammar::base_type(expr_)
a7f2648e   Benjamin Renard   Parser: First imp...
28
    {
8a7bf6d4   Benjamin Renard   Fix operation pri...
29
        expr_ = equal_.alias();
a7f2648e   Benjamin Renard   Parser: First imp...
30

8a7bf6d4   Benjamin Renard   Fix operation pri...
31
32
33
34
35
36
        equal_          = PARSERGRAMMAR_ADD_OPERATOR(EqualOperation,          unequal_,        equalOperator_); 
        unequal_        = PARSERGRAMMAR_ADD_OPERATOR(UnequalOperation,        greaterOrEqual_, unequalOperator_);
        greaterOrEqual_ = PARSERGRAMMAR_ADD_OPERATOR(GreaterOrEqualOperation, lowerOrEqual_,   greaterOrEqualOperator_);
        lowerOrEqual_   = PARSERGRAMMAR_ADD_OPERATOR(LowerOrEqualOperation,   greater_,        lowerOrEqualOperator_);
	greater_        = PARSERGRAMMAR_ADD_OPERATOR(GreaterOperation,        lower_,          greaterOperator_);
	lower_          = PARSERGRAMMAR_ADD_OPERATOR(LowerOperation,          or_,             lowerOperator_);
c1f4db8e   Benjamin Renard   Add process to te...
37

8a7bf6d4   Benjamin Renard   Fix operation pri...
38
39
40
41
42
43
	or_             = PARSERGRAMMAR_ADD_OPERATOR(OrOperation,             sum_,            orOperator_);
	sum_            = PARSERGRAMMAR_ADD_OPERATOR(SumOperation,            difference_,     sumOperator_);
	difference_     = PARSERGRAMMAR_ADD_OPERATOR(DifferenceOperation,     and_,            differenceOperator_);
	and_            = PARSERGRAMMAR_ADD_OPERATOR(AndOperation,            factor_,         andOperator_);
        factor_         = PARSERGRAMMAR_ADD_OPERATOR(FactorOperation,         division_,       factorOperator_);
        division_       = PARSERGRAMMAR_ADD_OPERATOR(DivisionOperation,       powerTen_,       divisionOperator_);
c0bbbeb7   Benjamin Renard   Fix some bug with...
44

82a9bc9e   Benjamin Renard   Support d operator
45
46
	powerTen_       = PARSERGRAMMAR_ADD_OPERATOR(PowerTenOperation,       powerTenD_,      powerTenOperator_);
	powerTenD_      = PARSERGRAMMAR_ADD_OPERATOR(PowerTenDOperation,      pow_,            powerTenDOperator_);
02869c99   Benjamin Renard   Improve parse of ...
47
	pow_            = PARSERGRAMMAR_ADD_OPERATOR(PowerOperation,          plusSign_,       powOperator_);
e33239bf   Benjamin Renard   Parse parameters
48

36749bea   Benjamin Renard   Use a common cont...
49
50
        plusSign_ = ((sumOperator_ >>-*sumOperator_)> minusSign_ ) [_val = boost::phoenix::construct<PlusSignOperation>(_1)] ||
                ((differenceOperator_ >>differenceOperator_)> minusSign_ ) [_val = boost::phoenix::construct<PlusSignOperation>(_1)] |minusSign_ [_val = _1];
02869c99   Benjamin Renard   Improve parse of ...
51
        minusSign_ = (((-*sumOperator_>>differenceOperator_ >>-*sumOperator_) ) > not_) [_val = boost::phoenix::construct<MinusSignOperation>(_1)] | not_[_val = _1];
8a7bf6d4   Benjamin Renard   Fix operation pri...
52
	not_ = (notOperator_ > functions_) [_val = boost::phoenix::construct<NotOperation>(_1)] | functions_[_val = _1];
a7f2648e   Benjamin Renard   Parser: First imp...
53

e33239bf   Benjamin Renard   Parse parameters
54

a7f2648e   Benjamin Renard   Parser: First imp...
55

66aeb1bf   Benjamin Renard   First step to sup...
56
57
        functions_ = (fourArgsFunction>>"(">>funArgs_>>argumentSeparator_>>funArgs_>>argumentSeparator_>>funArgs_>>argumentSeparator_>>funArgs_>>")")[_val= boost::phoenix::construct<FunctionOperation>(_1,_2,_3,_4,_5)] ||
        (threeArgsFunction>>"(">>funArgs_>>argumentSeparator_>>funArgs_>>argumentSeparator_>>funArgs_>>")")[_val= boost::phoenix::construct<FunctionOperation>(_1,_2,_3,_4)] ||
02869c99   Benjamin Renard   Improve parse of ...
58
        (twoArgsFunction>>"(">>funArgs_>>argumentSeparator_>>funArgs_>>")")[_val= boost::phoenix::construct<FunctionOperation>(_1,_2,_3)]||
8a7bf6d4   Benjamin Renard   Fix operation pri...
59
        (oneArgsFunction>>"(">>funArgs_>>")")[_val= boost::phoenix::construct<FunctionOperation>(_1,_2)]|const_[_val=_1];
a7f2648e   Benjamin Renard   Parser: First imp...
60
	// UNARY OPERATIONS
e33239bf   Benjamin Renard   Parse parameters
61
 
36749bea   Benjamin Renard   Use a common cont...
62
	const_ = (definedConstants) [_val = boost::phoenix::construct<ConstantOperation>(_1)] | param_[_val = _1];
93f280a8   Benjamin Renard   Implements templa...
63
64
        param_= ((localParams_ | derivedParam_ | uploadedParam_ | impexParam_ | themisParam_ | cdaWebParam_ | templatedParam_) >>('(' >> componentValue_ >> componentSeparator_ >> componentValue_ >>')'))[_val=boost::phoenix::construct<ParameterDef>(_1,_2,_3)] ||
		((localParams_ | derivedParam_ | uploadedParam_ | impexParam_ | themisParam_ | cdaWebParam_ | templatedParam_) >>('(' >> componentValue_ >> ')'))[_val=boost::phoenix::construct<ParameterDef>(_1,_2)] ||
ece7811b   Erdogan Furkan   Adding TT/Cat pos...
65
66
		((localParams_ | derivedParam_ | uploadedParam_ | impexParam_ | themisParam_ | cdaWebParam_ | templatedParam_ |
                                 timeTableParam_ | catalogParam_ | sharedtimeTableParam_ | sharedcatalogParam_))[_val=boost::phoenix::construct<ParameterDef>(_1)] | simple[_val = _1];
e33239bf   Benjamin Renard   Parse parameters
67

ea6be348   Benjamin Renard   Support arguments...
68
        funArgs_=((expr_   |var_ | definedArgsListValues) |functions_); 
a7f2648e   Benjamin Renard   Parser: First imp...
69
        simple = (('(' > expr_ > ')') | var_);
04d84599   Benjamin Renard   Parser: Add suppo...
70

e33239bf   Benjamin Renard   Parse parameters
71
	var_ = (+qi::char_('0','9') >> -qi::char_('.') >> -(+qi::char_('0','9'))) | ((qi::char_('.') >> +qi::char_('0','9')));
04d84599   Benjamin Renard   Parser: Add suppo...
72
73
	componentValue_ = (+qi::char_('0','9') | qi::char_('*') | (qi::string("range[") >> var_ >> qi::char_(',') >> var_ >> qi::string("]")) | (qi::string("indexes[") >> indexValue_ >> qi::char_(',') >> indexValue_ >> qi::string("]")));
	indexValue_ = +qi::char_('0','9');
c1f4db8e   Benjamin Renard   Add process to te...
74

9d0730bf   Benjamin Renard   Parser: add suppo...
75
76
77
78
79
	derivedParam_ = (qi::string("ws_") >> +(qi::alnum | qi::char_('_')));
	uploadedParam_ = (qi::string("wsd_") >> +(qi::alnum | qi::char_('_')));
	impexParam_ = (qi::string("spase___IMPEX_") >> +(qi::alnum | qi::char_('_')));
	themisParam_ = (qi::string("th") >> qi::char_('a','e') >> qi::char_('_') >> +(qi::alnum | qi::char_('_')));
	cdaWebParam_ = (qi::string("cdaweb_") >> +(qi::alnum | qi::char_('_')));
ece7811b   Erdogan Furkan   Adding TT/Cat pos...
80
81
82
83
        timeTableParam_ = (qi::string("tt_") >> +(qi::alnum | qi::char_('_')));
        catalogParam_ = (qi::string("cat_") >> +(qi::alnum | qi::char_('_')));
        sharedtimeTableParam_ = (qi::string("sharedtimeTable_") >> +(qi::alnum | qi::char_('_')));
        sharedcatalogParam_ = (qi::string("sharedcatalog_") >> +(qi::alnum | qi::char_('_')));
9d0730bf   Benjamin Renard   Parser: add suppo...
84

e33239bf   Benjamin Renard   Parse parameters
85
	powOperator_        = qi::char_('^');
36749bea   Benjamin Renard   Use a common cont...
86
	powerTenOperator_   = qi::char_('e');
82a9bc9e   Benjamin Renard   Support d operator
87
	powerTenDOperator_  = qi::char_('d');
a7f2648e   Benjamin Renard   Parser: First imp...
88
        notOperator_        = qi::char_('!');
f5ef5545   Benjamin Renard   Fix operators sym...
89
90
        andOperator_        = qi::string("&");
        orOperator_         = qi::string("|");
f5ef5545   Benjamin Renard   Fix operators sym...
91
        equalOperator_      = qi::string("=");
a7f2648e   Benjamin Renard   Parser: First imp...
92
        unequalOperator_    = qi::string("!=");
e33239bf   Benjamin Renard   Parse parameters
93
94
        sumOperator_        = qi::char_('+');
        differenceOperator_ = qi::char_('-');
a7f2648e   Benjamin Renard   Parser: First imp...
95
96
97
98
99
100
        factorOperator_     = qi::char_("*");
        divisionOperator_   = qi::char_("/");
        greaterOperator_   = qi::char_(">");
        greaterOrEqualOperator_   = qi::string(">=");
        lowerOrEqualOperator_   = qi::string("<=");
        lowerOperator_   = qi::char_("<");
02869c99   Benjamin Renard   Improve parse of ...
101
102
	argumentSeparator_    = qi::char_(",");
        componentSeparator_   = qi::char_(",");
e58d7be4   Benjamin Renard   Parser: Add const...
103
104
105
106

	// Define available constants
	std::map<std::string, std::string> existingConstants = ParserToolbox::getConstants(lProperties);
	for(std::map<std::string, std::string>::iterator it = existingConstants.begin(); it != existingConstants.end(); ++it) {
e33239bf   Benjamin Renard   Parse parameters
107
		definedConstants.add (it->first, it->second);
e58d7be4   Benjamin Renard   Parser: Add const...
108
        }
a7f2648e   Benjamin Renard   Parser: First imp...
109

9d0730bf   Benjamin Renard   Parser: add suppo...
110
	// Define available local params
e33239bf   Benjamin Renard   Parse parameters
111
	std::vector<std::string> existingParams = ParserToolbox::getParameters(lProperties);
8048fba8   Hacene SI HADJ MOHAND   8893
112
                    const char *otherPatterns[5] = { "ws_", "wsd", "spase___IMPEX_", "th", "cdaweb_"};
e33239bf   Benjamin Renard   Parse parameters
113
	for(std::vector<std::string>::iterator it = existingParams.begin(); it != existingParams.end(); ++it) {
8048fba8   Hacene SI HADJ MOHAND   8893
114
115
116
117
118
119
                               bool isLocal = true; 
                               for (auto patt : otherPatterns){
                                             if (it->rfind(patt, 0) == 0) 
                                                 isLocal = false;
                                         }
                              if(isLocal)
9d0730bf   Benjamin Renard   Parser: add suppo...
120
		localParams_.add(*it,*it);
e33239bf   Benjamin Renard   Parse parameters
121
	}
36749bea   Benjamin Renard   Use a common cont...
122
123
124
125
       
        // Defined functions available 
        std::map<std::string,FunctionInfo> existingFunctions = ParserToolbox::getFunctions(lProperties);
        for(auto const& x : existingFunctions ) {
66aeb1bf   Benjamin Renard   First step to sup...
126
127
		int nbAllArgs = x.second.getNbArgs() + x.second.getNbPromptedArgs();
                if (nbAllArgs == 1) {
36749bea   Benjamin Renard   Use a common cont...
128
                      oneArgsFunction.add(x.second.getIHMName(), x.second.getKernelName());
66aeb1bf   Benjamin Renard   First step to sup...
129
                }else if (nbAllArgs == 2) {
36749bea   Benjamin Renard   Use a common cont...
130
                      twoArgsFunction.add(x.second.getIHMName(), x.second.getKernelName());
66aeb1bf   Benjamin Renard   First step to sup...
131
                }else if (nbAllArgs == 3) {
36749bea   Benjamin Renard   Use a common cont...
132
                      threeArgsFunction.add(x.second.getIHMName(), x.second.getKernelName());
66aeb1bf   Benjamin Renard   First step to sup...
133
134
135
                }else if (nbAllArgs == 4) {
                      fourArgsFunction.add(x.second.getIHMName(), x.second.getKernelName());
		}
36749bea   Benjamin Renard   Use a common cont...
136
137
        } 

ea6be348   Benjamin Renard   Support arguments...
138
139
140
141
142
143
144
145
        // Defined available values for functions args list
        std::map<std::string,ArgListInfo> existingArgsLists = ParserToolbox::getArgsLists(lProperties);
	for(auto const& x : existingArgsLists ) {
		for(auto const& y : x.second.getValues()) {
			definedArgsListValues.add(y.first,y.first);
		}
	}

93f280a8   Benjamin Renard   Implements templa...
146
147
148
149
150
151
	// Defined templated parameters
	TemplateParamsList existingTemplateParams = ParserToolbox::getTemplateParams(lProperties);
	templatedParam_ = (qi::string("fakeparam"));
	for(auto const& t : existingTemplateParams ) {
		templatedParam_ = (templatedParam_.copy() | (qi::string(t.getParamId()) >> +(qi::alnum | qi::char_('_'))));;
	}
e33239bf   Benjamin Renard   Parse parameters
152
153
154

        BOOST_SPIRIT_DEBUG_NODES((expr_)(or_)(and_)(equal_)(unequal_)(greaterOrEqual_)(lowerOrEqual_)(lower_)(sum_)
                (difference_)(factor_)(division_)(simple)(notOperator_)(andOperator_)(orOperator_)(equalOperator_)(unequalOperator_)
36749bea   Benjamin Renard   Use a common cont...
155
                (sumOperator_)(differenceOperator_)(factorOperator_)(divisionOperator_)(greater_)(lower_)(functions_));
a7f2648e   Benjamin Renard   Parser: First imp...
156
157
158
    }

private:
ece7811b   Erdogan Furkan   Adding TT/Cat pos...
159
160
    qi::rule<It, Expression::var(), Skipper> var_, componentValue_, indexValue_, derivedParam_, uploadedParam_, impexParam_, themisParam_, 
                                cdaWebParam_, templatedParam_, timeTableParam_, catalogParam_, sharedtimeTableParam_, sharedcatalogParam_;
47755d13   Benjamin Renard   Minor changes
161
    qi::rule<It, Expression::ExpressionContainer(), Skipper> not_
e33239bf   Benjamin Renard   Parse parameters
162
        , pow_
36749bea   Benjamin Renard   Use a common cont...
163
	, powerTen_
82a9bc9e   Benjamin Renard   Support d operator
164
	, powerTenD_
a7f2648e   Benjamin Renard   Parser: First imp...
165
        , and_
a7f2648e   Benjamin Renard   Parser: First imp...
166
167
168
169
170
171
172
173
174
175
176
        , or_
        , equal_
        , unequal_
        , sum_
        , difference_
        , factor_
        , division_
        , simple
        , expr_
        ,plusSign_
        ,minusSign_
e58d7be4   Benjamin Renard   Parser: Add const...
177
178
179
180
        ,greater_
        ,greaterOrEqual_
        ,lowerOrEqual_
        ,lower_
e33239bf   Benjamin Renard   Parse parameters
181
	,const_
66aeb1bf   Benjamin Renard   First step to sup...
182
	,frame_
36749bea   Benjamin Renard   Use a common cont...
183
184
185
	,param_
        ,functions_
        ,funArgs_;
a7f2648e   Benjamin Renard   Parser: First imp...
186
187
188


    qi::rule<It, Skipper> notOperator_
e33239bf   Benjamin Renard   Parse parameters
189
	, powOperator_
36749bea   Benjamin Renard   Use a common cont...
190
	, powerTenOperator_
82a9bc9e   Benjamin Renard   Support d operator
191
	, powerTenDOperator_
a7f2648e   Benjamin Renard   Parser: First imp...
192
193
        , andOperator_
        , orOperator_
a7f2648e   Benjamin Renard   Parser: First imp...
194
195
196
197
198
199
200
201
        , equalOperator_
        , unequalOperator_
        , sumOperator_
        , differenceOperator_
        , factorOperator_
        , divisionOperator_
        , greaterOperator_ 
        , greaterOrEqualOperator_ 
02869c99   Benjamin Renard   Improve parse of ...
202
203
204
205
        , lowerOrEqualOperator_
	, lowerOperator_
	, argumentSeparator_
        , componentSeparator_;
a7f2648e   Benjamin Renard   Parser: First imp...
206

e33239bf   Benjamin Renard   Parse parameters
207
    qi::symbols<char, std::string> definedConstants;
ea6be348   Benjamin Renard   Support arguments...
208
    qi::symbols<char, std::string> definedArgsListValues;
9d0730bf   Benjamin Renard   Parser: add suppo...
209
    qi::symbols<char, std::string> localParams_;
36749bea   Benjamin Renard   Use a common cont...
210
211
    qi::symbols<char, std::string> twoArgsFunction;
    qi::symbols<char, std::string> oneArgsFunction;
e8489ddc   Benjamin Renard   Fix printer for a...
212
    qi::symbols<char, std::string> threeArgsFunction;
66aeb1bf   Benjamin Renard   First step to sup...
213
    qi::symbols<char, std::string> fourArgsFunction;
a7f2648e   Benjamin Renard   Parser: First imp...
214
215
216
217
218
219
};

}
}

#endif