繁体   English   中英

将Visual Studio解决方案的构建顺序输出到文本文件

[英]Output Build Order of Visual Studio solution to a text file

有没有办法通过命令行将构建命令输出到文本文件?

解释:我们使用多个源分支,每个分支上都有100多个项目的大型解决方案。 我需要编写构建脚本以从命令行构建这些解决方案。 然后,我们可以在分支机构上定制解决方案,以仅获取团队正在从事的项目的项目参考。 我希望这会大大增加解决方案的加载时间,并减轻开发人员和我的挫败感,我希望:)

我将继续寻找,也许会使用VS提供的C#和API。 我们正在使用2012更新1。

这是Visual Studio插件项目的理想选择。

  1. 创建一个新的Visual Studio外接程序项目。
  2. 确保在项目创建向导中,在“ 选择加载项选项”步骤中选择以下配置(其他步骤并不重要,我假设您将使用C#):

在此处输入图片说明

  1. Connect.cs文件中,添加以下字段:

     private BuildEvents _buildEvents; private Events _events; private bool buildEventConnected = false; 
  2. 并相应地添加/修改这些方法:

     public void OnConnection(object application, ext_ConnectMode connectMode, object addInInst, ref Array custom) { _applicationObject = (DTE2)application; _addInInstance = (AddIn)addInInst; _events = _applicationObject.Events; _buildEvents = _events.BuildEvents; if (connectMode != ext_ConnectMode.ext_cm_UISetup && !buildEventConnected) { _buildEvents.OnBuildDone += new _dispBuildEvents_OnBuildDoneEventHandler(BuildEvents_OnBuildDone); buildEventConnected = true; } } private void BuildEvents_OnBuildDone(vsBuildScope Scope, vsBuildAction Action) { const string BUILD_OUTPUT_PANE_GUID = "{1BD8A850-02D1-11D1-BEE7-00A0C913D1F8}"; TextDocument txtOutput = default(TextDocument); TextSelection txtSelection = default(TextSelection); Window vsWindow = default(Window); vsWindow = _applicationObject.Windows.Item(EnvDTE.Constants.vsWindowKindOutput); OutputWindow vsOutputWindow = default(OutputWindow); OutputWindowPane objBuildOutputWindowPane = default(OutputWindowPane); vsOutputWindow = (OutputWindow)vsWindow.Object; foreach (OutputWindowPane objOutputWindowPane in vsOutputWindow.OutputWindowPanes) { if (objOutputWindowPane.Guid.ToUpper() == BUILD_OUTPUT_PANE_GUID) { objBuildOutputWindowPane = objOutputWindowPane; break; } } txtOutput = objBuildOutputWindowPane.TextDocument; txtSelection = txtOutput.Selection; txtSelection.StartOfDocument(false); txtSelection.EndOfDocument(true); objBuildOutputWindowPane.OutputString(System.DateTime.Now.ToString()); txtSelection = txtOutput.Selection; var solutionDir = System.IO.Path.GetDirectoryName(_applicationObject.Solution.FullName); System.IO.File.WriteAllText(solutionDir + "\\\\build_output.log", txtSelection.Text); } public void OnDisconnection(ext_DisconnectMode disconnectMode, ref Array custom) { if (buildEventConnected) { _buildEvents.OnBuildDone -= new _dispBuildEvents_OnBuildDoneEventHandler(BuildEvents_OnBuildDone); buildEventConnected = false; } } 

就这样,在每个构建中,您都将输出发送到解决方案文件夹中的build_output.log文件。

快速的方法是执行“清理解决方案”,以便您可以在构建日志中看到倒序的顺序。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM