-
-
Notifications
You must be signed in to change notification settings - Fork 95
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
Introduction of Compiler Command class #243
Conversation
I really like this idea. My first instinct though was that I'd have too much trouble maintaining it long-term, but then I finally caved and decided to throw in the towel (after months of agonizing over it). #247 is a request for a new maintainer(s) and I think it makes sense to let whoever takes over the project decide the direction of open PRs. Thanks for the effort - hopefully this really helps the next team by allowing them to start from a better place on the compiler interaction! |
eebe2f7
to
6d037a4
Compare
@phmonte, @daveaglick : I think I finalized this PR. The parsing of the compiler is handled by a dedicated (internal) parser that uses 3 seperate tokenizers (C#, VB.NET, F#). The result is an immutable class that has direct access to Switches, Items, and Source Files. The items required by I decorated these structures with |
Not sure, if this is already covered, but today I discovered a bug in Buildalyzer where absolute Unix paths were not added to the SourceFiles collection. They have probably been treated as "unknown" options and were ignored. I have solved the problem by switching to Roslyn's CSharpCommandLineParser in my code (this is one of the reasons why I proposed exposing the raw command-line in #212). Maybe that would also be an option for Buildalyzer? Replicating the command-line parsing logic seems to be a lot of extra work and it's easy to miss some corner cases/platform-specific stuff. If you want me to open an issue for the bug, I can try to build a small reproducer. |
@siegfriedpammer It might be benefitial to use Roslyn's parser here as well (stating the obvious). We do not want to re-invent the wheel. I'll look into this. Thanks for mentioning it. |
de1ef9a
to
5a4a681
Compare
@siegfriedpammer I rewrote this PR based on your suggestion: It way less custom code if we use Roslyn's |
I'm evaluating the PR, I'll get back to you soon. @Corniel @siegfriedpammer! |
b770b7d
to
82ac923
Compare
@phmonte and @daveaglick Also found the F# equivalent (at least I think I did😉). Rewrote the intro for the PR, and now am working on replacing things step by step. |
I think I have it working. Note that C# and VB.NET commandline parsers apply a path combine on source, and additional files. I hope I did all F# mapping correct. and there are some TODO's left. Is there any F# expert who can help with those? |
I don't want this to sound negative, but I really liked the early tokenizer version of this PR and think adding the extra dependencies would be more trouble than it's worth in the long run. I had mixed feelings about My specific issues are:
The previous Buildalyzer vs Buildalyzer.Workspaces package split did a really good job of keeping these dependency chains separate, and this feels like a step backwards. Just my two cents (please take it as constructive 🙏 ). I'm really happy to see this project receiving so much love in the past few weeks 🙂 |
@slang25 That is useful feedback, and surely something to keep in mind. The added value for adding the F# dependency is the lowest, so dropping not adding a lot of code. For the other two: they provide tons of logic on how to interpreter the command line, taking care on a lot of logic. So there I think of the following options:
That being said, the second option is a lot of work. In general, (as pointed out during this PR) we - all people involved in maintaining this package - really need F# experts to help us. Secondly, I personally need some more inside in what this package is used for. I know what Stryker does with it, and obviously what my own Roslyn Test Tools uses it for, but to be of better help to others, feedback is needed. |
de774da
to
0f6515b
Compare
b2f6a7a
to
175892f
Compare
@Corniel , I'm evaluating this PR, the Compiler Command class is great, the AnalyzerResult.cs class is much more readable. But, I'm also worried about the issue of adding 3 more dependencies to the project, Regardless of whether we continue with option 1 or 2, I understand that your work will be used, because even following option 2 we would maintain all class contracts, and I could do this annoying part of "copying" the logic. You asked a great question about this package, asking how and where people are using it could be an alternative, perhaps opening an issue, looking for references in public projects, I'm thinking. |
@phmonte with the last PR, I dropped the F# dependency. I'll continue to also drop the other two dependencies. But that will take some time. |
3268575
to
511ad6a
Compare
After some further investigation, I came to the conclusion that the benefits of using Issues like those mentioned by @siegfriedpammer will dramatically reduce, and the code will be easier to maintain. @slang25 and @phmonte Feedback is appreciated. Now defined as: <PackageReference Include="Microsoft.CodeAnalysis.CSharp" Version="4.0.1" AllowedVersion="[4,)" />
<PackageReference Include="Microsoft.CodeAnalysis.VisualBasic" Version="4.0.1" AllowedVersion="[4,)" /> |
bc75e62
to
3fe1104
Compare
@phmonte I'd like to continue with this. Can we decide on how to do that? |
Actually using these packages saves a lot of lines of code, at first I was thinking about copying the library logic, but I confess that the idea of the minimum version seems very satisfactory to me and excludes compatibility problems if by chance the project already uses some of these libraries. But, I would feel safer applying these changes in a next version, if this is not a dependency for the other open PRs, what do you think @Corniel ? @daveaglick , if you have any feedback too, it would be greatly appreciated. |
@phmonte My idea is to prepare more 'drastic' changes that would require a new major version. Eventually I think the result of an analysis would be the CompilerCommand, the properties/items and the dot-net info. So we could decide to merge this not back to master, but keep it o next-stable-major-branch and continue this process. |
3fe1104
to
c17851c
Compare
@phmonte I did a rebase. I would like to create a next PR that combines this with the Compiler Items and Properties, but that obvious requires this to be merged first. |
Several projects that use this library have references to Microsoft.CodeAnalysis.CSharp and Microsoft.CodeAnalysis.VisualBasic, version 4+ would be compatibility from the year 2021, I think it is good compatibility and we will no longer need to worry about many lines of code, I did some tests and the behavior seems satisfactory, let's continue this way. |
Done. Feel free to make extra additions to the summary. |
The original commandline parsing is a weakly typed homegrown piece of code. It is hard to debug, and not trivial to write test for. I originally started by rewriting it to become strongly typed (but still homegrown).
Thanks to@siegfriedpammer, for mentioning the
CSharpCommandLineParser
. Roslyn already implemented it itself (and also for VB.NET with theVisualBasicCommandLineParser
).This should make our lives way easier. The only downside (but one I can live with) is the addition of 2 dependencies: