/* **************************************************************************** * * Copyright (c) Microsoft Corporation. * * This source code is subject to terms and conditions of the Apache License, Version 2.0. A * copy of the license can be found in the License.html file at the root of this distribution. If * you cannot locate the Apache License, Version 2.0, please send an email to * vspython@microsoft.com. By using this source code in any fashion, you are agreeing to be bound * by the terms of the Apache License, Version 2.0. * * You must not remove this notice, or any other, from this software. * * ***************************************************************************/ using System; using System.Collections; using System.Collections.Generic; using System.Diagnostics.CodeAnalysis; using System.Runtime.InteropServices; namespace Microsoft.VisualStudio.Project.Automation { /// /// This can navigate a collection object only (partial implementation of ProjectItems interface) /// [SuppressMessage("Microsoft.Naming", "CA1710:IdentifiersShouldHaveCorrectSuffix")] [ComVisible(true)] public class OANavigableProjectItems : EnvDTE.ProjectItems { #region fields private OAProject project; private HierarchyNode nodeWithItems; #endregion #region properties /// /// Defines a relationship to the associated project. /// public OAProject Project { get { return this.project; } } /// /// Defines the node that contains the items /// public HierarchyNode NodeWithItems { get { return this.nodeWithItems; } } #endregion #region ctor /// /// Constructor. /// /// The associated project. /// The node that defines the items. public OANavigableProjectItems(OAProject project, HierarchyNode nodeWithItems) { this.project = project; this.nodeWithItems = nodeWithItems; } #endregion #region EnvDTE.ProjectItems /// /// Gets a value indicating the number of objects in the collection. /// public virtual int Count { get { int count = 0; UIThread.Instance.RunSync(() => { for (HierarchyNode child = this.NodeWithItems.FirstChild; child != null; child = child.NextSibling) { if (child.GetAutomationObject() is EnvDTE.ProjectItem) { count += 1; } } }); return count; } } /// /// Gets the immediate parent object of a ProjectItems collection. /// public virtual object Parent { get { return this.nodeWithItems.GetAutomationObject(); } } /// /// Gets an enumeration indicating the type of object. /// public virtual string Kind { get { // TODO: Add OAProjectItems.Kind getter implementation return null; } } /// /// Gets the top-level extensibility object. /// public virtual EnvDTE.DTE DTE { get { return (EnvDTE.DTE)this.project.DTE; } } /// /// Gets the project hosting the project item or items. /// public virtual EnvDTE.Project ContainingProject { get { return this.project; } } /// /// Adds one or more ProjectItem objects from a directory to the ProjectItems collection. /// /// The directory from which to add the project item. /// A ProjectItem object. public virtual EnvDTE.ProjectItem AddFromDirectory(string directory) { throw new NotImplementedException(); } /// /// Creates a new project item from an existing item template file and adds it to the project. /// /// The full path and file name of the template project file. /// The file name to use for the new project item. /// A ProjectItem object. public virtual EnvDTE.ProjectItem AddFromTemplate(string fileName, string name) { throw new NotImplementedException(); } /// /// Creates a new folder in Solution Explorer. /// /// The name of the folder node in Solution Explorer. /// The type of folder to add. The available values are based on vsProjectItemsKindConstants and vsProjectItemKindConstants /// A ProjectItem object. public virtual EnvDTE.ProjectItem AddFolder(string name, string kind) { throw new NotImplementedException(); } /// /// Copies a source file and adds it to the project. /// /// The path and file name of the project item to be added. /// A ProjectItem object. public virtual EnvDTE.ProjectItem AddFromFileCopy(string filePath) { throw new NotImplementedException(); } /// /// Adds a project item from a file that is installed in a project directory structure. /// /// The file name of the item to add as a project item. /// A ProjectItem object. public virtual EnvDTE.ProjectItem AddFromFile(string fileName) { throw new NotImplementedException(); } /// /// Get Project Item from index /// /// Either index by number (1-based) or by name can be used to get the item /// Project Item. ArgumentException if invalid index is specified [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Performance", "CA1800:DoNotCastUnnecessarily")] public virtual EnvDTE.ProjectItem Item(object index) { // Changed from MPFProj: throws ArgumentException instead of returning null (http://mpfproj10.codeplex.com/workitem/9158) if (index is int) { int realIndex = (int)index - 1; if (realIndex >= 0) { for (HierarchyNode child = this.NodeWithItems.FirstChild; child != null; child = child.NextSibling) { var item = child.GetAutomationObject() as EnvDTE.ProjectItem; if (item != null) { if (realIndex == 0) { return item; } realIndex -= 1; } } } } else if (index is string) { string name = (string)index; for (HierarchyNode child = this.NodeWithItems.FirstChild; child != null; child = child.NextSibling) { var item = child.GetAutomationObject() as EnvDTE.ProjectItem; if (item != null && String.Compare(item.Name, name, StringComparison.OrdinalIgnoreCase) == 0) { return item; } } } throw new ArgumentException(); } /// /// Returns an enumeration for items in a collection. /// /// An IEnumerator for this object. public virtual IEnumerator GetEnumerator() { for (HierarchyNode child = this.NodeWithItems.FirstChild; child != null; child = child.NextSibling) { var item = child.GetAutomationObject() as EnvDTE.ProjectItem; if (item != null) { yield return item; } } } #endregion } }