The VS Feedback item has the original unredacted attachment illustrating the problem.
In this redacted example, you can see its removed the line breaks as well as changed the spacing before the closing element. Its changing the formatting of config files in this manner for projects that are not having any binding redirects added or changed, and for projects that aren't being targeted for the package update.
Its also creating new app.config files for projects that didnt have them and don't need them (class libraries).
All of these are a tedious venture to cleanup before checkin or submitting for code review. On larger solutions (> 50 projects) this can easily take an hour or more to clean up - every time a single package is updated in a project in the solution.
The general trashing of formatting is the result of using XmlDocument or XDocument. Other than parsing the file as text I dont think there is a way to preserve all existing formatting in a config file. I would consider that a defect in either those two classes, or in the decision to use XML files for .net configuration. FWIW, the ability to add comments to XML makes it better than JSON for this purpose, but I would expect this to be sensible about how much needless pending change churn it creates.
The creating of app.config files for projects that didnt have them and dont need them is a bug in nuget, as is the zero-change modification to an existing config file that causes pending changes in team explorer. Adding the binding redirect checkbox on the project property helps some, but is still kind of a bandaid.
To get around this as fast as possible, currently I can search for app.config files in Solution Explorer and delete all the ones with a pending add, then use Undo Unchanged from this extension (where did tfpt uu
go?) to cleanup the csproj changes.
@mishra14 - I'm sure you guys know how to do this stuff already, but if it helps address this issue faster, I figured out how to edit a part of the config file without wrecking the formatting of the rest of the file. Its not complete as far as adding/editing/removing specific assembly bindings (that code I think you would already have), but it does show how to avoid the unnecessary churn created from XmlDocument or XDocument.
This is an example where I had it rewrite the assembly bindings section only. Note the element closures and line breaks in the rest of the file are preserved.
@PatoBeltran is currently working on changing the code that reads xml files in NuGet. He might be better able to address this issue.
cc: @jainaashish @nkolev92
@mishra14 @PatoBeltran - any info about this?
I don't think his changes affect the web.config, but rather the NuGet.config files only.
So I don't think anything has changed.
@nkolev92 - is the "Settings" tag appropriate for this as its not settings related?
@nkolev92 - Also, this issue has had many reports on developer community and contrary to Alisa Gu's response, it is affecting all users of Visual Studio.
Its not a Packages.Config specific thing either, as installation of packages by Package ref also will create/modify app and web.config files for binding redirects.
@StingyJack
NuGet itself does not modify the app/web config as part of the PackageReference restore/install (which is really restore in the background) workflow.
So if there are changes, it's a different component.
@nkolev92 - what is it that adds binding redirects to config files after/during package installation? What is it that adds app.config files to projects that didnt have/need them? I'm pretty sure I've seen that code and it is in the nuget client repo.
EDIT: If you are telling me that package ref will install packages but not create binding redirects when necessary, then that is a different problem. I cant have software that compiles but has runtime issues due to missing redirects. That's going to be yet another entry in the list of 1000 cuts..
I'm pretty sure I've seen that code and it is in the nuget client repo.
You are correct, nuget does do that, but only in the case of packages.config. See for example that code is in a VisualStudio, while NuGet PackageReference also works the same in msbuild and dotnet.exe.
In PackageReference it works a bit differently, it's a different component that handles the binding redirects.
If you are telling me that package ref will install packages but not create binding redirects when necessary
I'm just saying it's not NuGet specifically that does that anymore, rather a different component. Which is why I tagged it as "packages.config" only.
@nkolev92 - Tagging this as packages.config means we will have to continue to deal with this burden because while the nuget team "supports" packages.config there will not be any attempts to fix bugs that do not overlap package ref.
A tool is only effective if it allows you to achieve more with a similar effort.
Not a great set of choices you all have decided to leave us with. Throwing an unexpected pile of work in front of someone who was using a tool you made is a foul thing to do.
@heng-liu and @zkat - just so its understood, this is still a problem for any developer who uses config files and nuget packages. I've just stopped complaining here since I've given a technique for how to fix the hard part and am now just waiting for you all to actually _do_ something
@heng-liu @zkat i have the same problem and it really annoys me. Every time before checkin i need to check each config file and undo changes to all config files that were unexpectedly changed. It also adds configs for library projects. If you have many projects in one solution it is really a nightmare. It takes extra efforts and time. It would be great if we can get some kind of feedback
I tried the XDocument APIs, but seems none of them could keep the indent in one element(between attributes).
e.g. for the following xml file:
<compiler language="c#;cs;csharp" extension=".cs"
type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=2.0.1.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
warningLevel="4" compilerOptions="/langversion:default /nowarn:1659;1699;1701"/>
<compiler language="vb;vbs;visualbasic;vbscript" extension=".vb"
type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.VBCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=2.0.1.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
warningLevel="4" compilerOptions="/langversion:default /nowarn:41008 /define:_MYTYPE=\"Web\" /optionInfer+"/>
If we save the above file in path1, and load the file and save it to path2
XDocument doc = XDocument.Load(path1, LoadOptions.PreserveWhitespace);
doc.Save(path2, SaveOptions.DisableFormatting);
Then the indent in path1 disappeared when loaded and saved in path2.
So looks like we need to implement a fundamental function to keep the whitespaces in one element(between attributes).
BTW, it affects legacy (non-SDK style) projects.
@heng-liu - I made a working POC a while ago
Thanks @StingyJack !
Do you mind turning it into a PR so that people could review it?
Here is the CONTRIBUTING.md document if you would like to contribute. Thanks.
Its a POC so I didnt bother with some of the niceties or adhering to any one particular style. I made it available to just about anyone to use however they wanted.
But I didn't create this incredible time vampire of a defect described in the OP thats just been getting ignored by its creator. It seemed to me that it was not getting fixed because the creator did not know how to go about fixing it. For that I am willing to help unblock them, but I should not be asked have to take on the entire burden of fixing it, including the inevitable PR grief and likely denial of the same.
Since you can add labels, I'm assuming you work for MSFT. I do not, so I'm not sure I'm even equipped to do this work since it may be inside VS.
Most helpful comment
@nkolev92 - what is it that adds binding redirects to config files after/during package installation? What is it that adds app.config files to projects that didnt have/need them? I'm pretty sure I've seen that code and it is in the nuget client repo.
EDIT: If you are telling me that package ref will install packages but not create binding redirects when necessary, then that is a different problem. I cant have software that compiles but has runtime issues due to missing redirects. That's going to be yet another entry in the list of 1000 cuts..