7

我已经使用 EnvDTE 列出了我的解决方案中的所有项目,但我在代码中发现了一个错误:我无法获取已卸载的项目。

我找到了一种跳过卸载项目的方法:

if (string.Compare(EnvDTE.Constants.vsProjectKindUnmodeled, project.Kind, System.StringComparison.OrdinalIgnoreCase) == 0)
  continue;

这样,我的代码不会崩溃——但我无法通过代码加载缺失的项目,因为它们已经存在。

如何将卸载的项目加载到解决方案中?

我努力了:

project.DTE.ExecuteCommand("Project.ReloadProject");

并得到错误:

System.Runtime.InteropServices.COMException (...):命令“Project.ReloadProject”不可用。

所以我试图以某种方式得到

application.DTE.ExecuteCommand("Project.ReloadProject");

但在此之前,从我在 NET 上搜索的每个地方,我必须预先选择解决方案中的项目——为此,我需要project.Name(我有)和我不需要的路径(我有的每个示例found 假设解决方案路径与项目路径相同,这在一般情况下是极不可能的)。

4

1 回答 1

5

Visual Studio SDK 显然是做到这一点的方法。

var dte = (EnvDTE.DTE)System.Runtime.InteropServices.Marshal.GetActiveObject("VisualStudio.DTE");
Microsoft.VisualStudio.Shell.Interop.IVsUIHierarchyWindow hierarchy;
ServiceProvider sp = new ServiceProvider((Microsoft.VisualStudio.OLE.Interop.IServiceProvider)dte);
IVsSolution sol = (IVsSolution)sp.GetService(typeof(SVsSolution));

foreach (ProjInfo info in GetProjectInfo(sol))
{
    info.Dump();

}
//from http://social.msdn.microsoft.com/Forums/en-US/vsx/thread/60fdd7b4-2247-4c18-b1da-301390edabf3/
static IEnumerable<ProjInfo> GetProjectInfo(IVsSolution sol)
{
  Guid ignored = Guid.Empty;
  IEnumHierarchies hierEnum;
  if (ErrorHandler.Failed(sol.GetProjectEnum((int)__VSENUMPROJFLAGS.EPF_ALLPROJECTS, ref ignored, out hierEnum)))
  {
    yield break;
  }

  IVsHierarchy[] hier = new IVsHierarchy[1];
  uint fetched;
  while ((hierEnum.Next((uint)hier.Length, hier, out fetched) == VSConstants.S_OK) && (fetched == hier.Length))
  {
    int res = (int)VSConstants.S_OK;

    Guid projGuid;
    if (ErrorHandler.Failed(res = sol.GetGuidOfProject(hier[0], out projGuid)))
    {
        Debug.Fail(String.Format("IVsolution::GetGuidOfProject returned 0x{0:X}.", res));
        continue;
    }

    string uniqueName;
    if (ErrorHandler.Failed(res = sol.GetUniqueNameOfProject(hier[0], out uniqueName)))
    {
        Debug.Fail(String.Format("IVsolution::GetUniqueNameOfProject returned 0x{0:X}.", res));
        continue;
    }
    if( System.IO.Path.GetInvalidPathChars().Any (p =>uniqueName.Contains(p) ))
    {
        uniqueName.Dump("invalid filename found");
        yield return new ProjInfo(projGuid,uniqueName);
    } 
    else {
        yield return new ProjInfo(projGuid, Path.GetFileName(uniqueName).BeforeOrSelf("{"));
    }
  }
}

大部分来自http://social.msdn.microsoft.com/Forums/en-US/vsx/thread/60fdd7b4-2247-4c18-b1da-301390edabf3/

于 2013-01-09T21:08:57.820 回答