X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/3c9160d9125ffa5abbd941f64ef570d16537d7f0..77714df234fec3610f18f873b569354599fac17d:/TODO diff --git a/TODO b/TODO index ea033d10..bc474d21 100644 --- a/TODO +++ b/TODO @@ -274,39 +274,8 @@ make it much easier to extend the grammar. * Parsing grammars Rewrite the reader in Flex/Bison. There will be delicate parts, in -particular, expect the scanner to be hard to write. - -* Problems with aliases -From: "Baum, Nathan I" -Subject: Token Alias Bug -To: "'bug-bison@gnu.org'" - -I've noticed a bug in bison. Sadly, our eternally wise sysadmins won't let -us use CVS, so I can't find out if it's been fixed already... - -Basically, I made a program (in flex) that went through a .y file looking -for "..."-tokens, and then outputed a %token -line for it. For single-character ""-tokens, I reasoned, I could just use -[%token 'A' "A"]. However, this causes Bison to output a [#define 'A' 65], -which cppp chokes on, not unreasonably. (And even if cppp didn't choke, I -obviously wouldn't want (char)'A' to be replaced with (int)65 throughout my -code. - -Bison normally forgoes outputing a #define for a character token. However, -it always outputs an aliased token -- even if the token is an alias for a -character token. We don't want that. The problem is in /output.c/, as I -recall. When it outputs the token definitions, it checks for a character -token, and then checks for an alias token. If the character token check is -placed after the alias check, then it works correctly. - -Alias tokens seem to be something of a kludge. What about an [%alias "..."] -command... - - %alias T_IF "IF" - -Hmm. I can't help thinking... What about a --generate-lex option that -creates an .l file for the alias tokens used... (Or an option to make a -gperf file, etc...) +particular, expect the scanner to be hard to write. Many interesting +features cannot be implemented without such a new reader. * Presentation of the report file From: "Baum, Nathan I" @@ -355,6 +324,10 @@ them, it is fairly well described there. It would be very nice to implement this in such a way that other programs could use lib/warnings.[ch]. +Don't work on this without first announcing you do, as I already have +thought about it, and know many of the components that can be used to +implement it. + * Pre and post actions. From: Florian Krohm Subject: YYACT_EPILOGUE