Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DataWeb / Client / System / Data / Services / Client / ALinq / PathBox.cs / 1305376 / PathBox.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] //--------------------------------------------------------------------- namespace System.Data.Services.Client { #region Namespaces. using System; using System.Text; using System.Collections.Generic; using System.Diagnostics; using System.Reflection; using System.Linq; using System.Linq.Expressions; #endregion Namespaces. ////// Holds state (Path, lambda parameter stack, etc) for projection analysis. /// internal class PathBox { #region Private fields. ///This class is used as a marker for an entity projected in its entirety. private const char EntireEntityMarker = UriHelper.ASTERISK; private readonly ListprojectionPaths = new List (); private readonly List expandPaths = new List (); private readonly Stack parameterExpressions = new Stack (); private readonly Dictionary basePaths = new Dictionary (ReferenceEqualityComparer .Instance); #endregion Private fields. /// Initializes a new internal PathBox() { // add a default empty path. projectionPaths.Add(new StringBuilder()); } internal IEnumerableinstance. ProjectionPaths { get { return projectionPaths.Where(s => s.Length > 0).Select(s => s.ToString()).Distinct(); } } internal IEnumerable ExpandPaths { get { return expandPaths.Where(s => s.Length > 0).Select(s => s.ToString()).Distinct(); } } internal void PushParamExpression(ParameterExpression pe) { StringBuilder basePath = projectionPaths.Last(); basePaths.Add(pe, basePath.ToString()); projectionPaths.Remove(basePath); parameterExpressions.Push(pe); } internal void PopParamExpression() { parameterExpressions.Pop(); } internal ParameterExpression ParamExpressionInScope { get { Debug.Assert(parameterExpressions.Count > 0); return parameterExpressions.Peek(); } } /// Starts a new path. internal void StartNewPath() { Debug.Assert(this.ParamExpressionInScope != null, "this.ParamExpressionInScope != null -- should not be starting new path with no lambda parameter in scope."); StringBuilder sb = new StringBuilder(basePaths[this.ParamExpressionInScope]); RemoveEntireEntityMarkerIfPresent(sb); expandPaths.Add(new StringBuilder(sb.ToString())); AddEntireEntityMarker(sb); projectionPaths.Add(sb); } internal void AppendToPath(PropertyInfo pi) { Debug.Assert(pi != null, "pi != null"); StringBuilder sb; Type t = TypeSystem.GetElementType(pi.PropertyType); if (ClientType.CheckElementTypeIsEntity(t)) { // an entity, so need to append to expand path also sb = expandPaths.Last(); Debug.Assert(sb != null); // there should always be an expand path because must call StartNewPath first. if (sb.Length > 0) { sb.Append(UriHelper.FORWARDSLASH); } sb.Append(pi.Name); } sb = projectionPaths.Last(); Debug.Assert(sb != null, "sb != null -- we are always building paths in the context of a parameter"); RemoveEntireEntityMarkerIfPresent(sb); if (sb.Length > 0) { sb.Append(UriHelper.FORWARDSLASH); } sb.Append(pi.Name); if (ClientType.CheckElementTypeIsEntity(t)) { AddEntireEntityMarker(sb); } } private static void RemoveEntireEntityMarkerIfPresent(StringBuilder sb) { if (sb.Length > 0 && sb[sb.Length - 1] == EntireEntityMarker) { sb.Remove(sb.Length - 1, 1); } if (sb.Length > 0 && sb[sb.Length - 1] == UriHelper.FORWARDSLASH) { sb.Remove(sb.Length - 1, 1); } } private static void AddEntireEntityMarker(StringBuilder sb) { if (sb.Length > 0) { sb.Append(UriHelper.FORWARDSLASH); } sb.Append(EntireEntityMarker); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] //--------------------------------------------------------------------- namespace System.Data.Services.Client { #region Namespaces. using System; using System.Text; using System.Collections.Generic; using System.Diagnostics; using System.Reflection; using System.Linq; using System.Linq.Expressions; #endregion Namespaces. ////// Holds state (Path, lambda parameter stack, etc) for projection analysis. /// internal class PathBox { #region Private fields. ///This class is used as a marker for an entity projected in its entirety. private const char EntireEntityMarker = UriHelper.ASTERISK; private readonly ListprojectionPaths = new List (); private readonly List expandPaths = new List (); private readonly Stack parameterExpressions = new Stack (); private readonly Dictionary basePaths = new Dictionary (ReferenceEqualityComparer .Instance); #endregion Private fields. /// Initializes a new internal PathBox() { // add a default empty path. projectionPaths.Add(new StringBuilder()); } internal IEnumerableinstance. ProjectionPaths { get { return projectionPaths.Where(s => s.Length > 0).Select(s => s.ToString()).Distinct(); } } internal IEnumerable ExpandPaths { get { return expandPaths.Where(s => s.Length > 0).Select(s => s.ToString()).Distinct(); } } internal void PushParamExpression(ParameterExpression pe) { StringBuilder basePath = projectionPaths.Last(); basePaths.Add(pe, basePath.ToString()); projectionPaths.Remove(basePath); parameterExpressions.Push(pe); } internal void PopParamExpression() { parameterExpressions.Pop(); } internal ParameterExpression ParamExpressionInScope { get { Debug.Assert(parameterExpressions.Count > 0); return parameterExpressions.Peek(); } } /// Starts a new path. internal void StartNewPath() { Debug.Assert(this.ParamExpressionInScope != null, "this.ParamExpressionInScope != null -- should not be starting new path with no lambda parameter in scope."); StringBuilder sb = new StringBuilder(basePaths[this.ParamExpressionInScope]); RemoveEntireEntityMarkerIfPresent(sb); expandPaths.Add(new StringBuilder(sb.ToString())); AddEntireEntityMarker(sb); projectionPaths.Add(sb); } internal void AppendToPath(PropertyInfo pi) { Debug.Assert(pi != null, "pi != null"); StringBuilder sb; Type t = TypeSystem.GetElementType(pi.PropertyType); if (ClientType.CheckElementTypeIsEntity(t)) { // an entity, so need to append to expand path also sb = expandPaths.Last(); Debug.Assert(sb != null); // there should always be an expand path because must call StartNewPath first. if (sb.Length > 0) { sb.Append(UriHelper.FORWARDSLASH); } sb.Append(pi.Name); } sb = projectionPaths.Last(); Debug.Assert(sb != null, "sb != null -- we are always building paths in the context of a parameter"); RemoveEntireEntityMarkerIfPresent(sb); if (sb.Length > 0) { sb.Append(UriHelper.FORWARDSLASH); } sb.Append(pi.Name); if (ClientType.CheckElementTypeIsEntity(t)) { AddEntireEntityMarker(sb); } } private static void RemoveEntireEntityMarkerIfPresent(StringBuilder sb) { if (sb.Length > 0 && sb[sb.Length - 1] == EntireEntityMarker) { sb.Remove(sb.Length - 1, 1); } if (sb.Length > 0 && sb[sb.Length - 1] == UriHelper.FORWARDSLASH) { sb.Remove(sb.Length - 1, 1); } } private static void AddEntireEntityMarker(StringBuilder sb) { if (sb.Length > 0) { sb.Append(UriHelper.FORWARDSLASH); } sb.Append(EntireEntityMarker); } } } // 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
- CollectionViewGroupInternal.cs
- MultiTrigger.cs
- Menu.cs
- MethodBody.cs
- ValidationError.cs
- Encoder.cs
- CollectionDataContractAttribute.cs
- EditorZoneDesigner.cs
- TableProviderWrapper.cs
- SoapInteropTypes.cs
- DataContext.cs
- DefaultPerformanceCounters.cs
- WindowsBrush.cs
- sqlmetadatafactory.cs
- KerberosSecurityTokenAuthenticator.cs
- DataSourceComponent.cs
- TransactionValidationBehavior.cs
- HtmlTable.cs
- GraphicsContext.cs
- ServiceDocumentFormatter.cs
- EventKeyword.cs
- DataGridSortingEventArgs.cs
- ProfileSettings.cs
- ValueCollectionParameterReader.cs
- TriggerBase.cs
- WasEndpointConfigContainer.cs
- DataBindingCollectionConverter.cs
- ButtonColumn.cs
- TypedAsyncResult.cs
- InvokeMethodActivityDesigner.cs
- RealizedColumnsBlock.cs
- DynamicHyperLink.cs
- GlyphingCache.cs
- SqlClientWrapperSmiStream.cs
- ExceptionUtil.cs
- WebPermission.cs
- BinaryQueryOperator.cs
- BuildManagerHost.cs
- Visual3D.cs
- loginstatus.cs
- ConfigUtil.cs
- ApplySecurityAndSendAsyncResult.cs
- QueryableDataSourceView.cs
- RadioButtonRenderer.cs
- ServiceParser.cs
- CorrelationTokenTypeConvertor.cs
- VectorAnimationBase.cs
- PkcsMisc.cs
- RMEnrollmentPage2.cs
- CodeMemberField.cs
- InternalTypeHelper.cs
- ConnectionsZoneAutoFormat.cs
- BinaryObjectReader.cs
- MenuCommand.cs
- TypeDescriptionProviderAttribute.cs
- SystemTcpConnection.cs
- Buffer.cs
- AdCreatedEventArgs.cs
- WindowsFormsLinkLabel.cs
- NullableFloatMinMaxAggregationOperator.cs
- DataServiceResponse.cs
- UserControl.cs
- ReadOnlyCollection.cs
- TextLineBreak.cs
- ObjectDataSourceMethodEventArgs.cs
- Attributes.cs
- XmlSchemaAttributeGroupRef.cs
- WebPartZoneBase.cs
- BinaryNegotiation.cs
- BooleanSwitch.cs
- StaticFileHandler.cs
- TextProviderWrapper.cs
- SqlDelegatedTransaction.cs
- StrokeDescriptor.cs
- StreamUpgradeBindingElement.cs
- SafeFindHandle.cs
- EndpointConfigContainer.cs
- MsmqInputChannelListenerBase.cs
- InvalidAsynchronousStateException.cs
- CapabilitiesAssignment.cs
- SecurityState.cs
- SortedList.cs
- StaticFileHandler.cs
- SqlParameterCollection.cs
- NestPullup.cs
- DefaultTraceListener.cs
- srgsitem.cs
- NegotiateStream.cs
- MultipleViewPattern.cs
- AutomationPropertyInfo.cs
- RunClient.cs
- Rectangle.cs
- FamilyMapCollection.cs
- OrderByQueryOptionExpression.cs
- LZCodec.cs
- XmlEventCache.cs
- ViewSimplifier.cs
- Ray3DHitTestResult.cs
- XmlSchemaObjectTable.cs
- TextRunCache.cs