/* ****************************************************************************
*
* 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
}
}