/* **************************************************************************** * * 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.Diagnostics; using System.Reflection; using System.Runtime.InteropServices; namespace Microsoft.VisualStudio.Project.Automation { [ComVisible(true)] public class OAProperty : EnvDTE.Property { #region fields private OAProperties parent; private PropertyInfo pi; #endregion #region ctors public OAProperty(OAProperties parent, PropertyInfo pi) { this.parent = parent; this.pi = pi; } #endregion #region EnvDTE.Property /// /// Microsoft public Use Only. /// public object Application { get { return null; } } /// /// Gets the Collection containing the Property object supporting this property. /// public EnvDTE.Properties Collection { get { //todo: EnvDTE.Property.Collection return this.parent; } } /// /// Gets the top-level extensibility object. /// public EnvDTE.DTE DTE { get { return this.parent.DTE; } } /// /// Returns one element of a list. /// /// The index of the item to display. /// The index of the item to display. Reserved for future use. /// The index of the item to display. Reserved for future use. /// The index of the item to display. Reserved for future use. /// The value of a property public object get_IndexedValue(object index1, object index2, object index3, object index4) { Debug.Assert(pi.GetIndexParameters().Length == 0); return this.Value; } /// /// Setter function to set properties values. /// /// public void let_Value(object value) { this.Value = value; } /// /// Gets the name of the object. /// public string Name { get { var attrs = pi.GetCustomAttributes(typeof(PropertyNameAttribute), true); if (attrs.Length > 0) { return ((PropertyNameAttribute)attrs[0]).Name; } return pi.Name; } } /// /// Gets the number of indices required to access the value. /// public short NumIndices { get { return (short)pi.GetIndexParameters().Length; } } /// /// Sets or gets the object supporting the Property object. /// public object Object { get { return this.parent.Target; } set { } } /// /// Microsoft public Use Only. /// public EnvDTE.Properties Parent { get { return this.parent; } } /// /// Sets the value of the property at the specified index. /// /// The index of the item to set. /// Reserved for future use. /// Reserved for future use. /// Reserved for future use. /// The value to set. public void set_IndexedValue(object index1, object index2, object index3, object index4, object value) { Debug.Assert(pi.GetIndexParameters().Length == 0); UIThread.Instance.RunSync(() => { this.Value = value; }); } /// /// Gets or sets the value of the property returned by the Property object. /// public object Value { get { return pi.GetValue(this.parent.Target, null); } set { using (AutomationScope scope = new AutomationScope(this.parent.Target.HierarchyNode.ProjectMgr.Site)) { UIThread.Instance.RunSync(() => { this.pi.SetValue(this.parent.Target, value, null); }); } } } #endregion } }