You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			173 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			173 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //---------------------------------------------------------------------
 | |
| // <copyright file="ComplexObject.cs" company="Microsoft">
 | |
| //      Copyright (c) Microsoft Corporation.  All rights reserved.
 | |
| // </copyright>
 | |
| //
 | |
| // @owner       [....]
 | |
| // @backupOwner [....]
 | |
| //---------------------------------------------------------------------
 | |
| using System.Data;
 | |
| using System.Diagnostics;
 | |
| using System.Reflection;
 | |
| using System.ComponentModel;
 | |
| using System.Runtime.Serialization;
 | |
| 
 | |
| namespace System.Data.Objects.DataClasses
 | |
| {
 | |
|     /// <summary>
 | |
|     /// This is the interface that represent the minimum interface required
 | |
|     /// to be an entity in ADO.NET.
 | |
|     /// </summary>
 | |
|     [DataContract(IsReference = true)]
 | |
|     [Serializable]
 | |
|     public abstract class ComplexObject : StructuralObject
 | |
|     {
 | |
|         // The following fields are serialized.  Adding or removing a serialized field is considered
 | |
|         // a breaking change.  This includes changing the field type or field name of existing
 | |
|         // serialized fields. If you need to make this kind of change, it may be possible, but it
 | |
|         // will require some custom serialization/deserialization code.
 | |
|         private StructuralObject _parent;     // Object that contains this ComplexObject (can be Entity or ComplexObject)
 | |
|         private string _parentPropertyName;   // Property name for this type on the containing object
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Associate the ComplexType with an Entity or another ComplexObject
 | |
|         /// Parent may be an Entity or ComplexObject
 | |
|         /// </summary>
 | |
|         /// <param name="parent">Object to be added to.</param>
 | |
|         /// <param name="parentPropertyName">The property on the parent that reference the complex type.</param>
 | |
|         internal void AttachToParent(
 | |
|             StructuralObject parent,
 | |
|             string parentPropertyName)
 | |
|         {
 | |
|             Debug.Assert(null != parent, "Attempt to attach to a null parent");
 | |
|             Debug.Assert(null != parentPropertyName, "Must provide parentPropertyName in order to attach");
 | |
| 
 | |
|             if (_parent != null)
 | |
|             {
 | |
|                 throw EntityUtil.ComplexObjectAlreadyAttachedToParent();
 | |
|             }
 | |
| 
 | |
|             Debug.Assert(_parentPropertyName == null);
 | |
| 
 | |
|             _parent = parent;
 | |
|             _parentPropertyName = parentPropertyName;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Removes this instance from the parent it was attached to. 
 | |
|         /// Parent may be an Entity or ComplexObject
 | |
|         /// </summary>
 | |
|         internal void DetachFromParent()
 | |
|         {
 | |
|             // We will null out _parent and _parentPropertyName anyway, so if they are already null
 | |
|             // it is an unexpected condition, but should not cause a failure in released code
 | |
|             Debug.Assert(_parent != null, "Attempt to detach from a null _parent");
 | |
|             Debug.Assert(_parentPropertyName != null, "Null _parentPropertyName on a non-null _parent");
 | |
| 
 | |
|             _parent = null;
 | |
|             _parentPropertyName = null;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Reports that a change is about to occur to one of the properties of this instance
 | |
|         /// to the containing object and then continues default change
 | |
|         /// reporting behavior.
 | |
|         /// </summary>
 | |
|         protected sealed override void ReportPropertyChanging(
 | |
|             string property)
 | |
|         {
 | |
|             EntityUtil.CheckStringArgument(property, "property");
 | |
| 
 | |
|             base.ReportPropertyChanging(property);
 | |
| 
 | |
|             // Since we are a ComplexObject, all changes (scalar or complex) are considered complex property changes            
 | |
|             ReportComplexPropertyChanging(null, this, property);            
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Reports a change to one of the properties of this instance
 | |
|         /// to the containing object and then continues default change
 | |
|         /// reporting behavior.
 | |
|         /// </summary>
 | |
|         protected sealed override void ReportPropertyChanged(
 | |
|             string property)
 | |
|         {
 | |
|             EntityUtil.CheckStringArgument(property, "property");
 | |
| 
 | |
|             // Since we are a ComplexObject, all changes (scalar or complex) are considered complex property changes
 | |
|             ReportComplexPropertyChanged(null, this, property);
 | |
|             
 | |
|             base.ReportPropertyChanged(property);
 | |
|         }
 | |
| 
 | |
| 
 | |
|         internal sealed override bool IsChangeTracked
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return _parent == null ? false : _parent.IsChangeTracked;                
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// This method is used to report all changes on this ComplexObject to its parent entity or ComplexObject
 | |
|         /// </summary>
 | |
|         /// <param name="entityMemberName">
 | |
|         /// Should be null in this method override.
 | |
|         /// This is only relevant in Entity's implementation of this method, so it is unused here
 | |
|         /// Instead of passing the most-derived property name up the hierarchy, we will always pass the current _parentPropertyName
 | |
|         /// Once this gets up to the Entity, it will actually use the value that was passed in
 | |
|         /// </param>
 | |
|         /// <param name="complexObject">
 | |
|         /// The instance of the object on which the property is changing.
 | |
|         /// </param>
 | |
|         /// <param name="complexMemberName">
 | |
|         /// The name of the changing property on complexObject.
 | |
|         /// </param>
 | |
|         internal sealed override void ReportComplexPropertyChanging(
 | |
|             string entityMemberName, ComplexObject complexObject, string complexMemberName)
 | |
|         {
 | |
|             // entityMemberName is unused here because we just keep passing the current parent name up the hierarchy
 | |
|             // This value is only used in the EntityObject override of this method
 | |
| 
 | |
|             Debug.Assert(complexObject != null, "invalid complexObject");
 | |
|             Debug.Assert(!String.IsNullOrEmpty(complexMemberName), "invalid complexMemberName");
 | |
|             
 | |
|             if (null != _parent)
 | |
|             {
 | |
|                 _parent.ReportComplexPropertyChanging(_parentPropertyName, complexObject, complexMemberName);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// This method is used to report all changes on this ComplexObject to its parent entity or ComplexObject
 | |
|         /// </summary>
 | |
|         /// <param name="entityMemberName">
 | |
|         /// Should be null in this method override.
 | |
|         /// This is only relevant in Entity's implementation of this method, so it is unused here
 | |
|         /// Instead of passing the most-derived property name up the hierarchy, we will always pass the current _parentPropertyName
 | |
|         /// Once this gets up to the Entity, it will actually use the value that was passed in.
 | |
|         /// </param>
 | |
|         /// <param name="complexObject">
 | |
|         /// The instance of the object on which the property is changing.
 | |
|         /// </param>
 | |
|         /// <param name="complexMemberName">
 | |
|         /// The name of the changing property on complexObject.
 | |
|         /// </param>
 | |
|         internal sealed override void ReportComplexPropertyChanged(
 | |
|             string entityMemberName, ComplexObject complexObject, string complexMemberName)
 | |
|         {
 | |
|             // entityMemberName is unused here because we just keep passing the current parent name up the hierarchy
 | |
|             // This value is only used in the EntityObject override of this method
 | |
| 
 | |
|             Debug.Assert(complexObject != null, "invalid complexObject");
 | |
|             Debug.Assert(!String.IsNullOrEmpty(complexMemberName), "invalid complexMemberName");
 | |
| 
 | |
|             if (null != _parent)
 | |
|             {
 | |
|                 _parent.ReportComplexPropertyChanged(_parentPropertyName, complexObject, complexMemberName);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 |