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
- PrimitiveType.cs
- BinaryWriter.cs
- HostProtectionPermission.cs
- RegexWorker.cs
- Type.cs
- FolderBrowserDialog.cs
- HitTestDrawingContextWalker.cs
- CreateUserErrorEventArgs.cs
- DocumentPaginator.cs
- SmtpDigestAuthenticationModule.cs
- OdbcFactory.cs
- EditorZoneDesigner.cs
- VarRemapper.cs
- Pair.cs
- WinFormsComponentEditor.cs
- SystemIcmpV4Statistics.cs
- BasicCellRelation.cs
- DeleteMemberBinder.cs
- TPLETWProvider.cs
- GacUtil.cs
- ADMembershipUser.cs
- CompiledXpathExpr.cs
- DesignerGeometryHelper.cs
- DocumentGridContextMenu.cs
- ServiceMetadataBehavior.cs
- CustomErrorsSection.cs
- base64Transforms.cs
- SystemIPGlobalStatistics.cs
- ObjectPersistData.cs
- EventManager.cs
- OptimizerPatterns.cs
- DateBoldEvent.cs
- TranslateTransform.cs
- Win32MouseDevice.cs
- SourceInterpreter.cs
- DecoderExceptionFallback.cs
- MetadataPropertyCollection.cs
- DBSchemaRow.cs
- DynamicQueryStringParameter.cs
- DistributedTransactionPermission.cs
- DtdParser.cs
- COAUTHINFO.cs
- VisualProxy.cs
- EntityDataSourceMemberPath.cs
- SmtpLoginAuthenticationModule.cs
- PermissionSetEnumerator.cs
- PhysicalOps.cs
- StyleHelper.cs
- HashSetDebugView.cs
- RadialGradientBrush.cs
- UIElement3DAutomationPeer.cs
- SystemIcons.cs
- OleDbFactory.cs
- WebCategoryAttribute.cs
- SR.Designer.cs
- StyleSelector.cs
- TimeIntervalCollection.cs
- PermissionListSet.cs
- ImageIndexConverter.cs
- DataAdapter.cs
- DefaultWorkflowLoaderService.cs
- MessageFormatterConverter.cs
- CustomAssemblyResolver.cs
- CornerRadius.cs
- CommandHelper.cs
- OfTypeExpression.cs
- control.ime.cs
- TemplateBindingExpressionConverter.cs
- GrammarBuilderPhrase.cs
- BrowserTree.cs
- ActivitySurrogateSelector.cs
- OptionUsage.cs
- Configuration.cs
- IsolatedStorageFilePermission.cs
- TypeReference.cs
- PropertyMetadata.cs
- SharedUtils.cs
- TrackingStringDictionary.cs
- ExpressionStringBuilder.cs
- assemblycache.cs
- SimplePropertyEntry.cs
- DetectEofStream.cs
- OracleParameterCollection.cs
- GridPatternIdentifiers.cs
- ViewSimplifier.cs
- BitmapSizeOptions.cs
- ResourceExpressionEditorSheet.cs
- CommandTreeTypeHelper.cs
- DbProviderConfigurationHandler.cs
- TaiwanCalendar.cs
- TextEditorLists.cs
- MonitorWrapper.cs
- NamespaceEmitter.cs
- formatter.cs
- RectangleF.cs
- RemoteWebConfigurationHost.cs
- Animatable.cs
- DatatypeImplementation.cs
- MessageBox.cs
- TemplatedMailWebEventProvider.cs