VS 2008 Package 备忘

    今天研究了一下vs 2008 package的部署,即怎样放置package中的dll、ProjectTemplate和ItemTemplate,趁着热乎劲先记录下来,免得以后忘记。

    首先,创建一个简单的package,供测试之用。

    打开visual studio 2008,新建项目,选择其他项目类型->扩展性->Visual Studio Integration Package,输入项目名称为DeployPackage,如下图:

image

    点击确定后,弹出创建package的向导,选择C#作为开发语言,选中Menu Command。如下两图:

   image

    image

    完成向导后,vs帮我们创建了空的package项目,如下图:

    image

    双击Guids.cs文件,添加一个guid,作为接下来要创建的ProjectFactory的guid,修改后的Guids.cs文件如下:

   1: using System;
   2:  
   3: namespace Company.DeployPackage
   4: {
   5:     static class GuidList
   6:     {
   7:         public const string guidDeployPackagePkgString = "bad3390c-b2a2-4bfc-a3ad-87e8119df413";
   8:         public const string guidDeployPackageCmdSetString = "b09083be-4856-4364-8bb1-243d133c7177";
   9:  
  10:  
  11:         //该Guid为接下来要创建的ProjectFactory的guid
  12:         public const string guidDixProjectFactoryString = "9819EC75-61CC-468c-9823-E853AEE0FE8C";
  13:  
  14:         public static readonly Guid guidDeployPackageCmdSet = new Guid(guidDeployPackageCmdSetString);
  15:     };
  16: }

 

    新增一个ProjectFactory,名为DixProjectFactory,如下:

   1: using System;
   2: using System.Runtime.InteropServices;
   3: using Microsoft.VisualStudio.Project;
   4: using IOleServiceProvider = Microsoft.VisualStudio.OLE.Interop.IServiceProvider;
   5:  
   6: namespace Company.DeployPackage
   7: {
   8:     //注意这个guid
   9:     [Guid(GuidList.guidDixProjectFactoryString)]
  10:     public class DixProjectFactory : ProjectFactory
  11:     {        
  12:         public DixProjectFactory(DeployPackagePackage package)
  13:             : base(package)
  14:         {
  15:         }
  16:  
  17:         protected override ProjectNode CreateProject()
  18:         {
  19:             DixProjectNode node = new DixProjectNode();
  20:             node.SetSite((IOleServiceProvider)((IServiceProvider)Package).GetService(typeof(IOleServiceProvider)));
  21:             return node;
  22:         }
  23:     }
  24: }

    注意DixProjectFactory的Guid就是刚刚在Guids.cs文件中的那个Guid。

    注意:需要下载MPFProjectBase才能使用ProjectFactory,以及下面的ProjectNode、ProjectPackage

    新增一个ProjectNode类,名为DixProjectNode,如下:

   1: using System;
   2: using Microsoft.VisualStudio.Project;
   3:  
   4: namespace Company.DeployPackage
   5: {
   6:     public class DixProjectNode : ProjectNode
   7:     {
   8:         /// <summary>
   9:         /// 返回DixProjectFactory的Guid
  10:         /// </summary>
  11:         public override Guid ProjectGuid
  12:         {
  13:             get { return typeof(DixProjectFactory).GUID; }
  14:         }
  15:  
  16:         public override string ProjectType
  17:         {
  18:             get { return "Dix"; }
  19:         }
  20:     }
  21: }

    修改DeployPackagePackage类,使它继承于ProjectPackage(原来是继承与Package的),并添加一个ProvideProjectFactoryAttribute,如下:

   1: ...
   2: [ProvideProjectFactory(typeof(DixProjectFactory), "我的dix项目", "Dix Project Files (*.dixproj);*.dixproj", "dixproj", "dixproj", "", LanguageVsTemplate = "DiX")]
   3: public sealed class DeployPackagePackage : ProjectPackage
   4: {
   5:     ...
   6: }

    修改DeployPackagePackage类的Initialize方法,添加RegisterProjectFactory(new DixProjectFactory(this))语句,修改后的Initialize方法如下:

   1: protected override void Initialize()
   2: {
   3:     Trace.WriteLine (string.Format(CultureInfo.CurrentCulture, "Entering Initialize() of: {0}", this.ToString()));
   4:     base.Initialize();
   5:  
   6:     // Add our command handlers for menu (commands must exist in the .vsct file)
   7:     OleMenuCommandService mcs = GetService(typeof(IMenuCommandService)) as OleMenuCommandService;
   8:     if ( null != mcs )
   9:     {
  10:         // Create the command for the menu item.
  11:         CommandID menuCommandID = new CommandID(GuidList.guidDeployPackageCmdSet, (int)PkgCmdIDList.cmdidMyCommand);
  12:         MenuCommand menuItem = new MenuCommand(MenuItemCallback, menuCommandID );
  13:         mcs.AddCommand( menuItem );
  14:     }
  15:  
  16:     //注册ProjectFactory
  17:     RegisterProjectFactory(new DixProjectFactory(this));
  18: }

    下面为该package添加ProjectTemplate和ItemTemplate。

    添加Templates、Projects、Items等文件夹和文件,添加后如下图:

    F([WRLT3[I0@TNJ4{8DGVA4

    注意这里面的cs文件需要改一下Build Action,否则编译不过。也可以把这堆文件的Build Action设置成ZipProject和ZipItem,但为了更加清楚模板的部署方式,我只是把他们的Build Action设置成了None。

    Projects文件夹中放置Project模板,Items文件夹中放置ProjectItem模板。

    Project模板以WinForm为例,要注意WinForm.vstemplate文件,该文件的定义如下:


    ProjectItem模板以Class为例,要注意Class.vstemplate文件,该文件的定义如下:


    在这两个vstemplate文件里,ProjectType要和DeployPackagePackage类声明中的ProvideProjectFactoryAttribute标记的LanguageVsTemplate相同,即都要是“Dix”。其他的文件是随便写的,里面的内容对于本次测试并不重要。

    好了,用于测试的Package已经做完了,编译成功后,下面开始测试如何在vs 2008里应用它。

1.在visual studio Experimental hive中测试

    在visual studio Experimental hive中测试比较简单,不需要再手动注册package了,因为我们的Package项目在编译成功后已经被自动注册到visual studio Experimental hive中了。编译时的输出片段如下:

   1: f:\Microsoft Visual Studio 2008 SDK\VisualStudioIntegration\Tools\bin\RegPkg.exe /root:Software\Microsoft\VisualStudio\9.0Exp "/pkgdeffile:obj\Debug\DeployPackage.pkgdef" "D:\DeployPackage\DeployPackage\bin\Debug\DeployPackage.dll" 
   2: f:\Microsoft Visual Studio 2008 SDK\VisualStudioIntegration\Tools\bin\RegPkg.exe /root:Software\Microsoft\VisualStudio\9.0Exp /ranu /codebase "D:\DeployPackage\DeployPackage\bin\Debug\DeployPackage.dll" 
   3: C:\Program Files\Microsoft Visual Studio 9.0\Common7\IDE\devenv.com /rt "Software\Microsoft\VisualStudio\9.0Exp" /RANU /setup /nosetupvstemplates 

    前两句执行完之后,在注册表的HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\9.0Exp\Configuration\InstalledProducts下可以看到该package的名称,在HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\9.0Exp\Configuration\Packages可以看到以该package的GUID为名的子项,在Projects,Menus等目录下也可以找到该package的信息。

    编译成功后,点击开始菜单,依次选择所有程序,Microsoft Visual Studio 2008 SDK,Tools,Start Microsoft Visual Studio 2008 SP1 under Experimental hive打开visual studio Experimental hive,可以看到在工具菜单下已经有了我们的package中的Menu Command,但是新建一个项目的时候,并没有出现我们的项目模板。这是因为我们并没有把模板部署到vs。

    注意上面的编译时输出的第3句C:\Program Files\Microsoft Visual Studio 9.0\Common7\IDE\devenv.com /rt "Software\Microsoft\VisualStudio\9.0Exp" /RANU /setup /nosetupvstemplates,这句命令最后有个/nosetupvstemplates的开关,意思是不需要安装vstemplate。编译package自动加上这个开关的原因是vs并不知道我们的package中存在template,如果我们把上面那堆模板文件设置成ZipProject或者ZipItem的话,vs在编译这个package的时候,就不会自动加这个开关了,这样编译后,模板就会自动拷贝到vs识别的目录里。

    由于我并没有设置Build Action为ZipProject或者ZipItem,所以现在要手动的去压缩模板:

    将Project模板分别压缩成WinForm.zip和ConsoleApp.zip,在C:\Documents and Settings\User Name\Application Data\Microsoft\VisualStudio\9.0Exp\ProjectTemplates\下建立Dix目录,并在Dix目录下建立Windows和控制台两个子目录,把WinForm.zip和ConsoleApp.zip分别放到这两个目录下。

    将ProjectItem模板分别压缩成WinForm.zip和Class.zip,在C:\Documents and Settings\kongxiangxin\Application Data\Microsoft\VisualStudio\9.0Exp\ItemTemplates下建立Dix目录,并在Dix目录下建立Windows Form和代码两个子目录,把WinForm.zip和Class.zip分别放到这两个目录下。

    注意,在压缩成zip文件的时候,只压缩文件,不要把文件夹整个压缩。

    运行"C:\Program Files\Microsoft Visual Studio 9.0\Common7\IDE\devenv.com" /rt "Software\Microsoft\VisualStudio\9.0Exp" /RANU /installvstemplates,等这条命令运行成功后,启动visual studio Experimental hive,新建项目,可以看到项目模板已经出现在新建项目对话框里了。

 image

    新建一个Dix WinForm Application的项目,然后添加新项,可以看到项模板出现在添加新项对话框里:

image

2.在visual studio中测试

    在visual studio里测试需要自己运行命令去注册package,可以参考package编译时执行的命令,把root参数和ranu参数去掉就可以了:

   1: f:\Microsoft Visual Studio 2008 SDK\VisualStudioIntegration\Tools\bin\RegPkg.exe /codebase "D:\DeployPackage\DeployPackage\bin\Debug\DeployPackage.dll" 
   2:  
   3: C:\Program Files\Microsoft Visual Studio 9.0\Common7\IDE\devenv.com /setup

    后记:完成这篇文章的时候,已经离开始写这篇文章有两个星期的时间了。一开始是没有时间写,拖的久了也就不想写了。所以后面的内容写的不够详细。

原文地址:https://www.cnblogs.com/default/p/1652669.html