NuGetPackageImportStamp project property

This commit is contained in:
juste 2014-03-07 16:17:31 -08:00
Родитель 3fc9e44b50
Коммит c1fd93208e
2 изменённых файлов: 35 добавлений и 1 удалений

Просмотреть файл

@ -60,6 +60,9 @@ namespace NuGet.VisualStudio
Project, Project,
Project.ToVsHierarchy(), Project.ToVsHierarchy(),
buildProject => NuGet.MSBuildProjectUtility.AddImportStatement(buildProject, relativeTargetPath, location)); buildProject => NuGet.MSBuildProjectUtility.AddImportStatement(buildProject, relativeTargetPath, location));
// notify the project system of the change
UpdateImportStamp(Project);
} }
public override void RemoveImport(string targetPath) public override void RemoveImport(string targetPath)
@ -98,6 +101,9 @@ namespace NuGet.VisualStudio
Project, Project,
Project.ToVsHierarchy(), Project.ToVsHierarchy(),
buildProject => NuGet.MSBuildProjectUtility.RemoveImportStatement(buildProject, relativeTargetPath)); buildProject => NuGet.MSBuildProjectUtility.RemoveImportStatement(buildProject, relativeTargetPath));
// notify the project system of the change
UpdateImportStamp(Project);
} }
} }
} }

Просмотреть файл

@ -8,7 +8,9 @@ using System.Linq;
using System.Reflection; using System.Reflection;
using System.Runtime.Versioning; using System.Runtime.Versioning;
using EnvDTE; using EnvDTE;
using Microsoft.VisualStudio;
using Microsoft.VisualStudio.Shell; using Microsoft.VisualStudio.Shell;
using Microsoft.VisualStudio.Shell.Interop;
using NuGet.VisualStudio.Resources; using NuGet.VisualStudio.Resources;
using MsBuildProject = Microsoft.Build.Evaluation.Project; using MsBuildProject = Microsoft.Build.Evaluation.Project;
using MsBuildProjectItem = Microsoft.Build.Evaluation.ProjectItem; using MsBuildProjectItem = Microsoft.Build.Evaluation.ProjectItem;
@ -392,7 +394,11 @@ namespace NuGet.VisualStudio
string relativeTargetPath = PathUtility.GetRelativePath(PathUtility.EnsureTrailingSlash(Root), targetPath); string relativeTargetPath = PathUtility.GetRelativePath(PathUtility.EnsureTrailingSlash(Root), targetPath);
Project.AddImportStatement(relativeTargetPath, location); Project.AddImportStatement(relativeTargetPath, location);
Project.Save(this); Project.Save(this);
// notify the project system of the change
UpdateImportStamp(Project);
} }
public virtual void RemoveImport(string targetPath) public virtual void RemoveImport(string targetPath)
@ -404,6 +410,9 @@ namespace NuGet.VisualStudio
string relativeTargetPath = PathUtility.GetRelativePath(PathUtility.EnsureTrailingSlash(Root), targetPath); string relativeTargetPath = PathUtility.GetRelativePath(PathUtility.EnsureTrailingSlash(Root), targetPath);
Project.RemoveImportStatement(relativeTargetPath); Project.RemoveImportStatement(relativeTargetPath);
Project.Save(this); Project.Save(this);
// notify the project system of the change
UpdateImportStamp(Project);
} }
public virtual bool IsSupportedFile(string path) public virtual bool IsSupportedFile(string path)
@ -470,6 +479,25 @@ namespace NuGet.VisualStudio
return y.Path.CompareTo(x.Path); return y.Path.CompareTo(x.Path);
} }
/// <summary>
/// Sets NuGetPackageImportStamp to a new random guid. This is a hack to let the project system know it is out of date.
/// The value does not matter, it just needs to change.
/// </summary>
protected static void UpdateImportStamp(Project project)
{
// There is no reason to call this for pre-Dev12 project systems.
if (VsVersionHelper.IsVisualStudio2013)
{
IVsBuildPropertyStorage propStore = project.ToVsHierarchy() as IVsBuildPropertyStorage;
if (propStore != null)
{
// <NuGetPackageImportStamp>af617720</NuGetPackageImportStamp>
string stamp = Guid.NewGuid().ToString().Split('-')[0];
ErrorHandler.ThrowOnFailure(propStore.SetPropertyValue("NuGetPackageImportStamp", string.Empty, (uint)_PersistStorageType.PST_PROJECT_FILE, stamp));
}
}
}
private static void TrySetCopyLocal(dynamic reference) private static void TrySetCopyLocal(dynamic reference)
{ {
// Always set copy local to true for references that we add // Always set copy local to true for references that we add