Moved ProviderCollectionTest.cs from System assembly to System.Configuration.
[mono.git] / mcs / class / corlib / System.Reflection / PropertyInfo.cs
old mode 100755 (executable)
new mode 100644 (file)
index 84c50e2..b979cc6
@@ -5,19 +5,46 @@
 //   Paolo Molaro (lupus@ximian.com)
 //
 // (C) 2001 Ximian, Inc.  http://www.ximian.com
+// Copyright (C) 2004-2005 Novell, Inc (http://www.novell.com)
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+// 
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+// 
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 //
 
-using System;
-using System.Reflection;
+using System.Diagnostics;
 using System.Globalization;
+using System.Runtime.InteropServices;
+using System.Runtime.CompilerServices;
 
 namespace System.Reflection {
+
+#if NET_2_0
+       [ComVisible (true)]
+       [ComDefaultInterfaceAttribute (typeof (_PropertyInfo))]
+#endif
        [Serializable]
-       public abstract class PropertyInfo : MemberInfo {
+       [ClassInterface(ClassInterfaceType.None)]
+       public abstract class PropertyInfo : MemberInfo, _PropertyInfo {
 
-               public abstract PropertyAttributes Attributes {get;}
-               public abstract bool CanRead {get;}
-               public abstract bool CanWrite {get;}
+               public abstract PropertyAttributes Attributes { get; }
+               public abstract bool CanRead { get; }
+               public abstract bool CanWrite { get; }
 
                public bool IsSpecialName {
                        get {return (Attributes & PropertyAttributes.SpecialName) != 0;}
@@ -26,30 +53,96 @@ namespace System.Reflection {
                public override MemberTypes MemberType {
                        get {return MemberTypes.Property;}
                }
-               public abstract Type PropertyType {get;}
+               public abstract Type PropertyType { get; }
        
-               protected PropertyInfo() {
-               }
+               protected PropertyInfo () { }
 
-               public MethodInfo[] GetAccessors() {
+               public MethodInfo[] GetAccessors ()
+               {
                        return GetAccessors (false);
                }
-               public abstract MethodInfo[] GetAccessors( bool nonPublic);
-               public MethodInfo GetGetMethod() {
+               
+               public abstract MethodInfo[] GetAccessors (bool nonPublic);
+
+               public MethodInfo GetGetMethod()
+               {
                        return GetGetMethod (false);
                }
-               public abstract MethodInfo GetGetMethod( bool nonPublic);
+               public abstract MethodInfo GetGetMethod(bool nonPublic);
+               
                public abstract ParameterInfo[] GetIndexParameters();
-               public MethodInfo GetSetMethod() {
+
+#if ONLY_1_1
+               public new Type GetType ()
+               {
+                       return base.GetType ();
+               }
+#endif
+
+               public MethodInfo GetSetMethod()
+               {
                        return GetSetMethod (false);
                }
-               public abstract MethodInfo GetSetMethod( bool nonPublic);
-               public virtual object GetValue( object obj, object[] index) {
-                       return null;
+               
+               public abstract MethodInfo GetSetMethod (bool nonPublic);
+               
+               [DebuggerHidden]
+               [DebuggerStepThrough]
+               public virtual object GetValue (object obj, object[] index)
+               {
+                       return GetValue(obj, BindingFlags.Default, null, index, null);
+               }
+               
+               public abstract object GetValue (object obj, BindingFlags invokeAttr, Binder binder, object[] index, CultureInfo culture);
+               
+               [DebuggerHidden]
+               [DebuggerStepThrough]
+               public virtual void SetValue (object obj, object value, object[] index)
+               {
+                       SetValue (obj, value, BindingFlags.Default, null, index, null);
+               }
+               
+               public abstract void SetValue (object obj, object value, BindingFlags invokeAttr, Binder binder, object[] index, CultureInfo culture);
+
+#if NET_2_0 || BOOTSTRAP_NET_2_0
+
+               public virtual Type[] GetOptionalCustomModifiers () {
+                       return Type.EmptyTypes;
+               }
+
+               public virtual Type[] GetRequiredCustomModifiers () {
+                       return Type.EmptyTypes;
+               }
+
+               [MonoTODO("Not implemented")]
+               public virtual object GetConstantValue () {
+                       throw new NotImplementedException ();
+               }
+
+               [MonoTODO("Not implemented")]
+               public virtual object GetRawConstantValue() {
+                       throw new NotImplementedException ();
+               }
+#endif
+
+               void _PropertyInfo.GetIDsOfNames ([In] ref Guid riid, IntPtr rgszNames, uint cNames, uint lcid, IntPtr rgDispId)
+               {
+                       throw new NotImplementedException ();
+               }
+
+               void _PropertyInfo.GetTypeInfo (uint iTInfo, uint lcid, IntPtr ppTInfo)
+               {
+                       throw new NotImplementedException ();
                }
-               public abstract object GetValue( object obj, BindingFlags invokeAttr, Binder binder, object[] index, CultureInfo culture);
-               public virtual void SetValue( object obj, object value, object[] index) {
+
+               void _PropertyInfo.GetTypeInfoCount (out uint pcTInfo)
+               {
+                       throw new NotImplementedException ();
+               }
+
+               void _PropertyInfo.Invoke (uint dispIdMember, [In] ref Guid riid, uint lcid, short wFlags, IntPtr pDispParams, IntPtr pVarResult, IntPtr pExcepInfo, IntPtr puArgErr)
+               {
+                       throw new NotImplementedException ();
                }
-               public abstract void SetValue( object obj, object value, BindingFlags invokeAttr, Binder binder, object[] index, CultureInfo culture);
        }
 }