X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=TODO;h=3fc264b1e144bc0808b937fe4d53bfb016fdcee4;hb=0398c22778ba28be93a68f69a54124fd95826403;hp=37eb859d2b790867b2455db3ce68c38b7e9223ad;hpb=853c9303530a0f2e68ac923538765f15efea6a90;p=cparser diff --git a/TODO b/TODO index 37eb859..3fc264b 100644 --- a/TODO +++ b/TODO @@ -1,23 +1,55 @@ +Driver: + +Refactoring: +- eliminate target_architecture.h and replace with stuff in lang_features.h +- create structures for variables and functions, removing the omnipotent declaration + 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: -- the expect macros abort functions directly. This leads to some functions - not resetting the current context properly (parse_for) +- disallow storage class specifiers in struct/union members - label: declaration; is no valid C99 but we parse it anyway -- designator support for initializers -- add constant folding code -- Refactor code, so code to handle number values and strings is - an own module and replacable +- 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 +- Support some attributes. noreturn, unused, printf, scanf, packed would be + interesting candidates +- Add columns to source positions +- SourcePositions could be stored selectively on expressions that really need + them. +- check semantic for functions declared/defined in global scope and declared + again in a local scope +- print initialisation type_path for initializer errors +- check switches for: double cases, all enums ast2firm: +- handle non-constant initializers - output source file positions for panics... +- handle bitfield members with 0 correctly (standard says they finish the + current unit) +Missing Errors: +* check switches for double cases -Coole Warnungen: +Missing Warnings: +* dead assignments (int x = 5; x = bla(); -> dead assignment at x = 5;) +* unused label +* check switches for all enums values - int x = 5; - x = bla(): - -> dead assignment +Spec-Status: +(only test datasets tried yet) +164.gzip: works +175.vpr: works +176.gcc: not ok +181.mcf: works +186.crafty: works (~though an asm is replaced with a stub) +253.perlbmk: not ok +254.gap: not ok +255.vortex: works +256.bzip2: works +300.twolf: works