Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / Net / System / GenericUriParser.cs / 5 / GenericUriParser.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /*++ Abstract: This is a public sealed class that exposes various Uri parsing options suported by built in Uri parser Author: Alexei Vopilov Jul 26 2004 Revision History: --*/ namespace System { using System.Globalization; using System.Collections; using System.Security.Permissions; // // This enum specifies the public options used to customize a hierarchical built-in parser. // [Flags] public enum GenericUriParserOptions { // A hierarchical URI, allows a userinfo, non empty Inet-based authority, path, query and fragment // The URI path gets agressively compressed means dots, slashes and backslashes are unescaped, // backslashesare converted, and then it compresses the path. It also removes trailing dots, // empty segments and dots-only segments Default = 0x0, // Allows a free style authority that would terminate with '/' GenericAuthority = 0x1, // Allows an empty authority foo:/// AllowEmptyAuthority = 0x2, // Disables a user info component, it implied in the case of GenericAuthority flag NoUserInfo = 0x4, // Disables a port component, it is implied in the case of GenericAuthority flag NoPort = 0x8, // Disables a query. A ? char is considered as part of the path and is escaped NoQuery = 0x10, // Disables a fragment. A # char is considered as part of the path or query and is escaped NoFragment = 0x20, // if false then converta \ to /, otheriwse does this conversion for the Path component. DontConvertPathBackslashes = 0x40, // if false, then a/./b or a/.../b becomes a/b and /a/../b becomes /b DontCompressPath = 0x80, // if false then a/%2e./b becomes a/../b and then usually compressed DontUnescapePathDotsAndSlashes= 0x100, // IDN hosts supported. if true then unicode hostname is converted to IDN host // and vice versa Idn = 0x200, // Iri strict parsing flag. Makes sense for Unicode. If true then string is // normalized, bidi control characters are removed, unicode char limits are checked IriParsing = 0x400 } // // A hierachical Uri parser that supports various customization options // // ATTN: This type must be compile-time registered with UriParser.CheckSetIsSimpleFlag() method // to avoid calling into the user code if there is no one. // public class GenericUriParser: UriParser { // // The only availabe .ctor. // public GenericUriParser(GenericUriParserOptions options) : base(MapGenericParserOptions(options)) { } // private static UriSyntaxFlags MapGenericParserOptions(GenericUriParserOptions options) { // // Here we map public flags to internal ones // Note an instacne of this parser is always a "simple parser" since the class is sealed. // UriSyntaxFlags flags = DefaultGenericUriParserFlags; if ((options & GenericUriParserOptions.GenericAuthority) != 0) { // Disable some options that are not compatible with generic authority flags &= ~(UriSyntaxFlags.MayHaveUserInfo | UriSyntaxFlags.MayHavePort | UriSyntaxFlags.AllowUncHost | UriSyntaxFlags.AllowAnInternetHost); flags |= UriSyntaxFlags.AllowAnyOtherHost; } if ((options & GenericUriParserOptions.AllowEmptyAuthority) != 0) { flags |= UriSyntaxFlags.AllowEmptyHost; } if ((options & GenericUriParserOptions.NoUserInfo) != 0) { flags &= ~UriSyntaxFlags.MayHaveUserInfo; } if ((options & GenericUriParserOptions.NoPort) != 0) { flags &= ~UriSyntaxFlags.MayHavePort; } if ((options & GenericUriParserOptions.NoQuery) != 0) { flags &= ~UriSyntaxFlags.MayHaveQuery; } if ((options & GenericUriParserOptions.NoFragment) != 0) { flags &= ~UriSyntaxFlags.MayHaveFragment; } if ((options & GenericUriParserOptions.DontConvertPathBackslashes) != 0) { flags &= ~UriSyntaxFlags.ConvertPathSlashes; } if ((options & GenericUriParserOptions.DontCompressPath) != 0) { flags &= ~(UriSyntaxFlags.CompressPath | UriSyntaxFlags.CanonicalizeAsFilePath); } if ((options & GenericUriParserOptions.DontUnescapePathDotsAndSlashes) != 0) { flags &= ~UriSyntaxFlags.UnEscapeDotsAndSlashes; } if ((options & GenericUriParserOptions.Idn) != 0) { flags |= UriSyntaxFlags.AllowIdn; } if ((options & GenericUriParserOptions.IriParsing) != 0) { flags |= UriSyntaxFlags.AllowIriParsing; } return flags; } private const UriSyntaxFlags DefaultGenericUriParserFlags = UriSyntaxFlags.MustHaveAuthority | // UriSyntaxFlags.MayHaveUserInfo | UriSyntaxFlags.MayHavePort | UriSyntaxFlags.MayHavePath | UriSyntaxFlags.MayHaveQuery | UriSyntaxFlags.MayHaveFragment | // UriSyntaxFlags.AllowUncHost | // UriSyntaxFlags.AllowAnInternetHost | // UriSyntaxFlags.PathIsRooted | // UriSyntaxFlags.ConvertPathSlashes | UriSyntaxFlags.CompressPath | UriSyntaxFlags.CanonicalizeAsFilePath | UriSyntaxFlags.UnEscapeDotsAndSlashes; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /*++ Abstract: This is a public sealed class that exposes various Uri parsing options suported by built in Uri parser Author: Alexei Vopilov Jul 26 2004 Revision History: --*/ namespace System { using System.Globalization; using System.Collections; using System.Security.Permissions; // // This enum specifies the public options used to customize a hierarchical built-in parser. // [Flags] public enum GenericUriParserOptions { // A hierarchical URI, allows a userinfo, non empty Inet-based authority, path, query and fragment // The URI path gets agressively compressed means dots, slashes and backslashes are unescaped, // backslashesare converted, and then it compresses the path. It also removes trailing dots, // empty segments and dots-only segments Default = 0x0, // Allows a free style authority that would terminate with '/' GenericAuthority = 0x1, // Allows an empty authority foo:/// AllowEmptyAuthority = 0x2, // Disables a user info component, it implied in the case of GenericAuthority flag NoUserInfo = 0x4, // Disables a port component, it is implied in the case of GenericAuthority flag NoPort = 0x8, // Disables a query. A ? char is considered as part of the path and is escaped NoQuery = 0x10, // Disables a fragment. A # char is considered as part of the path or query and is escaped NoFragment = 0x20, // if false then converta \ to /, otheriwse does this conversion for the Path component. DontConvertPathBackslashes = 0x40, // if false, then a/./b or a/.../b becomes a/b and /a/../b becomes /b DontCompressPath = 0x80, // if false then a/%2e./b becomes a/../b and then usually compressed DontUnescapePathDotsAndSlashes= 0x100, // IDN hosts supported. if true then unicode hostname is converted to IDN host // and vice versa Idn = 0x200, // Iri strict parsing flag. Makes sense for Unicode. If true then string is // normalized, bidi control characters are removed, unicode char limits are checked IriParsing = 0x400 } // // A hierachical Uri parser that supports various customization options // // ATTN: This type must be compile-time registered with UriParser.CheckSetIsSimpleFlag() method // to avoid calling into the user code if there is no one. // public class GenericUriParser: UriParser { // // The only availabe .ctor. // public GenericUriParser(GenericUriParserOptions options) : base(MapGenericParserOptions(options)) { } // private static UriSyntaxFlags MapGenericParserOptions(GenericUriParserOptions options) { // // Here we map public flags to internal ones // Note an instacne of this parser is always a "simple parser" since the class is sealed. // UriSyntaxFlags flags = DefaultGenericUriParserFlags; if ((options & GenericUriParserOptions.GenericAuthority) != 0) { // Disable some options that are not compatible with generic authority flags &= ~(UriSyntaxFlags.MayHaveUserInfo | UriSyntaxFlags.MayHavePort | UriSyntaxFlags.AllowUncHost | UriSyntaxFlags.AllowAnInternetHost); flags |= UriSyntaxFlags.AllowAnyOtherHost; } if ((options & GenericUriParserOptions.AllowEmptyAuthority) != 0) { flags |= UriSyntaxFlags.AllowEmptyHost; } if ((options & GenericUriParserOptions.NoUserInfo) != 0) { flags &= ~UriSyntaxFlags.MayHaveUserInfo; } if ((options & GenericUriParserOptions.NoPort) != 0) { flags &= ~UriSyntaxFlags.MayHavePort; } if ((options & GenericUriParserOptions.NoQuery) != 0) { flags &= ~UriSyntaxFlags.MayHaveQuery; } if ((options & GenericUriParserOptions.NoFragment) != 0) { flags &= ~UriSyntaxFlags.MayHaveFragment; } if ((options & GenericUriParserOptions.DontConvertPathBackslashes) != 0) { flags &= ~UriSyntaxFlags.ConvertPathSlashes; } if ((options & GenericUriParserOptions.DontCompressPath) != 0) { flags &= ~(UriSyntaxFlags.CompressPath | UriSyntaxFlags.CanonicalizeAsFilePath); } if ((options & GenericUriParserOptions.DontUnescapePathDotsAndSlashes) != 0) { flags &= ~UriSyntaxFlags.UnEscapeDotsAndSlashes; } if ((options & GenericUriParserOptions.Idn) != 0) { flags |= UriSyntaxFlags.AllowIdn; } if ((options & GenericUriParserOptions.IriParsing) != 0) { flags |= UriSyntaxFlags.AllowIriParsing; } return flags; } private const UriSyntaxFlags DefaultGenericUriParserFlags = UriSyntaxFlags.MustHaveAuthority | // UriSyntaxFlags.MayHaveUserInfo | UriSyntaxFlags.MayHavePort | UriSyntaxFlags.MayHavePath | UriSyntaxFlags.MayHaveQuery | UriSyntaxFlags.MayHaveFragment | // UriSyntaxFlags.AllowUncHost | // UriSyntaxFlags.AllowAnInternetHost | // UriSyntaxFlags.PathIsRooted | // UriSyntaxFlags.ConvertPathSlashes | UriSyntaxFlags.CompressPath | UriSyntaxFlags.CanonicalizeAsFilePath | UriSyntaxFlags.UnEscapeDotsAndSlashes; } } // 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
- CompilationSection.cs
- SQLBytes.cs
- TerminateDesigner.cs
- InternalsVisibleToAttribute.cs
- GroupBoxRenderer.cs
- EventLogInformation.cs
- StreamBodyWriter.cs
- WindowsEditBoxRange.cs
- StylusPoint.cs
- ExceptionHandler.cs
- HopperCache.cs
- CheckBox.cs
- ACL.cs
- CharAnimationBase.cs
- BaseDataListPage.cs
- OleDbErrorCollection.cs
- SamlAssertionKeyIdentifierClause.cs
- InvalidPrinterException.cs
- SqlGatherProducedAliases.cs
- SecurityRequiresReviewAttribute.cs
- XmlSchemaImport.cs
- FlowSwitch.cs
- TraversalRequest.cs
- ThaiBuddhistCalendar.cs
- OutputCacheProfile.cs
- PartDesigner.cs
- CodeDomLocalizationProvider.cs
- SoapMessage.cs
- MachineSettingsSection.cs
- ImportCatalogPart.cs
- userdatakeys.cs
- VBIdentifierTrimConverter.cs
- SqlXml.cs
- FontStretch.cs
- StackSpiller.Temps.cs
- ExpressionNode.cs
- xmlglyphRunInfo.cs
- DragEvent.cs
- ResourceAttributes.cs
- GridViewRowCollection.cs
- XmlUrlEditor.cs
- OraclePermission.cs
- SymbolMethod.cs
- XmlSchema.cs
- HttpException.cs
- X509Utils.cs
- SetterBaseCollection.cs
- DataGridViewTopRowAccessibleObject.cs
- DeferrableContent.cs
- SQLSingle.cs
- DataControlFieldCollection.cs
- Tool.cs
- PackWebRequest.cs
- MethodAccessException.cs
- ForEachAction.cs
- BulletedList.cs
- ManagementEventWatcher.cs
- CharUnicodeInfo.cs
- EventLogPermissionEntry.cs
- DeflateEmulationStream.cs
- DynamicDiscoSearcher.cs
- XmlConvert.cs
- DataObjectEventArgs.cs
- VectorKeyFrameCollection.cs
- LassoSelectionBehavior.cs
- XpsFilter.cs
- CollectionDataContractAttribute.cs
- MimeObjectFactory.cs
- PersonalizationStateInfoCollection.cs
- RestHandler.cs
- MenuItem.cs
- WindowsGraphicsCacheManager.cs
- MethodBody.cs
- Timer.cs
- MetabaseServerConfig.cs
- FlowLayoutPanelDesigner.cs
- DataGridViewCellConverter.cs
- TypeSource.cs
- CodeConstructor.cs
- SendKeys.cs
- ForeignKeyConstraint.cs
- Animatable.cs
- XmlDictionaryReaderQuotasElement.cs
- InternalRelationshipCollection.cs
- DivideByZeroException.cs
- WebMessageEncodingElement.cs
- EntitySet.cs
- ScriptMethodAttribute.cs
- AnnotationService.cs
- WindowsContainer.cs
- QilUnary.cs
- WebPartPersonalization.cs
- SymmetricCryptoHandle.cs
- Message.cs
- ColumnCollection.cs
- Compiler.cs
- RuleSettingsCollection.cs
- ButtonColumn.cs
- basenumberconverter.cs
- ReferenceSchema.cs