Review Request: Add "language features" to the C++ parser
Alexandre Courbot
gnurou at gmail.com
Sun May 13 06:41:20 UTC 2012
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
http://git.reviewboard.kde.org/r/104930/
-----------------------------------------------------------
(Updated May 13, 2012, 6:41 a.m.)
Review request for KDevelop.
Changes
-------
Only process designated initializers for C99 files. Also enabled a couple more C-specific features in the parser.
Description
-------
Currently the parser is a pure C++ parser with C++11 elements, without
any option to disable C++11 or to make it more C compatible. C
compatibility in particular is a big challenge since many C++ tokens can
be used as identifiers in C, and C also has some constructs that are not
valid in C++ (like designated initializers or casted braced init lists).
This patch adds "language features" which are flags that enable specific
language support in the parser. Currently flags exist for C99, C++ and
C++11. Code that invokes the parser can use the new
setLanguageFeatures() method to change the current set of supported
features (the default is C++ | C++11). This is useful for instance for
C-specific projects.
CppLanguageSupport::createParseJob has been modified to check for a
"Language" entry in the configuration of the project the parsed file
belongs to. Project controllers can set this option if they know that
the project is limited to C, C++ or C++11 files. Other means (for
instance, based on file extension of Makefile analysis) could be
implemented in the future.
Diffs (updated)
-----
languages/cpp/cpplanguagesupport.cpp 4ee1ffe
languages/cpp/cppparsejob.h debb1b0
languages/cpp/cppparsejob.cpp 1e0a51b
languages/cpp/parser/languagefeatures.h PRE-CREATION
languages/cpp/parser/lexer.h 3494cbd
languages/cpp/parser/lexer.cpp 81302d7
languages/cpp/parser/parser.h c519891
languages/cpp/parser/parser.cpp edeab85
languages/cpp/parser/tests/test_parser.h dea9902
languages/cpp/parser/tests/test_parser.cpp 804f379
languages/cpp/preprocessjob.cpp 803c237
Diff: http://git.reviewboard.kde.org/r/104930/diff/
Testing
-------
Modified kdev-kernel to set that "Language=C" option to the projects it manages. Checked that C++ keywords like "class", "private" were indeed treated as identifiers. This alone improves kernel parsing quality a great deal.
Made sure that parsing of C++ projects is not affected in any way by this patch.
Thanks,
Alexandre Courbot
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kdevelop-devel/attachments/20120513/680912dc/attachment.html>
More information about the KDevelop-devel
mailing list