Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to not copy app.config file to output directory

I have a WPF application I am building. I am using Visual Studio Community 2015. In an effort to create a "true" release build, I am changing up some build settings so it only generates necessary files that will be installed on the user's computer. So no vshost exe, no generated XML files, etc. etc. etc. (I am retaining PDB file generation, however).

I have everything exactly how I want it, except for one file. I have an App.config file in each project. I don't mind this getting copied to the output directory on my debug builds, but on my "true" release build I don't want it there.

The file is already set as "Do not copy" in its properties. See images below:

App.config image

Despite having the "Do not copy" setting, however, I still get an "MyAppName.exe.config" file generated every single time I build the project. Why is this so? How can I turn it off? It is quite annoying.

Thanks for any advice!

like image 694
David Avatar asked Oct 27 '16 16:10

David


People also ask

Where are app config files stored?

The file is stored inside this path "bin/debug/app. config", if you make changes while debugging, those changes should appear there. Just remember that this file is overwritten with the "app. config" from the project root each time you run the application on Visual Studio IDE.

Does app config get compiled?

Well, when you compile your application, the compiler actually copies the app. config file to the output folder, but gives it another name: When you start your application (ConsoleApp1.exe in our example), the matching config file will be loaded too.

Can I delete app config?

If the app has a configuration profile, delete it. Go to Settings > General > Profiles or Profiles & Device Management,* then tap the app's configuration profile. Then tap Delete Profile.


2 Answers

The handling of app.config is special, it is treated By Name, the build process will select the app.config file following this order:

  • Choose the value $(AppConfig) set in the main project.
  • Choose @(None) App.Config in the same folder as the project.
  • Choose @(Content) App.Config in the same folder as the project.
  • Choose @(None) App.Config in any subfolder in the project.
  • Choose @(Content) App.Config in any subfolder in the project.

$(AppConfig) is an MSBuild Property, if it is empty, it will look for a file with name "App.Config" in the "None" or "Content" MSBuild Item Groups, if there's a match, the file will be used and will be copied to the output directory replacing the app.config name by [AssemblyName].config

If you want to keep the file without delete it, you will need to change the "Build Action" property to something different to "None" or "Content", you can use any existing value on the list (I suggest "AdditionalFiles") or any value you want to use i.e. "MyConfigFile", and now the that will keep the file inside the project, but without the logic that generates the configuration file in the output directory.

Or you can rename the file to something different than "app.config" and keep the current property values for "Build Action" and "Copy to Output Directory".

like image 107
Rolo Avatar answered Sep 20 '22 11:09

Rolo


Add /p:AllowedReferenceRelatedFileExtensions=.pdb in the MSBuild parameters to suppress library project .config files, library xml docs, etc. With the above, only PDBs are retained.

This parameter can also be added to csproj files, but personally I find it easier to manage as part of the build configuration.

like image 27
Sorensen Avatar answered Sep 18 '22 11:09

Sorensen