X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=TODO;h=0436f7c09ebbd56e483bad44a751123024297c15;hb=d5415744758eb5532157cc4f70d5b560d45733d8;hp=16815885da04089a72da54aa2b70ba6752ba3ce8;hpb=57ee5531f3b100ad3bcb3df61c66224ef5a0bfb6;p=cparser diff --git a/TODO b/TODO index 1681588..0436f7c 100644 --- a/TODO +++ b/TODO @@ -3,12 +3,10 @@ Refactoring: Lexer: - Add preprocessor code. -- proper handling of different file encodings, parsing non-ascii strings - We could save some space by holding source positions in a separate (somehow compressed table) and only storing pointers to it on the AST. Parser: -- disallow storage class specifiers in struct/union members - add constant folding code (optional, ast2firm already does it) - Refactor code, so code to handle number values (and strings?) is an own module and replacable @@ -22,17 +20,12 @@ Parser: ast2firm: - output source file positions for panics. -- handle bitfield members with 0 correctly (standard says they finish the - current unit) Missing Errors: - goto over VLA declarations Missing Warnings: - dead assignments (int x = 5; x = bla(); -> dead assignment at x = 5;) -- catch the if(k = b) cases, maybe require all assignments to be in parentheses - (but some few exceptions like toplevel, nested assignments) - - warn when folding shift constants with too large shift amounts main/driver: -- delete output file if we had an error +- go through gcc manual and emulate all the gcc flags...