| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364 |
- //
- // Copyright (C) 2004 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.
- //
- //
- // System.Reflection/RuntimeFieldInfo.cs
- // The class used to represent Fields from the mono runtime.
- //
- // Author:
- // Paolo Molaro ([email protected])
- //
- // (C) 2001 Ximian, Inc. http://www.ximian.com
- //
- using System;
- using System.Collections.Generic;
- using System.Globalization;
- using System.Runtime.CompilerServices;
- using System.Runtime.InteropServices;
- using System.Runtime.Serialization;
- using System.Diagnostics;
- using System.Diagnostics.Contracts;
- namespace System.Reflection {
- abstract class RtFieldInfo : FieldInfo {
- internal abstract object UnsafeGetValue (object obj);
- internal abstract void UnsafeSetValue (Object obj, Object value, BindingFlags invokeAttr, Binder binder, CultureInfo culture);
- internal abstract void CheckConsistency(Object target);
- }
- [Serializable]
- [StructLayout (LayoutKind.Sequential)]
- class RuntimeFieldInfo : RtFieldInfo
- #if !NETCORE
- , ISerializable
- #endif
- {
- #pragma warning disable 649
- internal IntPtr klass;
- internal RuntimeFieldHandle fhandle;
- string name;
- Type type;
- FieldAttributes attrs;
- #pragma warning restore 649
- internal BindingFlags BindingFlags {
- get {
- return 0;
- }
- }
- public override Module Module {
- get {
- return GetRuntimeModule ();
- }
- }
- internal RuntimeType GetDeclaringTypeInternal ()
- {
- return (RuntimeType) DeclaringType;
- }
- RuntimeType ReflectedTypeInternal {
- get {
- return (RuntimeType) ReflectedType;
- }
- }
- internal RuntimeModule GetRuntimeModule ()
- {
- return GetDeclaringTypeInternal ().GetRuntimeModule ();
- }
- #if !NETCORE
- #region ISerializable Implementation
- public void GetObjectData(SerializationInfo info, StreamingContext context)
- {
- if (info == null)
- throw new ArgumentNullException("info");
- Contract.EndContractBlock();
- MemberInfoSerializationHolder.GetSerializationInfo(
- info,
- Name,
- ReflectedTypeInternal,
- ToString(),
- MemberTypes.Field);
- }
- #endregion
- #endif
- [MethodImplAttribute(MethodImplOptions.InternalCall)]
- internal override extern object UnsafeGetValue (object obj);
- internal override void CheckConsistency(Object target)
- {
- // only test instance fields
- if ((Attributes & FieldAttributes.Static) != FieldAttributes.Static)
- {
- if (!DeclaringType.IsInstanceOfType(target))
- {
- if (target == null)
- {
- #if FEATURE_LEGACYNETCF
- if (CompatibilitySwitches.IsAppEarlierThanWindowsPhone8)
- throw new ArgumentNullException(Environment.GetResourceString("RFLCT.Targ_StatFldReqTarg"));
- else
- #endif
- throw new TargetException(Environment.GetResourceString("RFLCT.Targ_StatFldReqTarg"));
- }
- else
- {
- throw new ArgumentException(
- String.Format(CultureInfo.CurrentUICulture, Environment.GetResourceString("Arg_FieldDeclTarget"),
- Name, DeclaringType, target.GetType()));
- }
- }
- }
- }
- [DebuggerStepThroughAttribute]
- [Diagnostics.DebuggerHidden]
- internal override void UnsafeSetValue (Object obj, Object value, BindingFlags invokeAttr, Binder binder, CultureInfo culture)
- {
- bool domainInitialized = false;
- RuntimeFieldHandle.SetValue (this, obj, value, null, Attributes, null, ref domainInitialized);
- }
- [DebuggerStepThroughAttribute]
- [Diagnostics.DebuggerHidden]
- public override void SetValueDirect(TypedReference obj, Object value)
- {
- if (obj.IsNull)
- throw new ArgumentException(Environment.GetResourceString("Arg_TypedReference_Null"));
- Contract.EndContractBlock();
- unsafe
- {
- // Passing TypedReference by reference is easier to make correct in native code
- RuntimeFieldHandle.SetValueDirect(this, (RuntimeType)FieldType, &obj, value, (RuntimeType)DeclaringType);
- }
- }
- [DebuggerStepThroughAttribute]
- [Diagnostics.DebuggerHidden]
- public override Object GetValueDirect(TypedReference obj)
- {
- if (obj.IsNull)
- throw new ArgumentException(Environment.GetResourceString("Arg_TypedReference_Null"));
- Contract.EndContractBlock();
- unsafe
- {
- // Passing TypedReference by reference is easier to make correct in native code
- return RuntimeFieldHandle.GetValueDirect(this, (RuntimeType)FieldType, &obj, (RuntimeType)DeclaringType);
- }
- }
-
- public override FieldAttributes Attributes {
- get {
- return attrs;
- }
- }
- public override RuntimeFieldHandle FieldHandle {
- get {
- return fhandle;
- }
- }
- [MethodImplAttribute(MethodImplOptions.InternalCall)]
- extern Type ResolveType ();
- public override Type FieldType {
- get {
- if (type == null)
- type = ResolveType ();
- return type;
- }
- }
- [MethodImplAttribute(MethodImplOptions.InternalCall)]
- private extern Type GetParentType (bool declaring);
- public override Type ReflectedType {
- get {
- return GetParentType (false);
- }
- }
- public override Type DeclaringType {
- get {
- return GetParentType (true);
- }
- }
- public override string Name {
- get {
- return name;
- }
- }
- public override bool IsDefined (Type attributeType, bool inherit) {
- return MonoCustomAttrs.IsDefined (this, attributeType, inherit);
- }
- public override object[] GetCustomAttributes( bool inherit) {
- return MonoCustomAttrs.GetCustomAttributes (this, inherit);
- }
- public override object[] GetCustomAttributes( Type attributeType, bool inherit) {
- return MonoCustomAttrs.GetCustomAttributes (this, attributeType, inherit);
- }
- #if !NETCORE
- [MethodImplAttribute(MethodImplOptions.InternalCall)]
- internal override extern int GetFieldOffset ();
- #endif
- [MethodImplAttribute(MethodImplOptions.InternalCall)]
- private extern object GetValueInternal (object obj);
- public override object GetValue (object obj)
- {
- if (!IsStatic) {
- if (obj == null)
- throw new TargetException ("Non-static field requires a target");
- if (!DeclaringType.IsAssignableFrom (obj.GetType ()))
- throw new ArgumentException (string.Format (
- "Field {0} defined on type {1} is not a field on the target object which is of type {2}.",
- Name, DeclaringType, obj.GetType ()),
- "obj");
- }
-
- if (!IsLiteral)
- CheckGeneric ();
- return GetValueInternal (obj);
- }
- public override string ToString () {
- return String.Format ("{0} {1}", FieldType, name);
- }
- [MethodImplAttribute(MethodImplOptions.InternalCall)]
- private static extern void SetValueInternal (FieldInfo fi, object obj, object value);
- public override void SetValue (object obj, object val, BindingFlags invokeAttr, Binder binder, CultureInfo culture)
- {
- if (!IsStatic) {
- if (obj == null)
- throw new TargetException ("Non-static field requires a target");
- if (!DeclaringType.IsAssignableFrom (obj.GetType ()))
- throw new ArgumentException (string.Format (
- "Field {0} defined on type {1} is not a field on the target object which is of type {2}.",
- Name, DeclaringType, obj.GetType ()),
- "obj");
- }
- if (IsLiteral)
- throw new FieldAccessException ("Cannot set a constant field");
- if (binder == null)
- binder = Type.DefaultBinder;
- CheckGeneric ();
- if (val != null) {
- RuntimeType fieldType = (RuntimeType) FieldType;
- val = fieldType.CheckValue (val, binder, culture, invokeAttr);
- }
- SetValueInternal (this, obj, val);
- }
-
- internal RuntimeFieldInfo Clone (string newName)
- {
- RuntimeFieldInfo field = new RuntimeFieldInfo ();
- field.name = newName;
- field.type = type;
- field.attrs = attrs;
- field.klass = klass;
- field.fhandle = fhandle;
- return field;
- }
- [MethodImplAttribute(MethodImplOptions.InternalCall)]
- public override extern object GetRawConstantValue ();
- public override IList<CustomAttributeData> GetCustomAttributesData () {
- return CustomAttributeData.GetCustomAttributes (this);
- }
- void CheckGeneric () {
- if (DeclaringType.ContainsGenericParameters)
- throw new InvalidOperationException ("Late bound operations cannot be performed on fields with types for which Type.ContainsGenericParameters is true.");
- }
- #if MOBILE
- static int get_core_clr_security_level ()
- {
- return 1;
- }
- #else
- //seclevel { transparent = 0, safe-critical = 1, critical = 2}
- [MethodImplAttribute(MethodImplOptions.InternalCall)]
- public extern int get_core_clr_security_level ();
- public override bool IsSecurityTransparent {
- get { return get_core_clr_security_level () == 0; }
- }
- public override bool IsSecurityCritical {
- get { return get_core_clr_security_level () > 0; }
- }
- public override bool IsSecuritySafeCritical {
- get { return get_core_clr_security_level () == 1; }
- }
- #endif
- #if !NETCORE
- public sealed override bool HasSameMetadataDefinitionAs (MemberInfo other) => HasSameMetadataDefinitionAsCore<RuntimeFieldInfo> (other);
- #endif
- public override int MetadataToken {
- get {
- return get_metadata_token (this);
- }
- }
-
- [MethodImplAttribute (MethodImplOptions.InternalCall)]
- internal static extern int get_metadata_token (RuntimeFieldInfo monoField);
- [MethodImplAttribute (MethodImplOptions.InternalCall)]
- extern Type[] GetTypeModifiers (bool optional);
- public override Type[] GetOptionalCustomModifiers () => GetCustomModifiers (true);
- public override Type[] GetRequiredCustomModifiers () => GetCustomModifiers (false);
- private Type[] GetCustomModifiers (bool optional) => GetTypeModifiers (optional) ?? Type.EmptyTypes;
- #if NETCORE
- internal object[] GetPseudoCustomAttributes () {
- throw new NotImplementedException ();
- }
- internal CustomAttributeData[] GetPseudoCustomAttributesData () {
- throw new NotImplementedException ();
- }
- #endif
- }
- }
|