Из моего файла .csproj:
<Content Include="log4net.config">
<SubType>Designer</SubType>
</Content>
<Content Include="log4net.Release.config">
<DependentUpon>log4net.config</DependentUpon>
</Content>
<Content Include="log4net.Debug.config">
<DependentUpon>log4net.config</DependentUpon>
</Content>
<Content Include="log4net.Live.config">
<DependentUpon>log4net.config</DependentUpon>
</Content>
<Content Include="log4net.Demo.config">
<DependentUpon>log4net.config</DependentUpon>
</Content>
В нижней части моего файла .csproj:
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v10.0\WebApplications\Microsoft.WebApplication.targets" />
<Target Name="AfterCompile" Condition="exists('log4net.$(Configuration).config')">
<TransformXml Source="log4net.config"
Destination="$(IntermediateOutputPath)$(TargetFileName).config"
Transform="log4net.$(Configuration).config" />
<ItemGroup>
<AppConfigWithTargetPath Remove="log4net.config"/>
<AppConfigWithTargetPath Include="$(IntermediateOutputPath)$(TargetFileName).config">
<TargetPath>$(TargetFileName).config</TargetPath>
</AppConfigWithTargetPath>
</ItemGroup>
</Target>
Из log4net.config
<connectionString name="ConnName"
value="Data Source=localhost\sqlexpress;Initial Catalog=localdb;Persist Security Info=True;Integrated Security=SSPI;" />
Из log4net.Live.config (удаленные конфиденциальные данные)
<?xml version="1.0" encoding="utf-8"?>
<configuration xmlns:xdt="http://schemas.microsoft.com/XML-Document-Transform">
<connectionString name="ConnName" value="Data Source=127.0.0.1;Initial Catalog=DBName;Persist Security Info=True;User ID=userid;Password=pword"
providerName="System.Data.SqlClient" xdt:Transform="Replace" xdt:Locator="Match(name)" />
</configuration>
Я проверил вывод msbuild, и я вижу, что он правильно изменил мой web.config, но я не вижу выхода для его преобразования log4net. Кроме того, когда я проверяю файл log4net.config после публикации, у него есть исходная строка соединения.
Что я делаю неправильно:)?
Спасибо!
Обновление
У меня были некоторые ошибки в коде, который msbuild выводил как предупреждения, которые я не видел. Я исправил их, и теперь я получаю некоторый вывод от MSBuild:
AfterCompile: Преобразование источника Файл: log4net.config Применение файла преобразования: log4net.Live.config Выходной файл: obj\Live\Common.UI.Web.dll.config
Трансформация преуспела
Это все еще проблема, потому что файл должен иметь имя log4net.config, а не Common.UI.Web.dll.config...
По какой-либо причине
$(TargetFileName)
берет имя имени файла .csproj. Если я заменил его только log4net, то он правильно выйдет
Обновление
Файл застрял в папке obj и не публикуется при публикации.