Вам нужно будет использовать VersionControlServer.QueryHistory
способом, аналогичным следующему.Обратите особое внимание на SlotMode
, который должен быть false
для того, чтобы последовали переименования.
private static void PrintNames(VersionControlServer vcs, Change change)
{
//The key here is to be sure Slot Mode is enabled.
IEnumerable<Changeset> queryHistory =
vcs.QueryHistory(
new QueryHistoryParameters(change.Item.ServerItem, RecursionType.None)
{
IncludeChanges = true,
SlotMode = false,
VersionEnd = new ChangesetVersionSpec(change.Item.ChangesetId)
});
string name = string.Empty;
var changes = queryHistory.SelectMany(changeset => changeset.Changes);
foreach (var chng in changes)
{
if (name != chng.Item.ServerItem)
{
name = chng.Item.ServerItem;
Console.WriteLine(name);
}
}
}
РЕДАКТИРОВАТЬ: Переместил другойрешение вверх.Дальнейшее сработало, когда я тестировал чистое изменение Rename, но сломалось, когда я устал от изменений Rename и Edit.
Это, вероятно, самый эффективный способ получить предыдущее имя.Хотя он работает (API TFS2013 против установки TFS2012), для меня это выглядит как ошибка.
private static string GetPreviousServerItem(VersionControlServer vcs, Item item)
{
Change[] changes = vcs.GetChangesForChangeset(
item.ChangesetId,
includeDownloadInfo: false,
pageSize: int.MaxValue,
lastItem: new ItemSpec(item.ServerItem, RecursionType.None));
string previousServerItem = changes.Single().Item.ServerItem;
//Yep, this passes
Trace.Assert(item.ServerItem != previousServerItem);
return previousServerItem;
}
он будет использоваться как:
if (change.ChangeType.HasFlag(ChangeType.Rename))
{
string oldServerPath = GetPreviousServerItem(vcs, change.Item);
// ...
}