-
Notifications
You must be signed in to change notification settings - Fork 230
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
[http-client-csharp] the post processor should always keep customized code as root documents #5481
base: main
Are you sure you want to change the base?
Conversation
c4a9678
to
668c68b
Compare
API change check API changes are not detected in this pull request. |
…-always-keep-customized-types
private async Task<Compilation> GetProjectCompilationAsync() | ||
{ | ||
_compilation ??= await _project.GetCompilationAsync(); | ||
return _compilation!; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this is a duplicate with GetCompilationAsync
method in this same class.
...ent-csharp/generator/Microsoft.Generator.CSharp/src/PostProcessing/GeneratedCodeWorkspace.cs
Outdated
Show resolved
Hide resolved
var compilation = await project.GetCompilationAsync(); | ||
return compilation!; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: return it instead of declaring a variable
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would like to do that but the return of this method is Task<Compilation?>
and here we want a Task<Compilation>
, we must have a local variable and assert it is not null.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
otherwise it might look like this:
return (await project.GetCompilationAsync())!;
I prefer local variable rather than the above
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So it will be null if SupportsCompilation is false. It's not clear to me when that would happen but perhaps we should add some assertion that it is not null rather than using the null-forgiving operator.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah I see this is specifically for the test helper, so probably less of an issue here. But for the GetCompilationAsync method we should add validation with a helpful error message that says SupportsCompilation must be true.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
do you mean that we should add an assertion here on compilation cannot be null?
This method GetCompilationAsync
is not our method, this method comes from roslyn API.
In our version of GetCompilationAsync
, we have Debug.Assert(compilation is not null)
and the method does not return a nullable result.
…rp/src/PostProcessing/GeneratedCodeWorkspace.cs Co-authored-by: Wei Hu <[email protected]>
@@ -29,7 +29,7 @@ public async Task ExecuteAsync() | |||
var generatedTestOutputPath = CodeModelPlugin.Instance.Configuration.TestGeneratedDirectory; | |||
|
|||
GeneratedCodeWorkspace workspace = await GeneratedCodeWorkspace.Create(); | |||
await CodeModelPlugin.Instance.InitializeSourceInputModelAsync(); | |||
CodeModelPlugin.Instance.SourceInputModel = new SourceInputModel(await workspace.GetCompilationAsync()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just curious why we change the initializing here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
just to make it simpler because this method does not have to be async any more, we could assign the constructed SourceInputModel.
Everything related with this change is internal or private.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we add a test?
I would love to but I did not really figured out a way that we could unit test this. |
@live1206 @JoshLove-msft I opened this issue to track adding test cases for post processor in case we forgot it in the future: #5569 |
Fixes #5441
Previously in our generator, we have two instances of
GeneratedCodeWorkspace
: one for the project that is being generated right now (the generated code project), one for the existing part of the generated library (the customized code project).This leads to an issue that in the post processor, only the generated documents are passed into the post processor, therefore the post processor actually does not know about the existence of the customized files.
This is not very correct because the generated files must need those customized files to work properly therefore they should be in the same project.
This PR refactors this part to change the structure of
GeneratedCodeWorkspace
: now we only create one instance ofGeneratedCodeWorkspace
, and the project inside it will be initialized with shared files and all the customized files in it.In this way, when we get to the post processor, it should be able to access all the necessary documents.