Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DataWeb / Server / System / Data / Services / ExpandSegment.cs / 1407647 / ExpandSegment.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // //// Provides a description of a segment in an $expand query option // for a WCF Data Service. // // // @owner [....] //--------------------------------------------------------------------- namespace System.Data.Services { #region Namespaces. using System; using System.Collections.Generic; using System.Data.Services.Providers; using System.Diagnostics; using System.Linq.Expressions; #endregion Namespaces. ////// Provides a description of a segment in an $expand query option for a WCF Data Service. /// ////// INTERNAL /// Expand providers may replace segments to indicate a different expansion shape. However, they are /// unable to set the MaxResultsExpected. The value for the instances created by external providers /// will always be Int32.MaxValue, but the value enforced by the serializers will be the one declared /// by the data service in the configuration. /// /// When the configuration supports a more granular value, we should overload the constructor to make /// the MaxResultsExpected property settable as well. /// [DebuggerDisplay("ExpandSegment ({name},Filter={filter})]")] public class ExpandSegment { #region Private fields. ///Container to which the segment belongs; possibly null. private readonly ResourceSetWrapper container; ///Filter expression for this segment on an $expand path. private readonly Expression filter; ///Name for this segment on an $expand path. private readonly string name; ///Property being expanded. private readonly ResourceProperty expandedProperty; ////// The maximum number of results expected for this property; Int32.MaxValue if no limit is expected. /// private readonly int maxResultsExpected; ///Collection of ordering information for this segment, used for paging private readonly OrderingInfo orderingInfo; #endregion Private fields. #region Constructors. ///Initializes a new /// Segment name. /// Filter expression for segment, possibly null. public ExpandSegment(string name, Expression filter) : this(name, filter, Int32.MaxValue, null, null, null) { } ///instance. Initializes a new /// Segment name. /// Filter expression for segment, possibly null. /// /// Expand providers may choose to return at most MaxResultsExpected + 1 elements to allow the /// data service to detect a failure to meet this constraint. /// /// Container to which the segment belongs; possibly null. /// Property expanded by this expand segment /// Collection of ordering information for this segment, used for paging internal ExpandSegment( string name, Expression filter, int maxResultsExpected, ResourceSetWrapper container, ResourceProperty expandedProperty, OrderingInfo orderingInfo) { WebUtil.CheckArgumentNull(name, "name"); CheckFilterType(filter); this.name = name; this.filter = filter; this.container = container; this.maxResultsExpected = maxResultsExpected; this.expandedProperty = expandedProperty; this.orderingInfo = orderingInfo; } #endregion Constructors. #region Public properties. ///instance. Filter expression for this segment on an $expand path. public Expression Filter { get { return this.filter; } } ///Whether this segment has a filter. public bool HasFilter { get { return this.Filter != null; } } ////// The maximum number of results expected for this property; Int32.MaxValue if no limit is expected. /// ////// Expand providers may choose to return at most MaxResultsExpected + 1 elements to allow the /// data service to detect a failure to meet this constraint. /// public int MaxResultsExpected { get { return this.maxResultsExpected; } } ///Name for this segment on an $expand path. public string Name { get { return this.name; } } ///Property being expanded. public ResourceProperty ExpandedProperty { get { return this.expandedProperty; } } ///Collection of ordering information for this segment, used for paging internal OrderingInfo OrderingInfo { get { return this.orderingInfo; } } #endregion Public properties. #region Internal properties. ///Gets the container to which this segment belongs; possibly null. internal ResourceSetWrapper Container { get { return this.container; } } #endregion Internal properties. #region Public methods. ///Checks whether any segments in the specified /// Path with segments to check. ///have a filter. true if any of the segments in public static bool PathHasFilter(IEnumerablehas a filter; false otherwise. path) { WebUtil.CheckArgumentNull(path, "path"); foreach (ExpandSegment segment in path) { if (segment.HasFilter) { return true; } } return false; } #endregion Public methods. #region Private methods. /// Checks that the specified filter is of the right type. /// Filter to check. private static void CheckFilterType(Expression filter) { if (filter == null) { return; } if (filter.NodeType != ExpressionType.Lambda) { throw new ArgumentException(Strings.ExpandSegment_FilterShouldBeLambda(filter.NodeType), "filter"); } LambdaExpression lambda = (LambdaExpression)filter; if (lambda.Body.Type != typeof(bool) && lambda.Body.Type != typeof(bool?)) { throw new ArgumentException( Strings.ExpandSegment_FilterBodyShouldReturnBool(lambda.Body.Type), "filter"); } if (lambda.Parameters.Count != 1) { throw new ArgumentException( Strings.ExpandSegment_FilterBodyShouldTakeOneParameter(lambda.Parameters.Count), "filter"); } } #endregion Private methods. } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // //// Provides a description of a segment in an $expand query option // for a WCF Data Service. // // // @owner [....] //--------------------------------------------------------------------- namespace System.Data.Services { #region Namespaces. using System; using System.Collections.Generic; using System.Data.Services.Providers; using System.Diagnostics; using System.Linq.Expressions; #endregion Namespaces. ////// Provides a description of a segment in an $expand query option for a WCF Data Service. /// ////// INTERNAL /// Expand providers may replace segments to indicate a different expansion shape. However, they are /// unable to set the MaxResultsExpected. The value for the instances created by external providers /// will always be Int32.MaxValue, but the value enforced by the serializers will be the one declared /// by the data service in the configuration. /// /// When the configuration supports a more granular value, we should overload the constructor to make /// the MaxResultsExpected property settable as well. /// [DebuggerDisplay("ExpandSegment ({name},Filter={filter})]")] public class ExpandSegment { #region Private fields. ///Container to which the segment belongs; possibly null. private readonly ResourceSetWrapper container; ///Filter expression for this segment on an $expand path. private readonly Expression filter; ///Name for this segment on an $expand path. private readonly string name; ///Property being expanded. private readonly ResourceProperty expandedProperty; ////// The maximum number of results expected for this property; Int32.MaxValue if no limit is expected. /// private readonly int maxResultsExpected; ///Collection of ordering information for this segment, used for paging private readonly OrderingInfo orderingInfo; #endregion Private fields. #region Constructors. ///Initializes a new /// Segment name. /// Filter expression for segment, possibly null. public ExpandSegment(string name, Expression filter) : this(name, filter, Int32.MaxValue, null, null, null) { } ///instance. Initializes a new /// Segment name. /// Filter expression for segment, possibly null. /// /// Expand providers may choose to return at most MaxResultsExpected + 1 elements to allow the /// data service to detect a failure to meet this constraint. /// /// Container to which the segment belongs; possibly null. /// Property expanded by this expand segment /// Collection of ordering information for this segment, used for paging internal ExpandSegment( string name, Expression filter, int maxResultsExpected, ResourceSetWrapper container, ResourceProperty expandedProperty, OrderingInfo orderingInfo) { WebUtil.CheckArgumentNull(name, "name"); CheckFilterType(filter); this.name = name; this.filter = filter; this.container = container; this.maxResultsExpected = maxResultsExpected; this.expandedProperty = expandedProperty; this.orderingInfo = orderingInfo; } #endregion Constructors. #region Public properties. ///instance. Filter expression for this segment on an $expand path. public Expression Filter { get { return this.filter; } } ///Whether this segment has a filter. public bool HasFilter { get { return this.Filter != null; } } ////// The maximum number of results expected for this property; Int32.MaxValue if no limit is expected. /// ////// Expand providers may choose to return at most MaxResultsExpected + 1 elements to allow the /// data service to detect a failure to meet this constraint. /// public int MaxResultsExpected { get { return this.maxResultsExpected; } } ///Name for this segment on an $expand path. public string Name { get { return this.name; } } ///Property being expanded. public ResourceProperty ExpandedProperty { get { return this.expandedProperty; } } ///Collection of ordering information for this segment, used for paging internal OrderingInfo OrderingInfo { get { return this.orderingInfo; } } #endregion Public properties. #region Internal properties. ///Gets the container to which this segment belongs; possibly null. internal ResourceSetWrapper Container { get { return this.container; } } #endregion Internal properties. #region Public methods. ///Checks whether any segments in the specified /// Path with segments to check. ///have a filter. true if any of the segments in public static bool PathHasFilter(IEnumerablehas a filter; false otherwise. path) { WebUtil.CheckArgumentNull(path, "path"); foreach (ExpandSegment segment in path) { if (segment.HasFilter) { return true; } } return false; } #endregion Public methods. #region Private methods. /// Checks that the specified filter is of the right type. /// Filter to check. private static void CheckFilterType(Expression filter) { if (filter == null) { return; } if (filter.NodeType != ExpressionType.Lambda) { throw new ArgumentException(Strings.ExpandSegment_FilterShouldBeLambda(filter.NodeType), "filter"); } LambdaExpression lambda = (LambdaExpression)filter; if (lambda.Body.Type != typeof(bool) && lambda.Body.Type != typeof(bool?)) { throw new ArgumentException( Strings.ExpandSegment_FilterBodyShouldReturnBool(lambda.Body.Type), "filter"); } if (lambda.Parameters.Count != 1) { throw new ArgumentException( Strings.ExpandSegment_FilterBodyShouldTakeOneParameter(lambda.Parameters.Count), "filter"); } } #endregion Private methods. } } // 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
- WebSysDescriptionAttribute.cs
- ListViewGroup.cs
- DatePickerTextBox.cs
- EventBindingService.cs
- FullTextState.cs
- SoundPlayer.cs
- DataGridPagerStyle.cs
- CoreChannel.cs
- TextPointerBase.cs
- SqlRowUpdatedEvent.cs
- BindingSource.cs
- DecoratedNameAttribute.cs
- updateconfighost.cs
- DbDataAdapter.cs
- XmlElementAttribute.cs
- DelayedRegex.cs
- ListViewTableRow.cs
- RichTextBox.cs
- XmlSerializerVersionAttribute.cs
- Type.cs
- SystemGatewayIPAddressInformation.cs
- ParserExtension.cs
- FontInfo.cs
- SHA384Cng.cs
- ContentWrapperAttribute.cs
- XmlCharCheckingWriter.cs
- RequestValidator.cs
- KerberosReceiverSecurityToken.cs
- BooleanConverter.cs
- Int64.cs
- StaticTextPointer.cs
- ReliabilityContractAttribute.cs
- AttributeExtensions.cs
- InvalidOleVariantTypeException.cs
- SqlCrossApplyToCrossJoin.cs
- QuaternionRotation3D.cs
- XmlWrappingReader.cs
- ElementProxy.cs
- BuildResult.cs
- Walker.cs
- QilParameter.cs
- XPathSelectionIterator.cs
- StringSorter.cs
- StringValueSerializer.cs
- PageTheme.cs
- ManipulationCompletedEventArgs.cs
- InternalConfigEventArgs.cs
- SharedStatics.cs
- WebPartsSection.cs
- DelegateTypeInfo.cs
- DoubleAnimation.cs
- Nodes.cs
- HandlerFactoryWrapper.cs
- Emitter.cs
- OpenFileDialog.cs
- HandleTable.cs
- SchemaSetCompiler.cs
- RoutedEventConverter.cs
- EntityContainerEmitter.cs
- TextTreeRootTextBlock.cs
- SqlFunctionAttribute.cs
- RightNameExpirationInfoPair.cs
- EllipseGeometry.cs
- AttachmentService.cs
- TempEnvironment.cs
- OracleCommandBuilder.cs
- ClientScriptManager.cs
- OracleInfoMessageEventArgs.cs
- CoreSwitches.cs
- HoistedLocals.cs
- ZipIOZip64EndOfCentralDirectoryLocatorBlock.cs
- BindingCompleteEventArgs.cs
- AppDomainFactory.cs
- OleDbTransaction.cs
- BulletChrome.cs
- StringExpressionSet.cs
- InlineUIContainer.cs
- Context.cs
- ThreadStartException.cs
- ButtonBaseAutomationPeer.cs
- MergeLocalizationDirectives.cs
- UndoUnit.cs
- Pair.cs
- ReleaseInstanceMode.cs
- FlowDocumentReaderAutomationPeer.cs
- FormsAuthenticationUserCollection.cs
- LogicalExpr.cs
- FatalException.cs
- QueryConverter.cs
- newinstructionaction.cs
- UnmanagedMemoryStream.cs
- GuidelineSet.cs
- RightsManagementEncryptionTransform.cs
- SortKey.cs
- GenericUriParser.cs
- ExpanderAutomationPeer.cs
- OdbcEnvironment.cs
- ClientTarget.cs
- KeyValuePairs.cs
- GeneralTransformCollection.cs