40 #ifndef YY_HOAYY_PARSEAUT_HH_INCLUDED 41 # define YY_HOAYY_PARSEAUT_HH_INCLUDED 43 #line 31 "parseaut.yy" // lalr1.cc:377 46 #include <spot/misc/common.hh> 50 #include <unordered_map> 52 #include <spot/twa/formula2bdd.hh> 53 #include <spot/parseaut/public.hh> 54 #include "spot/priv/accmap.hh" 55 #include <spot/tl/parse.hh> 56 #include <spot/twaalgos/alternation.hh> 58 #ifndef HAVE_STRVERSCMP 60 extern "C" int strverscmp(
const char *s1,
const char *s2);
65 #define PARSE_ERROR_LIST res.h->errors 69 typedef std::map<int, bdd> map_t;
76 typedef std::map<std::string, bdd> formula_cache;
78 typedef std::pair<int, std::string*> pair;
86 enum label_style_t { Mixed_Labels, State_Labels, Trans_Labels,
88 enum acc_style_t { Mixed_Acc, State_Acc, Trans_Acc };
94 bool declared =
false;
96 spot::location used_loc;
98 spot::parsed_aut_ptr h;
99 spot::twa_ptr aut_or_ks;
101 std::string format_version;
102 spot::location format_version_loc;
104 formula_cache fcache;
105 named_tgba_t* namer =
nullptr;
106 spot::acc_mapper_int* acc_mapper =
nullptr;
108 std::vector<bdd> guards;
109 std::vector<bdd>::const_iterator cur_guard;
111 std::vector<state_info> info_states;
112 std::vector<std::pair<spot::location,
113 std::vector<unsigned>>> start;
114 std::unordered_map<std::string, bdd> alias;
119 operator bool()
const 124 std::unordered_map<std::string, prop_info> props;
125 spot::location states_loc;
126 spot::location ap_loc;
127 spot::location state_label_loc;
128 spot::location accset_loc;
134 std::vector<std::string>* state_names =
nullptr;
135 std::map<unsigned, unsigned>* highlight_edges =
nullptr;
136 std::map<unsigned, unsigned>* highlight_states =
nullptr;
137 std::map<unsigned, unsigned> states_map;
138 std::set<int> ap_set;
145 bool has_state_label =
false;
146 bool ignore_more_ap =
false;
148 bool ignore_acc =
false;
150 bool ignore_acc_silent =
false;
151 bool ignore_more_acc =
false;
154 label_style_t label_style = Mixed_Labels;
155 acc_style_t acc_style = Mixed_Acc;
157 bool accept_all_needed =
false;
158 bool accept_all_seen =
false;
159 bool aliased_states =
false;
162 bool complete =
false;
163 bool trans_acc_seen =
false;
165 std::map<std::string, spot::location> labels;
167 prop_info prop_is_true(
const std::string& p)
169 auto i = props.find(p);
170 if (i == props.end())
171 return prop_info{spot::location(),
false};
175 prop_info prop_is_false(
const std::string& p)
177 auto i = props.find(p);
178 if (i == props.end())
179 return prop_info{spot::location(),
false};
180 return prop_info{i->second.loc, !i->second.val};
191 #line 192 "parseaut.hh" // lalr1.cc:377 196 # include <stdexcept> 204 # if (defined __GNUC__ \ 205 && (2 < __GNUC__ || (__GNUC__ == 2 && 96 <= __GNUC_MINOR__))) \ 206 || defined __SUNPRO_C && 0x5110 <= __SUNPRO_C 207 # define YY_ATTRIBUTE(Spec) __attribute__(Spec) 209 # define YY_ATTRIBUTE(Spec) 213 #ifndef YY_ATTRIBUTE_PURE 214 # define YY_ATTRIBUTE_PURE YY_ATTRIBUTE ((__pure__)) 217 #ifndef YY_ATTRIBUTE_UNUSED 218 # define YY_ATTRIBUTE_UNUSED YY_ATTRIBUTE ((__unused__)) 221 #if !defined _Noreturn \ 222 && (!defined __STDC_VERSION__ || __STDC_VERSION__ < 201112) 223 # if defined _MSC_VER && 1200 <= _MSC_VER 224 # define _Noreturn __declspec (noreturn) 226 # define _Noreturn YY_ATTRIBUTE ((__noreturn__)) 231 #if ! defined lint || defined __GNUC__ 232 # define YYUSE(E) ((void) (E)) 237 #if defined __GNUC__ && 407 <= __GNUC__ * 100 + __GNUC_MINOR__ 239 # define YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN \ 240 _Pragma ("GCC diagnostic push") \ 241 _Pragma ("GCC diagnostic ignored \"-Wuninitialized\"")\ 242 _Pragma ("GCC diagnostic ignored \"-Wmaybe-uninitialized\"") 243 # define YY_IGNORE_MAYBE_UNINITIALIZED_END \ 244 _Pragma ("GCC diagnostic pop") 246 # define YY_INITIAL_VALUE(Value) Value 248 #ifndef YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN 249 # define YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN 250 # define YY_IGNORE_MAYBE_UNINITIALIZED_END 252 #ifndef YY_INITIAL_VALUE 253 # define YY_INITIAL_VALUE(Value) 263 #line 264 "parseaut.hh" // lalr1.cc:377 277 #line 185 "parseaut.yy" // lalr1.cc:377 284 std::list<pair>* list;
286 std::vector<unsigned>* states;
288 #line 289 "parseaut.hh" // lalr1.cc:377 299 syntax_error (
const location_type& l,
const std::string& m);
300 location_type location;
322 SPOT_HIGHLIGHT_EDGES = 271,
323 SPOT_HIGHLIGHT_STATES = 272,
366 enum { empty_symbol = -2 };
377 template <
typename Base>
391 const location_type& l);
395 const semantic_type& v,
396 const location_type& l);
444 symbol_number_type type_get ()
const;
447 token_type
token ()
const;
460 parser (result_& res_yyarg, spot::location initial_loc_yyarg);
465 virtual int parse ();
468 std::ostream& debug_stream () const YY_ATTRIBUTE_PURE;
471 void set_debug_stream (
std::ostream &);
476 debug_level_type debug_level () const YY_ATTRIBUTE_PURE;
478 void set_debug_level (debug_level_type l);
484 virtual void error (
const location_type& loc,
const std::string& msg);
495 typedef int state_type;
500 virtual std::string yysyntax_error_ (state_type yystate,
501 const symbol_type& yyla)
const;
506 state_type yy_lr_goto_state_ (state_type yystate,
int yysym);
510 static bool yy_pact_value_is_default_ (
int yyvalue);
514 static bool yy_table_value_is_error_ (
int yyvalue);
516 static const short int yypact_ninf_;
517 static const signed char yytable_ninf_;
520 static token_number_type yytranslate_ (
int t);
525 static const short int yypact_[];
530 static const unsigned char yydefact_[];
533 static const short int yypgoto_[];
536 static const short int yydefgoto_[];
541 static const short int yytable_[];
543 static const short int yycheck_[];
547 static const unsigned char yystos_[];
550 static const unsigned char yyr1_[];
553 static const unsigned char yyr2_[];
557 static std::string yytnamerr_ (
const char *n);
561 static const char*
const yytname_[];
564 static const unsigned short int yyrline_[];
566 virtual void yy_reduce_print_ (
int r);
568 virtual void yystack_print_ ();
572 std::ostream* yycdebug_;
577 template <
typename Base>
585 template <
typename Base>
596 typedef state_type kind_type;
599 by_state (kind_type s);
602 by_state (
const by_state& other);
608 void move (by_state& that);
612 symbol_number_type type_get ()
const;
615 enum { empty_state = -1 };
628 stack_symbol_type ();
630 stack_symbol_type (state_type s, symbol_type& sym);
632 stack_symbol_type& operator= (
const stack_symbol_type& that);
646 void yypush_ (
const char* m, stack_symbol_type& s);
654 void yypush_ (
const char* m, state_type s, symbol_type& sym);
657 void yypop_ (
unsigned int n = 1);
674 spot::location initial_loc;
680 #line 681 "parseaut.hh" // lalr1.cc:377 685 #endif // !YY_HOAYY_PARSEAUT_HH_INCLUDED Definition: parseaut.hh:90
An environment that describes atomic propositions.
Definition: environment.hh:32
Symbol semantic values.
Definition: parseaut.hh:275
semantic_type value
The semantic value.
Definition: parseaut.hh:411
Syntax errors thrown from user actions.
Definition: parseaut.hh:297
Definition: formula.hh:1671
Definition: parseaut.hh:92
token::yytokentype token_type
(External) token type, as returned by yylex.
Definition: parseaut.hh:360
Definition: parseaut.hh:262
Definition: parseaut.hh:115
Tokens.
Definition: parseaut.hh:304
Type access provider for token (enum) based symbols.
Definition: parseaut.hh:422
token_type kind_type
The symbol type as needed by the constructor.
Definition: parseaut.hh:431
Base super_type
Alias to Base.
Definition: parseaut.hh:381
unsigned char token_number_type
Internal symbol number for tokens (subsumed by symbol_number_type).
Definition: parseaut.hh:369
A class implementing Kleene's three-valued logic.
Definition: trival.hh:33
int type
Definition: parseaut.hh:452
basic_symbol< by_type > symbol_type
"External" symbols: returned by the scanner.
Definition: parseaut.hh:456
spot::location location_type
Symbol locations.
Definition: parseaut.hh:294
Definition: parseaut.hh:67
A Bison parser.
Definition: parseaut.hh:270
Definition: parseaut.hh:378
location_type location
The location.
Definition: parseaut.hh:414
int symbol_number_type
Symbol type: an internal symbol number.
Definition: parseaut.hh:363
int debug_level_type
Type for debugging levels.
Definition: parseaut.hh:474