2014-07-22 56 views
1

我想使用MSBuild Copy任務將由我的構建創建的二進制文件複製到某個文件夾。不幸的是,這個過程無聲無息地失敗了。沒有錯誤信息發出並且沒有文件被複制。爲什麼MSBuild的複製任務不能複製?

這裏是我的.csproj文件的相關部分:

<Target Name="CopyFilesForModule" AfterTargets="AfterBuild"> 
    <CreateItem Include="bin\**\*.*" Exclude="bin\**\*.pdb;bin\**\*.xml"> 
    <Output TaskParameter="Include" ItemName="MySourceFiles" /> 
    </CreateItem> 
    <Copy SourceFiles="$(MySourceFiles)" DestinationFolder="Areas\KoobooModule7\bin"> 
    <Output 
      TaskParameter="CopiedFiles" 
      ItemName="Changed" /> 
    </Copy> 
    <Message Text="sourcefiles: @(MySourceFiles)" /> 
    <Message Text="changed:@(Changed)" Importance="high" /> 
</Target> 

正如你可以看到我已經添加了消息調試。我打電話的MSBuild使用以下命令行:

"c:\Program Files (x86)\MSBuild\12.0\Bin\MSBuild.exe" /t:rebuild /verbosity:d 
iag KoobooModule7.csproj > buildlog.txt

這裏是我的構建日誌的相關摘錄:

Target "CopyFilesForModule: (TargetId:75)" in project "C:\Users\chris\Documents\Visual Studio 2013\Projects\KoobooModule7\KoobooModule7\KoobooModule7.csproj" (target "Build" depends on it): 
Task "CreateItem" (TaskId:43) 
    Task Parameter:Include=bin\**\*.* (TaskId:43) 
    Task Parameter: 
     Exclude= 
      bin\**\*.pdb 
      bin\**\*.xml (TaskId:43) 
Done executing task "CreateItem". (TaskId:43) 
Task "Copy" (TaskId:44) 
    Task Parameter:DestinationFolder=Areas\KoobooModule7\bin (TaskId:44) 
Done executing task "Copy". (TaskId:44) 
Task "Message" (TaskId:45) 
    Task Parameter:Text=sourcefiles: bin\CookComputing.XmlRpcV2.dll;bin\DiffPlex.dll;bin\dotless.Core.dll;bin\DotNetOpenAuth.AspNet.dll;bin\DotNetOpenAuth.Core.dll;bin\DotNetOpenAuth.OAuth.Consumer.dll;bin\DotNetOpenAuth.OAuth.dll;bin\DotNetOpenAuth.OpenId.dll;bin\DotNetOpenAuth.OpenId.RelyingParty.dll;bin\HtmlAgilityPack.dll;bin\Ionic.Zip.Reduced.dll;bin\Kooboo.CMS.Account.dll;bin\Kooboo.CMS.Caching.dll;bin\Kooboo.CMS.Common.dll;bin\Kooboo.CMS.Common.Runtime.Dependency.Ninject.dll;bin\Kooboo.CMS.Content.dll;bin\Kooboo.CMS.Form.dll;bin\Kooboo.CMS.Membership.dll;bin\Kooboo.CMS.Search.dll;bin\Kooboo.CMS.Sites.dll;bin\Kooboo.CMS.Sites.TemplateEngines.Razor.dll;bin\Kooboo.CMS.Web.dll;bin\Kooboo.dll;bin\KoobooModule7.dll;bin\KoobooModule7.dll.config;bin\Lucene.Net.Contrib.Highlighter.dll;bin\Lucene.Net.dll;bin\Microsoft.Web.Infrastructure.dll;bin\Mono.Math.dll;bin\Newtonsoft.Json.dll;bin\Ninject.dll;bin\NuGet.Core.dll;bin\Org.Mentalis.Security.Cryptography.dll;bin\System.Net.Http.dll;bin\System.Web.Helpers.dll;bin\System.Web.Mvc.dll;bin\System.Web.Razor.dll;bin\System.Web.WebPages.Administration.dll;bin\System.Web.WebPages.Deployment.dll;bin\System.Web.WebPages.dll;bin\System.Web.WebPages.Razor.dll (TaskId:45) 
    sourcefiles: bin\CookComputing.XmlRpcV2.dll;bin\DiffPlex.dll;bin\dotless.Core.dll;bin\DotNetOpenAuth.AspNet.dll;bin\DotNetOpenAuth.Core.dll;bin\DotNetOpenAuth.OAuth.Consumer.dll;bin\DotNetOpenAuth.OAuth.dll;bin\DotNetOpenAuth.OpenId.dll;bin\DotNetOpenAuth.OpenId.RelyingParty.dll;bin\HtmlAgilityPack.dll;bin\Ionic.Zip.Reduced.dll;bin\Kooboo.CMS.Account.dll;bin\Kooboo.CMS.Caching.dll;bin\Kooboo.CMS.Common.dll;bin\Kooboo.CMS.Common.Runtime.Dependency.Ninject.dll;bin\Kooboo.CMS.Content.dll;bin\Kooboo.CMS.Form.dll;bin\Kooboo.CMS.Membership.dll;bin\Kooboo.CMS.Search.dll;bin\Kooboo.CMS.Sites.dll;bin\Kooboo.CMS.Sites.TemplateEngines.Razor.dll;bin\Kooboo.CMS.Web.dll;bin\Kooboo.dll;bin\KoobooModule7.dll;bin\KoobooModule7.dll.config;bin\Lucene.Net.Contrib.Highlighter.dll;bin\Lucene.Net.dll;bin\Microsoft.Web.Infrastructure.dll;bin\Mono.Math.dll;bin\Newtonsoft.Json.dll;bin\Ninject.dll;bin\NuGet.Core.dll;bin\Org.Mentalis.Security.Cryptography.dll;bin\System.Net.Http.dll;bin\System.Web.Helpers.dll;bin\System.Web.Mvc.dll;bin\System.Web.Razor.dll;bin\System.Web.WebPages.Administration.dll;bin\System.Web.WebPages.Deployment.dll;bin\System.Web.WebPages.dll;bin\System.Web.WebPages.Razor.dll (TaskId:45) 
Done executing task "Message". (TaskId:45) 
Task "Message" (TaskId:46) 
    Task Parameter:Text=changed: (TaskId:46) 
    Task Parameter:Importance=high (TaskId:46) 
    changed: (TaskId:46) 
Done executing task "Message". (TaskId:46) 
Done building target "CopyFilesForModule" in project "KoobooModule7.csproj".: (TargetId:75)

正如你所看到的,要複製的文件已被正確識別,而複製的文件是空的。我怎樣才能找出複製過程失敗的原因?

回答

2

您沒有引用複製任務中的MySourceFiles項目,而是MySourceFiles屬性。

<Copy SourceFiles="$(MySourceFiles)" DestinationFolder="Areas\KoobooModule7\bin"> 

應該

<Copy SourceFiles="@(MySourceFiles)" DestinationFolder="Areas\KoobooModule7\bin"> 
相關問題