Eu vim aqui de outra pergunta (marcada como duplicada) sobre como adicionar a marca de análise ao arquivo App.Config.
Quero adicionar uma nota lateral a isso - o Visual Studio já gerou um arquivo App.config, no entanto, a adição da marca de análise à marca de tempo de execução pré-gerado não funcionou! você precisa de uma tag de tempo de execução separada com a tag de análise incluída. Em resumo, seu App.Config deve ficar assim:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.7.2" />
</startup>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="System.Text.Encoding.CodePages" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-4.1.1.0" newVersion="4.1.1.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
<!-- Discover assemblies in /lib -->
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<probing privatePath="lib" />
</assemblyBinding>
</runtime>
</configuration>
Demorou algum tempo para descobrir, então estou postando aqui. Também créditos para o pacote PrettyBin NuGet . É um pacote que move as DLLs automaticamente. Eu gostei de uma abordagem mais manual, por isso não a usei.
Além disso - aqui está um script de pós-compilação que copia todos os arquivos .dll / .xml / .pdb para / Lib. Isso organiza a pasta / debug (ou / release), o que eu acho que as pessoas tentam alcançar.
:: Moves files to a subdirectory, to unclutter the application folder
:: Note that the new subdirectory should be probed so the dlls can be found.
SET path=$(TargetDir)\lib
if not exist "%path%" mkdir "%path%"
del /S /Q "%path%"
move /Y $(TargetDir)*.dll "%path%"
move /Y $(TargetDir)*.xml "%path%"
move /Y $(TargetDir)*.pdb "%path%"