| Index: tools/win/ChromeDebug/ChromeDebug/ChromeDebugPackage.cs
|
| diff --git a/tools/win/ChromeDebug/ChromeDebug/ChromeDebugPackage.cs b/tools/win/ChromeDebug/ChromeDebug/ChromeDebugPackage.cs
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..a26b8692e0961bba7dacb9106542a9c92afbfd6d
|
| --- /dev/null
|
| +++ b/tools/win/ChromeDebug/ChromeDebug/ChromeDebugPackage.cs
|
| @@ -0,0 +1,107 @@
|
| +// Copyright (c) 2013 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +using System;
|
| +using System.Diagnostics;
|
| +using System.Globalization;
|
| +using System.Runtime.InteropServices;
|
| +using System.ComponentModel.Design;
|
| +using Microsoft.Win32;
|
| +using Microsoft.VisualStudio;
|
| +using Microsoft.VisualStudio.Shell.Interop;
|
| +using Microsoft.VisualStudio.OLE.Interop;
|
| +using Microsoft.VisualStudio.Shell;
|
| +using System.Windows.Forms;
|
| +
|
| +namespace ChromeDebug {
|
| + /// <summary>
|
| + /// This is the class that implements the package exposed by this assembly.
|
| + ///
|
| + /// The minimum requirement for a class to be considered a valid package for Visual Studio
|
| + /// is to implement the IVsPackage interface and register itself with the shell.
|
| + /// This package uses the helper classes defined inside the Managed Package Framework (MPF)
|
| + /// to do it: it derives from the Package class that provides the implementation of the
|
| + /// IVsPackage interface and uses the registration attributes defined in the framework to
|
| + /// register itself and its components with the shell.
|
| + /// </summary>
|
| + // This attribute tells the PkgDef creation utility (CreatePkgDef.exe) that this class is
|
| + // a package.
|
| + [PackageRegistration(UseManagedResourcesOnly = true)]
|
| + // This attribute is used to register the information needed to show this package
|
| + // in the Help/About dialog of Visual Studio.
|
| + [InstalledProductRegistration("#110", "#112", "1.0", IconResourceID = 400)]
|
| + // This attribute is needed to let the shell know that this package exposes some menus.
|
| + [ProvideMenuResource("Menus.ctmenu", 1)]
|
| + [Guid(GuidList.guidChromeDebugPkgString)]
|
| + public sealed class ChromeDebugPackage : Package {
|
| + /// <summary>
|
| + /// Default constructor of the package.
|
| + /// Inside this method you can place any initialization code that does not require
|
| + /// any Visual Studio service because at this point the package object is created but
|
| + /// not sited yet inside Visual Studio environment. The place to do all the other
|
| + /// initialization is the Initialize method.
|
| + /// </summary>
|
| + public ChromeDebugPackage() {
|
| + Debug.WriteLine(string.Format(CultureInfo.CurrentCulture, "Entering constructor for: {0}",
|
| + this.ToString()));
|
| + }
|
| +
|
| +
|
| +
|
| + /////////////////////////////////////////////////////////////////////////////
|
| + // Overridden Package Implementation
|
| + #region Package Members
|
| +
|
| + /// <summary>
|
| + /// Initialization of the package; this method is called right after the package is sited, so this is the place
|
| + /// where you can put all the initialization code that rely on services provided by VisualStudio.
|
| + /// </summary>
|
| + protected override void Initialize() {
|
| + Debug.WriteLine(string.Format(CultureInfo.CurrentCulture, "Entering Initialize() of: {0}", this.ToString()));
|
| + base.Initialize();
|
| +
|
| + // Add our command handlers for menu (commands must exist in the .vsct file)
|
| + OleMenuCommandService mcs = GetService(typeof(IMenuCommandService)) as OleMenuCommandService;
|
| + if (null != mcs) {
|
| + // Create the command for the menu item.
|
| + CommandID menuCommandID = new CommandID(GuidList.guidChromeDebugCmdSet, (int)PkgCmdIDList.cmdidAttachToProcess);
|
| + MenuCommand menuItem = new MenuCommand(MenuItemCallback, menuCommandID);
|
| + mcs.AddCommand(menuItem);
|
| + }
|
| + }
|
| + #endregion
|
| +
|
| + /// <summary>
|
| + /// This function is the callback used to execute a command when the a menu item is clicked.
|
| + /// See the Initialize method to see how the menu item is associated to this function using
|
| + /// the OleMenuCommandService service and the MenuCommand class.
|
| + /// </summary>
|
| + private void MenuItemCallback(object sender, EventArgs e) {
|
| + // Show a Message Box to prove we were here
|
| + EnvDTE.DTE dte = (EnvDTE.DTE)GetService(typeof(EnvDTE.DTE));
|
| +
|
| + IVsUIShell uiShell = (IVsUIShell)GetService(typeof(SVsUIShell));
|
| + Guid clsid = Guid.Empty;
|
| + IntPtr parentHwnd = IntPtr.Zero;
|
| + uiShell.GetDialogOwnerHwnd(out parentHwnd);
|
| +
|
| + NativeWindow parentShim = new NativeWindow();
|
| + parentShim.AssignHandle(parentHwnd);
|
| + AttachDialog dialog = new AttachDialog();
|
| + DialogResult result = dialog.ShowDialog(parentShim);
|
| + if (result == DialogResult.OK) {
|
| + foreach (int selected_id in dialog.SelectedItems) {
|
| + foreach (EnvDTE90a.Process4 p in dte.Debugger.LocalProcesses) {
|
| + System.Diagnostics.Debug.WriteLine("Found process {0}", p.ProcessID);
|
| + if (p.ProcessID != selected_id)
|
| + continue;
|
| + p.Attach();
|
| + System.Diagnostics.Debug.WriteLine("Attaching to process successful.");
|
| + break;
|
| + }
|
| + }
|
| + }
|
| + }
|
| + }
|
| +}
|
|
|