Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / 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
- safePerfProviderHandle.cs
- ZipIOCentralDirectoryBlock.cs
- ReceiveDesigner.xaml.cs
- EventLogger.cs
- ObjectPersistData.cs
- ByteStack.cs
- CommandEventArgs.cs
- HandlerFactoryCache.cs
- TableLayout.cs
- LinqDataView.cs
- ValidatorCompatibilityHelper.cs
- ReflectionTypeLoadException.cs
- Config.cs
- StylusPointDescription.cs
- Char.cs
- DBConcurrencyException.cs
- OrderedDictionaryStateHelper.cs
- WinInet.cs
- XmlQueryTypeFactory.cs
- XamlTypeMapper.cs
- StrokeNodeOperations2.cs
- RemotingClientProxy.cs
- StateWorkerRequest.cs
- WebPartMovingEventArgs.cs
- ContextProperty.cs
- TemplateControlCodeDomTreeGenerator.cs
- PropertyFilterAttribute.cs
- TraceEventCache.cs
- StoryFragments.cs
- WindowsRichEditRange.cs
- RightsManagementErrorHandler.cs
- XmlHierarchicalEnumerable.cs
- ServerValidateEventArgs.cs
- clipboard.cs
- GeometryDrawing.cs
- LineInfo.cs
- ChannelManager.cs
- TraceUtils.cs
- BaseProcessor.cs
- MetaType.cs
- QilCloneVisitor.cs
- X509RecipientCertificateClientElement.cs
- LogEntryDeserializer.cs
- MessageQueueKey.cs
- PublisherIdentityPermission.cs
- WindowProviderWrapper.cs
- PartitionResolver.cs
- CatalogZoneBase.cs
- ResetableIterator.cs
- XamlVector3DCollectionSerializer.cs
- LoginName.cs
- DataExpression.cs
- InternalReceiveMessage.cs
- DESCryptoServiceProvider.cs
- TimeSpanConverter.cs
- FramingFormat.cs
- LinearQuaternionKeyFrame.cs
- LocalizationParserHooks.cs
- CompiledQueryCacheKey.cs
- SelfIssuedTokenFactoryCredential.cs
- DBParameter.cs
- StackSpiller.cs
- CompositeScriptReference.cs
- NotifyIcon.cs
- ValueHandle.cs
- GenericWebPart.cs
- RC2.cs
- DataSourceControlBuilder.cs
- RepeaterItem.cs
- ConsoleTraceListener.cs
- FrameworkElementFactoryMarkupObject.cs
- RunWorkerCompletedEventArgs.cs
- CodeGeneratorOptions.cs
- DataView.cs
- ServerIdentity.cs
- Parameter.cs
- ResolveCriteria11.cs
- StringExpressionSet.cs
- ValueQuery.cs
- ExpressionBindingsDialog.cs
- Label.cs
- GridProviderWrapper.cs
- MapPathBasedVirtualPathProvider.cs
- ConfigXmlDocument.cs
- NegotiateStream.cs
- Frame.cs
- srgsitem.cs
- ColumnWidthChangedEvent.cs
- SafeNativeMemoryHandle.cs
- Int32RectConverter.cs
- ArcSegment.cs
- Utils.cs
- InputLanguage.cs
- DataGridViewDataConnection.cs
- DecryptRequest.cs
- RankException.cs
- ManagementException.cs
- PrivilegeNotHeldException.cs
- ActivityBuilderHelper.cs
- GroupLabel.cs