Browse Source

working on prctl parser

tempestpy_adaptions
gereon 12 years ago
parent
commit
93d568bd82
  1. 81
      src/parser/readPrctlFile.cpp
  2. 4
      src/parser/readPrctlFile.h

81
src/parser/readPrctlFile.cpp

@ -4,63 +4,120 @@
#include <iostream>
#include <map>
//#include <pair>
#include <boost/spirit/include/classic_core.hpp>
#include <boost/spirit/include/qi_grammar.hpp>
#include <boost/spirit/include/qi_rule.hpp>
#include <boost/spirit/include/qi.hpp>
#include <boost/spirit/include/phoenix_operator.hpp>
#include <boost/spirit/include/qi_char_class.hpp>
#include <boost/bind.hpp>
namespace bs = boost::spirit;
namespace
{
using namespace bs;
using namespace bs::qi;
using namespace bs::standard;
struct PRCTLParser : public grammar< char const* >
{
typedef rule< char const* > rule_t;
typedef rule< char const* > rule_none;
typedef rule< char const*, double() > rule_double;
typedef rule< char const*, std::string() > rule_string;
/*!
* @brief Generic Nonterminals.
*/
rule_t variable, value;
rule_none ws;
rule_string variable;
rule_double value;
/*!
* @brief Nonterminals for file header.
*/
rule_t varDef, type;
rule< char const* > varDef;
rule_none type;
/*!
* @brief Nonterminals for formula.
*/
rule_t formula, opP;
rule_none formula, opP;
/*!
* @brief Nonterminals for high-level file structure.
*/
rule_t file, header;
rule_none file, header;
/*!
* @brief Variable assignments.
*/
std::map<std::string, double> variables;
/*!
* @brief Resulting formula.
*/
mrmc::formula::PCTLFormula* result;
struct dump
{
void print(double const& i, std::string& s)
{
std::cout << s << " = " << i << std::endl;
}
void operator()(double const& a, unused_type, unused_type) const
{
std::cout << a << std::endl;
}
void operator()(std::string const& a, unused_type, unused_type) const
{
std::cout << a << std::endl;
}
void operator()(utree const& a, unused_type, unused_type) const
{
std::cout << &a << std::endl;
}
};
PRCTLParser() : PRCTLParser::base_type(file, "PRCTL parser")
{
variable = alnum;
value = int_ | double_;
variable %= alnum;
ws = *( space );
value %= ( double_ | int_ ); // double_ must be *before* int_
type = string("int") | string("double");
varDef = string("const") >> type >> variable >> string("=") >> value >> string(";");
varDef =
string("const") >> ws >>
type >> ws >>
variable >> ws >>
string("=") >> ws >>
value >> ws >>
string(";");
header = *( varDef );
header = +( varDef >> ws );
file = header;
}
};
}
void readPrctlFile(const char* filename)
mrmc::formula::PCTLFormula* mrmc::parser::readPrctlFile(const char* filename)
{
PRCTLParser p;
mrmc::parser::MappedFile file(filename);
if (bs::qi::parse< char const* >(file.data, file.dataend, p))
char* data = file.data;
if (bs::qi::parse< char const* >(data, file.dataend, p))
{
std::cout << "File was parsed" << std::endl;
std::string rest(data, file.dataend);
std::cout << "Rest: " << rest << std::endl;
return p.result;
}
else return NULL;
}

4
src/parser/readPrctlFile.h

@ -1,13 +1,15 @@
#ifndef READPRCTLFILE_H_
#define READPRCTLFILE_H_
#include "src/formula/PCTLformula.h"
namespace mrmc {
namespace parser {
/*!
* @brief Load PRCTL file
*/
void readPrctlFile(const char * filename);
mrmc::formula::PCTLFormula* readPrctlFile(const char * filename);
} // namespace parser
} // namespace mrmc

Loading…
Cancel
Save