让TFS忽略我的包裹文件夹


332

我正在尝试让TFS(2013)忽略我的packages文件夹。我非常希望在使用NuGet时不要控制它的源代码,这太好了!

我尝试了伪装(似乎不起作用),我尝试了添加.tfignore文件-不会忽略任何内容。为什么TFS团队不像许多Subversion客户端那样添加一个选项来永久忽略文件夹或文件?


您正在使用什么版本的TFS和Visual Studio?您正在使用本地工作区还是服务器工作区?
James Reed



1
您应该更改此问题的答案
Chris Marisic 2015年

3
如果您使用的是NuGet,则需要packages文件夹。您可以将NuGet设置为还原构建时丢失的二进制文件(以便您对软件包文件夹进行源控制,但忽略二进制文件)。-但是有一个问题:NuGet二进制文件有可能被更新(版本号未更改)或被删除等。-各种奇怪的奇怪事情都有可能发生。不要让您的构建遇到麻烦-检入整个package文件夹。您会省去很多麻烦。
BrainSlugs83

Answers:


497

解决方法是:我们必须告诉NuGet TFS都忽略软件包,因为NuGet试图做绝对不应该做的与源代码控制相关的事情(不好的形式,微软!)。因此,您必须做两件事。

首先,添加一个名为文件.tfignore到解决方案文件夹(注意缺少stf)。其内容应如下:

\packages

这告诉TFS忽略您的packages文件夹。现在,您会认为这也会忽略该repositories.config文件。但是不会。为什么?谁知道,微软的方式是奇怪而神秘的。实际上,我认为这是我在下面概述的NuGet内容的一部分,但是如果以后修复了该问题,并且您希望保留repositories.config文件而不是让VS重新生成它,则应该可以使用此文件:

\packages
!\packages\repositories.config

好的,现在感谢我们的.tfignore文件,TFS将忽略您的软件包。一切都很好,对吧?,因为NuGet正在与源代码管理混在一起,并将软件包添加到您的未决更改中。因此,现在让我们告诉NuGet已将其裁剪掉。

.nuget在解决方案文件夹的根目录中创建一个名为的文件夹。1现在,创建一个名为的文件NuGet.config,并将其放在此新文件夹2中。其内容应如下所示:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <solution>
    <add key="disableSourceControlIntegration" value="true" />
  </solution>
</configuration>

现在你的软件包应该留源失控。只需记住将NuGet.config.tfignore文件添加到源代码管理中,这样它们就不会丢失。

编辑:如果您遇到问题,则可能要删除您的packages文件夹,签入该更改,然后执行上述步骤。

还编辑:看来新的Nuget版本不会发生这种情况。因此,如果您切换到VS / TFS 2017,则可能会解决此问题,而不必跳过上面的说明。

1。使用源代码管理资源管理器添加文件夹;右键单击解决方案->添加文件夹->。nuget
2。当我使用VS 2013弄清楚这一点时,我发现NuGet.config必须放在.nuget文件夹中。即使您的解决方案文件夹的根目录中已经有一个NuGet.config文件(例如,由于您的公司具有内部nuget提要)。但是,其中的一些注释表明它在VS 2015的解决方案根目录中可以正常工作。就我个人而言,我切换到在git模式下使用TFS,因此无法测试。此外,如果您确实有一个自定义提要,请确保同时将自定义提要和nuget.org都作为Nuget.config文件中的键,否则TFS有时会随机决定它无法还原软件包。


1
我认为这至少需要TFS 2012。 stackoverflow.com/questions/14365929/...
ClearCloud8

2
@zespri哪个文件要删除?NuGet包?那不应该等待删除...应该删除!完成上述建议后,转到Team Explorer并删除可能已在源代码控制中的所有Nuget程序包。或者只是完全删除packages文件夹。我已经使用此设置几个月了,从未遇到该错误。
Pharylon

5
据透露在VS2015,nuget.config也没有必须在里面/.nuget/。它在解决方案的根目录下效果很好。
jnm2 2015年

141
对于想知道如何创建以句点开头的文件夹和文件的任何人,请以另一个句点结尾。因此将是.tfignore。和.nuget。
Derek Ziemba

16
@DerekZiemba整洁的把戏!这些年来,我一直在命令行中进行操作。我认为值得一提的是,当您执行此操作时,尾随“。”。将被删除,我起初以为您的建议是再加上一个'。最后。

53

上面的替代解决方案如下。

  • 将packages文件夹添加到TFS(不包含任何文件或子文件夹)
  • 右键单击“软件包”文件夹
  • 左键单击高级
  • 点击披风

值得注意的是,该解决方案将需要在每个TFS工作空间中应用。对于我来说,它比使用.tfignore文件更加可靠。

