Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DataEntity / System / Data / Objects / Internal / SnapshotChangeTrackingStrategy.cs / 1305376 / SnapshotChangeTrackingStrategy.cs
using System; using System.Collections.Generic; using System.Text; using System.Data.Objects.DataClasses; namespace System.Data.Objects.Internal { ////// Implementation of the change tracking strategy for entities that require snapshot change tracking. /// These are typically entities that do not implement IEntityWithChangeTracker. /// internal sealed class SnapshotChangeTrackingStrategy : IChangeTrackingStrategy { private static SnapshotChangeTrackingStrategy _instance = new SnapshotChangeTrackingStrategy(); ////// Returns the single static instance of this class; a single instance is all that is needed /// because the class is stateless. /// public static SnapshotChangeTrackingStrategy Instance { get { return _instance; } } // Private constructor to help prevent additional instances being created. private SnapshotChangeTrackingStrategy() { } // See IChangeTrackingStrategy documentation public void SetChangeTracker(IEntityChangeTracker changeTracker) { // Nothing to do when using snapshots for change tracking } // See IChangeTrackingStrategy documentation public void TakeSnapshot(EntityEntry entry) { if (entry != null) { entry.TakeSnapshot(false); } } // See IChangeTrackingStrategy documentation public void SetCurrentValue(EntityEntry entry, StateManagerMemberMetadata member, int ordinal, object target, object value) { // If the target is the entity, then this is a change to a member on the entity itself rather than // a change to some complex type hanging off the entity. In this case we can use the change tracking // API in the normal way. if (Object.ReferenceEquals(target, entry.Entity)) { // equivalent of EntityObject.ReportPropertyChanging() ((IEntityChangeTracker)entry).EntityMemberChanging(member.CLayerName); member.SetValue(target, value); // equivalent of EntityObject.ReportPropertyChanged() ((IEntityChangeTracker)entry).EntityMemberChanged(member.CLayerName); if (member.IsComplex) { // This is required because the OSE contains a separate cache of user objects for // complex objects such that original values can be looked up correctly. entry.UpdateComplexObjectSnapshot(member, target, ordinal, value); } } else { // Must be a complex type. We would like to do this: // ((IEntityChangeTracker)entry).EntityComplexMemberChanging(topLevelMember.CLayerName, target, member.CLayerName); // ((IEntityChangeTracker)entry).EntityComplexMemberChanged(topLevelMember.CLayerName, target, member.CLayerName); // // However, we have no way of getting the topLevelMember.CLayerName. This is because the value record does not // contain any reference to its parent. (In non-POCO, ComplexObject takes care of this.) // Therefore, in this case we are going to just call a localized DetectChanges to make sure that changes in the // complex types are found. // // Note that this case only happens when the entity is POCO and complex types are set through the CurrentValues // object. This is probably not a very common pattern. member.SetValue(target, value); if (entry.State != EntityState.Added) { // Entry is not Detached - checked in ValidateState() in EntityEntry.SetCurrentEntityValue entry.DetectChangesInProperties(true); } } } // See IChangeTrackingStrategy documentation public void UpdateCurrentValueRecord(object value, EntityEntry entry) { // No change tracker, but may or may not be a proxy entry.UpdateRecordWithoutSetModified(value, entry.CurrentValues); entry.DetectChangesInProperties(false); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System; using System.Collections.Generic; using System.Text; using System.Data.Objects.DataClasses; namespace System.Data.Objects.Internal { ////// Implementation of the change tracking strategy for entities that require snapshot change tracking. /// These are typically entities that do not implement IEntityWithChangeTracker. /// internal sealed class SnapshotChangeTrackingStrategy : IChangeTrackingStrategy { private static SnapshotChangeTrackingStrategy _instance = new SnapshotChangeTrackingStrategy(); ////// Returns the single static instance of this class; a single instance is all that is needed /// because the class is stateless. /// public static SnapshotChangeTrackingStrategy Instance { get { return _instance; } } // Private constructor to help prevent additional instances being created. private SnapshotChangeTrackingStrategy() { } // See IChangeTrackingStrategy documentation public void SetChangeTracker(IEntityChangeTracker changeTracker) { // Nothing to do when using snapshots for change tracking } // See IChangeTrackingStrategy documentation public void TakeSnapshot(EntityEntry entry) { if (entry != null) { entry.TakeSnapshot(false); } } // See IChangeTrackingStrategy documentation public void SetCurrentValue(EntityEntry entry, StateManagerMemberMetadata member, int ordinal, object target, object value) { // If the target is the entity, then this is a change to a member on the entity itself rather than // a change to some complex type hanging off the entity. In this case we can use the change tracking // API in the normal way. if (Object.ReferenceEquals(target, entry.Entity)) { // equivalent of EntityObject.ReportPropertyChanging() ((IEntityChangeTracker)entry).EntityMemberChanging(member.CLayerName); member.SetValue(target, value); // equivalent of EntityObject.ReportPropertyChanged() ((IEntityChangeTracker)entry).EntityMemberChanged(member.CLayerName); if (member.IsComplex) { // This is required because the OSE contains a separate cache of user objects for // complex objects such that original values can be looked up correctly. entry.UpdateComplexObjectSnapshot(member, target, ordinal, value); } } else { // Must be a complex type. We would like to do this: // ((IEntityChangeTracker)entry).EntityComplexMemberChanging(topLevelMember.CLayerName, target, member.CLayerName); // ((IEntityChangeTracker)entry).EntityComplexMemberChanged(topLevelMember.CLayerName, target, member.CLayerName); // // However, we have no way of getting the topLevelMember.CLayerName. This is because the value record does not // contain any reference to its parent. (In non-POCO, ComplexObject takes care of this.) // Therefore, in this case we are going to just call a localized DetectChanges to make sure that changes in the // complex types are found. // // Note that this case only happens when the entity is POCO and complex types are set through the CurrentValues // object. This is probably not a very common pattern. member.SetValue(target, value); if (entry.State != EntityState.Added) { // Entry is not Detached - checked in ValidateState() in EntityEntry.SetCurrentEntityValue entry.DetectChangesInProperties(true); } } } // See IChangeTrackingStrategy documentation public void UpdateCurrentValueRecord(object value, EntityEntry entry) { // No change tracker, but may or may not be a proxy entry.UpdateRecordWithoutSetModified(value, entry.CurrentValues); entry.DetectChangesInProperties(false); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- WorkflowRuntimeEndpoint.cs
- OleDbConnectionInternal.cs
- WizardStepBase.cs
- LingerOption.cs
- XslUrlEditor.cs
- ContractMapping.cs
- OdbcCommandBuilder.cs
- NavigationWindowAutomationPeer.cs
- SpeakInfo.cs
- UIAgentInitializationException.cs
- PerformanceCounterLib.cs
- ProfilePropertySettingsCollection.cs
- BlockExpression.cs
- CommandConverter.cs
- TypeListConverter.cs
- QuadTree.cs
- AuthenticatedStream.cs
- TreeNodeStyle.cs
- COM2PropertyDescriptor.cs
- ColumnCollection.cs
- StdValidatorsAndConverters.cs
- SimpleType.cs
- StylusDevice.cs
- TemplateXamlParser.cs
- ObjectDataSourceStatusEventArgs.cs
- SiteMapNodeItemEventArgs.cs
- CommandEventArgs.cs
- SplineQuaternionKeyFrame.cs
- _NestedSingleAsyncResult.cs
- RoleManagerSection.cs
- ContextMenu.cs
- SafeHandle.cs
- PersonalizationStateInfoCollection.cs
- ImageFormat.cs
- PtsCache.cs
- AsymmetricSignatureDeformatter.cs
- MarkupCompiler.cs
- CustomTrackingQuery.cs
- DataColumnMapping.cs
- ComponentChangedEvent.cs
- DayRenderEvent.cs
- LoginUtil.cs
- ByteStorage.cs
- MenuItem.cs
- AssemblyCollection.cs
- CopyNamespacesAction.cs
- ApplicationServiceManager.cs
- DataIdProcessor.cs
- HtmlTitle.cs
- SplitterPanelDesigner.cs
- InfoCardArgumentException.cs
- FilterableAttribute.cs
- SafeNativeMethods.cs
- PropertyMapper.cs
- DataSourceHelper.cs
- ScriptBehaviorDescriptor.cs
- X509CertificateCollection.cs
- ExpressionBuilderCollection.cs
- FeatureSupport.cs
- MulticastOption.cs
- EntityProviderServices.cs
- _NTAuthentication.cs
- BinaryConverter.cs
- HttpBindingExtension.cs
- Aggregates.cs
- coordinatorscratchpad.cs
- ToolZone.cs
- HealthMonitoringSection.cs
- MetricEntry.cs
- Base64Encoding.cs
- SiteIdentityPermission.cs
- BasicCellRelation.cs
- ActivityDesigner.cs
- ClientSponsor.cs
- SpotLight.cs
- Membership.cs
- ButtonFlatAdapter.cs
- ObjectTokenCategory.cs
- OleDbCommand.cs
- RegionInfo.cs
- XmlNode.cs
- StructuredType.cs
- XmlReader.cs
- BeginCreateSecurityTokenRequest.cs
- PrivateFontCollection.cs
- TreeChangeInfo.cs
- PartitionResolver.cs
- HttpWebResponse.cs
- UInt64.cs
- TextProviderWrapper.cs
- UnsafeNetInfoNativeMethods.cs
- MemoryMappedFile.cs
- NotImplementedException.cs
- StringFunctions.cs
- Int32CAMarshaler.cs
- MaterialCollection.cs
- DeclarationUpdate.cs
- Latin1Encoding.cs
- ObjectQuery_EntitySqlExtensions.cs
- SQLGuid.cs