File: src\libraries\System.Private.CoreLib\src\System\Reflection\PropertyInfo.cs
Web Access
Project: src\src\coreclr\System.Private.CoreLib\System.Private.CoreLib.csproj (System.Private.CoreLib)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
 
using System.Diagnostics;
using System.Globalization;
using System.Runtime.CompilerServices;
 
namespace System.Reflection
{
    public abstract class PropertyInfo : MemberInfo
    {
        protected PropertyInfo() { }
 
        public override MemberTypes MemberType => MemberTypes.Property;
 
        public abstract Type PropertyType { get; }
        public abstract ParameterInfo[] GetIndexParameters();
 
        public abstract PropertyAttributes Attributes { get; }
        public bool IsSpecialName => (Attributes & PropertyAttributes.SpecialName) != 0;
 
        public abstract bool CanRead { get; }
        public abstract bool CanWrite { get; }
 
        public MethodInfo[] GetAccessors() => GetAccessors(nonPublic: false);
        public abstract MethodInfo[] GetAccessors(bool nonPublic);
 
        public virtual MethodInfo? GetMethod => GetGetMethod(nonPublic: true);
        public MethodInfo? GetGetMethod() => GetGetMethod(nonPublic: false);
        public abstract MethodInfo? GetGetMethod(bool nonPublic);
 
        public virtual MethodInfo? SetMethod => GetSetMethod(nonPublic: true);
        public MethodInfo? GetSetMethod() => GetSetMethod(nonPublic: false);
        public abstract MethodInfo? GetSetMethod(bool nonPublic);
 
        public virtual Type GetModifiedPropertyType() => throw new NotSupportedException();
        public virtual Type[] GetOptionalCustomModifiers() => Type.EmptyTypes;
        public virtual Type[] GetRequiredCustomModifiers() => Type.EmptyTypes;
 
        [DebuggerHidden]
        [DebuggerStepThrough]
        public object? GetValue(object? obj) => GetValue(obj, index: null);
        [DebuggerHidden]
        [DebuggerStepThrough]
        public virtual object? GetValue(object? obj, object?[]? index) => GetValue(obj, BindingFlags.Default, binder: null, index: index, culture: null);
        public abstract object? GetValue(object? obj, BindingFlags invokeAttr, Binder? binder, object?[]? index, CultureInfo? culture);
 
        public virtual object? GetConstantValue() { throw NotImplemented.ByDesign; }
        public virtual object? GetRawConstantValue() { throw NotImplemented.ByDesign; }
 
        [DebuggerHidden]
        [DebuggerStepThrough]
        public void SetValue(object? obj, object? value) => SetValue(obj, value, index: null);
        [DebuggerHidden]
        [DebuggerStepThrough]
        public virtual void SetValue(object? obj, object? value, object?[]? index) => SetValue(obj, value, BindingFlags.Default, binder: null, index: index, culture: null);
        public abstract void SetValue(object? obj, object? value, BindingFlags invokeAttr, Binder? binder, object?[]? index, CultureInfo? culture);
 
        public override bool Equals(object? obj) => base.Equals(obj);
        public override int GetHashCode() => base.GetHashCode();
 
        [MethodImpl(MethodImplOptions.AggressiveInlining)]
        public static bool operator ==(PropertyInfo? left, PropertyInfo? right)
        {
            // Test "right" first to allow branch elimination when inlined for null checks (== null)
            // so it can become a simple test
            if (right is null)
            {
                return left is null;
            }
 
            // Try fast reference equality and opposite null check prior to calling the slower virtual Equals
            if (ReferenceEquals(left, right))
            {
                return true;
            }
 
            return (left is null) ? false : left.Equals(right);
        }
 
        public static bool operator !=(PropertyInfo? left, PropertyInfo? right) => !(left == right);
    }
}