您可以在博客文章“ 阻止TFS将已安装的NuGet软件包添加到源代码管理”中阅读有关此方法的更多信息。


23

对于报告.tfignore选项不适用于nuget.config设置的人们,可能对此很感兴趣-这些步骤终于对我有用:

  1. 删除我的包裹文件夹中的所有内容
  2. 确保TFS在该文件夹附近没有任何更改
  3. 关闭VS
  4. 重新打开VS,并重新加载解决方案-使用Nuget restore重新填充程序包注意,TFS源代码管理没有任何更改待处理

3
在应用Pharylon的解决方案后,这对我有用,而在恢复软件包之后,我这样做了。
user849924

1
确实很有帮助,我们必须在初始时间(将.tfignore文件首次提交到TFS)中执行此操作,但不是每个人都这样做。如果我是正确的。
RajeshKdev

我认为这种方法仅适用于制造披风的机器。我是对的吗?因此,这并不能解决所有团队成员的根本问题。
panox

对此的一种变体对我起作用-我确保“软件包”中的任何内容都尚未提交,然后从磁盘中删除“软件包”目录。此时,它在VS团队资源管理器中仍显示为待处理的更改,因此我选择撤消包目录中待处理的更改。这清理了它(不需要我关闭/重新打开),并且它们没有回来=)
传真

8

在解决方案的.nuget文件夹中添加nuget.config文件。将以下内容添加到nuget.config文件中:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <solution>
    <add key="disableSourceControlIntegration" value="true" />
  </solution>
</configuration>

disableSourceControlIntegration是TFS版本控制的窍门。


无效-根本不是全局解决方案。
杰斯特2014年

@这么多哥布林:您是否在一个全新的项目/ sln上尝试过此方法?(仅用于检查)我很好奇您的设置中有什么使它不起作用,因为每次我自己做时它都起作用,这是使用TFS / nuget的推荐方式。另外,您看到哪个版本的VS / TFS?
TerjeSandstrøm2015年

Visual Studio2013。新的解决方案,是的。我解决了此问题,添加了一个.tfignore,显式地忽略了每个程序包。
这么多地精2015年

2
好的,这实际上是“启用NuGet软件包还原”的功能。只要确保关闭并重新打开您的解决方案即可!仅在打开解决方案时才会读取NuGet.config文件。
Heliac'3

在Visual Studio Online和VS2013上,这对我不起作用。我使用了右键单击解决方案>启用NuGet软件包还原。这会将Nuget.config文件添加到解决方案根目录。.tfignore。我通常通过在解决方案的根目录中添加一个文本文件来做到这一点,让它检测到该问题,然后通过单击“检测到的添加”>右键单击忽略来排除。然后检入所有内容,包括所有软件包,然后删除解决方案中的所有软件包并进行此更改(这将从TFS中删除软件包)。打开解决方案并进行构建,以添加软件包,但TFS不会提取它们。
大卫·威尔顿

7

您需要使用本地工作区.tfignore才能工作。该.tfignore文件必须位于包含要忽略的文件或文件夹的文件夹中。

因此,如果您的解决方案结构如下所示:

\Project
   \Packages
   \OtherStuff
   foo.cs

您将.tfignore文件放在\ Project中:

\Project
   \Packages
   \OtherStuff
   foo.cs
   .tfignore

您的情况下.tfignore的内容为:

\packages

这是为您提供的一些文档:http : //msdn.microsoft.com/library/vstudio/ms245454(v=vs.110).aspx#tfignore


2
我已经添加了.tfignore文件,并且在构建项目时,它仍在尝试向tfs中添加软件包。我似乎无能为力了。
马特

您可以发布添加的忽略文件吗?
MrHinsh-Martin Hinshelwood 2014年

2
请参阅docs.nuget.org/docs/reference/package-restore-with-team-build-这是一个带有.tfignore的NuGet错误,但可以通过指示NuGet自行进行SCM集成来纠正。
user2864740 2014年

1
看来您的榜样可能是错误的,它认为应该是相对的packages而不是\packages
马丁

6

您可以AppData\Roaming为所有解决方案(新旧)永久设置一次。

%AppData%\NuGet\NuGet.Config文件中,在</configuration>XML标签之前添加以下内容...

<config>
  <add key="repositoryPath" value="C:\NuGetPackages" />
</config>
<solution>
  <add key="disableSourceControlIntegration" value="true" />
</solution>

...您可以指定所需的任何路径-重要的是将其放置在TFS工作空间之外!

现在,您不必再担心这些东西。您的解决方案文件夹将不再包含任何软件包。所有解决方案将默认使用您的自定义软件包位置。

注意-此功能基于每个用户。


