Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / Common / EntitySql / Identifier.cs / 2 / Identifier.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backup [....] //--------------------------------------------------------------------- namespace System.Data.Common.EntitySql { using System; using System.Globalization; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.Text; ////// represents identifier /// internal sealed class Identifier : Expr { private string _name; private bool _isEscaped; ////// initializes identifier /// /// /// /// /// internal Identifier( string symbol, bool isEscaped, string query, int inputPos ) : base(query, inputPos) { ValidateIdentifier(symbol, isEscaped); _name = symbol; _isEscaped = isEscaped; } ////// returns identifier name (without escaping chars if escaped id) /// internal string Name { get { return (IsEscaped) ? _name.Substring(1, _name.Length - 2) : _name; } } ////// returns original identifier name /// internal string OriginalName { get { return _name; } } ////// returns if an identifier is escaped /// internal bool IsEscaped { get { return _isEscaped; } } private void ValidateIdentifier( string symbol, bool isEscaped ) { if (isEscaped) { Debug.Assert(!String.IsNullOrEmpty(symbol), "!String.IsNullOrEmpty(symbol)"); if (symbol[0] != '[' || symbol[symbol.Length - 1] != ']') { throw EntityUtil.EntitySqlError(this.ErrCtx, System.Data.Entity.Strings.InvalidEscapedIdentifier(symbol)); } } else { // this is a special case since our language grammar does NOT allow [] to be used as // part of identifiers, but it is needed for Byte[] as type identifier. The only case when // [] will show up at the end as in 'System.Byte[]' if (symbol.Length > 1 && symbol[symbol.Length - 2] == '[' && symbol[symbol.Length - 1] == ']') { symbol = symbol.Substring(0, symbol.Length - 2); } bool isIdentifierASCII = true; if (!CqlLexer.IsLetterOrDigitOrUnderscore(symbol, out isIdentifierASCII)) { if (isIdentifierASCII) { throw EntityUtil.EntitySqlError(this.ErrCtx, System.Data.Entity.Strings.InvalidSimpleIdentifier(symbol)); } else { throw EntityUtil.EntitySqlError(this.ErrCtx, System.Data.Entity.Strings.InvalidSimpleIdentifierNonASCII(symbol)); } } } } } ////// represents dotted identifier /// internal sealed class DottedIdentifier : Expr { private List_identifiers = new List (); private string[] _names; private string _fullName; /// /// intializes singleton dot identifier => simple id /// /// internal DottedIdentifier( Identifier id ) { _identifiers.Add(id); _names = new string[] { id.Name }; _fullName = id.Name; ErrCtx = id.ErrCtx; } ////// intializes dot identifier from dot expression /// /// internal DottedIdentifier( DotExpr dotExpr ) { _names = dotExpr.Names; _fullName = dotExpr.FullName; Expr expr = dotExpr; while (expr is DotExpr) { DotExpr newDotExpr = (DotExpr)expr; _identifiers.Add(newDotExpr.Identifier); expr = newDotExpr.Left; } _identifiers.Add((Identifier)expr); _identifiers.Reverse(); ErrCtx = expr.ErrCtx; ErrCtx.ErrorContextInfo = EntityRes.CtxIdentifier; } ////// returns fqn as single string /// internal string FullName { get { return _fullName; } } ////// returns array of names /// internal string[] Names { get { return _names; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backup [....] //--------------------------------------------------------------------- namespace System.Data.Common.EntitySql { using System; using System.Globalization; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.Text; ////// represents identifier /// internal sealed class Identifier : Expr { private string _name; private bool _isEscaped; ////// initializes identifier /// /// /// /// /// internal Identifier( string symbol, bool isEscaped, string query, int inputPos ) : base(query, inputPos) { ValidateIdentifier(symbol, isEscaped); _name = symbol; _isEscaped = isEscaped; } ////// returns identifier name (without escaping chars if escaped id) /// internal string Name { get { return (IsEscaped) ? _name.Substring(1, _name.Length - 2) : _name; } } ////// returns original identifier name /// internal string OriginalName { get { return _name; } } ////// returns if an identifier is escaped /// internal bool IsEscaped { get { return _isEscaped; } } private void ValidateIdentifier( string symbol, bool isEscaped ) { if (isEscaped) { Debug.Assert(!String.IsNullOrEmpty(symbol), "!String.IsNullOrEmpty(symbol)"); if (symbol[0] != '[' || symbol[symbol.Length - 1] != ']') { throw EntityUtil.EntitySqlError(this.ErrCtx, System.Data.Entity.Strings.InvalidEscapedIdentifier(symbol)); } } else { // this is a special case since our language grammar does NOT allow [] to be used as // part of identifiers, but it is needed for Byte[] as type identifier. The only case when // [] will show up at the end as in 'System.Byte[]' if (symbol.Length > 1 && symbol[symbol.Length - 2] == '[' && symbol[symbol.Length - 1] == ']') { symbol = symbol.Substring(0, symbol.Length - 2); } bool isIdentifierASCII = true; if (!CqlLexer.IsLetterOrDigitOrUnderscore(symbol, out isIdentifierASCII)) { if (isIdentifierASCII) { throw EntityUtil.EntitySqlError(this.ErrCtx, System.Data.Entity.Strings.InvalidSimpleIdentifier(symbol)); } else { throw EntityUtil.EntitySqlError(this.ErrCtx, System.Data.Entity.Strings.InvalidSimpleIdentifierNonASCII(symbol)); } } } } } ////// represents dotted identifier /// internal sealed class DottedIdentifier : Expr { private List_identifiers = new List (); private string[] _names; private string _fullName; /// /// intializes singleton dot identifier => simple id /// /// internal DottedIdentifier( Identifier id ) { _identifiers.Add(id); _names = new string[] { id.Name }; _fullName = id.Name; ErrCtx = id.ErrCtx; } ////// intializes dot identifier from dot expression /// /// internal DottedIdentifier( DotExpr dotExpr ) { _names = dotExpr.Names; _fullName = dotExpr.FullName; Expr expr = dotExpr; while (expr is DotExpr) { DotExpr newDotExpr = (DotExpr)expr; _identifiers.Add(newDotExpr.Identifier); expr = newDotExpr.Left; } _identifiers.Add((Identifier)expr); _identifiers.Reverse(); ErrCtx = expr.ErrCtx; ErrCtx.ErrorContextInfo = EntityRes.CtxIdentifier; } ////// returns fqn as single string /// internal string FullName { get { return _fullName; } } ////// returns array of names /// internal string[] Names { get { return _names; } } } } // 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
- OdbcTransaction.cs
- GridViewColumnCollection.cs
- XmlAttributeHolder.cs
- Rotation3DAnimation.cs
- ConnectionPoint.cs
- AssemblyInfo.cs
- TypeSystemHelpers.cs
- InvalidWMPVersionException.cs
- PointLight.cs
- InfoCardBaseException.cs
- HwndStylusInputProvider.cs
- SmtpAuthenticationManager.cs
- Util.cs
- UxThemeWrapper.cs
- XmlDigitalSignatureProcessor.cs
- ObjectHandle.cs
- SslStream.cs
- ParameterBuilder.cs
- DataGridViewRowPrePaintEventArgs.cs
- XPathDescendantIterator.cs
- TreeNodeBindingCollection.cs
- WmpBitmapDecoder.cs
- XDRSchema.cs
- WorkflowClientDeliverMessageWrapper.cs
- DeferredReference.cs
- ListControlBuilder.cs
- OdbcFactory.cs
- CodeSnippetStatement.cs
- dbdatarecord.cs
- CoordinationService.cs
- ValidationError.cs
- FileReader.cs
- AssociatedControlConverter.cs
- TextSelectionHelper.cs
- TraceInternal.cs
- CannotUnloadAppDomainException.cs
- CaseInsensitiveComparer.cs
- XmlImplementation.cs
- LockedBorderGlyph.cs
- HashLookup.cs
- ServiceMetadataExtension.cs
- dtdvalidator.cs
- SqlVisitor.cs
- SynchronousChannel.cs
- DebugView.cs
- InstalledFontCollection.cs
- Hashtable.cs
- HandlerWithFactory.cs
- MatrixAnimationUsingKeyFrames.cs
- TemplateManager.cs
- CopyAttributesAction.cs
- EntitySet.cs
- ReadOnlyCollectionBase.cs
- XmlSchemaProviderAttribute.cs
- SecurityToken.cs
- ToolStripPanelRenderEventArgs.cs
- DBSqlParserColumnCollection.cs
- LoginCancelEventArgs.cs
- IIS7UserPrincipal.cs
- DbProviderSpecificTypePropertyAttribute.cs
- Misc.cs
- ProfileParameter.cs
- InternalPolicyElement.cs
- LowerCaseStringConverter.cs
- TimelineClockCollection.cs
- MembershipSection.cs
- MessageDecoder.cs
- MDIWindowDialog.cs
- TailCallAnalyzer.cs
- OpenTypeCommon.cs
- FontConverter.cs
- AffineTransform3D.cs
- FileUpload.cs
- SequenceNumber.cs
- SqlConnectionStringBuilder.cs
- SmiConnection.cs
- DesignerVerb.cs
- StorageEntityContainerMapping.cs
- Command.cs
- TransformProviderWrapper.cs
- NameTable.cs
- EventSourceCreationData.cs
- OpenFileDialog.cs
- DependencyPropertyValueSerializer.cs
- EventLogEntry.cs
- Manipulation.cs
- LineInfo.cs
- HostedHttpRequestAsyncResult.cs
- EventMappingSettings.cs
- GAC.cs
- metadatamappinghashervisitor.hashsourcebuilder.cs
- EncryptedData.cs
- WebControlsSection.cs
- GridViewRowCollection.cs
- ErrorWrapper.cs
- DataSourceCache.cs
- RenderingEventArgs.cs
- OleDbParameter.cs
- Int32CollectionConverter.cs
- TableStyle.cs