YACC grammaire réduire / réduire les conflits
-
11-12-2019 - |
Question
J'ai la grammaire suivante pour vérifier la validité d'un fichier XML, le fichier commence par un élément puis le nœud racine.
program
: terminal_node
root
;
root
: '<' ID attribute_list '>' node_list '<' ID '/''>'
;
node_list
: node
| node node_list
;
node
: terminal_node
: nonterminal_node
;
terminal_node
: '<' ID attribute_list '/''>'
;
nonterminal_node
: '<' ID attribute_list '>' node_list '<' ID '/''>'
;
attribute_list
: attribute
| attribute attribute_list
;
attribute
: ID ASSIGNOP '"' ID '"'
| ID ASSIGNOP '"' NUM '"'
;
Je reçois 1 Réduire / réduire le conflit, et je ne sais pas comment le trouver.Toute aide serait appréciée.
La solution
This looks a bit strange for an XML grammar. Are you sure you don't want empty node_list
s or attribute_list
s?
Anyway, try this:
node_list
: node
| node_list node /* list first, element second, this is the LALR way */
;
node
: terminal_node
| nonterminal_node /* note a typo in your code here */
;
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow