blob: fb8b632bd58e2d9c7fe46eb02bdf9eb1f5ea07d8 [file] [log] [blame]
Eli Bendersky19400fd2012-06-22 09:38:23 +03001+ Version 2.08 (??)
2
Eli Bendersky09fc2002012-08-10 07:41:42 +03003 - Issue 73: initial support for #pragma directives. Consume them without
4 errors and ignore (no tokens are returned). Line numbers are preserved.
Eli Bendersky5a0abdf2012-07-07 06:52:23 +03005 - Issue 68: more correct handling of source files without any actual content.
6 - Issue 69: running all tests will now set appropriate return code.
Eli Bendersky0a3ef0b2012-07-06 15:54:29 +03007 - Better error reporting in case where multiple type specifiers are provided.
8 Also fixes Issue 60.
Eli Bendersky5a0abdf2012-07-07 06:52:23 +03009 - Issue 63: line endings cleanup for consistent LF ending.
10 - Issues 64 & 65: added some more headers and typedefs to fake includes.
Eli Bendersky949ad822012-08-10 07:04:20 +030011 - Refactoring the cpp invocation in parse_file into a separate function, which
12 can also be used as a utility.
Eli Bendersky19400fd2012-06-22 09:38:23 +030013
Eli Bendersky081bac22012-06-16 16:10:39 +030014+ Version 2.07 (16.06.2012)
Eli Bendersky13d0a6f2012-06-15 09:30:04 +030015
Eli Bendersky203b9672012-06-15 10:11:24 +030016 - Issue 54: added an optional parser argument to parse_file
17 - Issue 59: added some more fake headers for C99
18 - Issue 62: correct coord for Ellipsis nodes
Eli Bendersky3b1b08d2012-06-15 12:37:54 +030019 - Issue 57: support for C99 hexadecimal float constants
Eli Bendersky13d0a6f2012-06-15 09:30:04 +030020 - Made running tests that call on 'cpp' a bit more robust.
21
22+ Version 2.06 (04.02.2012)
23
24 - Issue 48: gracefully handle parsing of empty files
25 - Issues 49 & 50: handle more escaped chars in paths to #line - "..\..\test.h".
26 - Support for C99 _Complex type.
27 - CGenerator moves from examples/ to pycparser/ as a first-class citizen, and
28 added some fixes to it. examples/c-to-c.py still stays as a convenience
29 wrapper.
30 - Fix problem with parsing a file in which the first statement is just a
31 semicolon.
32 - Improved the AST created for switch statements, making it closer to the
33 semantic meaning than to the grammar.
34
35+ Version 2.05 (16.10.2011)
36
37 - Added support for the C99 ``_Bool`` type and ``stdbool.h`` header file
38 - Expanded ``examples/explore_ast.py`` with more details on working with the
39 AST
40 - Relaxed the rules on parsing unnamed struct members (helps parse ``windows.h``)
41 - Bug fixes:
42
43 * Fixed spacing issue for some type declarations
44 * Issue 47: display empty statements (lone ';') correctly after parsing
45
46+ Version 2.04 (21.05.2011)
47
48 - License changed from LGPL to BSD
49 - Bug fixes:
50
51 * Issue 31: constraining the scope of typedef definitions
52 * Issues 33, 35: fixes for the c-to-c.py example
53
54 - Added C99 integer types to fake headers
55 - Added unit tests for the c-to-c.py example
56
57+ Version 2.03 (06.03.2011)
58
59 - Bug fixes:
60
61 * Issue 17: empty file-level declarations
62 * Issue 18: empty statements and declarations in functions
63 * Issue 19: anonymous structs & union fields
64 * Issue 23: fix coordinates of Cast nodes
65
66 - New example added (``examples/c-to-c.py``) for translating ASTs generated by ``pycparser`` back into C code.
67 - ``pycparser`` is now on PyPI (Python Package Index)
68 - Created `FAQ <http://code.google.com/p/pycparser/wiki/FAQ>`_ on the ``pycparser`` project page
69 - Removed support for Python 2.5. ``pycparser`` supports Python 2 from 2.6 and on, and Python 3.
70
71+ Version 2.02 (10.12.2010)
72
73 * The name of a ``NamedInitializer`` node was turned into a sequence of nodes
74 instead of an attribute, to make it discoverable by the AST node visitor.
75 * Documentation updates
76
77+ Version 2.01 (04.12.2010)
78
79 * Removed dependency on YAML. Parsing of the AST node configuration file is done with a simple parser.
80 * Fixed issue 12: installation problems
81
82+ Version 2.00 (31.10.2010)
83
84 * Support for C99 (read `this wiki page <http://code.google.com/p/pycparser/wiki/C99support>`_ for more information).
85
86+ Version 1.08 (09.10.2010)
87
88 * Bug fixes:
89
90 + Correct handling of ``do{} ... while`` statements in some cases
91 + Issues 6 & 7: Concatenation of string literals
92 + Issue 9: Support for unnamed bitfields in structs
93
94+ Version 1.07 (18.05.2010)
95
96 * Python 3.1 compatibility: ``pycparser`` was modified to run on Python 3.1 as well as 2.6
97
98+ Version 1.06 (10.04.2010)
99
100 * Bug fixes:
101
102 + coord not propagated to FuncCall nodes
103 + lexing of the ^= token (XOREQUALS)
104 + parsing failed on some abstract declarator rules
105
106 * Linux compatibility: fixed end-of-line and ``cpp`` path issues to allow all tests and examples run on Linux
107
108
109+ Version 1.05 (16.10.2009)
110
111 * Fixed the ``parse_file`` auxiliary function to handle multiple arguments to ``cpp`` correctly
112
113+ Version 1.04 (22.05.2009)
114
115 * Added the ``fake_libc_include`` directory to allow parsing of C code that uses standard C library include files without dependency on a real C library.
116 * Tested with Python 2.6 and PLY 3.2
117
118+ Version 1.03 (31.01.2009)
119
120 * Accept enumeration lists with a comma after the last item (C99 feature).
121
122+ Version 1.02 (16.01.2009)
123
124 * Fixed problem of parsing struct/enum/union names that were named similarly to previously defined ``typedef`` types.
125
126+ Version 1.01 (09.01.2009)
127
128 * Fixed subprocess invocation in the helper function parse_file - now it's more portable
129
130+ Version 1.0 (15.11.2008)
131
132 * Initial release
133 * Support for ANSI C89
134
135
136
137