目前我有2个分支 - 开发和发布。
是否有可能获得从开发到发布的所有未合并更改集?
目前我们使用默认的Merge Wizzard。但是它有一个很大的限制 - 它不能被用户过滤。因此,我正在考虑构建一个应用程序,将所有未合并的变更集从开发转移到发布,并允许我按用户过滤这些变更集。
答案 0 :(得分:4)
您可以编写一个类似于此的小型控制台应用程序:
using System;
using Microsoft.TeamFoundation.Client;
using Microsoft.TeamFoundation.VersionControl.Client;
namespace UnmergedChangesets
{
class Program
{
static void Main(string[] args)
{
TfsTeamProjectCollection tpc = TfsTeamProjectCollectionFactory.GetTeamProjectCollection(new Uri("http://myserver:8080/collection"));
VersionControlServer vcs = (VersionControlServer) tpc.GetService(typeof (VersionControlServer));
MergeCandidate[] mergeCandidates = vcs.GetMergeCandidates("$/Development", "$/Release", RecursionType.Full);
}
}
}
通过这种方式,您可以mergeCandidates
进入Release
分支中缺少的所有变更集。
如果您想进一步过滤某个用户,可以使用以下内容进行过滤:
foreach (var mergeCandidate in mergeCandidates)
{
if(mergeCandidate.Changeset.Owner == @"DOMAIN\ChuckNorris")
{
//This is an unmerged changeset commited by Chuck
}
}
答案 1 :(得分:1)
如果您的标准窗口不符合您的需求,请查看codeproject。
有人做过这样的应用程序,所以你可以看看它是如何工作的
TFS 2010 SDK: Smart Merge - Programmatically Create your own Merge Tool
修改强>
我忘记了,我使用VS2010的这个项目模板