diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2016-03-17 00:09:14 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2016-03-17 00:09:14 (GMT) |
commit | ceda50048870217cfa6de1ebad22f851d1259718 (patch) | |
tree | 8dca59d100ebb4946d34188214f3479481bb8f7b /tools/d2c | |
parent | 4021e5f02ce71b35423852cd89fb6f0f2776f7b8 (diff) |
Fixed two reduce/reduce conflicts in d2c.
Diffstat (limited to 'tools/d2c')
-rw-r--r-- | tools/d2c/grammar.y | 28 |
1 files changed, 17 insertions, 11 deletions
diff --git a/tools/d2c/grammar.y b/tools/d2c/grammar.y index 02b2671..f0c1779 100644 --- a/tools/d2c/grammar.y +++ b/tools/d2c/grammar.y @@ -175,28 +175,31 @@ name : COPYRIGHT TITLE INS_NAME { save_notes_for_coder(coder encodings : /* empty */ | encoding encodings -encoding : ENCODING TYPE NUMBER format_content { push_encoding_spec(coder, $2, $3); } - | ENCODING format_content { push_encoding_spec(coder, NULL, -1); } - | ENCODING TYPE NUMBER content { push_encoding_spec(coder, $2, $3); } +encoding : ENCODING TYPE NUMBER format_encoding { push_encoding_spec(coder, $2, $3); } + | ENCODING format_encoding { push_encoding_spec(coder, NULL, -1); } + | ENCODING TYPE NUMBER raw_encoding { push_encoding_spec(coder, $2, $3); } /* Définitions à l'aide d'un format défini */ -format_content : /* empty */ - | format format_content +format_encoding : format format_content format : FORMAT RAW_LINE { handle_coder_format(coder, $2); } +format_content : /* empty */ + | hooks format_content + | rules format_content + /* Définitions à l'aide de données brutes */ +raw_encoding : bitfield raw_content -content : /* empty */ - | bitfield content - | syntax content - | conversions content - | hooks content - | rules content +raw_content : /* empty */ + | syntax raw_content + | conversions raw_content + | hooks raw_content + | rules raw_content bitfield : HALF RAW_LINE { handle_coder_bits(coder, 16, $2); } | WORD RAW_LINE { handle_coder_bits(coder, 32, $2); } @@ -205,6 +208,9 @@ syntax : SYNTAX RAW_LINE { handle_coder_syntax(coder, $2); } conversions : CONV RAW_BLOCK { handle_coder_conversions(coder, $2); } + +/* Définitions communes */ + hooks : HOOKS RAW_BLOCK { handle_coder_hooks(coder, $2); } rules : RULES RAW_BLOCK { handle_coder_rules(coder, $2); } |