-
Notifications
You must be signed in to change notification settings - Fork 278
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
regexps cannot be used to parse C! #438
Comments
The goal has been to move CMock to a real parser for some time. The trouble has been that many C-compilers in the wild extend C/cpp in various ways... so we've yet to find a parser which supports the extensions we need (try to find a parser which can 100% files meant for IAR, Green Hills, and GCC from the same parser... you'll see what I mean.) One option is to preprocess the non-standard parts out first... but then we're back to using regexes or similar. We haven't given up on this goal. If you dig through the older open issues, you'll see that this issue is already there and has much discussion around it. We're definitely open to more thoughts. |
Indeed, this is a problem. Also, do we want to generate mocks for "anonymous" functions, or functions that are just declared thru function pointer variables? eg. cf. Anyways, for now, I'm just implementing a parser tracking the parentheses balancing, with ad-hoc identifying of the various parts. |
You can do that - you just mock the function (someFunc) and then put it as global structure for the pointer variables (that's the ugly part - but only for unit test) and assign in test case |
I believe this is the same issue as this one from 2017. It's been a stumbling block for me over the past few weeks, as any external library header files with a If there are any workarounds to this, they'd be very appreciated ^^ |
Hi!
A lot of issues concerning the parsing of C come actually from the fact that regexps are used to try to parse C code. This is doomed.
For example, when trying to parse function signatures followed by
__attribute__
such as:void foo() __attribute__((noreturn))
the regexps fail, because they match parentheses without balancing them.
We could have more complex declarators:
int (*)(int(*)(int)) foo(int(fun*)(int),int x) __attribute__((glop))
What is your opinion on using a real C parser such as rcc (gem), or libclang?
Note, even if we want to parse a more relaxed version of C rather than strictly adhering to a specific standard, using an actual parser would be of great benefit.
https://groups.google.com/g/ttsforums/c/Ow6acueWPdY
The text was updated successfully, but these errors were encountered: