Fix attribute handling for pointer declarators #92
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This commit resolves a bug where attributes on complex declarators, such as pointers to functions, were not parsed correctly, resulting in a
NotImplementedError.The
p_xxx_declarator_2method inpycparserext/ext_c_parser.pyhas been updated to correctly handle these cases. The new implementation traverses the declarator chain to locate the innermostTypeDecland attaches the attributes to it by converting it to aTypeDeclExt.A new test case has been added to
test/test_pycparserext.pyto verify that attributes on pointer-to-function declarations are now parsed correctly. This test fails before the fix and passes after, confirming that the bug is resolved.Fixes #66 and #85