Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / Objects / DataClasses / RelationshipNavigation.cs / 1 / RelationshipNavigation.cs
//----------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//
// @owner [....]
// @backupOwner [....]
//---------------------------------------------------------------------
using System;
using System.Collections.Generic;
using System.Data.Common;
using System.Globalization;
using System.Text;
namespace System.Data.Objects.DataClasses
{
///
/// This class describes a relationship navigation from the
/// navigation property on one entity to another entity. It is
/// used throughout the collections and refs system to describe a
/// relationship and to connect from the navigation property on
/// one end of a relationship to the navigation property on the
/// other end.
///
// devnote: Might be able to change this back to a valuetype given its current purpose
[Serializable]
internal class RelationshipNavigation
{
// ------------
// Constructors
// ------------
///
/// Creates a navigation object with the given relationship
/// name, role name for the source and role name for the
/// destination.
///
/// Canonical-space name of the relationship.
/// Name of the role/navigation property which is the source of the navigation.
/// Name of the role/navigation property which is the destination of the navigation.
internal RelationshipNavigation(string relationshipName, string from, string to)
{
EntityUtil.CheckStringArgument(relationshipName, "relationshipName");
EntityUtil.CheckStringArgument(from, "from");
EntityUtil.CheckStringArgument(to, "to");
_relationshipName = relationshipName;
_from = from;
_to = to;
}
// ------
// Fields
// ------
// 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 readonly string _relationshipName;
private readonly string _from;
private readonly string _to;
[NonSerialized]
private RelationshipNavigation _reverse;
// ----------
// Properties
// ----------
///
/// Canonical-space relationship name.
///
internal string RelationshipName
{
get
{
return _relationshipName;
}
}
///
/// Role/navigation property name for the source of this navigation.
///
internal string From
{
get
{
return _from;
}
}
///
/// Role/navigation property name for the destination of this navigation.
///
internal string To
{
get
{
return _to;
}
}
///
/// The "reverse" version of this navigation.
///
internal RelationshipNavigation Reverse
{
get
{
if (_reverse == null)
{
// the reverse relationship is exactly like this
// one but from & to are switched
_reverse = new RelationshipNavigation(_relationshipName, _to, _from);
}
return _reverse;
}
}
///
/// Compares this instance to a given Navigation by their values.
///
public override bool Equals(object obj)
{
RelationshipNavigation compareTo = obj as RelationshipNavigation;
return ((this == compareTo)
|| ((null != this) && (null != compareTo)
&& (this.RelationshipName == compareTo.RelationshipName)
&& (this.From == compareTo.From)
&& (this.To == compareTo.To)));
}
///
/// Returns a value-based hash code.
///
/// the hash value of this Navigation
public override int GetHashCode()
{
return this.RelationshipName.GetHashCode();
}
// -------
// Methods
// -------
///
/// ToString is provided to simplify debugging, etc.
///
public override string ToString()
{
return String.Format(CultureInfo.InvariantCulture,
"RelationshipNavigation: ({0},{1},{2})",
_relationshipName,
_from,
_to);
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
//----------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//
// @owner [....]
// @backupOwner [....]
//---------------------------------------------------------------------
using System;
using System.Collections.Generic;
using System.Data.Common;
using System.Globalization;
using System.Text;
namespace System.Data.Objects.DataClasses
{
///
/// This class describes a relationship navigation from the
/// navigation property on one entity to another entity. It is
/// used throughout the collections and refs system to describe a
/// relationship and to connect from the navigation property on
/// one end of a relationship to the navigation property on the
/// other end.
///
// devnote: Might be able to change this back to a valuetype given its current purpose
[Serializable]
internal class RelationshipNavigation
{
// ------------
// Constructors
// ------------
///
/// Creates a navigation object with the given relationship
/// name, role name for the source and role name for the
/// destination.
///
/// Canonical-space name of the relationship.
/// Name of the role/navigation property which is the source of the navigation.
/// Name of the role/navigation property which is the destination of the navigation.
internal RelationshipNavigation(string relationshipName, string from, string to)
{
EntityUtil.CheckStringArgument(relationshipName, "relationshipName");
EntityUtil.CheckStringArgument(from, "from");
EntityUtil.CheckStringArgument(to, "to");
_relationshipName = relationshipName;
_from = from;
_to = to;
}
// ------
// Fields
// ------
// 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 readonly string _relationshipName;
private readonly string _from;
private readonly string _to;
[NonSerialized]
private RelationshipNavigation _reverse;
// ----------
// Properties
// ----------
///
/// Canonical-space relationship name.
///
internal string RelationshipName
{
get
{
return _relationshipName;
}
}
///
/// Role/navigation property name for the source of this navigation.
///
internal string From
{
get
{
return _from;
}
}
///
/// Role/navigation property name for the destination of this navigation.
///
internal string To
{
get
{
return _to;
}
}
///
/// The "reverse" version of this navigation.
///
internal RelationshipNavigation Reverse
{
get
{
if (_reverse == null)
{
// the reverse relationship is exactly like this
// one but from & to are switched
_reverse = new RelationshipNavigation(_relationshipName, _to, _from);
}
return _reverse;
}
}
///
/// Compares this instance to a given Navigation by their values.
///
public override bool Equals(object obj)
{
RelationshipNavigation compareTo = obj as RelationshipNavigation;
return ((this == compareTo)
|| ((null != this) && (null != compareTo)
&& (this.RelationshipName == compareTo.RelationshipName)
&& (this.From == compareTo.From)
&& (this.To == compareTo.To)));
}
///
/// Returns a value-based hash code.
///
/// the hash value of this Navigation
public override int GetHashCode()
{
return this.RelationshipName.GetHashCode();
}
// -------
// Methods
// -------
///
/// ToString is provided to simplify debugging, etc.
///
public override string ToString()
{
return String.Format(CultureInfo.InvariantCulture,
"RelationshipNavigation: ({0},{1},{2})",
_relationshipName,
_from,
_to);
}
}
}
// 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
- Int32AnimationUsingKeyFrames.cs
- TextChange.cs
- PersonalizationProviderHelper.cs
- FacetDescription.cs
- WindowsStatusBar.cs
- WorkflowOperationAsyncResult.cs
- ITreeGenerator.cs
- SectionXmlInfo.cs
- ListBoxAutomationPeer.cs
- MessageBox.cs
- Queue.cs
- ColorMatrix.cs
- Coordinator.cs
- TypeForwardedToAttribute.cs
- ValidatingPropertiesEventArgs.cs
- RsaSecurityToken.cs
- OutputCacheProfile.cs
- ContentIterators.cs
- SiteMapDataSource.cs
- LineVisual.cs
- EntityProviderServices.cs
- Converter.cs
- DropAnimation.xaml.cs
- PropertyKey.cs
- ArraySegment.cs
- LeafCellTreeNode.cs
- LogicalTreeHelper.cs
- QuadraticEase.cs
- Utils.cs
- PackageDigitalSignatureManager.cs
- MdiWindowListItemConverter.cs
- SignatureDescription.cs
- Journaling.cs
- MimeXmlReflector.cs
- Object.cs
- DESCryptoServiceProvider.cs
- ObjectHandle.cs
- WebPartRestoreVerb.cs
- PreloadedPackages.cs
- LinkAreaEditor.cs
- TextViewBase.cs
- DynamicDataResources.Designer.cs
- XmlObjectSerializerReadContextComplex.cs
- SymbolMethod.cs
- printdlgexmarshaler.cs
- DetailsViewRow.cs
- SizeConverter.cs
- Point3D.cs
- WebPartEditorApplyVerb.cs
- Context.cs
- Form.cs
- EnumConverter.cs
- ProxyElement.cs
- DemultiplexingClientMessageFormatter.cs
- DriveInfo.cs
- Int32Rect.cs
- ModifiableIteratorCollection.cs
- ImageField.cs
- TreeSet.cs
- FontInfo.cs
- DataContractAttribute.cs
- DependencyObjectType.cs
- FramingEncoders.cs
- CommonXSendMessage.cs
- QuaternionRotation3D.cs
- MetadataArtifactLoaderComposite.cs
- RunWorkerCompletedEventArgs.cs
- AttributeAction.cs
- Literal.cs
- Literal.cs
- Thread.cs
- Pointer.cs
- tabpagecollectioneditor.cs
- DocumentEventArgs.cs
- SqlGenerator.cs
- VariableAction.cs
- Geometry3D.cs
- UrlPath.cs
- TextElementEditingBehaviorAttribute.cs
- DataGridRowAutomationPeer.cs
- TimeoutException.cs
- Int64AnimationUsingKeyFrames.cs
- UrlEncodedParameterWriter.cs
- BevelBitmapEffect.cs
- SoapElementAttribute.cs
- WriteableBitmap.cs
- HistoryEventArgs.cs
- OleServicesContext.cs
- PixelFormats.cs
- XmlDictionaryWriter.cs
- FixedHyperLink.cs
- FileLogRecord.cs
- ReflectionUtil.cs
- CustomAttributeBuilder.cs
- DesignerDataView.cs
- TransactedBatchingElement.cs
- PropertyStore.cs
- CaseInsensitiveHashCodeProvider.cs
- SecurityElement.cs
- MetadataStore.cs