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 / Runtime / Serialization / SerializationEventsCache.cs / 1 / SerializationEventsCache.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** ** Class: SerializationEventsCache ** ** ** Purpose: Caches the various serialization events such as On(De)Seriliz(ed)ing ** ** ============================================================*/ namespace System.Runtime.Serialization { using System; using System.Collections; using System.Collections.Generic; using System.Reflection; using System.Reflection.Cache; using System.Globalization; internal class SerializationEvents { private Listm_OnSerializingMethods = null; private List m_OnSerializedMethods = null; private List m_OnDeserializingMethods = null; private List m_OnDeserializedMethods = null; private List GetMethodsWithAttribute(Type attribute, Type t) { List mi = new List (); Type baseType = t; // Traverse the hierarchy to find all methods with the particular attribute while (baseType != null && baseType != typeof(Object)) { RuntimeType rt = (RuntimeType)baseType; // Get all methods which are declared on this type, instance and public or nonpublic MethodInfo[] mis = baseType.GetMethods(BindingFlags.DeclaredOnly | BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public); #if _DEBUG bool found = false; #endif foreach(MethodInfo m in mis) { // For each method find if attribute is present, the return type is void and the method is not virtual if (m.IsDefined(attribute, false)) { #if _DEBUG BCLDebug.Assert(m.ReturnType == typeof(void) && !m.IsVirtual, "serialization events methods cannot be virtual and need to have void return"); ParameterInfo[] paramInfo = m.GetParameters(); // Only add it if this method has one parameter of type StreamingContext if (paramInfo.Length == 1 && paramInfo[0].ParameterType == typeof(StreamingContext)) { if (found) BCLDebug.Assert(false, "Mutliple methods with same serialization attribute"); #endif mi.Add(m); #if _DEBUG found = true; } else BCLDebug.Assert(false, "Incorrect serialization event signature"); #endif } } #if _DEBUG found = false; #endif baseType = baseType.BaseType; } mi.Reverse(); // We should invoke the methods starting from base return (mi.Count == 0) ? null : mi; } internal SerializationEvents(Type t) { // Initialize all events m_OnSerializingMethods = GetMethodsWithAttribute(typeof(OnSerializingAttribute), t); m_OnSerializedMethods = GetMethodsWithAttribute(typeof(OnSerializedAttribute), t); m_OnDeserializingMethods = GetMethodsWithAttribute(typeof(OnDeserializingAttribute), t); m_OnDeserializedMethods = GetMethodsWithAttribute(typeof(OnDeserializedAttribute), t); } internal bool HasOnSerializingEvents { get { return m_OnSerializingMethods != null || m_OnSerializedMethods != null; } } internal void InvokeOnSerializing(Object obj, StreamingContext context) { BCLDebug.Assert(obj != null, "object should have been initialized"); // Invoke all OnSerializingMethods if (m_OnSerializingMethods != null) { Object[] p = new Object[] {context}; SerializationEventHandler handler = null; foreach(MethodInfo m in m_OnSerializingMethods) { SerializationEventHandler onSerializing = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onSerializing); } handler(context); } } internal void InvokeOnDeserializing(Object obj, StreamingContext context) { BCLDebug.Assert(obj != null, "object should have been initialized"); // Invoke all OnDeserializingMethods if (m_OnDeserializingMethods != null) { Object[] p = new Object[] {context}; SerializationEventHandler handler = null; foreach(MethodInfo m in m_OnDeserializingMethods) { SerializationEventHandler onDeserializing = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onDeserializing); } handler(context); } } internal void InvokeOnDeserialized(Object obj, StreamingContext context) { BCLDebug.Assert(obj != null, "object should have been initialized"); // Invoke all OnDeserializingMethods if (m_OnDeserializedMethods != null) { Object[] p = new Object[] {context}; SerializationEventHandler handler = null; foreach(MethodInfo m in m_OnDeserializedMethods) { SerializationEventHandler onDeserialized = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onDeserialized); } handler(context); } } internal SerializationEventHandler AddOnSerialized(Object obj, SerializationEventHandler handler) { // Add all OnSerialized methods to a delegate if (m_OnSerializedMethods != null) { foreach(MethodInfo m in m_OnSerializedMethods) { SerializationEventHandler onSerialized = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onSerialized); } } return handler; } internal SerializationEventHandler AddOnDeserialized(Object obj, SerializationEventHandler handler) { // Add all OnDeserialized methods to a delegate if (m_OnDeserializedMethods != null) { foreach(MethodInfo m in m_OnDeserializedMethods) { SerializationEventHandler onDeserialized = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onDeserialized); } } return handler; } } internal static class SerializationEventsCache { private static Hashtable cache = new Hashtable(); internal static SerializationEvents GetSerializationEventsForType(Type t) { SerializationEvents events; if ((events = (SerializationEvents)cache[t]) == null) { events = new SerializationEvents(t); cache[t] = events; // Add this to the cache. } return events; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** ** Class: SerializationEventsCache ** ** ** Purpose: Caches the various serialization events such as On(De)Seriliz(ed)ing ** ** ============================================================*/ namespace System.Runtime.Serialization { using System; using System.Collections; using System.Collections.Generic; using System.Reflection; using System.Reflection.Cache; using System.Globalization; internal class SerializationEvents { private List m_OnSerializingMethods = null; private List m_OnSerializedMethods = null; private List m_OnDeserializingMethods = null; private List m_OnDeserializedMethods = null; private List GetMethodsWithAttribute(Type attribute, Type t) { List mi = new List (); Type baseType = t; // Traverse the hierarchy to find all methods with the particular attribute while (baseType != null && baseType != typeof(Object)) { RuntimeType rt = (RuntimeType)baseType; // Get all methods which are declared on this type, instance and public or nonpublic MethodInfo[] mis = baseType.GetMethods(BindingFlags.DeclaredOnly | BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public); #if _DEBUG bool found = false; #endif foreach(MethodInfo m in mis) { // For each method find if attribute is present, the return type is void and the method is not virtual if (m.IsDefined(attribute, false)) { #if _DEBUG BCLDebug.Assert(m.ReturnType == typeof(void) && !m.IsVirtual, "serialization events methods cannot be virtual and need to have void return"); ParameterInfo[] paramInfo = m.GetParameters(); // Only add it if this method has one parameter of type StreamingContext if (paramInfo.Length == 1 && paramInfo[0].ParameterType == typeof(StreamingContext)) { if (found) BCLDebug.Assert(false, "Mutliple methods with same serialization attribute"); #endif mi.Add(m); #if _DEBUG found = true; } else BCLDebug.Assert(false, "Incorrect serialization event signature"); #endif } } #if _DEBUG found = false; #endif baseType = baseType.BaseType; } mi.Reverse(); // We should invoke the methods starting from base return (mi.Count == 0) ? null : mi; } internal SerializationEvents(Type t) { // Initialize all events m_OnSerializingMethods = GetMethodsWithAttribute(typeof(OnSerializingAttribute), t); m_OnSerializedMethods = GetMethodsWithAttribute(typeof(OnSerializedAttribute), t); m_OnDeserializingMethods = GetMethodsWithAttribute(typeof(OnDeserializingAttribute), t); m_OnDeserializedMethods = GetMethodsWithAttribute(typeof(OnDeserializedAttribute), t); } internal bool HasOnSerializingEvents { get { return m_OnSerializingMethods != null || m_OnSerializedMethods != null; } } internal void InvokeOnSerializing(Object obj, StreamingContext context) { BCLDebug.Assert(obj != null, "object should have been initialized"); // Invoke all OnSerializingMethods if (m_OnSerializingMethods != null) { Object[] p = new Object[] {context}; SerializationEventHandler handler = null; foreach(MethodInfo m in m_OnSerializingMethods) { SerializationEventHandler onSerializing = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onSerializing); } handler(context); } } internal void InvokeOnDeserializing(Object obj, StreamingContext context) { BCLDebug.Assert(obj != null, "object should have been initialized"); // Invoke all OnDeserializingMethods if (m_OnDeserializingMethods != null) { Object[] p = new Object[] {context}; SerializationEventHandler handler = null; foreach(MethodInfo m in m_OnDeserializingMethods) { SerializationEventHandler onDeserializing = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onDeserializing); } handler(context); } } internal void InvokeOnDeserialized(Object obj, StreamingContext context) { BCLDebug.Assert(obj != null, "object should have been initialized"); // Invoke all OnDeserializingMethods if (m_OnDeserializedMethods != null) { Object[] p = new Object[] {context}; SerializationEventHandler handler = null; foreach(MethodInfo m in m_OnDeserializedMethods) { SerializationEventHandler onDeserialized = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onDeserialized); } handler(context); } } internal SerializationEventHandler AddOnSerialized(Object obj, SerializationEventHandler handler) { // Add all OnSerialized methods to a delegate if (m_OnSerializedMethods != null) { foreach(MethodInfo m in m_OnSerializedMethods) { SerializationEventHandler onSerialized = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onSerialized); } } return handler; } internal SerializationEventHandler AddOnDeserialized(Object obj, SerializationEventHandler handler) { // Add all OnDeserialized methods to a delegate if (m_OnDeserializedMethods != null) { foreach(MethodInfo m in m_OnDeserializedMethods) { SerializationEventHandler onDeserialized = (SerializationEventHandler)Delegate.InternalCreateDelegate(typeof(SerializationEventHandler), obj, m); handler = (SerializationEventHandler)Delegate.Combine(handler, onDeserialized); } } return handler; } } internal static class SerializationEventsCache { private static Hashtable cache = new Hashtable(); internal static SerializationEvents GetSerializationEventsForType(Type t) { SerializationEvents events; if ((events = (SerializationEvents)cache[t]) == null) { events = new SerializationEvents(t); cache[t] = events; // Add this to the cache. } return events; } } } // 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
- FixedSOMTable.cs
- AuthenticationException.cs
- PTProvider.cs
- relpropertyhelper.cs
- FontResourceCache.cs
- RefExpr.cs
- WebPartConnection.cs
- ClientSettingsProvider.cs
- TypeAccessException.cs
- TracingConnectionInitiator.cs
- StaticFileHandler.cs
- BamlTreeMap.cs
- BitmapImage.cs
- EntityDesignerUtils.cs
- DrawingCollection.cs
- Encoder.cs
- BamlRecordHelper.cs
- HtmlTernaryTree.cs
- SmtpNegotiateAuthenticationModule.cs
- UrlPath.cs
- ToolStripManager.cs
- SineEase.cs
- HyperLinkStyle.cs
- CustomValidator.cs
- AcceleratedTokenProviderState.cs
- RawUIStateInputReport.cs
- BitStack.cs
- DataGridViewCellErrorTextNeededEventArgs.cs
- coordinator.cs
- ConfigurationLockCollection.cs
- PersonalizationEntry.cs
- MaterialGroup.cs
- CorrelationTokenTypeConvertor.cs
- SqlConnectionStringBuilder.cs
- UnmanagedHandle.cs
- JournalNavigationScope.cs
- XsltFunctions.cs
- HelpOperationInvoker.cs
- SqlBuffer.cs
- ConfigXmlWhitespace.cs
- SystemResourceHost.cs
- URIFormatException.cs
- CodeNamespace.cs
- sapiproxy.cs
- XmlBindingWorker.cs
- XmlSchemaAnnotation.cs
- DoubleLink.cs
- PageSetupDialog.cs
- XmlSchemaComplexContentExtension.cs
- TwoPhaseCommitProxy.cs
- ListViewGroupConverter.cs
- WebServiceMethodData.cs
- DataViewSetting.cs
- IndentTextWriter.cs
- _ServiceNameStore.cs
- WinEventQueueItem.cs
- SchemaImporterExtensionsSection.cs
- CqlQuery.cs
- CodeTypeReference.cs
- DecoderBestFitFallback.cs
- PackageStore.cs
- MenuScrollingVisibilityConverter.cs
- LightweightCodeGenerator.cs
- Model3DCollection.cs
- Speller.cs
- BitmapEffectRenderDataResource.cs
- QilTypeChecker.cs
- FontFaceLayoutInfo.cs
- XmlSerializationGeneratedCode.cs
- MenuAdapter.cs
- UniqueIdentifierService.cs
- MobileControlsSectionHandler.cs
- PenLineJoinValidation.cs
- RegisteredScript.cs
- PointF.cs
- ExpressionBuilderCollection.cs
- MouseEvent.cs
- NotifyInputEventArgs.cs
- BrowserCapabilitiesFactory35.cs
- AnimationClock.cs
- HttpTransportManager.cs
- X509SecurityTokenAuthenticator.cs
- Html32TextWriter.cs
- SafeFindHandle.cs
- QueryCacheManager.cs
- FileLevelControlBuilderAttribute.cs
- XPathScanner.cs
- PropertyCondition.cs
- FormClosingEvent.cs
- Renderer.cs
- XPathEmptyIterator.cs
- XmlIncludeAttribute.cs
- XmlLinkedNode.cs
- TraceHelpers.cs
- PermissionAttributes.cs
- Section.cs
- XmlException.cs
- ResolveResponse.cs
- InstanceCreationEditor.cs
- relpropertyhelper.cs