Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / clr / src / BCL / System / TypedReference.cs / 1 / TypedReference.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== namespace System { // TypedReference is basically only ever seen on the call stack, and in param arrays. // These are blob that must be dealt with by the compiler. using System; using System.Reflection; using System.Runtime.CompilerServices; using CultureInfo = System.Globalization.CultureInfo; using FieldInfo = System.Reflection.FieldInfo; using System.Security.Permissions; [CLSCompliant(false)] [System.Runtime.InteropServices.ComVisible(true)] public struct TypedReference { private IntPtr Value; private IntPtr Type; [CLSCompliant(false)] [ReflectionPermission(SecurityAction.LinkDemand, MemberAccess=true)] public static TypedReference MakeTypedReference(Object target, FieldInfo[] flds) { if (target == null) throw new ArgumentNullException("target"); if (flds == null) throw new ArgumentNullException("flds"); if (flds.Length == 0) throw new ArgumentException(Environment.GetResourceString("Arg_ArrayZeroError")); else { RuntimeFieldHandle[] fields = new RuntimeFieldHandle[flds.Length]; // For proper handling of Nullabledon't change GetType() to something like 'IsAssignableFrom' // Currently we can't make a TypedReference to fields of Nullable , which is fine. Type targetType = target.GetType(); for (int i = 0; i < flds.Length; i++) { FieldInfo field = flds[i]; if (!(field is RuntimeFieldInfo)) throw new ArgumentException(Environment.GetResourceString("Argument_MustBeRuntimeFieldInfo")); else if (field.IsInitOnly || field.IsStatic) throw new ArgumentException(Environment.GetResourceString("Argument_TypedReferenceInvalidField")); if (targetType != field.DeclaringType && !targetType.IsSubclassOf(field.DeclaringType)) throw new MissingMemberException(Environment.GetResourceString("MissingMemberTypeRef")); Type fieldType = field.FieldType; if (fieldType.IsPrimitive) throw new ArgumentException(Environment.GetResourceString("Arg_TypeRefPrimitve")); if (i < flds.Length - 1) if (!fieldType.IsValueType) throw new MissingMemberException(Environment.GetResourceString("MissingMemberNestErr")); fields[i] = field.FieldHandle; targetType = fieldType; } TypedReference result = new TypedReference (); // reference to TypedReference is banned, so have to pass result as pointer unsafe { InternalMakeTypedReference(&result, target, fields, targetType.TypeHandle); } return result; } } [MethodImplAttribute(MethodImplOptions.InternalCall)] // reference to TypedReference is banned, so have to pass result as pointer private unsafe static extern void InternalMakeTypedReference(void * result, Object target, RuntimeFieldHandle[] flds, RuntimeTypeHandle lastFieldType); public override int GetHashCode() { if (Type == IntPtr.Zero) return 0; else return __reftype(this).GetHashCode(); } public override bool Equals(Object o) { throw new NotSupportedException(Environment.GetResourceString("NotSupported_NYI")); } public unsafe static Object ToObject(TypedReference value) { return InternalToObject(&value); } [MethodImplAttribute(MethodImplOptions.InternalCall)] internal unsafe extern static Object InternalToObject(void * value); internal bool IsNull { get { return Value.IsNull() && Type.IsNull(); } } public static Type GetTargetType (TypedReference value) { return __reftype(value); } public static RuntimeTypeHandle TargetTypeToken (TypedReference value) { return __reftype(value).TypeHandle; } // This may cause the type to be changed. [CLSCompliant(false)] public unsafe static void SetTypedReference(TypedReference target, Object value) { InternalSetTypedReference(&target, value); } [MethodImplAttribute(MethodImplOptions.InternalCall)] internal unsafe extern static void InternalSetTypedReference(void * target, Object value); } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== namespace System { // TypedReference is basically only ever seen on the call stack, and in param arrays. // These are blob that must be dealt with by the compiler. using System; using System.Reflection; using System.Runtime.CompilerServices; using CultureInfo = System.Globalization.CultureInfo; using FieldInfo = System.Reflection.FieldInfo; using System.Security.Permissions; [CLSCompliant(false)] [System.Runtime.InteropServices.ComVisible(true)] public struct TypedReference { private IntPtr Value; private IntPtr Type; [CLSCompliant(false)] [ReflectionPermission(SecurityAction.LinkDemand, MemberAccess=true)] public static TypedReference MakeTypedReference(Object target, FieldInfo[] flds) { if (target == null) throw new ArgumentNullException("target"); if (flds == null) throw new ArgumentNullException("flds"); if (flds.Length == 0) throw new ArgumentException(Environment.GetResourceString("Arg_ArrayZeroError")); else { RuntimeFieldHandle[] fields = new RuntimeFieldHandle[flds.Length]; // For proper handling of Nullable don't change GetType() to something like 'IsAssignableFrom' // Currently we can't make a TypedReference to fields of Nullable , which is fine. Type targetType = target.GetType(); for (int i = 0; i < flds.Length; i++) { FieldInfo field = flds[i]; if (!(field is RuntimeFieldInfo)) throw new ArgumentException(Environment.GetResourceString("Argument_MustBeRuntimeFieldInfo")); else if (field.IsInitOnly || field.IsStatic) throw new ArgumentException(Environment.GetResourceString("Argument_TypedReferenceInvalidField")); if (targetType != field.DeclaringType && !targetType.IsSubclassOf(field.DeclaringType)) throw new MissingMemberException(Environment.GetResourceString("MissingMemberTypeRef")); Type fieldType = field.FieldType; if (fieldType.IsPrimitive) throw new ArgumentException(Environment.GetResourceString("Arg_TypeRefPrimitve")); if (i < flds.Length - 1) if (!fieldType.IsValueType) throw new MissingMemberException(Environment.GetResourceString("MissingMemberNestErr")); fields[i] = field.FieldHandle; targetType = fieldType; } TypedReference result = new TypedReference (); // reference to TypedReference is banned, so have to pass result as pointer unsafe { InternalMakeTypedReference(&result, target, fields, targetType.TypeHandle); } return result; } } [MethodImplAttribute(MethodImplOptions.InternalCall)] // reference to TypedReference is banned, so have to pass result as pointer private unsafe static extern void InternalMakeTypedReference(void * result, Object target, RuntimeFieldHandle[] flds, RuntimeTypeHandle lastFieldType); public override int GetHashCode() { if (Type == IntPtr.Zero) return 0; else return __reftype(this).GetHashCode(); } public override bool Equals(Object o) { throw new NotSupportedException(Environment.GetResourceString("NotSupported_NYI")); } public unsafe static Object ToObject(TypedReference value) { return InternalToObject(&value); } [MethodImplAttribute(MethodImplOptions.InternalCall)] internal unsafe extern static Object InternalToObject(void * value); internal bool IsNull { get { return Value.IsNull() && Type.IsNull(); } } public static Type GetTargetType (TypedReference value) { return __reftype(value); } public static RuntimeTypeHandle TargetTypeToken (TypedReference value) { return __reftype(value).TypeHandle; } // This may cause the type to be changed. [CLSCompliant(false)] public unsafe static void SetTypedReference(TypedReference target, Object value) { InternalSetTypedReference(&target, value); } [MethodImplAttribute(MethodImplOptions.InternalCall)] internal unsafe extern static void InternalSetTypedReference(void * target, Object value); } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- SettingsSavedEventArgs.cs
- LogArchiveSnapshot.cs
- Int64KeyFrameCollection.cs
- CompilationSection.cs
- AssemblyName.cs
- OneToOneMappingSerializer.cs
- StringAnimationBase.cs
- Rijndael.cs
- DBCommandBuilder.cs
- XmlSchemaSimpleContentRestriction.cs
- storepermissionattribute.cs
- SectionInformation.cs
- DisplayNameAttribute.cs
- WorkflowPrinting.cs
- Trustee.cs
- WindowsFont.cs
- GlyphsSerializer.cs
- EdmTypeAttribute.cs
- KerberosTicketHashIdentifierClause.cs
- BufferedGraphicsManager.cs
- ArglessEventHandlerProxy.cs
- VirtualizedItemPattern.cs
- MSG.cs
- XmlAttributes.cs
- ModuleConfigurationInfo.cs
- Int16Animation.cs
- SecuritySessionFilter.cs
- EventSinkActivityDesigner.cs
- Compiler.cs
- BufferModesCollection.cs
- RawAppCommandInputReport.cs
- NameService.cs
- Calendar.cs
- Int16Converter.cs
- TPLETWProvider.cs
- NumberSubstitution.cs
- _Semaphore.cs
- Policy.cs
- PropertyFilterAttribute.cs
- ShutDownListener.cs
- TdsParserHelperClasses.cs
- TextWriter.cs
- BamlLocalizabilityResolver.cs
- AsyncDataRequest.cs
- GridViewActionList.cs
- XmlSchemaParticle.cs
- AssertSection.cs
- RegistryDataKey.cs
- ExpressionBuilder.cs
- DescendantOverDescendantQuery.cs
- MD5Cng.cs
- _ReceiveMessageOverlappedAsyncResult.cs
- TextProperties.cs
- Lease.cs
- QilReference.cs
- BinaryFormatterWriter.cs
- OutputCacheProfileCollection.cs
- Memoizer.cs
- Deflater.cs
- RelationshipEndCollection.cs
- CodeParameterDeclarationExpression.cs
- ExtensionQuery.cs
- EventMappingSettings.cs
- BridgeDataRecord.cs
- ControlPersister.cs
- OneToOneMappingSerializer.cs
- ServiceEndpointCollection.cs
- XpsColorContext.cs
- MemoryPressure.cs
- MethodImplAttribute.cs
- ZoneLinkButton.cs
- ToolStripSplitStackLayout.cs
- TextModifier.cs
- ExtensibleClassFactory.cs
- HttpCapabilitiesEvaluator.cs
- GroupItem.cs
- XPathBinder.cs
- XslCompiledTransform.cs
- FillBehavior.cs
- XmlDataImplementation.cs
- ActivityDesignerHelper.cs
- IncrementalHitTester.cs
- BindingMemberInfo.cs
- Propagator.ExtentPlaceholderCreator.cs
- PointLight.cs
- Buffer.cs
- UITypeEditor.cs
- EastAsianLunisolarCalendar.cs
- COM2Enum.cs
- ListViewInsertionMark.cs
- Tool.cs
- ReadWriteSpinLock.cs
- PrintController.cs
- CodeMemberMethod.cs
- EntityContainerEntitySetDefiningQuery.cs
- XsdValidatingReader.cs
- SoapHeaders.cs
- HierarchicalDataSourceConverter.cs
- IxmlLineInfo.cs
- InputDevice.cs