You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Many projects use swift preprocessor directives / active compilation conditions to enable conditional compilation. (e.g. lines surrounded by an if/ifdef/ifndef directive that should only compile when their condition – usually an environment variable – evaluates to true.)
As far as I can tell, Sourcery appears not to be aware of these markers and therefore blocks of code marked to be ignored are still processed by Sourcery – leading to compilation errors.
@tcldr that's a really good suggestion.
If that's the issue we can maybe add special annotation to surround such blocks. But need to check what is the actual behaviour in this case and is there a way to solve it with SourceKitten.
But this might become more complicated if we would want Sourcery to parse source code depending on if conditions in such #ifdef are met or not, i.e. depending on the platform, swift version or compiler flag.
A special annotation could work, skippedByCompiler or something.
But if it's simpler, maybe skipping those blocks entirely and simply leveraging the preprocessor?
I guess it depends on whether there is a use-case for knowing which code the compiler has skipped during a Sourcery pass – but I imagine if you have marked code to be skipped during the preprocessor phase, you'd likely want it ignored by Sourcery too.
Many projects use swift preprocessor directives / active compilation conditions to enable conditional compilation. (e.g. lines surrounded by an if/ifdef/ifndef directive that should only compile when their condition – usually an environment variable – evaluates to true.)
As far as I can tell, Sourcery appears not to be aware of these markers and therefore blocks of code marked to be ignored are still processed by Sourcery – leading to compilation errors.
Searching the source code I see that the Source Kitten dependency may expose those lines of code which should be ignored so this may be something that could be added relatively simply?
The text was updated successfully, but these errors were encountered: