Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / Data / System / Data / Filter / NameNode.cs / 1 / NameNode.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //[....] //[....] //----------------------------------------------------------------------------- namespace System.Data { using System; using System.ComponentModel; using System.Collections.Generic; using System.Diagnostics; using System.Globalization; internal sealed class NameNode : ExpressionNode { internal char open = '\0'; internal char close = '\0'; internal string name; internal bool found; internal bool type = false; internal DataColumn column; internal NameNode(DataTable table, char[] text, int start, int pos) : base(table) { this.name = ParseName(text, start, pos); } internal NameNode(DataTable table, string name) : base(table) { this.name = name; } internal override bool IsSqlColumn{ get{ return column.IsSqlType; } } internal override void Bind(DataTable table, Listlist) { BindTable(table); if (table == null) throw ExprException.UnboundName(name); try { this.column = table.Columns[name]; } catch (Exception e) { found = false; // if (!Common.ADP.IsCatchableExceptionType(e)) { throw; } throw ExprException.UnboundName(name); } if (column == null) throw ExprException.UnboundName(name); name = column.ColumnName; found = true; // add column to the dependency list, do not add duplicate columns Debug.Assert(column != null, "Failed to bind column " + name); int i; for (i = 0; i < list.Count; i++) { // walk the list, check if the current column already on the list DataColumn dataColumn = list[i]; if (column == dataColumn) { break; } } if (i >= list.Count) { list.Add(column); } } internal override object Eval() { // can not eval column without ROW value; throw ExprException.EvalNoContext(); } internal override object Eval(DataRow row, DataRowVersion version) { if (!found) { throw ExprException.UnboundName(name); } if (row == null) { if(IsTableConstant()) // this column is TableConstant Aggregate Function return column.DataExpression.Evaluate(); else { throw ExprException.UnboundName(name); } } return column[row.GetRecordFromVersion(version)]; } internal override object Eval(int[] records) { throw ExprException.ComputeNotAggregate(this.ToString()); } internal override bool IsConstant() { return false; } internal override bool IsTableConstant() { if (column != null && column.Computed) { return this.column.DataExpression.IsTableAggregate(); } return false; } internal override bool HasLocalAggregate() { if (column != null && column.Computed) { return this.column.DataExpression.HasLocalAggregate(); } return false; } internal override bool HasRemoteAggregate() { if (column != null && column.Computed) { return this.column.DataExpression.HasRemoteAggregate(); } return false; } internal override bool DependsOn(DataColumn column) { if (this.column == column) return true; if (this.column.Computed) { return this.column.DataExpression.DependsOn(column); } return false; } internal override ExpressionNode Optimize() { return this; } /// /// Parses given name and checks it validity /// internal static string ParseName(char[] text, int start, int pos) { char esc = '\0'; string charsToEscape = ""; int saveStart = start; int savePos = pos; if (text[start] == '`') { Debug.Assert(text[checked((int)pos-1)] == '`', "Invalid identifyer bracketing, pos = " + pos.ToString(CultureInfo.InvariantCulture) + ", end = " + text[checked((int)pos-1)].ToString(CultureInfo.InvariantCulture)); start = checked((int)start+1); pos = checked((int)pos-1); esc = '\\'; charsToEscape = "`"; } else if (text[start] == '[') { Debug.Assert(text[checked((int)pos-1)] == ']', "Invalid identifyer bracketing of name " + new string(text, start, pos-start) + " pos = " + pos.ToString(CultureInfo.InvariantCulture) + ", end = " + text[checked((int)pos-1)].ToString(CultureInfo.InvariantCulture)); start = checked((int)start+1); pos = checked((int)pos-1); esc = '\\'; charsToEscape = "]\\"; } if (esc != '\0') { // scan the name in search for the ESC int posEcho = start; for (int i = start; i < pos; i++) { if (text[i] == esc) { if (i+1 < pos && charsToEscape.IndexOf(text[i+1]) >= 0) { i++; } } text[posEcho] = text[i]; posEcho++; } pos = posEcho; } if (pos == start) throw ExprException.InvalidName(new string(text, saveStart, savePos - saveStart)); return new string(text, start, pos - start); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //[....] //[....] //----------------------------------------------------------------------------- namespace System.Data { using System; using System.ComponentModel; using System.Collections.Generic; using System.Diagnostics; using System.Globalization; internal sealed class NameNode : ExpressionNode { internal char open = '\0'; internal char close = '\0'; internal string name; internal bool found; internal bool type = false; internal DataColumn column; internal NameNode(DataTable table, char[] text, int start, int pos) : base(table) { this.name = ParseName(text, start, pos); } internal NameNode(DataTable table, string name) : base(table) { this.name = name; } internal override bool IsSqlColumn{ get{ return column.IsSqlType; } } internal override void Bind(DataTable table, Listlist) { BindTable(table); if (table == null) throw ExprException.UnboundName(name); try { this.column = table.Columns[name]; } catch (Exception e) { found = false; // if (!Common.ADP.IsCatchableExceptionType(e)) { throw; } throw ExprException.UnboundName(name); } if (column == null) throw ExprException.UnboundName(name); name = column.ColumnName; found = true; // add column to the dependency list, do not add duplicate columns Debug.Assert(column != null, "Failed to bind column " + name); int i; for (i = 0; i < list.Count; i++) { // walk the list, check if the current column already on the list DataColumn dataColumn = list[i]; if (column == dataColumn) { break; } } if (i >= list.Count) { list.Add(column); } } internal override object Eval() { // can not eval column without ROW value; throw ExprException.EvalNoContext(); } internal override object Eval(DataRow row, DataRowVersion version) { if (!found) { throw ExprException.UnboundName(name); } if (row == null) { if(IsTableConstant()) // this column is TableConstant Aggregate Function return column.DataExpression.Evaluate(); else { throw ExprException.UnboundName(name); } } return column[row.GetRecordFromVersion(version)]; } internal override object Eval(int[] records) { throw ExprException.ComputeNotAggregate(this.ToString()); } internal override bool IsConstant() { return false; } internal override bool IsTableConstant() { if (column != null && column.Computed) { return this.column.DataExpression.IsTableAggregate(); } return false; } internal override bool HasLocalAggregate() { if (column != null && column.Computed) { return this.column.DataExpression.HasLocalAggregate(); } return false; } internal override bool HasRemoteAggregate() { if (column != null && column.Computed) { return this.column.DataExpression.HasRemoteAggregate(); } return false; } internal override bool DependsOn(DataColumn column) { if (this.column == column) return true; if (this.column.Computed) { return this.column.DataExpression.DependsOn(column); } return false; } internal override ExpressionNode Optimize() { return this; } /// /// Parses given name and checks it validity /// internal static string ParseName(char[] text, int start, int pos) { char esc = '\0'; string charsToEscape = ""; int saveStart = start; int savePos = pos; if (text[start] == '`') { Debug.Assert(text[checked((int)pos-1)] == '`', "Invalid identifyer bracketing, pos = " + pos.ToString(CultureInfo.InvariantCulture) + ", end = " + text[checked((int)pos-1)].ToString(CultureInfo.InvariantCulture)); start = checked((int)start+1); pos = checked((int)pos-1); esc = '\\'; charsToEscape = "`"; } else if (text[start] == '[') { Debug.Assert(text[checked((int)pos-1)] == ']', "Invalid identifyer bracketing of name " + new string(text, start, pos-start) + " pos = " + pos.ToString(CultureInfo.InvariantCulture) + ", end = " + text[checked((int)pos-1)].ToString(CultureInfo.InvariantCulture)); start = checked((int)start+1); pos = checked((int)pos-1); esc = '\\'; charsToEscape = "]\\"; } if (esc != '\0') { // scan the name in search for the ESC int posEcho = start; for (int i = start; i < pos; i++) { if (text[i] == esc) { if (i+1 < pos && charsToEscape.IndexOf(text[i+1]) >= 0) { i++; } } text[posEcho] = text[i]; posEcho++; } pos = posEcho; } if (pos == start) throw ExprException.InvalidName(new string(text, saveStart, savePos - saveStart)); return new string(text, start, pos - start); } } } // 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
- BrushValueSerializer.cs
- PrimitiveDataContract.cs
- Token.cs
- Effect.cs
- Constants.cs
- PropertyManager.cs
- Add.cs
- ServiceMemoryGates.cs
- FontCollection.cs
- BinarySerializer.cs
- ContractMapping.cs
- Expressions.cs
- EmptyControlCollection.cs
- DecoderBestFitFallback.cs
- HandlerMappingMemo.cs
- DefaultHttpHandler.cs
- LogicalExpressionTypeConverter.cs
- StandardToolWindows.cs
- HorizontalAlignConverter.cs
- BindingExpressionBase.cs
- StorageMappingItemCollection.cs
- XmlSchemaException.cs
- RequestCachePolicy.cs
- BufferModeSettings.cs
- CollectionType.cs
- IntegerValidator.cs
- ParameterEditorUserControl.cs
- InputScopeNameConverter.cs
- SapiRecognizer.cs
- MSHTMLHost.cs
- FileStream.cs
- TextBreakpoint.cs
- CollectionViewGroup.cs
- ValidatorCollection.cs
- XsdDuration.cs
- SqlComparer.cs
- XmlElementList.cs
- DatagridviewDisplayedBandsData.cs
- UserValidatedEventArgs.cs
- CommentEmitter.cs
- SchemaNotation.cs
- BitmapSource.cs
- SuppressMergeCheckAttribute.cs
- OletxCommittableTransaction.cs
- BitmapScalingModeValidation.cs
- TagPrefixInfo.cs
- BackStopAuthenticationModule.cs
- VirtualPathUtility.cs
- DocumentEventArgs.cs
- RegexCaptureCollection.cs
- ISAPIWorkerRequest.cs
- DataBinding.cs
- EnvelopedPkcs7.cs
- SqlDependencyUtils.cs
- StateChangeEvent.cs
- RtfNavigator.cs
- GenericWebPart.cs
- AddingNewEventArgs.cs
- EventSchemaTraceListener.cs
- DataViewManagerListItemTypeDescriptor.cs
- ViewManager.cs
- XamlRtfConverter.cs
- InkCanvasAutomationPeer.cs
- TaskFormBase.cs
- ValidatorUtils.cs
- embossbitmapeffect.cs
- HttpRuntime.cs
- MarkupProperty.cs
- SimpleExpression.cs
- DictionaryEntry.cs
- ComPlusInstanceProvider.cs
- ColumnCollection.cs
- Formatter.cs
- BitmapPalette.cs
- PeerInvitationResponse.cs
- MessageDecoder.cs
- ArithmeticLiteral.cs
- SqlCrossApplyToCrossJoin.cs
- ContextMenuStripGroupCollection.cs
- CodeComment.cs
- MimePart.cs
- ClipboardData.cs
- InfiniteIntConverter.cs
- BitmapImage.cs
- entityreference_tresulttype.cs
- SoapObjectReader.cs
- BehaviorEditorPart.cs
- SqlDependency.cs
- SessionStateUtil.cs
- ServiceObjectContainer.cs
- AnnotationService.cs
- IResourceProvider.cs
- PeerObject.cs
- Ray3DHitTestResult.cs
- TransformerInfoCollection.cs
- TrackPoint.cs
- JournalNavigationScope.cs
- XhtmlBasicLiteralTextAdapter.cs
- SchemaHelper.cs
- LayoutUtils.cs