1
听起来不错,可能更简单。如果采用这种方法,您确实必须在整个团队中强制执行此设置,尤其是构建服务器的登录/设置。
克里斯·卡罗尔

我会这样想。抱歉,我尚未测试此WRT构建服务器。我也可以想象到lib文件夹的不同文件夹路径可能会引起问题(如果我记得正确的话,我认为某些NuGet软件包对lib路径具有硬引用)。
希里亚克

2

将您的解决方案设置为在构建时还原,软件包文件夹和软件包文件将被检入,但软件包不会被检入。


1
请说明“在构建时还原”。
user2864740 2014年

10
从NuGet 2.7开始,不建议使用Visual Studio右键单击“启用NuGet软件包还原”功能-TFS 2013本机支持在没有NuGet.targets文件和proj文件的修改的情况下还原NuGet软件包。
丹尼尔·曼

1

如果将Git与TFS一起使用,则需要添加“ .gitignore”文件。您可以在“团队项目|设置|'添加忽略文件'”中执行此操作。然后打开文件并取消注释Nuget Packages的内置ignore语句。

如果您使用的是TFVC,并且配置了本地工作区,则可以使用“ .tfignore”文件,该文件采用与Git文件相同的格式。我认为您需要“ packages /”。


我们使用了TFSVC,并且正如在最初的帖子中已经提到的-.tfignore文件不起作用。
杰斯特2014年

正如我所说,您需要使用正确的.tfignore格式。我相信您的做法是错误的斜线
MrHinsh-Martin Hinshelwood 2014年

@MrHinsh与Ed Thompson交谈后,.tfignore文件无法正常工作。.gitignore可以。
DaveShaw 2014年

@Ed需要解决这个问题;)
MrHinsh-Martin Hinshelwood 2014年

1

在Visual Studio Online和VS2013上,这对我不起作用。

  • 右键单击解决方案>启用NuGet软件包还原。这会将Nuget.config文件添加到解决方案中

在此处输入图片说明

  • 添加.tfignore。我通常通过在解决方案的根目录中添加一个文本文件来做到这一点,让它检测到该问题,然后通过单击“检测到的添加”>右键单击忽略来排除。

在此处输入图片说明

  • 将软件包添加到.tfignore,并告诉它包括repositories.config

在此处输入图片说明

从其他评论看来,此时您的里程可能有所不同。这是我的工作:

  • 检查所有内容,包括所有软件包。

  • 删除解决方案中的所有软件包,然后签入此更改(这将从TFS中删除软件包)

  • 打开解决方案并进行构建,这会将软件包添加到项目中,但是TFS不会将其提取。


2
首先,Enable Nuget restore已弃用,如果您稍后再选择该路线,则在VS 2015中不可用。第二:检入其中的软件包和dll将把它们添加到源代码管理中,在解决方案中将其删除,并检入in不会将它们从SC中删除,仅从分支的顶端即可。–
TerjeSandstrøm2015年

1
@TerjeSandstrøm要点,但问题仅针对2013。是的,您是对的,您必须使用tf destroy将其从源代码管理中永久删除,但是我发现没有其他方法可以使TFS遵守.tfignore文件
大卫·威尔顿(David Wilton)

1

对我有用的解决方案是在Nuget.Config中创建.tfignore 以下设置:

<configuration>
  ...
  <solution>
    <add key="disableSourceControlIntegration" value="true" />
  </solution>  
  ...
</configuration>

我的.tfignore包含以下行:

\packages

[我正在使用Visual Studio 2015 Update 2]

这不是理想的,并且当前在github / nuget上记录为一个未解决的问题:

使从TFVC#493省略软件包更容易


0

Terje的答案并非一直都对我有用,有时会持续一会儿,但随后又会给我带来很多“增加”的负担。

我找到永久解决此问题的唯一方法是在Workspace中隐藏“ packages”文件夹。

例如:

Type      Server                Local
============================================
Active    $/Work/Main           C:\Code\Main
Cloaked   $/Work/Main/Packages

那太奇怪了。最新的Visual Studio和NuGet版本会发生这种情况吗?
2014年

是的,我在TFS 2012本地工作区上运行VS 2013.4和NuGet 2.8。
DaveShaw 2014年

您必须掩盖每个程序包文件夹才能获得数十个项目和污染。此外,团队中的每个成员都必须对每个工作区重复该过程
Jaster 2014年

斗篷不是一个好的答案,上面的其他两个答案是设计使然的。您的环境中肯定还有其他情况。
MrHinsh-Martin Hinshelwood 2014年

@MrHinsh-部门中的许多人都已经看过了,它已经坏了。使用Git似乎还可以,但是在使用TFVC时,它总是会这样做。
DaveShaw 2014年

0

我遇到过同样的问题。/packages应该可以,但是对我不适合。packages*.*做过。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.